73 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Factor
		
	
	
		
			Executable File
		
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Factor
		
	
	
		
			Executable File
		
	
| ! Copyright (C) 2008 Slava Pestov.
 | |
| ! See http://factorcode.org/license.txt for BSD license.
 | |
| USING: accessors parser-combinators memoize kernel sequences
 | |
| logging arrays words strings vectors io io.files
 | |
| namespaces combinators combinators.lib logging.server
 | |
| calendar calendar.format ;
 | |
| IN: logging.parser
 | |
| 
 | |
| : string-of ( quot -- parser ) satisfy <!*> [ >string ] <@ ;
 | |
| 
 | |
| SYMBOL: multiline
 | |
| 
 | |
| : 'date' ( -- parser )
 | |
|     [ "]" member? not ] string-of [
 | |
|         dup multiline-header =
 | |
|         [ drop multiline ] [ rfc3339>timestamp ] if
 | |
|     ] <@
 | |
|     "[" "]" surrounded-by ;
 | |
| 
 | |
| : 'log-level' ( -- parser )
 | |
|     log-levels [
 | |
|         [ name>> token ] keep [ nip ] curry <@
 | |
|     ] map <or-parser> ;
 | |
| 
 | |
| : 'word-name' ( -- parser )
 | |
|     [ " :" member? not ] string-of ;
 | |
| 
 | |
| SYMBOL: malformed
 | |
| 
 | |
| : 'malformed-line' ( -- parser )
 | |
|     [ drop t ] string-of [ malformed swap 2array ] <@ ;
 | |
| 
 | |
| : 'log-message' ( -- parser )
 | |
|     [ drop t ] string-of [ 1vector ] <@ ;
 | |
| 
 | |
| MEMO: 'log-line' ( -- parser )
 | |
|     'date' " " token <&
 | |
|     'log-level' " " token <& <&>
 | |
|     'word-name' ": " token <& <:&>
 | |
|     'log-message' <:&>
 | |
|     'malformed-line' <|> ;
 | |
| 
 | |
| : parse-log-line ( string -- entry )
 | |
|     'log-line' parse-1 ;
 | |
| 
 | |
| : malformed? ( line -- ? )
 | |
|     first malformed eq? ;
 | |
| 
 | |
| : multiline? ( line -- ? )
 | |
|     first multiline eq? ;
 | |
| 
 | |
| : malformed-line ( line -- )
 | |
|     "Warning: malformed log line:" print
 | |
|     second print ;
 | |
| 
 | |
| : add-multiline ( line -- )
 | |
|     building get empty? [
 | |
|         "Warning: log begins with multiline entry" print drop
 | |
|     ] [
 | |
|         fourth first building get peek fourth push
 | |
|     ] if ;
 | |
| 
 | |
| : parse-log ( lines -- entries )
 | |
|     [
 | |
|         [
 | |
|             parse-log-line {
 | |
|                 { [ dup malformed? ] [ malformed-line ] }
 | |
|                 { [ dup multiline? ] [ add-multiline ] }
 | |
|                 [ , ]
 | |
|             } cond
 | |
|         ] each
 | |
|     ] { } make ;
 |