erijo / xsonrpc

An XML/JSON RPC library for C++11

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Build Status

xsonrpc

An LGPL licensed XML/JSON RPC library for C++11.

Examples

A simple server handling both XML-RPC and JSON-RPC:

std::string Concat(const std::string& a, const std::string& b)
{
  return a + b;
}

int main()
{
  xsonrpc::Server server(8080);

  xsonrpc::JsonFormatHandler jsonFormatHandler;
  xsonrpc::XmlFormatHandler xmlFormatHandler;
  server.RegisterFormatHandler(jsonFormatHandler);
  server.RegisterFormatHandler(xmlFormatHandler);

  auto& dispatcher = server.GetDispatcher();
  dispatcher.AddMethod("concat", &Concat);

  bool run = true;
  dispatcher.AddMethod("exit", [&] () { run = false; }).SetHidden();

  server.Run();

  pollfd fd;
  fd.fd = server.GetFileDescriptor();
  fd.events = POLLIN;

  while (run && poll(&fd, 1, -1) == 1) {
    server.OnReadableFileDescriptor();
  }

  return 0;
}

A client capable of calling the server above could look like this:

int main(int argc, char** argv)
{
  xsonrpc::Client::GlobalInit();

  std::unique_ptr<xsonrpc::FormatHandler> formatHandler;
  for (int i = 1; i < argc; ++i) {
    if (strcmp(argv[i], "json") == 0) {
      std::cout << "Using JSON format\n";
      formatHandler.reset(new xsonrpc::JsonFormatHandler());
      break;
    }
  }
  if (!formatHandler) {
    std::cout << "Using XML format\n";
    formatHandler.reset(new xsonrpc::XmlFormatHandler());
  }
  xsonrpc::Client client("localhost", 8080, *formatHandler);

  std::cout << client.Call("concat", "Hello, ", "World!") << "\n";
  client.Call("exit");
  return 0;
}

Build instructions

To build xsonrpc you need:

mkdir build
cd build
cmake path/to/xsonrpc
make

About

An XML/JSON RPC library for C++11

License:GNU Lesser General Public License v2.1


Languages

Language:C++ 94.7%Language:C 1.4%Language:CMake 1.0%Language:Python 0.8%Language:Objective-C 0.8%Language:CSS 0.3%Language:Groff 0.3%Language:Objective-C++ 0.2%Language:Shell 0.2%Language:HTML 0.1%Language:Makefile 0.0%