| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | ! Copyright (C) 2009 Jose Antonio Ortega Ruiz. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | USING: accessors arrays assocs definitions help.topics io.pathnames | 
					
						
							|  |  |  | kernel math math.order memoize namespaces sequences sets sorting | 
					
						
							| 
									
										
										
										
											2009-05-04 07:44:17 -04:00
										 |  |  | tools.completion tools.crossref vocabs vocabs.parser vocabs.hierarchy | 
					
						
							| 
									
										
										
										
											2009-03-07 07:55:22 -05:00
										 |  |  | words ;
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | IN: fuel.xref | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : normalize-loc ( seq -- path line )
 | 
					
						
							| 
									
										
										
										
											2009-10-28 18:25:50 -04:00
										 |  |  |     [ dup length 0 > [ first absolute-path ] [ drop f ] if ] | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  |     [ dup length 1 > [ second ] [ drop 1 ] if ] bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : get-loc ( object -- loc ) normalize-loc 2array ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : word>xref ( word -- xref )
 | 
					
						
							|  |  |  |     [ name>> ] [ vocabulary>> ] [ where normalize-loc ] tri 4array ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  | : vocab>xref ( vocab -- xref )
 | 
					
						
							|  |  |  |     dup dup >vocab-link where normalize-loc 4array ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | : sort-xrefs ( seq -- seq' )
 | 
					
						
							| 
									
										
										
										
											2009-08-02 21:17:25 -04:00
										 |  |  |     [ first ] sort-with ;
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : format-xrefs ( seq -- seq' )
 | 
					
						
							| 
									
										
										
										
											2009-05-29 06:37:48 -04:00
										 |  |  |     [ word? ] filter [ word>xref ] map ;
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : filter-prefix ( seq prefix -- seq )
 | 
					
						
							| 
									
										
										
										
											2009-05-29 06:37:48 -04:00
										 |  |  |     [ drop-prefix nip length 0 = ] curry filter prune ;
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | MEMO: (vocab-words) ( name -- seq )
 | 
					
						
							|  |  |  |     >vocab-link words [ name>> ] map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : current-words ( -- seq )
 | 
					
						
							| 
									
										
										
										
											2009-05-15 00:23:06 -04:00
										 |  |  |     manifest get
 | 
					
						
							| 
									
										
										
										
											2009-07-31 11:46:52 -04:00
										 |  |  |     [ search-vocabs>> ] [ qualified-vocabs>> ] bi [ [ words>> ] map ] bi@
 | 
					
						
							|  |  |  |     append H{ } [ assoc-union ] reduce keys ;
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : vocabs-words ( names -- seq )
 | 
					
						
							| 
									
										
										
										
											2009-05-29 06:37:48 -04:00
										 |  |  |     prune [ (vocab-words) ] map concat ;
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : callers-xref ( word -- seq ) usage format-xrefs sort-xrefs ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : callees-xref ( word -- seq ) uses format-xrefs sort-xrefs ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : apropos-xref ( str -- seq ) words-matching format-xrefs ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vocab-xref ( vocab -- seq ) words format-xrefs ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : word-location ( word -- loc ) where get-loc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vocab-location ( vocab -- loc ) >vocab-link where get-loc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  | : vocab-uses-xref ( vocab -- seq ) vocab-uses [ vocab>xref ] map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vocab-usage-xref ( vocab -- seq ) vocab-usage [ vocab>xref ] map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | : doc-location ( word -- loc ) props>> "help-loc" swap at get-loc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : article-location ( name -- loc ) article loc>> get-loc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-06 05:55:23 -04:00
										 |  |  | : get-vocabs ( -- seq ) all-vocab-names ;
 | 
					
						
							| 
									
										
										
										
											2009-01-22 10:11:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : get-vocabs/prefix ( prefix -- seq ) get-vocabs swap filter-prefix ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : get-vocabs-words/prefix ( prefix names/f -- seq )
 | 
					
						
							|  |  |  |     [ vocabs-words ] [ current-words ] if* natural-sort swap filter-prefix ;
 |