windowspipe

This commit is contained in:
Dmitry K 2016-08-02 11:11:04 +03:00
parent 17957d3a93
commit d1c7444509
2 changed files with 28 additions and 0 deletions

View File

@ -32,6 +32,8 @@ using namespace dev;
IPCSocket::IPCSocket(string const& _path): m_path(_path) IPCSocket::IPCSocket(string const& _path): m_path(_path)
{ {
#if defined(_WIN32)
#else
if (_path.length() >= sizeof(sockaddr_un::sun_path)) if (_path.length() >= sizeof(sockaddr_un::sun_path))
BOOST_FAIL("Error opening IPC: socket path is too long!"); BOOST_FAIL("Error opening IPC: socket path is too long!");
@ -48,10 +50,14 @@ IPCSocket::IPCSocket(string const& _path): m_path(_path)
BOOST_FAIL("Error connecting to IPC socket: " << _path); BOOST_FAIL("Error connecting to IPC socket: " << _path);
m_fp = fdopen(m_socket, "r"); m_fp = fdopen(m_socket, "r");
#endif
} }
string IPCSocket::sendRequest(string const& _req) string IPCSocket::sendRequest(string const& _req)
{ {
#if defined(_WIN32)
return "";
#else
send(m_socket, _req.c_str(), _req.length(), 0); send(m_socket, _req.c_str(), _req.length(), 0);
char c; char c;
@ -64,6 +70,7 @@ string IPCSocket::sendRequest(string const& _req)
break; break;
} }
return response; return response;
#endif
} }
RPCSession& RPCSession::instance(const string& _path) RPCSession& RPCSession::instance(const string& _path)

View File

@ -22,12 +22,32 @@
#include <string> #include <string>
#include <stdio.h> #include <stdio.h>
#include <map> #include <map>
#if defined(_WIN32)
#else
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <sys/un.h> #include <sys/un.h>
#endif
#include <json/value.h> #include <json/value.h>
#include <boost/test/unit_test.hpp> #include <boost/test/unit_test.hpp>
#if defined(_WIN32)
class IPCSocket : public boost::noncopyable
{
public:
IPCSocket(std::string const& _path);
std::string sendRequest(std::string const& _req);
~IPCSocket() { fclose(m_fp); }
std::string const& path() const { return m_path; }
private:
FILE *m_fp;
std::string m_path;
int m_socket;
};
#else
class IPCSocket: public boost::noncopyable class IPCSocket: public boost::noncopyable
{ {
public: public:
@ -43,6 +63,7 @@ private:
int m_socket; int m_socket;
}; };
#endif
class RPCSession: public boost::noncopyable class RPCSession: public boost::noncopyable
{ {