- virtual int WaitForChild(wxExecuteData& execData) = 0;
-
-
- // wxThread helpers
- // ----------------
-
- // TODO
-
-
- // other miscellaneous helpers
- // ---------------------------
-
- // wxGetOsVersion() behaves differently in GUI and non-GUI builds udner
- // Unix: in the former case it returns the information about the toolkit
- // and in the latter -- about the OS, so we need to virtualize it
- virtual int GetOSVersion(int *verMaj, int *verMin) = 0;
+ //
+ // 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);
+
+#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
+
+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);