| 
									
										
										
										
											2009-01-29 14:33:04 -05:00
										 |  |  | ! Copyright (C) 2004, 2009 Chris Double, Daniel Ehrenberg. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-01-13 18:35:45 -05:00
										 |  |  | USING: io io.styles kernel namespaces prettyprint quotations | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  | sequences strings words xml.entities compiler.units effects | 
					
						
							| 
									
										
										
										
											2009-02-05 22:17:03 -05:00
										 |  |  | xml.data urls math math.parser combinators | 
					
						
							| 
									
										
										
										
											2009-01-30 20:28:16 -05:00
										 |  |  | present fry io.streams.string xml.writer html ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: html.elements | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 21:44:17 -05:00
										 |  |  | SYMBOL: html | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : write-html ( str -- )
 | 
					
						
							|  |  |  |     H{ { html t } } format ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : print-html ( str -- )
 | 
					
						
							|  |  |  |     write-html "\n" write-html ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  | << | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-19 16:45:45 -04:00
										 |  |  | : elements-vocab ( -- vocab-name ) "html.elements" ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-11 00:48:04 -05:00
										 |  |  | : html-word ( name def effect -- )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     #! Define 'word creating' word to allow | 
					
						
							|  |  |  |     #! dynamically creating words. | 
					
						
							| 
									
										
										
										
											2008-12-03 09:46:16 -05:00
										 |  |  |     [ elements-vocab create ] 2dip define-declared ;
 | 
					
						
							| 
									
										
										
										
											2008-01-11 00:48:04 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-06 19:58:45 -05:00
										 |  |  | : <foo> ( str -- <str> ) "<" ">" surround ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : def-for-html-word-<foo> ( name -- )
 | 
					
						
							|  |  |  |     #! Return the name and code for the <foo> patterned | 
					
						
							|  |  |  |     #! word. | 
					
						
							| 
									
										
										
										
											2008-09-10 23:11:40 -04:00
										 |  |  |     dup <foo> swap '[ _ <foo> write-html ] | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     ( -- ) html-word ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : <foo ( str -- <str ) "<" prepend ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : def-for-html-word-<foo ( name -- )
 | 
					
						
							|  |  |  |     #! Return the name and code for the <foo patterned | 
					
						
							|  |  |  |     #! word. | 
					
						
							| 
									
										
										
										
											2008-09-10 23:11:40 -04:00
										 |  |  |     <foo dup '[ _ write-html ] | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     ( -- ) html-word ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : foo> ( str -- foo> ) ">" append ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : def-for-html-word-foo> ( name -- )
 | 
					
						
							|  |  |  |     #! Return the name and code for the foo> patterned | 
					
						
							|  |  |  |     #! word. | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     foo> [ ">" write-html ] ( -- ) html-word ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-06 19:58:45 -05:00
										 |  |  | : </foo> ( str -- </str> ) "</" ">" surround ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : def-for-html-word-</foo> ( name -- )
 | 
					
						
							|  |  |  |     #! Return the name and code for the </foo> patterned | 
					
						
							| 
									
										
										
										
											2008-01-11 00:48:04 -05:00
										 |  |  |     #! word. | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     </foo> dup '[ _ write-html ] ( -- ) html-word ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-06 19:58:45 -05:00
										 |  |  | : <foo/> ( str -- <str/> ) "<" "/>" surround ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : def-for-html-word-<foo/> ( name -- )
 | 
					
						
							|  |  |  |     #! Return the name and code for the <foo/> patterned | 
					
						
							|  |  |  |     #! word. | 
					
						
							| 
									
										
										
										
											2008-09-10 23:11:40 -04:00
										 |  |  |     dup <foo/> swap '[ _ <foo/> write-html ] | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     ( -- ) html-word ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : foo/> ( str -- str/> ) "/>" append ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : def-for-html-word-foo/> ( name -- )
 | 
					
						
							|  |  |  |     #! Return the name and code for the foo/> patterned | 
					
						
							| 
									
										
										
										
											2008-01-11 00:48:04 -05:00
										 |  |  |     #! word. | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     foo/> [ "/>" write-html ] ( -- ) html-word ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-11 00:48:04 -05:00
										 |  |  | : define-closed-html-word ( name -- )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     #! Given an HTML tag name, define the words for | 
					
						
							|  |  |  |     #! that closable HTML tag. | 
					
						
							|  |  |  |     dup def-for-html-word-<foo> | 
					
						
							|  |  |  |     dup def-for-html-word-<foo | 
					
						
							|  |  |  |     dup def-for-html-word-foo> | 
					
						
							|  |  |  |     def-for-html-word-</foo> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-11 00:48:04 -05:00
										 |  |  | : define-open-html-word ( name -- )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     #! Given an HTML tag name, define the words for | 
					
						
							|  |  |  |     #! that open HTML tag. | 
					
						
							|  |  |  |     dup def-for-html-word-<foo/> | 
					
						
							|  |  |  |     dup def-for-html-word-<foo | 
					
						
							|  |  |  |     def-for-html-word-foo/> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : write-attr ( value name -- )
 | 
					
						
							|  |  |  |     " " write-html | 
					
						
							|  |  |  |     write-html | 
					
						
							|  |  |  |     "='" write-html | 
					
						
							| 
									
										
										
										
											2008-06-05 01:18:36 -04:00
										 |  |  |     present escape-quoted-string write-html | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     "'" write-html ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : define-attribute-word ( name -- )
 | 
					
						
							| 
									
										
										
										
											2008-03-19 20:15:32 -04:00
										 |  |  |     dup "=" prepend swap
 | 
					
						
							| 
									
										
										
										
											2011-10-18 16:18:42 -04:00
										 |  |  |     '[ _ write-attr ] ( string -- ) html-word ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  | ! Define some closed HTML tags | 
					
						
							|  |  |  | [ | 
					
						
							|  |  |  |     "h1" "h2" "h3" "h4" "h5" "h6" "h7" "h8" "h9" | 
					
						
							|  |  |  |     "ol" "li" "form" "a" "p" "html" "head" "body" "title" | 
					
						
							| 
									
										
										
										
											2009-06-30 11:26:51 -04:00
										 |  |  |     "b" "i" "ul" "table" "thead" "tfoot" "tbody" "tr" "td" "th" "pre" "textarea" | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  |     "script" "div" "span" "select" "option" "style" "input" | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  |     "strong" | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  | ] [ define-closed-html-word ] each
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Define some open HTML tags | 
					
						
							|  |  |  | [ | 
					
						
							|  |  |  |     "input" | 
					
						
							|  |  |  |     "br" | 
					
						
							| 
									
										
										
										
											2008-09-23 02:50:34 -04:00
										 |  |  |     "hr" | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  |     "link" | 
					
						
							|  |  |  |     "img" | 
					
						
							| 
									
										
										
										
											2008-09-29 05:10:00 -04:00
										 |  |  |     "base" | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  | ] [ define-open-html-word ] each
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Define some attributes | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | [ | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  |     "method" "action" "type" "value" "name" | 
					
						
							|  |  |  |     "size" "href" "class" "border" "rows" "cols" | 
					
						
							|  |  |  |     "id" "onclick" "style" "valign" "accesskey" | 
					
						
							|  |  |  |     "src" "language" "colspan" "onchange" "rel" | 
					
						
							|  |  |  |     "width" "selected" "onsubmit" "xmlns" "lang" "xml:lang" | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  |     "media" "title" "multiple" "checked" | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  |     "summary" "cellspacing" "align" "scope" "abbr" | 
					
						
							| 
									
										
										
										
											2008-09-29 05:10:00 -04:00
										 |  |  |     "nofollow" "alt" "target" | 
					
						
							| 
									
										
										
										
											2008-05-23 18:33:31 -04:00
										 |  |  | ] [ define-attribute-word ] each
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | >> |