| 
									
										
										
										
											2009-01-27 00:18:57 -05:00
										 |  |  | ! Copyright (C) 2008, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2008-04-11 23:36:24 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-05-15 00:23:12 -04:00
										 |  |  | USING: io.backend kernel continuations destructors namespaces | 
					
						
							|  |  |  | sequences assocs hashtables sorting arrays threads boxes | 
					
						
							| 
									
										
										
										
											2009-01-27 00:18:57 -05:00
										 |  |  | io.timeouts accessors concurrency.mailboxes fry | 
					
						
							| 
									
										
										
										
											2008-07-02 22:52:28 -04:00
										 |  |  | system vocabs.loader combinators ;
 | 
					
						
							| 
									
										
										
										
											2008-04-11 23:36:24 -04:00
										 |  |  | IN: io.monitors | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HOOK: init-monitors io-backend ( -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object init-monitors ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HOOK: dispose-monitors io-backend ( -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object dispose-monitors ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : with-monitors ( quot -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         init-monitors | 
					
						
							|  |  |  |         [ dispose-monitors ] [ ] cleanup
 | 
					
						
							|  |  |  |     ] with-scope ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: monitor < identity-tuple path queue timeout ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: monitor hashcode* path>> hashcode* ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: monitor timeout timeout>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: monitor set-timeout (>>timeout) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-14 06:07:31 -04:00
										 |  |  | : new-monitor ( path mailbox class -- monitor )
 | 
					
						
							| 
									
										
										
										
											2008-04-13 16:06:27 -04:00
										 |  |  |     new
 | 
					
						
							| 
									
										
										
										
											2008-04-11 23:36:24 -04:00
										 |  |  |         swap >>queue | 
					
						
							|  |  |  |         swap >>path ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-27 00:18:57 -05:00
										 |  |  | TUPLE: file-change path changed monitor ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-11 23:36:24 -04:00
										 |  |  | : queue-change ( path changes monitor -- )
 | 
					
						
							|  |  |  |     3dup and and
 | 
					
						
							| 
									
										
										
										
											2009-01-27 00:18:57 -05:00
										 |  |  |     [ [ file-change boa ] keep queue>> mailbox-put ] [ 3drop ] if ;
 | 
					
						
							| 
									
										
										
										
											2008-04-11 23:36:24 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | HOOK: (monitor) io-backend ( path recursive? mailbox -- monitor )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <monitor> ( path recursive? -- monitor )
 | 
					
						
							|  |  |  |     <mailbox> (monitor) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-27 00:18:57 -05:00
										 |  |  | : next-change ( monitor -- change )
 | 
					
						
							|  |  |  |     [ queue>> ] [ timeout ] bi mailbox-get-timeout ;
 | 
					
						
							| 
									
										
										
										
											2008-04-11 23:36:24 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: +add-file+ | 
					
						
							|  |  |  | SYMBOL: +remove-file+ | 
					
						
							|  |  |  | SYMBOL: +modify-file+ | 
					
						
							|  |  |  | SYMBOL: +rename-file-old+ | 
					
						
							|  |  |  | SYMBOL: +rename-file-new+ | 
					
						
							|  |  |  | SYMBOL: +rename-file+ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : with-monitor ( path recursive? quot -- )
 | 
					
						
							| 
									
										
										
										
											2008-12-02 04:10:13 -05:00
										 |  |  |     [ <monitor> ] dip with-disposal ; inline
 | 
					
						
							| 
									
										
										
										
											2008-07-02 22:52:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-27 00:18:57 -05:00
										 |  |  | : run-monitor ( path recursive? quot -- )
 | 
					
						
							|  |  |  |     '[ [ @ t ] loop ] with-monitor ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : spawn-monitor ( path recursive? quot -- )
 | 
					
						
							|  |  |  |     [ '[ _ _ _ run-monitor ] ] [ 2drop "Monitoring " prepend ] 3bi
 | 
					
						
							|  |  |  |     spawn drop ;
 | 
					
						
							| 
									
										
										
										
											2008-07-02 22:52:28 -04:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-14 21:03:00 -05:00
										 |  |  |     { [ os macosx? ] [ "io.monitors.macosx" require ] } | 
					
						
							|  |  |  |     { [ os linux? ] [ "io.monitors.linux" require ] } | 
					
						
							|  |  |  |     { [ os winnt? ] [ "io.monitors.windows.nt" require ] } | 
					
						
							| 
									
										
										
										
											2009-01-27 00:18:57 -05:00
										 |  |  |     { [ os bsd? ] [ ] } | 
					
						
							| 
									
										
										
										
											2008-07-02 22:52:28 -04:00
										 |  |  | } cond
 |