Add vocab-usage. and vocab-uses. words, vocab browser now prints more information
							parent
							
								
									958ba935f6
								
							
						
					
					
						commit
						d7e1c276f8
					
				|  | @ -1,7 +1,13 @@ | ||||||
| USING: help.markup help.syntax io strings ; | USING: help.markup help.syntax io strings ; | ||||||
| IN: tools.vocabs.browser | IN: tools.vocabs.browser | ||||||
| 
 | 
 | ||||||
|  | ARTICLE: "vocab-tags" "Vocabulary tags" | ||||||
|  | { $all-tags } ; | ||||||
|  | 
 | ||||||
|  | ARTICLE: "vocab-authors" "Vocabulary authors" | ||||||
|  | { $all-authors } ; | ||||||
|  | 
 | ||||||
| ARTICLE: "vocab-index" "Vocabulary index" | ARTICLE: "vocab-index" "Vocabulary index" | ||||||
| { $tags } | { $subsection "vocab-tags" } | ||||||
| { $authors } | { $subsection "vocab-authors" } | ||||||
| { $describe-vocab "" } ; | { $describe-vocab "" } ; | ||||||
|  |  | ||||||
|  | @ -1,9 +1,12 @@ | ||||||
| ! Copyright (C) 2007, 2008 Slava Pestov. | ! Copyright (C) 2007, 2008 Slava Pestov. | ||||||
| ! See http://factorcode.org/license.txt for BSD license. | ! See http://factorcode.org/license.txt for BSD license. | ||||||
| USING: accessors kernel combinators vocabs vocabs.loader | USING: accessors arrays assocs classes classes.builtin | ||||||
| tools.vocabs io io.files io.styles help.markup help.stylesheet | classes.intersection classes.mixin classes.predicate | ||||||
| sequences assocs help.topics namespaces prettyprint words | classes.singleton classes.tuple classes.union combinators | ||||||
| sorting definitions arrays summary sets generic ; | definitions effects fry generic help help.markup | ||||||
|  | help.stylesheet help.topics io io.files io.styles kernel macros | ||||||
|  | make namespaces prettyprint sequences sets sorting summary | ||||||
|  | tools.vocabs vocabs vocabs.loader words ; | ||||||
| IN: tools.vocabs.browser | IN: tools.vocabs.browser | ||||||
| 
 | 
 | ||||||
| : vocab-status-string ( vocab -- string ) | : vocab-status-string ( vocab -- string ) | ||||||
|  | @ -34,7 +37,7 @@ IN: tools.vocabs.browser | ||||||
|     [ "Children from " prepend ] [ "Children" ] if* |     [ "Children from " prepend ] [ "Children" ] if* | ||||||
|     $heading ; |     $heading ; | ||||||
| 
 | 
 | ||||||
| : vocabs. ( assoc -- ) | : $vocabs ( assoc -- ) | ||||||
|     [ |     [ | ||||||
|         [ |         [ | ||||||
|             drop |             drop | ||||||
|  | @ -46,23 +49,13 @@ IN: tools.vocabs.browser | ||||||
|         ] if-empty |         ] if-empty | ||||||
|     ] assoc-each ; |     ] assoc-each ; | ||||||
| 
 | 
 | ||||||
| : describe-summary ( vocab -- ) |  | ||||||
|     vocab-summary [ |  | ||||||
|         "Summary" $heading print-element |  | ||||||
|     ] when* ; |  | ||||||
| 
 |  | ||||||
| TUPLE: vocab-tag name ; | TUPLE: vocab-tag name ; | ||||||
| 
 | 
 | ||||||
| INSTANCE: vocab-tag topic | INSTANCE: vocab-tag topic | ||||||
| 
 | 
 | ||||||
| C: <vocab-tag> vocab-tag | C: <vocab-tag> vocab-tag | ||||||
| 
 | 
 | ||||||
