]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/unix/pipe.h
create wxTheClipboard on first use, not startup -- this fixes crash in console-only...
[wxWidgets.git] / include / wx / unix / pipe.h
index a142b752a98585d3c1034bb3bae157e908047ce8..33f6b40f7934bbe09aa9eb25f2eed517bb705bf6 100644 (file)
@@ -5,7 +5,7 @@
 // Modified by:
 // Created:     24.06.2003 (extracted from src/unix/utilsunx.cpp)
 // RCS-ID:      $Id$
 // Modified by:
 // Created:     24.06.2003 (extracted from src/unix/utilsunx.cpp)
 // RCS-ID:      $Id$
-// Copyright:   (c) 2003 Vadim Zeitlin <vadim@wxwindows.org>
+// Copyright:   (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 
 // Licence:     wxWindows licence
 ///////////////////////////////////////////////////////////////////////////////
 
@@ -14,6 +14,9 @@
 
 #include <unistd.h>
 
 
 #include <unistd.h>
 
+#include "wx/log.h"
+#include "wx/intl.h"
+
 // ----------------------------------------------------------------------------
 // wxPipe: this class encapsulates pipe() system call
 // ----------------------------------------------------------------------------
 // ----------------------------------------------------------------------------
 // wxPipe: this class encapsulates pipe() system call
 // ----------------------------------------------------------------------------
@@ -25,7 +28,8 @@ public:
     enum Direction
     {
         Read,
     enum Direction
     {
         Read,
-        Write
+        Write,
+        Direction_Max
     };
 
     enum
     };
 
     enum
@@ -53,21 +57,12 @@ public:
     bool IsOk() const { return m_fds[Read] != INVALID_FD; }
 
     // return the descriptor for one of the pipe ends
     bool IsOk() const { return m_fds[Read] != INVALID_FD; }
 
     // return the descriptor for one of the pipe ends
-    int operator[](Direction which) const
-    {
-        wxASSERT_MSG( which >= 0 && (size_t)which < WXSIZEOF(m_fds),
-                      _T("invalid pipe index") );
-
-        return m_fds[which];
-    }
+    int operator[](Direction which) const { return m_fds[which]; }
 
     // detach a descriptor, meaning that the pipe dtor won't close it, and
     // return it
     int Detach(Direction which)
     {
 
     // detach a descriptor, meaning that the pipe dtor won't close it, and
     // return it
     int Detach(Direction which)
     {
-        wxASSERT_MSG( which >= 0 && (size_t)which < WXSIZEOF(m_fds),
-                      _T("invalid pipe index") );
-
         int fd = m_fds[which];
         m_fds[which] = INVALID_FD;
 
         int fd = m_fds[which];
         m_fds[which] = INVALID_FD;
 
@@ -88,8 +83,30 @@ public:
     ~wxPipe() { Close(); }
 
 private:
     ~wxPipe() { Close(); }
 
 private:
-    int m_fds[2];
+    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;
+};
+
+#endif // wxUSE_STREAMS
+
 #endif // _WX_UNIX_PIPE_H_
 
 #endif // _WX_UNIX_PIPE_H_