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
 |