Skip to content

rafzi/WAMP_POCO

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

62 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Autobahn|Cpp

Autobahn|Cpp is a subproject of Autobahn which provides a WAMP implementation in C++ with the following roles

  • Caller
  • Callee
  • Publisher
  • Subscriber

running over TCP, Unix domain sockets or pipes (stdio), using rawsocket-msgpack WAMP transport.

The library is "header-only" and depends on

  • C++ 11 compiler
  • boost::asio
  • boost::any
  • boost::future

Note: While C++ 11 provides a std::future, that lacks continuations. Autobahn|Cpp makes use of boost::future.then for attaching continuations to futures as outlined in the proposal here. This feature will come to standard C++, but probably not before 2015:

Building

Build tools

Install some libs and build tools:

sudo apt-get install libbz2-dev libssl-dev ruby libtool autoconf scons

clang

Install clang and libc++:

sudo apt-get install clang-3.4 libc++1 libc++-dev

Boost

Get the latest Boost from here. Then

cd $HOME
tar xvjf Downloads/boost_1_55_0.tar.bz2
cd boost_1_55_0/
./bootstrap.sh
./b2 toolset=clang cxxflags="-stdlib=libc++" linkflags="-stdlib=libc++"

Get Boost trunk by doing:

git clone --recursive [email protected]:boostorg/boost.git


svn co  http://svn.boost.org/svn/boost/trunk boost-trunk

Add the following to $HOME/.profile

export LD_LIBRARY_PATH=${HOME}/boost_1_55_0/stage/lib:${LD_LIBRARY_PATH}

MsgPack-C

Get MsgPack-C and build with clang:

cd $HOME
git clone https://github.com/msgpack/msgpack-c.git
cd msgpack-c
./bootstrap
CXX=`which clang++` CC=`which clang` CXXFLAGS="-std=c++11 -stdlib=libc++" \
   LDFLAGS="-stdlib=libc++" ./configure --prefix=$HOME/msgpack_clang
make
make install

Add the following to $HOME/.profile

export LD_LIBRARY_PATH=${HOME}/msgpack_clang/lib:${LD_LIBRARY_PATH}

Autobahn|Cpp

Finally, to build Autobahn|Cpp

source $HOME/.profile
cd $HOME
git clone [email protected]:tavendo/AutobahnCpp.git
cd AutobahnCpp
scons

Building Documentation

The documentation is built using Sphinx, Doxygen and Breathe.

Doxygen takes the C++ source files and autogenerates XML files from the documented C++ source code.

Breathe takes the XML files generated by Doxygen and generates Sphinx RST files.

Sphinx takes the RST files generated plus manually written RST files and generates the final documentation in HTML format.

Install documentation build tools

sudo apt-get install doxygen python-sphinx
sudo /usr/bin/pip install breathe

_gen/doxygen

Futures

Closures Cheetsheet

  • [] Capture nothing (or, a scorched earth strategy?)
  • [&] Capture any referenced variable by reference
  • [=] Capture any referenced variable by making a copy
  • [=, &foo] Capture any referenced variable by making a copy, but capture variable foo by reference
  • [bar] Capture bar by making a copy; don't copy anything else
  • [this] Capture the this pointer of the enclosing class

About

WAMP for C++ 11 on POCO

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 91.1%
  • Python 8.1%
  • CMake 0.8%