| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | ! Copyright (C) 2008 Slava Pestov, Doug Coleman | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: accessors fry io io.encodings io.streams.null kernel | 
					
						
							|  |  |  | namespaces timers ;
 | 
					
						
							|  |  |  | IN: io.timeouts | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: timeout ( obj -- dt/f )
 | 
					
						
							|  |  |  | GENERIC: set-timeout ( dt/f obj -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: decoder set-timeout stream>> set-timeout ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: encoder set-timeout stream>> set-timeout ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: cancel-operation ( obj -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : queue-timeout ( obj timeout -- timer )
 | 
					
						
							|  |  |  |     [ '[ _ cancel-operation ] ] dip later ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : with-timeout* ( obj timeout quot -- )
 | 
					
						
							| 
									
										
										
										
											2015-08-10 13:55:27 -04:00
										 |  |  |     2over queue-timeout | 
					
						
							|  |  |  |     [ nip call ] dip stop-timer ; inline
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : with-timeout ( obj quot -- )
 | 
					
						
							| 
									
										
										
										
											2015-08-10 13:55:27 -04:00
										 |  |  |     over timeout | 
					
						
							|  |  |  |     [ [ dup timeout ] dip with-timeout* ] [ call ] if ; inline
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : timeouts ( dt -- )
 | 
					
						
							|  |  |  |     [ input-stream get set-timeout ] | 
					
						
							|  |  |  |     [ output-stream get set-timeout ] bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: null-stream set-timeout 2drop ;
 |