| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | ! Copyright (C) 2008 Doug Coleman. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-01-30 20:28:16 -05:00
										 |  |  | USING: accessors arrays combinators io | 
					
						
							| 
									
										
										
										
											2008-09-29 20:43:15 -04:00
										 |  |  | io.streams.string kernel math namespaces peg peg.ebnf | 
					
						
							| 
									
										
										
										
											2009-01-30 12:29:30 -05:00
										 |  |  | sequences sequences.deep strings xml.entities xml.literals | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  | vectors splitting xmode.code2html urls.encoding xml.data | 
					
						
							|  |  |  | xml.writer ;
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | IN: farkup | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: relative-link-prefix | 
					
						
							|  |  |  | SYMBOL: disable-images? | 
					
						
							|  |  |  | SYMBOL: link-no-follow? | 
					
						
							| 
									
										
										
										
											2008-10-01 18:11:19 -04:00
										 |  |  | SYMBOL: line-breaks? | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-19 16:46:02 -04:00
										 |  |  | TUPLE: heading1 child ;
 | 
					
						
							|  |  |  | TUPLE: heading2 child ;
 | 
					
						
							|  |  |  | TUPLE: heading3 child ;
 | 
					
						
							|  |  |  | TUPLE: heading4 child ;
 | 
					
						
							|  |  |  | TUPLE: strong child ;
 | 
					
						
							|  |  |  | TUPLE: emphasis child ;
 | 
					
						
							|  |  |  | TUPLE: superscript child ;
 | 
					
						
							|  |  |  | TUPLE: subscript child ;
 | 
					
						
							|  |  |  | TUPLE: inline-code child ;
 | 
					
						
							|  |  |  | TUPLE: paragraph child ;
 | 
					
						
							| 
									
										
										
										
											2008-09-22 21:13:24 -04:00
										 |  |  | TUPLE: list-item child ;
 | 
					
						
							| 
									
										
										
										
											2008-09-22 21:05:06 -04:00
										 |  |  | TUPLE: unordered-list child ;
 | 
					
						
							|  |  |  | TUPLE: ordered-list child ;
 | 
					
						
							| 
									
										
										
										
											2008-09-19 16:46:02 -04:00
										 |  |  | TUPLE: table child ;
 | 
					
						
							|  |  |  | TUPLE: table-row child ;
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | TUPLE: link href text ;
 | 
					
						
							|  |  |  | TUPLE: image href text ;
 | 
					
						
							|  |  |  | TUPLE: code mode string ;
 | 
					
						
							| 
									
										
										
										
											2008-09-23 02:27:39 -04:00
										 |  |  | TUPLE: line ;
 | 
					
						
							| 
									
										
										
										
											2008-10-01 18:11:19 -04:00
										 |  |  | TUPLE: line-break ;
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  | : absolute-url? ( string -- ? )
 | 
					
						
							| 
									
										
										
										
											2009-01-29 23:19:07 -05:00
										 |  |  |     { "http://" "https://" "ftp://" } [ head? ] with any? ;
 | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : simple-link-title ( string -- string' )
 | 
					
						
							| 
									
										
										
										
											2008-11-22 21:00:37 -05:00
										 |  |  |     dup absolute-url? [ "/" split1-last swap or ] unless ;
 | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-19 16:46:02 -04:00
										 |  |  | EBNF: parse-farkup | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | nl               = ("\r\n" | "\r" | "\n") => [[ drop "\n" ]] | 
					
						
							| 
									
										
										
										
											2008-09-24 23:22:36 -04:00
										 |  |  | whitespace       = " " | "\t" | nl
 | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | heading1      = "=" (!("=" | nl).)+ "=" | 
					
						
							|  |  |  |     => [[ second >string heading1 boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | heading2      = "==" (!("=" | nl).)+ "==" | 
					
						
							|  |  |  |     => [[ second >string heading2 boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | heading3      = "===" (!("=" | nl).)+ "===" | 
					
						
							|  |  |  |     => [[ second >string heading3 boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | heading4      = "====" (!("=" | nl).)+ "====" | 
					
						
							|  |  |  |     => [[ second >string heading4 boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  | heading          = heading4 | heading3 | heading2 | heading1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | strong        = "*" (!("*" | nl).)+ "*" | 
					
						
							|  |  |  |     => [[ second >string strong boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | emphasis      = "_" (!("_" | nl).)+ "_" | 
					
						
							|  |  |  |     => [[ second >string emphasis boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | superscript   = "^" (!("^" | nl).)+ "^" | 
					
						
							|  |  |  |     => [[ second >string superscript boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | subscript     = "~" (!("~" | nl).)+ "~" | 
					
						
							|  |  |  |     => [[ second >string subscript boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline-code   = "%" (!("%" | nl).)+ "%" | 
					
						
							|  |  |  |     => [[ second >string inline-code boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-08 22:45:59 -04:00
										 |  |  | link-content     = (!("|"|"]").)+ | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  |                     => [[ >string ]] | 
					
						
							| 
									
										
										
										
											2008-09-08 22:45:59 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | image-link       = "[[image:" link-content  "|" link-content "]]" | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |                     => [[ [ second >string ] [ fourth >string ] bi image boa ]] | 
					
						
							| 
									
										
										
										
											2008-09-08 22:45:59 -04:00
										 |  |  |                   | "[[image:" link-content "]]" | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |                     => [[ second >string f image boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-08 22:45:59 -04:00
										 |  |  | simple-link      = "[[" link-content "]]" | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  |     => [[ second >string dup simple-link-title link boa ]] | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-08 22:45:59 -04:00
										 |  |  | labelled-link    = "[[" link-content "|" link-content "]]" | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |     => [[ [ second >string ] [ fourth >string ] bi link boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | link             = image-link | labelled-link | simple-link | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-28 11:10:58 -04:00
										 |  |  | escaped-char  = "\" .
 | 
					
						
							|  |  |  |     => [[ second 1string ]] | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | inline-tag       = strong | emphasis | superscript | subscript | inline-code | 
					
						
							|  |  |  |                    | link | escaped-char | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | inline-delimiter = '*' | '_' | '^' | '~' | '%' | '\' | '[' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-19 16:46:02 -04:00
										 |  |  | cell             = (!(inline-delimiter | '|' | nl).)+ | 
					
						
							|  |  |  |     => [[ >string ]] | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | table-column     = (list | cell | inline-tag | inline-delimiter  ) '|' | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |     => [[ first ]] | 
					
						
							|  |  |  | table-row        = "|" (table-column)+ | 
					
						
							|  |  |  |     => [[ second table-row boa ]] | 
					
						
							|  |  |  | table            =  ((table-row nl => [[ first ]] )+ table-row? | table-row) | 
					
						
							|  |  |  |     => [[ table boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-19 16:46:02 -04:00
										 |  |  | text = (!(nl | code | heading | inline-delimiter | table ).)+ | 
					
						
							|  |  |  |     => [[ >string ]] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-01 18:11:19 -04:00
										 |  |  | paragraph-nl-item = nl list | 
					
						
							|  |  |  |     | nl line | 
					
						
							|  |  |  |     | nl => [[ line-breaks? get [ drop line-break new ] when ]] | 
					
						
							| 
									
										
										
										
											2008-09-28 11:10:58 -04:00
										 |  |  | paragraph-item = (table | code | text | inline-tag | inline-delimiter)+ | 
					
						
							|  |  |  | paragraph = ((paragraph-item paragraph-nl-item)+ nl+ => [[ first ]] | 
					
						
							|  |  |  |              | (paragraph-item paragraph-nl-item)+ paragraph-item? | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |              | paragraph-item) | 
					
						
							|  |  |  |     => [[ paragraph boa ]] | 
					
						
							| 
									
										
										
										
											2008-09-19 16:46:02 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-28 22:30:59 -04:00
										 |  |  | list-item     = (cell | inline-tag | inline-delimiter)* | 
					
						
							| 
									
										
										
										
											2008-09-22 21:05:06 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ordered-list-item      = '#' list-item | 
					
						
							| 
									
										
										
										
											2008-09-22 21:13:24 -04:00
										 |  |  |     => [[ second list-item boa ]] | 
					
						
							| 
									
										
										
										
											2008-09-22 21:05:06 -04:00
										 |  |  | ordered-list = ((ordered-list-item nl)+ ordered-list-item? | ordered-list-item) | 
					
						
							|  |  |  |     => [[ ordered-list boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | unordered-list-item    = '-' list-item | 
					
						
							| 
									
										
										
										
											2008-09-22 21:13:24 -04:00
										 |  |  |     => [[ second list-item boa ]] | 
					
						
							| 
									
										
										
										
											2008-09-22 21:05:06 -04:00
										 |  |  | unordered-list = ((unordered-list-item nl)+ unordered-list-item? | unordered-list-item) | 
					
						
							|  |  |  |     => [[ unordered-list boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | list = ordered-list | unordered-list | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-23 02:27:39 -04:00
										 |  |  | line = '___' | 
					
						
							|  |  |  |     => [[ drop line new ]] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-28 11:10:58 -04:00
										 |  |  | named-code | 
					
						
							|  |  |  |            =  '[' (!('{' | whitespace | '[').)+ '{' (!("}]").)+ "}]" | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |     => [[ [ second >string ] [ fourth >string ] bi code boa ]] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-06 20:13:48 -04:00
										 |  |  | simple-code | 
					
						
							|  |  |  |            = "[{" (!("}]").)+ "}]" | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  |     => [[ second >string f swap code boa ]] | 
					
						
							| 
									
										
										
										
											2008-09-06 20:13:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  | code = named-code | simple-code | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-06 20:13:48 -04:00
										 |  |  | stand-alone | 
					
						
							| 
									
										
										
										
											2008-09-24 20:19:51 -04:00
										 |  |  |            = (line | code | heading | list | table | paragraph | nl)* | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | ;EBNF | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : invalid-url "javascript:alert('Invalid URL in farkup');" ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : check-url ( href -- href' )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { [ dup empty? ] [ drop invalid-url ] } | 
					
						
							| 
									
										
										
										
											2009-01-29 23:19:07 -05:00
										 |  |  |         { [ dup [ 127 > ] any? ] [ drop invalid-url ] } | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |         { [ dup first "/\\" member? ] [ drop invalid-url ] } | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  |         { [ CHAR: : over member? ] [ dup absolute-url? [ drop invalid-url ] unless ] } | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  |         [ relative-link-prefix get prepend "" like ] | 
					
						
							|  |  |  |     } cond url-encode ;
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  | : write-link ( href text -- xml )
 | 
					
						
							|  |  |  |     [ check-url link-no-follow? get "true" and ] dip
 | 
					
						
							|  |  |  |     [XML <a href=<-> nofollow=<->><-></a> XML] ;
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  | : write-image-link ( href text -- xml )
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |     disable-images? get [ | 
					
						
							| 
									
										
										
										
											2008-09-07 19:06:20 -04:00
										 |  |  |         2drop
 | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  |         [XML <strong>Images are not allowed</strong> XML] | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |     ] [ | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  |         [ check-url ] [ f like ] bi*
 | 
					
						
							|  |  |  |         [XML <img src=<-> alt=<->/> XML] | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  | : render-code ( string mode -- xml )
 | 
					
						
							|  |  |  |     [ string-lines ] dip htmlize-lines | 
					
						
							|  |  |  |     [XML <pre><-></pre> XML] ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: (write-farkup) ( farkup -- xml )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : farkup-inside ( farkup name -- xml )
 | 
					
						
							|  |  |  |     <simple-name> swap T{ attrs } swap
 | 
					
						
							|  |  |  |     child>> (write-farkup) 1array <tag> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: heading1 (write-farkup) "h1" farkup-inside ;
 | 
					
						
							|  |  |  | M: heading2 (write-farkup) "h2" farkup-inside ;
 | 
					
						
							|  |  |  | M: heading3 (write-farkup) "h3" farkup-inside ;
 | 
					
						
							|  |  |  | M: heading4 (write-farkup) "h4" farkup-inside ;
 | 
					
						
							|  |  |  | M: strong (write-farkup) "strong" farkup-inside ;
 | 
					
						
							|  |  |  | M: emphasis (write-farkup) "em" farkup-inside ;
 | 
					
						
							|  |  |  | M: superscript (write-farkup) "sup" farkup-inside ;
 | 
					
						
							|  |  |  | M: subscript (write-farkup) "sub" farkup-inside ;
 | 
					
						
							|  |  |  | M: inline-code (write-farkup) "code" farkup-inside ;
 | 
					
						
							|  |  |  | M: list-item (write-farkup) "li" farkup-inside ;
 | 
					
						
							|  |  |  | M: unordered-list (write-farkup) "ul" farkup-inside ;
 | 
					
						
							|  |  |  | M: ordered-list (write-farkup) "ol" farkup-inside ;
 | 
					
						
							|  |  |  | M: paragraph (write-farkup) "p" farkup-inside ;
 | 
					
						
							|  |  |  | M: table (write-farkup) "table" farkup-inside ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: link (write-farkup) | 
					
						
							|  |  |  |     [ href>> ] [ text>> ] bi write-link ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: image (write-farkup) | 
					
						
							|  |  |  |     [ href>> ] [ text>> ] bi write-image-link ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: code (write-farkup) | 
					
						
							|  |  |  |     [ string>> ] [ mode>> ] bi render-code ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: line (write-farkup) | 
					
						
							|  |  |  |     drop [XML <hr/> XML] ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: line-break (write-farkup) | 
					
						
							|  |  |  |     drop [XML <br/> XML] ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: table-row (write-farkup) | 
					
						
							|  |  |  |     child>> | 
					
						
							|  |  |  |     [ (write-farkup) [XML <td><-></td> XML] ] map
 | 
					
						
							|  |  |  |     [XML <tr><-></tr> XML] ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: string (write-farkup) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: vector (write-farkup) [ (write-farkup) ] map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: f (write-farkup) ;
 | 
					
						
							| 
									
										
										
										
											2008-09-07 19:20:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-27 01:03:42 -05:00
										 |  |  | : farkup>xml ( string -- xml )
 | 
					
						
							|  |  |  |     parse-farkup (write-farkup) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-07 19:20:31 -04:00
										 |  |  | : write-farkup ( string -- )
 | 
					
						
							| 
									
										
										
										
											2009-01-29 14:33:04 -05:00
										 |  |  |     farkup>xml write-xml ;
 | 
					
						
							| 
									
										
										
										
											2008-07-16 00:56:25 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : convert-farkup ( string -- string' )
 | 
					
						
							| 
									
										
										
										
											2009-01-26 22:38:36 -05:00
										 |  |  |     [ write-farkup ] with-string-writer ;
 |