2003-06-24 00:56:19 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/unix/pipe.h
|
|
|
|
// Purpose: wxPipe class
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 24.06.2003 (extracted from src/unix/utilsunx.cpp)
|
2004-05-23 14:56:36 +00:00
|
|
|
// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
|
2004-05-23 20:53:33 +00:00
|
|
|
// Licence: wxWindows licence
|
2003-06-24 00:56:19 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_UNIX_PIPE_H_
|
|
|
|
#define _WX_UNIX_PIPE_H_
|
|
|
|
|
|
|
|
#include <unistd.h>
|
2013-07-03 00:29:53 +00:00
|
|
|
#include <fcntl.h>
|
2003-06-24 00:56:19 +00:00
|
|
|
|
2003-06-25 17:08:01 +00:00
|
|
|
#include "wx/log.h"
|
|
|
|
#include "wx/intl.h"
|
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxPipe: this class encapsulates pipe() system call
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class wxPipe
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// the symbolic names for the pipe ends
|
|
|
|
enum Direction
|
|
|
|
{
|
|
|
|
Read,
|
2004-06-21 12:36:34 +00:00
|
|
|
Write
|
2003-06-24 00:56:19 +00: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"));
|
|
|
|
|
2009-10-09 17:39:19 +00:00
|
|
|
return false;
|
2003-06-24 00:56:19 +00:00
|
|
|
}
|
|
|
|
|
2009-10-09 17:39:19 +00:00
|
|
|
return true;
|
2003-06-24 00:56:19 +00:00
|
|
|
}
|
|
|
|
|
2010-11-02 11:57:19 +00:00
|
|
|
// 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;
|
|
|
|
}
|
|
|
|
|
2003-06-24 00:56:19 +00:00
|
|
|
// 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 18:35:36 +00:00
|
|
|
int operator[](Direction which) const { return m_fds[which]; }
|
2003-06-24 00:56:19 +00: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 09:13:10 +00:00
|
|
|
{
|
2003-06-24 00:56:19 +00:00
|
|
|
close(m_fds[n]);
|
2006-05-17 09:13:10 +00:00
|
|
|
m_fds[n] = INVALID_FD;
|
|
|
|
}
|
2003-06-24 00:56:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// dtor closes the pipe descriptors
|
|
|
|
~wxPipe() { Close(); }
|
|
|
|
|
|
|
|
private:
|
2004-06-21 12:36:34 +00:00
|
|
|
int m_fds[2];
|
2003-06-24 00:56:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _WX_UNIX_PIPE_H_
|
|
|
|
|