]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/unix/pipe.h
Test using wxString::ToCDouble() in wxAny.
[wxWidgets.git] / include / wx / unix / pipe.h
index 356ee9d394e55a45d14fb537998fa4a2939d871e..e4799024edb7f4d274c3dd0fa8893a4a6db0acdb 100644 (file)
@@ -46,10 +46,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
@@ -74,7 +84,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;
+            }
         }
     }
 
         }
     }
 
@@ -85,7 +98,7 @@ private:
     int m_fds[2];
 };
 
     int m_fds[2];
 };
 
-#if wxUSE_STREAMS
+#if wxUSE_STREAMS && wxUSE_FILE
 
 #include "wx/wfstream.h"
 
 
 #include "wx/wfstream.h"
 
@@ -105,7 +118,21 @@ public:
     virtual bool CanRead() const;
 };
 
     virtual bool CanRead() const;
 };
 
-#endif // wxUSE_STREAMS
+// ----------------------------------------------------------------------------
+// wxPipeOutputStream: stream for writing to a pipe
+// ----------------------------------------------------------------------------
+
+class wxPipeOutputStream : public wxFileOutputStream
+{
+public:
+    wxPipeOutputStream(int fd) : wxFileOutputStream(fd) { }
+
+    // Override the base class version to ignore "pipe full" errors: this is
+    // not an error for this class.
+    size_t OnSysWrite(const void *buffer, size_t size);
+};
+
+#endif // wxUSE_STREAMS && wxUSE_FILE
 
 #endif // _WX_UNIX_PIPE_H_
 
 
 #endif // _WX_UNIX_PIPE_H_