| 
									
										
										
										
											2008-04-20 06:15:46 -04:00
										 |  |  | USING: kernel alien.c-types alien.strings sequences math unix | 
					
						
							|  |  |  | vectors kernel namespaces continuations threads assocs vectors | 
					
						
							|  |  |  | io.unix.backend io.encodings.utf8 ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | IN: unix.process | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-20 17:07:18 -05:00
										 |  |  | ! Low-level Unix process launching utilities. These are used | 
					
						
							|  |  |  | ! to implement io.launcher on Unix. User code should use | 
					
						
							|  |  |  | ! io.launcher instead. | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-05 18:07:37 -05:00
										 |  |  | : >argv ( seq -- alien )
 | 
					
						
							| 
									
										
										
										
											2008-04-20 06:15:46 -04:00
										 |  |  |     [ utf8 malloc-string ] map f suffix >c-void*-array ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : exec ( pathname argv -- int )
 | 
					
						
							| 
									
										
										
										
											2008-04-20 06:15:46 -04:00
										 |  |  |     [ utf8 malloc-string ] [ >argv ] bi* execv ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : exec-with-path ( filename argv -- int )
 | 
					
						
							| 
									
										
										
										
											2008-04-20 06:15:46 -04:00
										 |  |  |     [ utf8 malloc-string ] [ >argv ] bi* execvp ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : exec-with-env ( filename argv envp -- int )
 | 
					
						
							| 
									
										
										
										
											2008-04-20 06:15:46 -04:00
										 |  |  |     [ utf8 malloc-string ] [ >argv ] [ >argv ] tri* execve ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-20 17:07:18 -05:00
										 |  |  | : exec-args ( seq -- int )
 | 
					
						
							|  |  |  |     [ first ] [ ] bi exec ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-20 17:07:18 -05:00
										 |  |  | : exec-args-with-path ( seq -- int )
 | 
					
						
							|  |  |  |     [ first ] [ ] bi exec-with-path ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-20 17:07:18 -05:00
										 |  |  | : exec-args-with-env  ( seq seq -- int )
 | 
					
						
							|  |  |  |     >r [ first ] [ ] bi r> exec-with-env ;
 | 
					
						
							| 
									
										
										
										
											2007-11-14 18:32:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-20 17:07:18 -05:00
										 |  |  | : with-fork ( child parent -- )
 | 
					
						
							| 
									
										
										
										
											2008-02-05 18:07:37 -05:00
										 |  |  |     fork dup io-error dup zero? -roll swap curry if ; inline
 | 
					
						
							| 
									
										
										
										
											2007-11-15 18:49:43 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-20 17:07:18 -05:00
										 |  |  | : wait-for-pid ( pid -- status )
 | 
					
						
							| 
									
										
										
										
											2008-03-24 19:02:39 -04:00
										 |  |  |     0 <int> [ 0 waitpid drop ] keep *int WEXITSTATUS ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : set-priority ( n -- )
 | 
					
						
							|  |  |  |     0 0 rot setpriority io-error ;
 |