! Copyright (C) 2008, 2011 Slava Pestov. ! See http://factorcode.org/license.txt for BSD license. USING: accessors arrays assocs colors.constants debugger fry help help.crossref help.home help.markup help.stylesheet help.topics help.vocabs html html.streams io io.directories io.encodings.binary io.encodings.utf8 io.files io.files.temp io.pathnames io.styles kernel make math.parser memoize namespaces sequences serialize splitting tools.completion vocabs vocabs.hierarchy words xml.syntax xml.writer ; FROM: io.encodings.ascii => ascii ; FROM: ascii => ascii? ; IN: help.html : escape-char ( ch -- ) dup ascii? [ dup H{ { CHAR: " "__quo__" } { CHAR: * "__star__" } { CHAR: : "__colon__" } { CHAR: < "__lt__" } { CHAR: > "__gt__" } { CHAR: ? "__que__" } { CHAR: \\ "__back__" } { CHAR: | "__pipe__" } { CHAR: / "__slash__" } { CHAR: , "__comma__" } { CHAR: @ "__at__" } { CHAR: # "__hash__" } { CHAR: % "__percent__" } } at [ % ] [ , ] ?if ] [ number>string "__" "__" surround % ] if ; : escape-filename ( string -- filename ) [ [ escape-char ] each ] "" make ; GENERIC: topic>filename* ( topic -- name prefix ) M: word topic>filename* dup vocabulary>> [ [ name>> ] [ vocabulary>> ] bi 2array "word" ] [ drop f f ] if ; M: link topic>filename* name>> dup [ "article" ] [ topic>filename* ] if ; M: word-link topic>filename* name>> topic>filename* ; M: vocab-spec topic>filename* vocab-name "vocab" ; M: vocab-tag topic>filename* name>> "tag" ; M: vocab-author topic>filename* name>> "author" ; M: f topic>filename* drop \ f topic>filename* ; : topic>filename ( topic -- filename ) topic>filename* [ [ % "-" % dup array? [ [ escape-filename ] map "," join ] [ escape-filename ] if % ".html" % ] "" make ] [ drop f ] if* ; M: topic url-of topic>filename ; M: pathname url-of string>> "resource:" ?head [ "https://github.com/slavapestov/factor/blob/master/" prepend ] [ drop f ] if ; : help-stylesheet ( -- xml ) "vocab:help/html/stylesheet.css" ascii file-contents [XML XML] ; : help-navbar ( -- xml ) "conventions" >link topic>filename [XML XML] ; : help>html ( topic -- xml ) [ article-title " - Factor Documentation" append ] [ drop help-stylesheet ] [ [ help-navbar ] [ [ title-style get { { page-color COLOR: FactorLightTan } } assoc-union title-style [ print-topic ] with-variable ] with-html-writer ] bi* append ] tri simple-page ; : generate-help-file ( topic -- ) dup topic>filename utf8 [ help>html write-xml ] with-file-writer ; : all-vocabs-really ( -- seq ) all-disk-vocabs-recursive no-roots remove-redundant-prefixes [ vocab-name "scratchpad" = ] reject ; : all-topics ( -- topics ) [ articles get keys [ >link ] map % all-words [ >link ] map % all-authors [ ] map % all-tags [ ] map % all-vocabs-really % ] { } make ; : serialize-index ( index file -- ) binary [ [ [ topic>filename ] dip ] { } assoc-map-as serialize ] with-file-writer ; : generate-article-index ( -- ) articles get [ [ >link ] [ article-title ] bi* ] assoc-map "articles.idx" serialize-index ; : generate-word-index ( -- ) all-words [ dup name>> ] { } map>assoc "words.idx" serialize-index ; : generate-vocab-index ( -- ) all-vocabs-really [ dup vocab-name ] { } map>assoc "vocabs.idx" serialize-index ; : generate-indices ( -- ) generate-article-index generate-word-index generate-vocab-index ; : generate-help-files ( -- ) H{ { recent-searches f } { recent-words f } { recent-articles f } { recent-vocabs f } } [ all-topics [ '[ _ generate-help-file ] try ] each ] with-variables ; : generate-help ( -- ) "docs" cache-file [ make-directories ] [ [ generate-indices generate-help-files ] with-directory ] bi ; MEMO: load-index ( name -- index ) binary file-contents bytes>object ; : offline-apropos ( string index -- results ) load-index completions ; : article-apropos ( string -- results ) "articles.idx" offline-apropos ; : word-apropos ( string -- results ) "words.idx" offline-apropos ; : vocab-apropos ( string -- results ) "vocabs.idx" offline-apropos ;