48 lines
		
	
	
		
			926 B
		
	
	
	
		
			Factor
		
	
	
		
		
			
		
	
	
			48 lines
		
	
	
		
			926 B
		
	
	
	
		
			Factor
		
	
	
|  | 
 | ||
|  | USING: accessors arrays kernel lexer locals math namespaces parser | ||
|  |        sequences splitting ;
 | ||
|  | 
 | ||
|  | IN: easy-help.expand-markup | ||
|  | 
 | ||
|  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
|  | 
 | ||
|  | : scan-one-array ( string -- array rest )
 | ||
|  |   string-lines | ||
|  |   lexer-factory get call
 | ||
|  |   [ | ||
|  |   [ | ||
|  |     \ } parse-until >array
 | ||
|  |     lexer get line-text>> | ||
|  |     lexer get column>> tail
 | ||
|  |   ] | ||
|  |   with-lexer | ||
|  |   ] | ||
|  |   with-scope ;
 | ||
|  | 
 | ||
|  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
|  | 
 | ||
|  | : contains-markup? ( string -- ? ) "{ $" swap subseq? ;
 | ||
|  | 
 | ||
|  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
|  | 
 | ||
|  | :: expand-markup ( LINE -- lines )
 | ||
|  |    | ||
|  |   LINE contains-markup? | ||
|  |     [ | ||
|  |      | ||
|  |       [let | N [ "{ $" LINE start ] | | ||
|  | 
 | ||
|  |         LINE N head
 | ||
|  | 
 | ||
|  |         LINE N 2 + tail scan-one-array  dup " " head? [ 1 tail ] [ ] if
 | ||
|  | 
 | ||
|  |         [ 2array ] dip
 | ||
|  | 
 | ||
|  |         expand-markup | ||
|  | 
 | ||
|  |         append ] | ||
|  |          | ||
|  |     ] | ||
|  |     [ LINE 1array ] | ||
|  |   if ;
 |