| 
									
										
										
										
											2008-02-18 17:20:18 -05:00
										 |  |  | ! Copyright (C) 2008 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2008-02-18 10:08:59 -05:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-08-19 15:06:20 -04:00
										 |  |  | USING: deques threads kernel arrays sequences alarms ;
 | 
					
						
							| 
									
										
										
										
											2008-02-18 10:08:59 -05:00
										 |  |  | IN: concurrency.conditions | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-19 15:06:20 -04:00
										 |  |  | : notify-1 ( deque -- )
 | 
					
						
							|  |  |  |     dup deque-empty? [ drop ] [ pop-back resume-now ] if ;
 | 
					
						
							| 
									
										
										
										
											2008-02-18 10:08:59 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-19 15:06:20 -04:00
										 |  |  | : notify-all ( deque -- )
 | 
					
						
							|  |  |  |     [ resume-now ] slurp-deque ;
 | 
					
						
							| 
									
										
										
										
											2008-02-22 00:47:06 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : queue-timeout ( queue timeout -- alarm )
 | 
					
						
							|  |  |  |     #! Add an alarm which removes the current thread from the | 
					
						
							|  |  |  |     #! queue, and resumes it, passing it a value of t. | 
					
						
							| 
									
										
										
										
											2008-06-11 03:58:38 -04:00
										 |  |  |     >r [ self swap push-front* ] keep [ | 
					
						
							|  |  |  |         [ delete-node ] [ drop node-value ] 2bi
 | 
					
						
							|  |  |  |         t swap resume-with | 
					
						
							| 
									
										
										
										
											2008-02-22 00:47:06 -05:00
										 |  |  |     ] 2curry r> later ;
 | 
					
						
							| 
									
										
										
										
											2008-02-18 10:08:59 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-19 15:38:02 -05:00
										 |  |  | : wait ( queue timeout status -- )
 | 
					
						
							| 
									
										
										
										
											2008-02-22 00:47:06 -05:00
										 |  |  |     over [ | 
					
						
							|  |  |  |         >r queue-timeout [ drop ] r> suspend | 
					
						
							|  |  |  |         [ "Timeout" throw ] [ cancel-alarm ] if
 | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         >r drop [ push-front ] curry r> suspend drop
 | 
					
						
							|  |  |  |     ] if ;
 |