| : tags. ( seq -- ) [ <vocab-tag> ] map $links ; | : $tags ( seq -- ) [ <vocab-tag> ] map $links ; | ||||||
| 
 |  | ||||||
| : describe-tags ( vocab -- ) |  | ||||||
|     vocab-tags f like [ |  | ||||||
|         "Tags" $heading tags. |  | ||||||
|     ] when* ; |  | ||||||
| 
 | 
 | ||||||
| TUPLE: vocab-author name ; | TUPLE: vocab-author name ; | ||||||
| 
 | 
 | ||||||
|  | @ -70,20 +63,18 @@ INSTANCE: vocab-author topic | ||||||
| 
 | 
 | ||||||
| C: <vocab-author> vocab-author | C: <vocab-author> vocab-author | ||||||
| 
 | 
 | ||||||
| : authors. ( seq -- ) [ <vocab-author> ] map $links ; | : $authors ( seq -- ) [ <vocab-author> ] map $links ; | ||||||
| 
 |  | ||||||
| : describe-authors ( vocab -- ) |  | ||||||
|     vocab-authors f like [ |  | ||||||
|         "Authors" $heading authors. |  | ||||||
|     ] when* ; |  | ||||||
| 
 | 
 | ||||||
| : describe-help ( vocab -- ) | : describe-help ( vocab -- ) | ||||||
|     vocab-help [ |     [ | ||||||
|         "Documentation" $heading ($link) |         dup vocab-help | ||||||
|     ] when* ; |         [ "Documentation" $heading ($link) ] | ||||||
|  |         [ "Summary" $heading vocab-summary print-element ] | ||||||
|  |         ?if | ||||||
|  |     ] unless-empty ; | ||||||
| 
 | 
 | ||||||
| : describe-children ( vocab -- ) | : describe-children ( vocab -- ) | ||||||
|     vocab-name all-child-vocabs vocabs. ; |     vocab-name all-child-vocabs $vocabs ; | ||||||
| 
 | 
 | ||||||
| : describe-files ( vocab -- ) | : describe-files ( vocab -- ) | ||||||
|     vocab-files [ <pathname> ] map [ |     vocab-files [ <pathname> ] map [ | ||||||
|  | @ -95,50 +86,163 @@ C: <vocab-author> vocab-author | ||||||
|                 ] with-nesting |                 ] with-nesting | ||||||
|             ] with-style |             ] with-style | ||||||
|         ] ($block) |         ] ($block) | ||||||
|     ] when* ; |     ] unless-empty ; | ||||||
| 
 | 
 | ||||||
| : describe-words ( vocab -- ) | : describe-tuple-classes ( classes -- ) | ||||||
|  |     [ | ||||||
|  |         "Tuple classes" $subheading | ||||||
|  |         [ | ||||||
|  |             [ <$link> ] | ||||||
|  |             [ superclass <$link> ] | ||||||
|  |             [ "slots" word-prop [ name>> ] map " " join \ $snippet swap 2array ] | ||||||
|  |             tri 3array | ||||||
|  |         ] map | ||||||
|  |         { { $strong "Class" } { $strong "Superclass" } { $strong "Slots" } } prefix | ||||||
|  |         $table | ||||||
|  |     ] unless-empty ; | ||||||
|  | 
 | ||||||
|  | : describe-predicate-classes ( classes -- ) | ||||||
|  |     [ | ||||||
|  |         "Predicate classes" $subheading | ||||||
|  |         [ | ||||||
|  |             [ <$link> ] | ||||||
|  |             [ superclass <$link> ] | ||||||
|  |             bi 2array | ||||||
|  |         ] map | ||||||
|  |         { { $strong "Class" } { $strong "Superclass" } } prefix | ||||||
|  |         $table | ||||||
|  |     ] unless-empty ; | ||||||
|  | 
 | ||||||
|  | : (describe-classes) ( classes heading -- ) | ||||||
|  |     '[ | ||||||
|  |         _ $subheading | ||||||
|  |         [ <$link> 1array ] map $table | ||||||
|  |     ] unless-empty ; | ||||||
|  | 
 | ||||||
