| 
									
										
										
										
											2009-05-10 19:06:28 -04:00
										 |  |  | ! Copyright (C) 2009 Bruno Deferrari | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: combinators io kernel math math.parser sequences ;
 | 
					
						
							|  |  |  | IN: redis.response-parser | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-02 16:41:44 -04:00
										 |  |  | DEFER: read-response | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: redis-response message ;
 | 
					
						
							|  |  |  | ERROR: redis-error message ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <redis-response> ( message -- redis-response )
 | 
					
						
							|  |  |  |     redis-response boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-10 19:06:28 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-02 16:41:44 -04:00
										 |  |  | : read-bulk ( n -- bytes )
 | 
					
						
							|  |  |  |     dup 0 < [ drop f ] [ read 2 read drop ] if ;
 | 
					
						
							| 
									
										
										
										
											2009-05-10 19:06:28 -04:00
										 |  |  | : read-multi-bulk ( n -- seq/f )
 | 
					
						
							| 
									
										
										
										
											2014-05-02 16:41:44 -04:00
										 |  |  |     dup 0 <
 | 
					
						
							|  |  |  |     [ drop f ] | 
					
						
							|  |  |  |     [ [ read-response ] replicate ] if ;
 | 
					
						
							| 
									
										
										
										
											2009-05-10 19:06:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-02 16:41:44 -04:00
										 |  |  | : handle-response ( string -- string )
 | 
					
						
							|  |  |  |     <redis-response> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : handle-error ( string -- * )
 | 
					
						
							| 
									
										
										
										
											2015-08-13 19:13:05 -04:00
										 |  |  |     redis-error ;
 | 
					
						
							| 
									
										
										
										
											2009-05-10 19:06:28 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : read-response ( -- response )
 | 
					
						
							|  |  |  |     readln unclip { | 
					
						
							|  |  |  |         { CHAR: : [ string>number ] } | 
					
						
							|  |  |  |         { CHAR: + [ handle-response ] } | 
					
						
							|  |  |  |         { CHAR: $ [ string>number read-bulk ] } | 
					
						
							|  |  |  |         { CHAR: * [ string>number read-multi-bulk ] } | 
					
						
							|  |  |  |         { CHAR: - [ handle-error ] } | 
					
						
							|  |  |  |     } case ;
 | 
					
						
							| 
									
										
										
										
											2014-05-02 16:41:44 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : check-response ( -- )
 | 
					
						
							|  |  |  |     read-response drop ;
 |