2003-06-23 20:56:19 -04:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/unix/pipe.h
|
|
|
|
// Purpose: wxPipe class
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 24.06.2003 (extracted from src/unix/utilsunx.cpp)
|
|
|
|
// RCS-ID: $Id$
|
2004-05-23 10:56:36 -04:00
|
|
|
// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
|
2004-05-23 16:53:33 -04:00
|
|
|
// Licence: wxWindows licence
|
2003-06-23 20:56:19 -04:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_UNIX_PIPE_H_
|
|
|
|
#define _WX_UNIX_PIPE_H_
|
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
2003-06-25 13:08:01 -04:00
|
|
|
#include "wx/log.h"
|
|
|
|
#include "wx/intl.h"
|
|
|
|
|
2003-06-23 20:56:19 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxPipe: this class encapsulates pipe() system call
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class wxPipe
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// the symbolic names for the pipe ends
|
|
|
|
enum Direction
|
|
|
|
{
|
|
|
|
Read,
|
2004-06-21 08:36:34 -04:00
|
|
|
Write
|
2003-06-23 20:56:19 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
INVALID_FD = -1
|
|
|
|
};
|
|
|
|
|
|
|
|
// default ctor doesn't do anything
|
|
|
|
wxPipe() { m_fds[Read] = m_fds[Write] = INVALID_FD; }
|
|
|
|
|
|
|
|
// create the pipe, return TRUE if ok, FALSE on error
|
|
|
|
bool Create()
|
|
|
|
{
|
|
|
|
if ( pipe(m_fds) == -1 )
|
|
|
|
{
|
|
|
|
wxLogSysError(_("Pipe creation failed"));
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// return TRUE if we were created successfully
|
|
|
|
bool IsOk() const { return m_fds[Read] != INVALID_FD; }
|
|
|
|
|
|
|
|
// return the descriptor for one of the pipe ends
|
2004-05-09 14:35:36 -04:00
|
|
|
int operator[](Direction which) const { return m_fds[which]; }
|
2003-06-23 20:56:19 -04:00
|
|
|
|
|
|
|
// detach a descriptor, meaning that the pipe dtor won't close it, and
|
|
|
|
// return it
|
|
|
|
int Detach(Direction which)
|
|
|
|
{
|
|
|
|
int fd = m_fds[which];
|
|
|
|
m_fds[which] = INVALID_FD;
|
|
|
|
|
|
|
|
return fd;
|
|
|
|
}
|
|
|
|
|
|
|
|
// close the pipe descriptors
|
|
|
|
void Close()
|
|
|
|
{
|
|
|
|
for ( size_t n = 0; n < WXSIZEOF(m_fds); n++ )
|
|
|
|
{
|
|
|
|
if ( m_fds[n] != INVALID_FD )
|
2006-05-17 05:13:10 -04:00
|
|
|
{
|
2003-06-23 20:56:19 -04:00
|
|
|
close(m_fds[n]);
|
2006-05-17 05:13:10 -04:00
|
|
|
m_fds[n] = INVALID_FD;
|
|
|
|
}
|
2003-06-23 20:56:19 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// dtor closes the pipe descriptors
|
|
|
|
~wxPipe() { Close(); }
|
|
|
|
|
|
|
|
private:
|
2004-06-21 08:36:34 -04:00
|
|
|
int m_fds[2];
|
2003-06-23 20:56:19 -04:00
|
|
|
};
|
|
|
|
|
2006-08-08 09:06:05 -04:00
|
|
|
#if wxUSE_STREAMS && wxUSE_FILE
|
2003-06-25 21:14:22 -04:00
|
|
|
|
|
|
|
#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;
|
|
|
|
};
|
|
|
|
|
2006-08-08 09:06:05 -04:00
|
|
|
#endif // wxUSE_STREAMS && wxUSE_FILE
|
2003-06-25 21:14:22 -04:00
|
|
|
|
2003-06-23 20:56:19 -04:00
|
|
|
#endif // _WX_UNIX_PIPE_H_
|
|
|
|
|