This header is private and is not supposed to be used from the outside the library. See #16325. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@76683 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			103 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        wx/unix/private/execute.h
 | |
| // Purpose:     private details of wxExecute() implementation
 | |
| // Author:      Vadim Zeitlin
 | |
| // Copyright:   (c) 1998 Robert Roebling, Julian Smart, Vadim Zeitlin
 | |
| //              (c) 2013 Vadim Zeitlin
 | |
| // Licence:     wxWindows licence
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef _WX_UNIX_EXECUTE_H
 | |
| #define _WX_UNIX_EXECUTE_H
 | |
| 
 | |
| #include "wx/app.h"
 | |
| #include "wx/hashmap.h"
 | |
| #include "wx/process.h"
 | |
| 
 | |
| #if wxUSE_STREAMS
 | |
|     #include "wx/unix/pipe.h"
 | |
|     #include "wx/private/streamtempinput.h"
 | |
| #endif
 | |
| 
 | |
| class wxEventLoopBase;
 | |
| 
 | |
| // Information associated with a running child process.
 | |
| class wxExecuteData
 | |
| {
 | |
| public:
 | |
|     wxExecuteData()
 | |
|     {
 | |
|         flags =
 | |
|         pid = 0;
 | |
|         exitcode = -1;
 | |
| 
 | |
|         process = NULL;
 | |
| 
 | |
|         syncEventLoop = NULL;
 | |
| 
 | |
| #if wxUSE_STREAMS
 | |
|         fdOut =
 | |
|         fdErr = wxPipe::INVALID_FD;
 | |
| #endif // wxUSE_STREAMS
 | |
|     }
 | |
| 
 | |
|     // This must be called in the parent process as soon as fork() returns to
 | |
|     // update us with the effective child PID. It also ensures that we handle
 | |
|     // SIGCHLD to be able to detect when this PID exits, so wxTheApp must be
 | |
|     // available.
 | |
|     void OnStart(int pid);
 | |
| 
 | |
|     // Called when the child process exits.
 | |
|     void OnExit(int exitcode);
 | |
| 
 | |
|     // Return true if we should (or already did) redirect the child IO.
 | |
|     bool IsRedirected() const { return process && process->IsRedirected(); }
 | |
| 
 | |
| 
 | |
|     // wxExecute() flags
 | |
|     int flags;
 | |
| 
 | |
|     // the pid of the child process
 | |
|     int pid;
 | |
| 
 | |
|     // The exit code of the process, set once the child terminates.
 | |
|     int exitcode;
 | |
| 
 | |
|     // the associated process object or NULL
 | |
|     wxProcess *process;
 | |
| 
 | |
|     // Local event loop used to wait for the child process termination in
 | |
|     // synchronous execution case. We can't create it ourselves as its exact
 | |
|     // type depends on the application kind (console/GUI), so we rely on
 | |
|     // wxAppTraits setting up this pointer to point to the appropriate object.
 | |
|     wxEventLoopBase *syncEventLoop;
 | |
| 
 | |
| #if wxUSE_STREAMS
 | |
|     // the input buffer bufOut is connected to stdout, this is why it is
 | |
|     // called bufOut and not bufIn
 | |
|     wxStreamTempInputBuffer bufOut,
 | |
|                             bufErr;
 | |
| 
 | |
|     // the corresponding FDs, -1 if not redirected
 | |
|     int fdOut,
 | |
|         fdErr;
 | |
| #endif // wxUSE_STREAMS
 | |
| 
 | |
| 
 | |
| private:
 | |
|     // SIGCHLD signal handler that checks whether any of the currently running
 | |
|     // children have exited.
 | |
|     static void OnSomeChildExited(int sig);
 | |
| 
 | |
|     // All currently running child processes indexed by their PID.
 | |
|     //
 | |
|     // Notice that the container doesn't own its elements.
 | |
|     WX_DECLARE_HASH_MAP(int, wxExecuteData*, wxIntegerHash, wxIntegerEqual,
 | |
|                         ChildProcessesData);
 | |
|     static ChildProcessesData ms_childProcesses;
 | |
| 
 | |
|     wxDECLARE_NO_COPY_CLASS(wxExecuteData);
 | |
| };
 | |
| 
 | |
| #endif // _WX_UNIX_EXECUTE_H
 |