2003-06-24 00:56:19 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/unix/apptbase.h
|
|
|
|
// Purpose: declaration of wxAppTraits for Unix systems
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 23.06.2003
|
|
|
|
// RCS-ID: $Id$
|
2004-05-23 14:56:36 +00:00
|
|
|
// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
2003-06-24 00:56:19 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_UNIX_APPTBASE_H_
|
|
|
|
#define _WX_UNIX_APPTBASE_H_
|
|
|
|
|
2008-03-22 00:07:13 +00:00
|
|
|
struct wxEndProcessData;
|
2004-09-26 16:28:51 +00:00
|
|
|
struct wxExecuteData;
|
2009-08-17 23:02:46 +00:00
|
|
|
class wxFDIOManager;
|
2003-06-24 00:56:19 +00:00
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxAppTraits: the Unix version adds extra hooks needed by Unix code
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2007-12-12 01:35:53 +00:00
|
|
|
class WXDLLIMPEXP_BASE wxAppTraits : public wxAppTraitsBase
|
2003-06-24 00:56:19 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// wxExecute() support methods
|
|
|
|
// ---------------------------
|
|
|
|
|
|
|
|
// wait for the process termination, return whatever wxExecute() must
|
|
|
|
// return
|
2008-03-22 00:07:13 +00:00
|
|
|
//
|
|
|
|
// base class implementation handles all cases except wxEXEC_SYNC without
|
|
|
|
// wxEXEC_NOEVENTS one which is implemented at the GUI level
|
|
|
|
virtual int WaitForChild(wxExecuteData& execData);
|
|
|
|
|
|
|
|
// integrate the monitoring of the given fd with the port-specific event
|
|
|
|
// loop: when this fd, which corresponds to a dummy pipe opened between the
|
|
|
|
// parent and child processes, is closed by the child, the parent is
|
|
|
|
// notified about this via a call to wxHandleProcessTermination() function
|
|
|
|
//
|
|
|
|
// the default implementation uses wxFDIODispatcher and so is suitable for
|
|
|
|
// the console applications or ports which don't have any specific event
|
|
|
|
// loop
|
|
|
|
virtual int AddProcessCallback(wxEndProcessData *data, int fd);
|
2003-06-24 00:56:19 +00:00
|
|
|
|
2009-08-17 23:02:46 +00:00
|
|
|
#if wxUSE_SOCKETS
|
|
|
|
// return a pointer to the object which should be used to integrate
|
|
|
|
// monitoring of the file descriptors to the event loop (currently this is
|
|
|
|
// used for the sockets only but should be used for arbitrary event loop
|
|
|
|
// sources in the future)
|
|
|
|
//
|
|
|
|
// this object may be different for the console and GUI applications
|
|
|
|
//
|
|
|
|
// the pointer is not deleted by the caller as normally it points to a
|
|
|
|
// static variable
|
|
|
|
virtual wxFDIOManager *GetFDIOManager();
|
|
|
|
#endif // wxUSE_SOCKETS
|
2003-06-24 00:56:19 +00:00
|
|
|
|
2008-03-22 03:46:04 +00:00
|
|
|
protected:
|
|
|
|
// a helper for the implementation of WaitForChild() in wxGUIAppTraits:
|
|
|
|
// checks the streams used for redirected IO in execData and returns true
|
|
|
|
// if there is any activity in them
|
|
|
|
bool CheckForRedirectedIO(wxExecuteData& execData);
|
2003-06-24 00:56:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _WX_UNIX_APPTBASE_H_
|
|
|
|
|