| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | ! Copyright (C) 2008, 2010 Slava Pestov. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: deques threads kernel arrays sequences timers fry ;
 | 
					
						
							|  |  |  | IN: concurrency.conditions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : notify-1 ( deque -- )
 | 
					
						
							|  |  |  |     dup deque-empty? [ drop ] [ pop-back resume-now ] if ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : notify-all ( deque -- )
 | 
					
						
							|  |  |  |     [ resume-now ] slurp-deque ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : queue-timeout ( queue timeout -- timer )
 | 
					
						
							| 
									
										
										
										
											2015-09-08 19:15:10 -04:00
										 |  |  |     ! Add an timer which removes the current thread from the | 
					
						
							|  |  |  |     ! queue, and resumes it, passing it a value of t. | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         [ self swap push-front* ] keep '[ | 
					
						
							|  |  |  |             _ _ | 
					
						
							|  |  |  |             [ delete-node ] [ drop node-value ] 2bi
 | 
					
						
							|  |  |  |             t swap resume-with | 
					
						
							|  |  |  |         ] | 
					
						
							|  |  |  |     ] dip later ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ERROR: timed-out-error timer ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : queue ( queue -- )
 | 
					
						
							|  |  |  |     [ self ] dip push-front ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : wait ( queue timeout status -- )
 | 
					
						
							|  |  |  |     over [ | 
					
						
							|  |  |  |         [ queue-timeout ] dip suspend | 
					
						
							| 
									
										
										
										
											2015-08-13 19:13:05 -04:00
										 |  |  |         [ timed-out-error ] [ stop-timer ] if
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     ] [ | 
					
						
							|  |  |  |         [ drop queue ] dip suspend drop
 | 
					
						
							|  |  |  |     ] if ; inline
 |