|  | : describe-builtin-classes ( classes -- ) | ||||||
|  |     "Builtin classes" (describe-classes) ; | ||||||
|  | 
 | ||||||
|  | : describe-singleton-classes ( classes -- ) | ||||||
|  |     "Singleton classes" (describe-classes) ; | ||||||
|  | 
 | ||||||
|  | : describe-mixin-classes ( classes -- ) | ||||||
|  |     "Mixin classes" (describe-classes) ; | ||||||
|  | 
 | ||||||
|  | : describe-union-classes ( classes -- ) | ||||||
|  |     "Union classes" (describe-classes) ; | ||||||
|  | 
 | ||||||
|  | : describe-intersection-classes ( classes -- ) | ||||||
|  |     "Intersection classes" (describe-classes) ; | ||||||
|  | 
 | ||||||
|  | : describe-classes ( classes -- ) | ||||||
|  |     [ builtin-class? ] partition | ||||||
|  |     [ tuple-class? ] partition | ||||||
|  |     [ singleton-class? ] partition | ||||||
|  |     [ predicate-class? ] partition | ||||||
|  |     [ mixin-class? ] partition | ||||||
|  |     [ union-class? ] partition | ||||||
|  |     [ intersection-class? ] filter | ||||||
|  |     { | ||||||
|  |         [ describe-builtin-classes ] | ||||||
|  |         [ describe-tuple-classes ] | ||||||
|  |         [ describe-singleton-classes ] | ||||||
|  |         [ describe-predicate-classes ] | ||||||
|  |         [ describe-mixin-classes ] | ||||||
|  |         [ describe-union-classes ] | ||||||
|  |         [ describe-intersection-classes ] | ||||||
|  |     } spread ; | ||||||
|  | 
 | ||||||
|  | : word-syntax ( word -- string/f ) | ||||||
|  |     \ $syntax swap word-help elements dup length 1 = | ||||||
|  |     [ first second ] [ drop f ] if ; | ||||||
|  | 
 | ||||||
|  | : describe-parsing ( words -- ) | ||||||
|  |     [ | ||||||
|  |         "Parsing words" $subheading | ||||||
|  |         [ | ||||||
|  |             [ <$link> ] | ||||||
|  |             [ word-syntax dup [ \ $snippet swap 2array ] when ] | ||||||
|  |             bi 2array | ||||||
|  |         ] map | ||||||
|  |         { { $strong "Word" } { $strong "Syntax" } } prefix | ||||||
|  |         $table | ||||||
|  |     ] unless-empty ; | ||||||
|  | 
 | ||||||
|  | : (describe-words) ( words heading -- ) | ||||||
|  |     '[ | ||||||
|  |         _ $subheading | ||||||
|  |         [ | ||||||
|  |             [ <$link> ] | ||||||
|  |             [ stack-effect dup [ effect>string \ $snippet swap 2array ] when ] | ||||||
|  |             bi 2array | ||||||
|  |         ] map | ||||||
|  |         { { $strong "Word" } { $strong "Stack effect" } } prefix | ||||||
|  |         $table | ||||||
|  |     ] unless-empty ; | ||||||
|  | 
 | ||||||
|  | : describe-generics ( words -- ) | ||||||
|  |     "Generic words" (describe-words) ; | ||||||
|  | 
 | ||||||
|  | : describe-macros ( words -- ) | ||||||
|  |     "Macro words" (describe-words) ; | ||||||
|  | 
 | ||||||
|  | : describe-primitives ( words -- ) | ||||||
|  |     "Primitives" (describe-words) ; | ||||||
|  | 
 | ||||||
|  | : describe-compounds ( words -- ) | ||||||
|  |     "Ordinary words" (describe-words) ; | ||||||
|  | 
 | ||||||
