]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/unix/pipe.h
Document wxKill(wxSIGTERM) reliance on having an open window in wxMSW.
[wxWidgets.git] / include / wx / unix / pipe.h
index a3a8e6e7a376a9a968b19ba13d475ab4a86d869b..8e4af9824f31c1ec0f2cd0330e9d0b7c38faf35e 100644 (file)
@@ -6,13 +6,14 @@
 // Created:     24.06.2003 (extracted from src/unix/utilsunx.cpp)
 // RCS-ID:      $Id$
 // Copyright:   (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
 // Created:     24.06.2003 (extracted from src/unix/utilsunx.cpp)
 // RCS-ID:      $Id$
 // Copyright:   (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
-// Licence:     wxWidgets licence
+// Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 
 #ifndef _WX_UNIX_PIPE_H_
 #define _WX_UNIX_PIPE_H_
 
 #include <unistd.h>
 ///////////////////////////////////////////////////////////////////////////////
 
 #ifndef _WX_UNIX_PIPE_H_
 #define _WX_UNIX_PIPE_H_
 
 #include <unistd.h>
+#include <fcntl.h>
 
 #include "wx/log.h"
 #include "wx/intl.h"
 
 #include "wx/log.h"
 #include "wx/intl.h"
@@ -28,8 +29,7 @@ public:
     enum Direction
     {
         Read,
     enum Direction
     {
         Read,
-        Write,
-        Direction_Max
+        Write
     };
 
     enum
     };
 
     enum
@@ -47,10 +47,20 @@ public:
         {
             wxLogSysError(_("Pipe creation failed"));
 
         {
             wxLogSysError(_("Pipe creation failed"));
 
-            return FALSE;
+            return false;
         }
 
         }
 
-        return TRUE;
+        return true;
+    }
+
+    // switch the given end of the pipe to non-blocking IO
+    bool MakeNonBlocking(Direction which)
+    {
+        const int flags = fcntl(m_fds[which], F_GETFL, 0);
+        if ( flags == -1 )
+            return false;
+
+        return fcntl(m_fds[which], F_SETFL, flags | O_NONBLOCK) == 0;
     }
 
     // return TRUE if we were created successfully
     }
 
     // return TRUE if we were created successfully
@@ -75,7 +85,10 @@ public:
         for ( size_t n = 0; n < WXSIZEOF(m_fds); n++ )
         {
             if ( m_fds[n] != INVALID_FD )
         for ( size_t n = 0; n < WXSIZEOF(m_fds); n++ )
         {
             if ( m_fds[n] != INVALID_FD )
+            {
                 close(m_fds[n]);
                 close(m_fds[n]);
+                m_fds[n] = INVALID_FD;
+            }
         }
     }
 
         }
     }
 
@@ -83,30 +96,8 @@ public:
     ~wxPipe() { Close(); }
 
 private:
     ~wxPipe() { Close(); }
 
 private:
-    int m_fds[Direction_Max];
-};
-
-#if wxUSE_STREAMS
-
-#include "wx/wfstream.h"
-
-// ----------------------------------------------------------------------------
-// wxPipeInputStream: stream for reading from a pipe
-// ----------------------------------------------------------------------------
-
-class wxPipeInputStream : public wxFileInputStream
-{
-public:
-    wxPipeInputStream(int fd) : wxFileInputStream(fd) { }
-
-    // return TRUE if the pipe is still opened
-    bool IsOpened() const { return !Eof(); }
-
-    // return TRUE if we have anything to read, don't block
-    virtual bool CanRead() const;
+    int m_fds[2];
 };
 
 };
 
-#endif // wxUSE_STREAMS
-
 #endif // _WX_UNIX_PIPE_H_
 
 #endif // _WX_UNIX_PIPE_H_