X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=src%2Fpipe.cpp;h=4b3dde1d3e6ab9001c719764479074e7c65126db;hb=219ffa015c0e35b03fae0788b0e8e6abcfde1a81;hp=227f31d57ddc49422dfef458a71352a0612d9ea8;hpb=baa590770e6d3729fbaef99277c669ab417e6d8f;p=metaproxy-moved-to-github.git diff --git a/src/pipe.cpp b/src/pipe.cpp index 227f31d..4b3dde1 100644 --- a/src/pipe.cpp +++ b/src/pipe.cpp @@ -1,8 +1,7 @@ +/* $Id: pipe.cpp,v 1.11 2007-02-26 13:19:23 adam Exp $ + Copyright (c) 2005-2007, Index Data. -/* $Id: pipe.cpp,v 1.3 2005-11-07 22:43:17 adam Exp $ - Copyright (c) 2005, Index Data. - -%LICENSE% + See the LICENSE file for details */ #include "config.hpp" @@ -10,6 +9,7 @@ #include #endif +#include #include #ifdef WIN32 #include @@ -37,12 +37,14 @@ #include -#include +#include #include #include "pipe.hpp" -namespace yp2 { +namespace mp = metaproxy_1; + +namespace metaproxy_1 { class Pipe::Rep : public boost::noncopyable { friend class Pipe; Rep(); @@ -53,7 +55,7 @@ namespace yp2 { }; } -using namespace yp2; +using namespace mp; void Pipe::Rep::close(int &fd) { @@ -91,6 +93,14 @@ bool Pipe::Rep::nonblock(int s) Pipe::Pipe(int port_to_use) : m_p(new Rep) { +#ifdef WIN32 + WSADATA wsaData; + WORD wVersionRequested = MAKEWORD(2, 0); + if (WSAStartup( wVersionRequested, &wsaData )) + throw Pipe::Error("WSAStartup failed"); +#else + port_to_use = 0; // we'll just use pipe on Unix +#endif if (port_to_use) { // create server socket @@ -165,7 +175,13 @@ Pipe::Pipe(int port_to_use) : m_p(new Rep) else { #ifndef WIN32 - pipe(m_p->m_fd); + if (pipe(m_p->m_fd)) + throw Pipe::Error("pipe failed"); + else + { + assert(m_p->m_fd[0] >= 0); + assert(m_p->m_fd[1] >= 0); + } #endif } } @@ -175,6 +191,9 @@ Pipe::~Pipe() m_p->close(m_p->m_fd[0]); m_p->close(m_p->m_fd[1]); m_p->close(m_p->m_socket); +#ifdef WIN32 + WSACleanup(); +#endif } int &Pipe::read_fd() const