| 
									
										
										
										
											2009-01-30 20:34:31 -05:00
										 |  |  | ! Copyright (C) 2007, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2008-09-10 23:11:40 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: accessors xmode.tokens xmode.rules xmode.keyword-map | 
					
						
							| 
									
										
										
										
											2009-02-05 22:17:03 -05:00
										 |  |  | xml.data xml.traversal xml assocs kernel combinators sequences | 
					
						
							| 
									
										
										
										
											2008-09-18 14:48:18 -04:00
										 |  |  | math.parser namespaces make parser lexer xmode.utilities | 
					
						
							| 
									
										
										
										
											2009-02-12 21:42:32 -05:00
										 |  |  | regexp io.files splitting arrays xml.syntax xml.syntax.private ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | IN: xmode.loader.syntax | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Rule tag parsing utilities | 
					
						
							|  |  |  | : (parse-rule-tag) ( rule-set tag specs class -- )
 | 
					
						
							| 
									
										
										
										
											2008-08-27 20:27:06 -04:00
										 |  |  |     new swap init-from-tag swap add-rule ; inline
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-21 02:27:50 -04:00
										 |  |  | SYNTAX: RULE: | 
					
						
							| 
									
										
										
										
											2009-02-12 21:42:32 -05:00
										 |  |  |     scan scan-word scan-word [ | 
					
						
							| 
									
										
										
										
											2009-03-16 21:11:36 -04:00
										 |  |  |         [ parse-definition call( -- ) ] { } make | 
					
						
							| 
									
										
										
										
											2009-02-12 21:42:32 -05:00
										 |  |  |         swap [ (parse-rule-tag) ] 2curry
 | 
					
						
							| 
									
										
										
										
											2009-03-21 02:27:50 -04:00
										 |  |  |     ] dip swap define-tag ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Attribute utilities | 
					
						
							|  |  |  | : string>boolean ( string -- ? ) "TRUE" = ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : string>match-type ( string -- obj )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { "RULE" [ f ] } | 
					
						
							|  |  |  |         { "CONTEXT" [ t ] } | 
					
						
							|  |  |  |         [ string>token ] | 
					
						
							|  |  |  |     } case ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : string>rule-set-name ( string -- name ) "MAIN" or ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! PROP, PROPS | 
					
						
							|  |  |  | : parse-prop-tag ( tag -- key value )
 | 
					
						
							| 
									
										
										
										
											2009-01-29 00:56:47 -05:00
										 |  |  |     [ "NAME" attr ] [ "VALUE" attr ] bi ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : parse-props-tag ( tag -- assoc )
 | 
					
						
							| 
									
										
										
										
											2009-02-12 14:18:43 -05:00
										 |  |  |     children-tags | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  |     [ parse-prop-tag ] H{ } map>assoc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : position-attrs ( tag -- at-line-start? at-whitespace-end? at-word-start? )
 | 
					
						
							|  |  |  |     ! XXX Wrong logic! | 
					
						
							|  |  |  |     { "AT_LINE_START" "AT_WHITESPACE_END" "AT_WORD_START" } | 
					
						
							| 
									
										
										
										
											2009-01-29 00:56:47 -05:00
										 |  |  |     [ attr string>boolean ] with map first3 ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : parse-literal-matcher ( tag -- matcher )
 | 
					
						
							|  |  |  |     dup children>string | 
					
						
							| 
									
										
										
										
											2009-01-30 20:34:31 -05:00
										 |  |  |     rule-set get ignore-case?>> <string-matcher> | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  |     swap position-attrs <matcher> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : parse-regexp-matcher ( tag -- matcher )
 | 
					
						
							| 
									
										
										
										
											2009-02-12 21:42:32 -05:00
										 |  |  |     dup children>string | 
					
						
							|  |  |  |     rule-set get ignore-case?>> <?insensitive-regexp> | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  |     swap position-attrs <matcher> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : shared-tag-attrs ( -- )
 | 
					
						
							| 
									
										
										
										
											2010-05-05 16:52:54 -04:00
										 |  |  |     { "TYPE" string>token body-token<< } , ; inline
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-30 20:34:31 -05:00
										 |  |  | : parse-delegate ( string -- pair )
 | 
					
						
							|  |  |  |     "::" split1 [ rule-set get swap ] unless* 2array ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : delegate-attr ( -- )
 | 
					
						
							| 
									
										
										
										
											2010-05-05 16:52:54 -04:00
										 |  |  |     { "DELEGATE" f delegate<< } , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : regexp-attr ( -- )
 | 
					
						
							| 
									
										
										
										
											2010-05-05 16:52:54 -04:00
										 |  |  |     { "HASH_CHAR" f chars<< } , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : match-type-attr ( -- )
 | 
					
						
							| 
									
										
										
										
											2010-05-05 16:52:54 -04:00
										 |  |  |     { "MATCH_TYPE" string>match-type match-token<< } , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : span-attrs ( -- )
 | 
					
						
							| 
									
										
										
										
											2010-05-05 16:52:54 -04:00
										 |  |  |     { "NO_LINE_BREAK" string>boolean no-line-break?<< } , | 
					
						
							|  |  |  |     { "NO_WORD_BREAK" string>boolean no-word-break?<< } , | 
					
						
							|  |  |  |     { "NO_ESCAPE" string>boolean no-escape?<< } , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : literal-start ( -- )
 | 
					
						
							| 
									
										
										
										
											2008-08-30 21:53:59 -04:00
										 |  |  |     [ parse-literal-matcher >>start drop ] , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : regexp-start ( -- )
 | 
					
						
							| 
									
										
										
										
											2008-08-30 21:53:59 -04:00
										 |  |  |     [ parse-regexp-matcher >>start drop ] , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : literal-end ( -- )
 | 
					
						
							| 
									
										
										
										
											2008-08-30 21:53:59 -04:00
										 |  |  |     [ parse-literal-matcher >>end drop ] , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! SPAN's children | 
					
						
							| 
									
										
										
										
											2009-02-12 14:18:43 -05:00
										 |  |  | TAGS: parse-begin/end-tag ( rule tag -- )
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-12 14:18:43 -05:00
										 |  |  | TAG: BEGIN parse-begin/end-tag | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  |     ! XXX | 
					
						
							| 
									
										
										
										
											2008-08-30 21:53:59 -04:00
										 |  |  |     parse-literal-matcher >>start drop ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-12 14:18:43 -05:00
										 |  |  | TAG: END parse-begin/end-tag | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  |     ! XXX | 
					
						
							| 
									
										
										
										
											2008-08-30 21:53:59 -04:00
										 |  |  |     parse-literal-matcher >>end drop ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : parse-begin/end-tags ( -- )
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  |     [ | 
					
						
							|  |  |  |         ! XXX: handle position attrs on span tag itself | 
					
						
							| 
									
										
										
										
											2009-02-12 14:18:43 -05:00
										 |  |  |         children-tags [ parse-begin/end-tag ] with each
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  |     ] , ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : init-span-tag ( -- ) [ drop init-span ] , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : init-eol-span-tag ( -- ) [ drop init-eol-span ] , ;
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:04:42 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : parse-keyword-tag ( tag keyword-map -- )
 | 
					
						
							| 
									
										
										
										
											2008-12-17 20:17:37 -05:00
										 |  |  |     [ dup main>> string>token swap children>string ] dip set-at ;
 |