]> git.saurik.com Git - wxWidgets.git/blame_incremental - include/wx/unix/pipe.h
Move msw configuration checking to chkconf.h
[wxWidgets.git] / include / wx / unix / pipe.h
... / ...
CommitLineData
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/unix/pipe.h
3// Purpose: wxPipe class
4// Author: Vadim Zeitlin
5// Modified by:
6// Created: 24.06.2003 (extracted from src/unix/utilsunx.cpp)
7// RCS-ID: $Id$
8// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
9// Licence: wxWindows licence
10///////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_UNIX_PIPE_H_
13#define _WX_UNIX_PIPE_H_
14
15#include <unistd.h>
16
17#include "wx/log.h"
18#include "wx/intl.h"
19
20// ----------------------------------------------------------------------------
21// wxPipe: this class encapsulates pipe() system call
22// ----------------------------------------------------------------------------
23
24class wxPipe
25{
26public:
27 // the symbolic names for the pipe ends
28 enum Direction
29 {
30 Read,
31 Write
32 };
33
34 enum
35 {
36 INVALID_FD = -1
37 };
38
39 // default ctor doesn't do anything
40 wxPipe() { m_fds[Read] = m_fds[Write] = INVALID_FD; }
41
42 // create the pipe, return TRUE if ok, FALSE on error
43 bool Create()
44 {
45 if ( pipe(m_fds) == -1 )
46 {
47 wxLogSysError(_("Pipe creation failed"));
48
49 return false;
50 }
51
52 return true;
53 }
54
55 // switch the given end of the pipe to non-blocking IO
56 bool MakeNonBlocking(Direction which)
57 {
58 const int flags = fcntl(m_fds[which], F_GETFL, 0);
59 if ( flags == -1 )
60 return false;
61
62 return fcntl(m_fds[which], F_SETFL, flags | O_NONBLOCK) == 0;
63 }
64
65 // return TRUE if we were created successfully
66 bool IsOk() const { return m_fds[Read] != INVALID_FD; }
67
68 // return the descriptor for one of the pipe ends
69 int operator[](Direction which) const { return m_fds[which]; }
70
71 // detach a descriptor, meaning that the pipe dtor won't close it, and
72 // return it
73 int Detach(Direction which)
74 {
75 int fd = m_fds[which];
76 m_fds[which] = INVALID_FD;
77
78 return fd;
79 }
80
81 // close the pipe descriptors
82 void Close()
83 {
84 for ( size_t n = 0; n < WXSIZEOF(m_fds); n++ )
85 {
86 if ( m_fds[n] != INVALID_FD )
87 {
88 close(m_fds[n]);
89 m_fds[n] = INVALID_FD;
90 }
91 }
92 }
93
94 // dtor closes the pipe descriptors
95 ~wxPipe() { Close(); }
96
97private:
98 int m_fds[2];
99};
100
101#if wxUSE_STREAMS && wxUSE_FILE
102
103#include "wx/wfstream.h"
104
105// ----------------------------------------------------------------------------
106// wxPipeInputStream: stream for reading from a pipe
107// ----------------------------------------------------------------------------
108
109class wxPipeInputStream : public wxFileInputStream
110{
111public:
112 wxPipeInputStream(int fd) : wxFileInputStream(fd) { }
113
114 // return TRUE if the pipe is still opened
115 bool IsOpened() const { return !Eof(); }
116
117 // return TRUE if we have anything to read, don't block
118 virtual bool CanRead() const;
119};
120
121// ----------------------------------------------------------------------------
122// wxPipeOutputStream: stream for writing to a pipe
123// ----------------------------------------------------------------------------
124
125class wxPipeOutputStream : public wxFileOutputStream
126{
127public:
128 wxPipeOutputStream(int fd) : wxFileOutputStream(fd) { }
129
130 // Override the base class version to ignore "pipe full" errors: this is
131 // not an error for this class.
132 size_t OnSysWrite(const void *buffer, size_t size);
133};
134
135#endif // wxUSE_STREAMS && wxUSE_FILE
136
137#endif // _WX_UNIX_PIPE_H_
138