|  | @@ -89,8 +89,7 @@ class Process {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		var opt = { args: setArgs(cmd, args), stdio : stdio };
 |  |  		var opt = { args: setArgs(cmd, args), stdio : stdio };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		var p : lua.lib.luv.Process.LuvSpawn;
 |  | 
 | 
											
												
													
														|  | -		p = lua.lib.luv.Process.spawn( _shell, opt, function(code : Int, signal : Signal){
 |  | 
 | 
											
												
													
														|  | 
 |  | +		var p = lua.lib.luv.Process.spawn( _shell, opt, function(code : Int, signal : Signal){
 | 
											
												
													
														|  |  			_code = code;
 |  |  			_code = code;
 | 
											
												
													
														|  |  		});
 |  |  		});
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -105,9 +104,9 @@ class Process {
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	public function close() : Void {
 |  |  	public function close() : Void {
 | 
											
												
													
														|  | -		stdout.close();
 |  | 
 | 
											
												
													
														|  | -		stdin.close();
 |  | 
 | 
											
												
													
														|  |  		stderr.close();
 |  |  		stderr.close();
 | 
											
												
													
														|  | 
 |  | +		stdin.close();
 | 
											
												
													
														|  | 
 |  | +		stdout.close();
 | 
											
												
													
														|  |  		_handle.close();
 |  |  		_handle.close();
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -193,7 +192,17 @@ private class ProcessInput extends haxe.io.Input {
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	override public function close() {
 |  |  	override public function close() {
 | 
											
												
													
														|  | -		b.close();
 |  | 
 | 
											
												
													
														|  | 
 |  | +		if (b.is_closing()){
 | 
											
												
													
														|  | 
 |  | +			return;
 | 
											
												
													
														|  | 
 |  | +		} else if (b.is_active()) {
 | 
											
												
													
														|  | 
 |  | +			b.shutdown((type, status)-> {
 | 
											
												
													
														|  | 
 |  | +				if (status != 0){
 | 
											
												
													
														|  | 
 |  | +					throw "Invalid shutdown";
 | 
											
												
													
														|  | 
 |  | +				} else {
 | 
											
												
													
														|  | 
 |  | +					b.close();
 | 
											
												
													
														|  | 
 |  | +				}
 | 
											
												
													
														|  | 
 |  | +			});
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -210,7 +219,17 @@ private class ProcessOutput extends haxe.io.Output {
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	override public function close(){
 |  |  	override public function close(){
 | 
											
												
													
														|  | -		b.close();
 |  | 
 | 
											
												
													
														|  | 
 |  | +		if (b.is_closing()){
 | 
											
												
													
														|  | 
 |  | +			return;
 | 
											
												
													
														|  | 
 |  | +		} else {
 | 
											
												
													
														|  | 
 |  | +			b.shutdown((type, status)-> {
 | 
											
												
													
														|  | 
 |  | +				if (status != 0){
 | 
											
												
													
														|  | 
 |  | +					throw "Invalid shutdown";
 | 
											
												
													
														|  | 
 |  | +				} else {
 | 
											
												
													
														|  | 
 |  | +					b.close();
 | 
											
												
													
														|  | 
 |  | +				}
 | 
											
												
													
														|  | 
 |  | +			});
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 |