|  | : describe-predicates ( words -- ) | ||||||
|  |     "Class predicate words" (describe-words) ; | ||||||
|  | 
 | ||||||
|  | : describe-symbols ( words -- ) | ||||||
|  |     [ | ||||||
|  |         "Symbol words" $subheading | ||||||
|  |         [ <$link> 1array ] map $table | ||||||
|  |     ] unless-empty ; | ||||||
|  | 
 | ||||||
|  | : words. ( vocab -- ) | ||||||
|     words [ |     words [ | ||||||
|         "Words" $heading |         "Words" $heading | ||||||
|         natural-sort $links | 
 | ||||||
|  |         natural-sort | ||||||
|  |         [ [ class? ] filter describe-classes ] | ||||||
|  |         [ | ||||||
|  |             [ [ class? ] [ symbol? ] bi and not ] filter | ||||||
|  |             [ parsing-word? ] partition | ||||||
|  |             [ generic? ] partition | ||||||
|  |             [ macro? ] partition | ||||||
|  |             [ symbol? ] partition | ||||||
|  |             [ primitive? ] partition | ||||||
|  |             [ predicate? ] partition swap | ||||||
|  |             { | ||||||
|  |                 [ describe-parsing ] | ||||||
|  |                 [ describe-generics ] | ||||||
|  |                 [ describe-macros ] | ||||||
|  |                 [ describe-symbols ] | ||||||
|  |                 [ describe-primitives ] | ||||||
|  |                 [ describe-compounds ] | ||||||
|  |                 [ describe-predicates ] | ||||||
|  |             } spread | ||||||
|  |         ] bi | ||||||
|     ] unless-empty ; |     ] unless-empty ; | ||||||
| 
 | 
 | ||||||
| : vocab-xref ( vocab quot -- vocabs ) | : describe-metadata ( vocab -- ) | ||||||
|     >r dup vocab-name swap words [ generic? not ] filter r> map |     [ | ||||||
|     [ [ word? ] filter [ vocabulary>> ] map ] gather natural-sort |         [ vocab-tags [ "Tags:" swap \ $tags prefix 2array , ] unless-empty ] | ||||||
|     remove sift ; inline |         [ vocab-authors [ "Authors:" swap \ $authors prefix 2array , ] unless-empty ] | ||||||
| 
 |         bi | ||||||
| : vocab-uses ( vocab -- vocabs ) [ uses ] vocab-xref ; |     ] { } make | ||||||
| 
 |     [ "Meta-data" $heading $table ] unless-empty ; | ||||||
| : vocab-usage ( vocab -- vocabs ) [ usage ] vocab-xref ; |  | ||||||
| 
 |  | ||||||
| : describe-uses ( vocab -- ) |  | ||||||
|     vocab-uses [ |  | ||||||
|         "Uses" $heading |  | ||||||
|         $vocab-links |  | ||||||
|     ] unless-empty ; |  | ||||||
| 
 |  | ||||||
| : describe-usage ( vocab -- ) |  | ||||||
|     vocab-usage [ |  | ||||||
|         "Used by" $heading |  | ||||||
|         $vocab-links |  | ||||||
|     ] unless-empty ; |  | ||||||
| 
 | 
 | ||||||
| : $describe-vocab ( element -- ) | : $describe-vocab ( element -- ) | ||||||
|     first |     first { | ||||||
|     dup describe-children |         [ describe-help ] | ||||||
|     dup find-vocab-root [ |         [ describe-metadata ] | ||||||
|         dup describe-summary |         [ words. ] | ||||||
|         dup describe-tags |         [ describe-files ] | ||||||
|         dup describe-authors |         [ describe-children ] | ||||||
|         dup describe-files |     } cleave ; | ||||||
|     ] when |  | ||||||
|     dup vocab [ |  | ||||||
|         dup describe-help |  | ||||||
|         dup describe-words |  | ||||||
|         dup describe-uses |  | ||||||
|         dup describe-usage |  | ||||||
|     ] when drop ; |  | ||||||
| 
 | 
 | ||||||
