| 
									
										
										
										
											2009-01-27 05:27:22 -05:00
										 |  |  | ! Copyright (C) 2006, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  | USING: assocs continuations fry help help.lint.checks | 
					
						
							|  |  |  | help.topics io kernel namespaces parser sequences | 
					
						
							| 
									
										
										
										
											2009-05-04 07:44:17 -04:00
										 |  |  | source-files.errors vocabs.hierarchy vocabs words classes | 
					
						
							| 
									
										
										
										
											2009-06-07 22:59:13 -04:00
										 |  |  | locals tools.errors listener ;
 | 
					
						
							| 
									
										
										
										
											2009-04-11 22:26:36 -04:00
										 |  |  | FROM: help.lint.checks => all-vocabs ;
 | 
					
						
							| 
									
										
										
										
											2009-07-06 05:55:23 -04:00
										 |  |  | FROM: vocabs => child-vocabs ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: help.lint | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  | SYMBOL: lint-failures | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | lint-failures [ H{ } clone ] initialize
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: help-lint-error < source-file-error ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: +help-lint-failure+ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-12 17:08:46 -04:00
										 |  |  | T{ error-type | 
					
						
							|  |  |  |    { type +help-lint-failure+ } | 
					
						
							|  |  |  |    { word ":lint-failures" } | 
					
						
							|  |  |  |    { plural "help lint failures" } | 
					
						
							|  |  |  |    { icon "vocab:ui/tools/error-list/icons/help-lint-error.tiff" } | 
					
						
							|  |  |  |    { quot [ lint-failures get values ] } | 
					
						
							| 
									
										
										
										
											2009-04-15 01:27:02 -04:00
										 |  |  |    { forget-quot [ lint-failures get delete-at ] } | 
					
						
							| 
									
										
										
										
											2009-04-12 17:08:46 -04:00
										 |  |  | } define-error-type | 
					
						
							| 
									
										
										
										
											2009-04-11 23:26:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-12 17:08:46 -04:00
										 |  |  | M: help-lint-error error-type drop +help-lint-failure+ ;
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <help-lint-error> ( error topic -- help-lint-error )
 | 
					
						
							|  |  |  |     \ help-lint-error <definition-error> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : help-lint-error ( error topic -- )
 | 
					
						
							| 
									
										
										
										
											2009-04-13 15:40:03 -04:00
										 |  |  |     lint-failures get pick
 | 
					
						
							|  |  |  |     [ [ [ <help-lint-error> ] keep ] dip set-at ] [ delete-at drop ] if
 | 
					
						
							|  |  |  |     notify-error-observers ;
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :: check-something ( topic quot -- )
 | 
					
						
							|  |  |  |     [ quot call( -- ) f ] [ ] recover
 | 
					
						
							|  |  |  |     topic help-lint-error ; inline
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : check-word ( word -- )
 | 
					
						
							| 
									
										
										
										
											2009-01-27 05:11:43 -05:00
										 |  |  |     [ with-file-vocabs ] vocabs-quot set
 | 
					
						
							| 
									
										
										
										
											2007-12-11 22:36:40 -05:00
										 |  |  |     dup word-help [ | 
					
						
							| 
									
										
										
										
											2009-04-11 22:26:36 -04:00
										 |  |  |         [ >link ] keep '[ | 
					
						
							| 
									
										
										
										
											2009-01-27 05:11:43 -05:00
										 |  |  |             _ dup word-help | 
					
						
							|  |  |  |             [ check-values ] | 
					
						
							| 
									
										
										
										
											2009-03-10 18:28:17 -04:00
										 |  |  |             [ check-class-description ] | 
					
						
							|  |  |  |             [ nip [ check-nulls ] [ check-see-also ] [ check-markup ] tri ] 2tri
 | 
					
						
							| 
									
										
										
										
											2007-12-11 22:36:40 -05:00
										 |  |  |         ] check-something | 
					
						
							|  |  |  |     ] [ drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : check-article ( article -- )
 | 
					
						
							| 
									
										
										
										
											2009-01-27 05:11:43 -05:00
										 |  |  |     [ with-interactive-vocabs ] vocabs-quot set
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  |     >link dup '[ | 
					
						
							| 
									
										
										
										
											2009-01-27 05:27:22 -05:00
										 |  |  |         _ | 
					
						
							|  |  |  |         [ check-article-title ] | 
					
						
							|  |  |  |         [ article-content check-markup ] bi
 | 
					
						
							|  |  |  |     ] check-something ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-30 02:44:46 -04:00
										 |  |  | : check-about ( vocab -- )
 | 
					
						
							| 
									
										
										
										
											2009-05-16 10:43:01 -04:00
										 |  |  |     vocab-link boa dup
 | 
					
						
							|  |  |  |     '[ _ vocab-help [ article drop ] when* ] check-something ;
 | 
					
						
							| 
									
										
										
										
											2008-06-30 02:44:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  | : check-vocab ( vocab -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-25 07:01:27 -05:00
										 |  |  |     "Checking " write dup write "..." print flush
 | 
					
						
							| 
									
										
										
										
											2009-05-16 10:43:01 -04:00
										 |  |  |     [ check-about ] | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  |     [ words [ check-word ] each ] | 
					
						
							|  |  |  |     [ vocab-articles get at [ check-article ] each ] | 
					
						
							|  |  |  |     tri ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : help-lint ( prefix -- )
 | 
					
						
							| 
									
										
										
										
											2007-12-11 22:36:40 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2009-06-18 20:34:56 -04:00
										 |  |  |         auto-use? off
 | 
					
						
							| 
									
										
										
										
											2009-07-06 05:55:23 -04:00
										 |  |  |         all-vocab-names all-vocabs set
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  |         group-articles vocab-articles set
 | 
					
						
							| 
									
										
										
										
											2008-02-26 21:20:30 -05:00
										 |  |  |         child-vocabs | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  |         [ check-vocab ] each
 | 
					
						
							| 
									
										
										
										
											2008-02-26 21:20:30 -05:00
										 |  |  |     ] with-scope ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : help-lint-all ( -- ) "" help-lint ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-04 14:10:27 -04:00
										 |  |  | : :lint-failures ( -- ) lint-failures get values errors. ;
 | 
					
						
							| 
									
										
										
										
											2009-04-12 17:08:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-11 22:36:40 -05:00
										 |  |  | : unlinked-words ( words -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |     all-word-help [ article-parent not ] filter ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : linked-undocumented-words ( -- seq )
 | 
					
						
							|  |  |  |     all-words | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |     [ word-help not ] filter
 | 
					
						
							|  |  |  |     [ article-parent ] filter
 | 
					
						
							| 
									
										
										
										
											2009-04-11 21:30:09 -04:00
										 |  |  |     [ predicate? not ] filter ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-26 21:20:30 -05:00
										 |  |  | MAIN: help-lint |