| 
									
										
										
										
											2009-01-27 14:34:14 -05:00
										 |  |  | ! Copyright (C) 2005, 2009 Daniel Ehrenberg | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-06-30 04:57:00 -04:00
										 |  |  | USING: accessors kernel namespaces sequences words io assocs | 
					
						
							| 
									
										
										
										
											2008-06-25 04:25:08 -04:00
										 |  |  | quotations strings parser lexer arrays xml.data xml.writer debugger | 
					
						
							| 
									
										
										
										
											2009-01-27 14:34:14 -05:00
										 |  |  | splitting vectors sequences.deep combinators fry memoize ;
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | IN: xml.utilities | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : children>string ( tag -- string )
 | 
					
						
							| 
									
										
										
										
											2008-08-27 18:02:54 -04:00
										 |  |  |     children>> { | 
					
						
							| 
									
										
										
										
											2008-06-27 02:30:23 -04:00
										 |  |  |         { [ dup empty? ] [ drop "" ] } | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  |         { | 
					
						
							|  |  |  |             [ dup [ string? not ] any? ] | 
					
						
							|  |  |  |             [ "XML tag unexpectedly contains non-text children" throw ] | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2008-06-27 02:30:23 -04:00
										 |  |  |         [ concat ] | 
					
						
							|  |  |  |     } cond ;
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : children-tags ( tag -- sequence )
 | 
					
						
							| 
									
										
										
										
											2008-08-27 18:02:54 -04:00
										 |  |  |     children>> [ tag? ] filter ;
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : first-child-tag ( tag -- tag )
 | 
					
						
							| 
									
										
										
										
											2008-08-27 18:02:54 -04:00
										 |  |  |     children>> [ tag? ] find nip ;
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | : tag-named? ( name elem -- ? )
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  |     dup tag? [ names-match? ] [ 2drop f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  | : tag-named ( tag name/string -- matching-tag )
 | 
					
						
							|  |  |  |     assure-name '[ _ swap tag-named? ] find nip ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 13:17:50 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  | : tags-named ( tag name/string -- tags-seq )
 | 
					
						
							|  |  |  |     assure-name '[ _ swap tag-named? ] filter { } like ;
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  | : prepare-deep ( xml name/string -- tag name/string )
 | 
					
						
							|  |  |  |     [ dup xml? [ body>> ] when ] [ assure-name ] bi* ;
 | 
					
						
							| 
									
										
										
										
											2007-12-29 11:36:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : deep-tag-named ( tag name/string -- matching-tag )
 | 
					
						
							|  |  |  |     prepare-deep '[ _ swap tag-named? ] deep-find ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : deep-tags-named ( tag name/string -- tags-seq )
 | 
					
						
							|  |  |  |     prepare-deep '[ _ swap tag-named? ] deep-filter { } like ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : tag-with-attr? ( elem attr-value attr-name -- ? )
 | 
					
						
							| 
									
										
										
										
											2009-01-29 14:33:04 -05:00
										 |  |  |     rot dup tag? [ swap attr = ] [ 3drop f ] if ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : tag-with-attr ( tag attr-value attr-name -- matching-tag )
 | 
					
						
							| 
									
										
										
										
											2008-12-02 20:59:16 -05:00
										 |  |  |     assure-name '[ _ _ tag-with-attr? ] find nip ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : tags-with-attr ( tag attr-value attr-name -- tags-seq )
 | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  |     assure-name '[ _ _ tag-with-attr? ] filter children>> ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-06 13:17:50 -05:00
										 |  |  | : deep-tag-with-attr ( tag attr-value attr-name -- matching-tag )
 | 
					
						
							| 
									
										
										
										
											2008-12-02 20:59:16 -05:00
										 |  |  |     assure-name '[ _ _ tag-with-attr? ] deep-find ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-06 13:17:50 -05:00
										 |  |  | : deep-tags-with-attr ( tag attr-value attr-name -- tags-seq )
 | 
					
						
							| 
									
										
										
										
											2009-01-31 22:01:55 -05:00
										 |  |  |     assure-name '[ _ _ tag-with-attr? ] deep-filter ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-27 19:16:35 -05:00
										 |  |  | : get-id ( tag id -- elem )
 | 
					
						
							| 
									
										
										
										
											2008-01-06 13:17:50 -05:00
										 |  |  |     "id" deep-tag-with-attr ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : deep-tags-named-with-attr ( tag tag-name attr-value attr-name -- tags )
 | 
					
						
							| 
									
										
										
										
											2008-12-02 20:59:16 -05:00
										 |  |  |     [ deep-tags-named ] 2dip tags-with-attr ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 13:17:50 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : assert-tag ( name name -- )
 | 
					
						
							|  |  |  |     names-match? [ "Unexpected XML tag found" throw ] unless ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 12:30:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-06 13:17:50 -05:00
										 |  |  | : insert-children ( children tag -- )
 | 
					
						
							| 
									
										
										
										
											2008-08-27 18:02:54 -04:00
										 |  |  |     dup children>> [ push-all ] | 
					
						
							|  |  |  |     [ swap V{ } like >>children drop ] if ;
 | 
					
						
							| 
									
										
										
										
											2008-01-06 13:17:50 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : insert-child ( child tag -- )
 | 
					
						
							| 
									
										
										
										
											2008-12-02 20:59:16 -05:00
										 |  |  |     [ 1vector ] dip insert-children ;
 | 
					
						
							| 
									
										
										
										
											2009-01-27 14:34:14 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : XML-NS: | 
					
						
							|  |  |  |     CREATE-WORD (( string -- name )) over set-stack-effect | 
					
						
							|  |  |  |     scan '[ f swap _ <name> ] define-memoized ; parsing |