| : keyed-vocabs ( str quot -- seq ) | : keyed-vocabs ( str quot -- seq ) | ||||||
|     all-vocabs [ |     all-vocabs [ | ||||||
|  | @ -154,16 +258,16 @@ C: <vocab-author> vocab-author | ||||||
|     [ vocab-authors ] keyed-vocabs ; |     [ vocab-authors ] keyed-vocabs ; | ||||||
| 
 | 
 | ||||||
| : $tagged-vocabs ( element -- ) | : $tagged-vocabs ( element -- ) | ||||||
|     first tagged vocabs. ; |     first tagged $vocabs ; | ||||||
| 
 | 
 | ||||||
| : $authored-vocabs ( element -- ) | : $authored-vocabs ( element -- ) | ||||||
|     first authored vocabs. ; |     first authored $vocabs ; | ||||||
| 
 | 
 | ||||||
| : $tags ( element -- ) | : $all-tags ( element -- ) | ||||||
|     drop "Tags" $heading all-tags tags. ; |     drop "Tags" $heading all-tags $tags ; | ||||||
| 
 | 
 | ||||||
| : $authors ( element -- ) | : $all-authors ( element -- ) | ||||||
|     drop "Authors" $heading all-authors authors. ; |     drop "Authors" $heading all-authors $authors ; | ||||||
| 
 | 
 | ||||||
| INSTANCE: vocab topic | INSTANCE: vocab topic | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -4,9 +4,31 @@ USING: kernel io io.styles io.files io.encodings.utf8 | ||||||
| vocabs.loader vocabs sequences namespaces make math.parser | vocabs.loader vocabs sequences namespaces make math.parser | ||||||
| arrays hashtables assocs memoize summary sorting splitting | arrays hashtables assocs memoize summary sorting splitting | ||||||
| combinators source-files debugger continuations compiler.errors | combinators source-files debugger continuations compiler.errors | ||||||
| init checksums checksums.crc32 sets accessors ; | init checksums checksums.crc32 sets accessors generic | ||||||
|  | definitions words ; | ||||||
| IN: tools.vocabs | IN: tools.vocabs | ||||||
| 
 | 
 | ||||||
|  | : vocab-xref ( vocab quot -- vocabs ) | ||||||
|  |     [ [ vocab-name ] [ words [ generic? not ] filter ] bi ] dip map | ||||||
|  |     [ | ||||||
|  |         [ [ word? ] [ generic? not ] bi and ] filter [ | ||||||
|  |             dup method-body? | ||||||
|  |             [ "method-generic" word-prop ] when | ||||||
|  |             vocabulary>> | ||||||
|  |         ] map | ||||||
|  |     ] gather natural-sort remove sift ; inline | ||||||
|  | 
 | ||||||
|  | : vocabs. ( seq -- ) | ||||||
|  |     [ dup >vocab-link write-object nl ] each ; | ||||||
|  | 
 | ||||||
|  | : vocab-uses ( vocab -- vocabs ) [ uses ] vocab-xref ; | ||||||
|  | 
 | ||||||
|  | : vocab-uses. ( vocab -- ) vocab-uses vocabs. ; | ||||||
|  | 
 | ||||||
|  | : vocab-usage ( vocab -- vocabs ) [ usage ] vocab-xref ; | ||||||
|  | 
 | ||||||
|  | : vocab-usage. ( vocab -- ) vocab-usage vocabs. ; | ||||||
|  | 
 | ||||||
| : vocab-tests-file ( vocab -- path ) | : vocab-tests-file ( vocab -- path ) | ||||||
|     dup "-tests.factor" vocab-dir+ vocab-append-path dup |     dup "-tests.factor" vocab-dir+ vocab-append-path dup | ||||||
|     [ dup exists? [ drop f ] unless ] [ drop f ] if ; |     [ dup exists? [ drop f ] unless ] [ drop f ] if ; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue