1999-03-06 00:11:27 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: unix/execute.h
|
|
|
|
// Purpose: private details of wxExecute() implementation
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Id: $Id$
|
|
|
|
// Copyright: (c) 1998 Robert Roebling, Julian Smart, Vadim Zeitlin
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
1999-03-06 00:11:27 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_UNIX_EXECUTE_H
|
|
|
|
#define _WX_UNIX_EXECUTE_H
|
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
#include "wx/unix/pipe.h"
|
|
|
|
|
2007-07-09 10:09:52 +00:00
|
|
|
class WXDLLIMPEXP_FWD_BASE wxProcess;
|
2003-06-24 00:56:19 +00:00
|
|
|
class wxStreamTempInputBuffer;
|
|
|
|
|
1999-03-06 00:11:27 +00:00
|
|
|
struct wxEndProcessData
|
|
|
|
{
|
2008-03-22 15:37:16 +00:00
|
|
|
wxEndProcessData()
|
|
|
|
{
|
|
|
|
pid =
|
|
|
|
tag =
|
|
|
|
exitcode = -1;
|
|
|
|
process = NULL;
|
|
|
|
async = false;
|
|
|
|
}
|
|
|
|
|
2007-12-19 18:52:55 +00:00
|
|
|
int pid; // pid of the process
|
|
|
|
int tag; // port dependent value
|
1999-03-06 00:11:27 +00:00
|
|
|
wxProcess *process; // if !NULL: notified on process termination
|
2008-03-22 15:37:16 +00:00
|
|
|
int exitcode; // the exit code
|
|
|
|
bool async; // if true, delete us on process termination
|
1999-03-06 00:11:27 +00:00
|
|
|
};
|
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
// struct in which information is passed from wxExecute() to wxAppTraits
|
|
|
|
// methods
|
|
|
|
struct wxExecuteData
|
|
|
|
{
|
|
|
|
wxExecuteData()
|
|
|
|
{
|
|
|
|
flags =
|
|
|
|
pid = 0;
|
|
|
|
|
|
|
|
process = NULL;
|
|
|
|
|
|
|
|
#if wxUSE_STREAMS
|
|
|
|
bufOut =
|
|
|
|
bufErr = NULL;
|
2008-03-22 14:10:54 +00:00
|
|
|
|
|
|
|
fdOut =
|
|
|
|
fdErr = wxPipe::INVALID_FD;
|
2003-06-24 00:56:19 +00:00
|
|
|
#endif // wxUSE_STREAMS
|
|
|
|
}
|
|
|
|
|
2008-03-22 14:10:54 +00:00
|
|
|
// get the FD corresponding to the read end of the process end detection
|
|
|
|
// pipe and close the write one
|
|
|
|
int GetEndProcReadFD()
|
|
|
|
{
|
|
|
|
const int fd = pipeEndProcDetect.Detach(wxPipe::Read);
|
|
|
|
pipeEndProcDetect.Close();
|
|
|
|
return fd;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
// wxExecute() flags
|
|
|
|
int flags;
|
|
|
|
|
|
|
|
// the pid of the child process
|
|
|
|
int pid;
|
|
|
|
|
|
|
|
// the associated process object or NULL
|
|
|
|
wxProcess *process;
|
|
|
|
|
|
|
|
// pipe used for end process detection
|
|
|
|
wxPipe pipeEndProcDetect;
|
|
|
|
|
|
|
|
#if wxUSE_STREAMS
|
|
|
|
// the input buffer bufOut is connected to stdout, this is why it is
|
|
|
|
// called bufOut and not bufIn
|
|
|
|
wxStreamTempInputBuffer *bufOut,
|
|
|
|
*bufErr;
|
2008-03-22 14:10:54 +00:00
|
|
|
|
|
|
|
// the corresponding FDs, -1 if not redirected
|
|
|
|
int fdOut,
|
|
|
|
fdErr;
|
2003-06-24 00:56:19 +00:00
|
|
|
#endif // wxUSE_STREAMS
|
|
|
|
};
|
|
|
|
|
1999-03-06 00:11:27 +00:00
|
|
|
// this function is called when the process terminates from port specific
|
|
|
|
// callback function and is common to all ports (src/unix/utilsunx.cpp)
|
2005-08-02 22:58:06 +00:00
|
|
|
extern WXDLLIMPEXP_BASE void wxHandleProcessTermination(wxEndProcessData *proc_data);
|
1999-03-06 00:11:27 +00:00
|
|
|
|
|
|
|
#endif // _WX_UNIX_EXECUTE_H
|