Generic observable objects and expressions for C++
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.
benchmark Small CMake refactoring to organize projects in folders inside IDEs. Feb 20, 2017
cmake Simplify compiler flags Sep 9, 2018
examples Fix warnings and improve warning handling Sep 8, 2018
observable Remove unused header Nov 8, 2018
tests Switch from GTest to Catch for unit tests Sep 9, 2018
vendor Switch from GTest to Catch for unit tests Sep 9, 2018
.gitignore Ignore the .vs folder (created by VS when opening a directory). Feb 20, 2017
.travis.yml Fix C++ standard flag Sep 8, 2018
CMakeLists.txt Switch from GTest to Catch for unit tests Sep 9, 2018
LICENSE.txt Add license and update readme. Aug 24, 2016
README.rst Update compiler list Sep 8, 2018
visual-studio.runsettings Switch from GTest to Catch for unit tests Sep 9, 2018


Observable: Generic observable objects for C++

If you want to write code in a reactive style or just implement the observer pattern, this is for you.

Quick start

The library is header-only and has no dependencies; add the observable/include directory to your include path and you're set.


#include <iostream>
#include <observable/observable.hpp>

using namespace std;
using namespace observable;

int main()
    auto sub = subject<void(string)> { };
    sub.subscribe([](auto const & msg) { cout << msg << endl; });

    // "Hello world!" will be printed on stdout.
    sub.notify("Hello world!");

    auto a = value<int> { 5 };
    auto b = value<int> { 5 };
    auto avg = observe(
                    (a + b) / 2.0f
    auto eq_msg = observe(
                    select(a == b, "equal", "not equal")

    avg.subscribe([](auto val) { cout << val << endl; });
    eq_msg.subscribe([](auto const & msg) { cout << msg << endl; });

    // "10" and "not equal" will be printed on stdout in an
    // unspecified order.
    b = 15;

    return 0;


You can access the documentation here:

What's with the CMake files?

The library is using CMake to build the tests, benchmarks and documentation. You won't need CMake if you don't want to work on the library as a developer.

Why not just use Boost.Signals2 or Qt?

Boost.Signals2 and Qt are pretty cool libraries and do their jobs well.

This library is not meant to replace signals and slots, it focuses more on providing easy to use observable objects and expressions that can help with patterns like MVC and reactive programming.

Choose whichever library works best for your case; you can even choose them both (for example, have your models use this library and your views use Qt).


Bug reports, feature requests, documentation and code contributions are welcome and highly appreciated.

Legal and Licensing

The library is licensed under the Apache License version 2.0.

Please note that all contributions are considered to be provided under the terms of this license.

Supported compilers

Any relatively recent compiler with C++14 support should work.

The code has been tested with the following compilers:

  • MSVC 15 (Visual Studio 2017)
  • MSVC 14 (Visual Studio 2015)
  • GCC 5, 6, 7
  • Clang 3.6, 3.8
  • AppleClang 9.1

Build status

Visual Studio 2017 builds:

  • win32 15 build C++14 (32 bit, C++14)
  • win64 15 build C++14 (64 bit, C++14)
  • win32 15 build C++17 (32 bit, C++17)
  • win64 15 build C++17 (64 bit, C++17)

Visual Studio 2015 builds:

  • win32 14 build (32 bit, C++14)
  • win64 14 build (64 bit, C++14)

Linux (GCC, Clang) and OS X (Clang) builds:

  • travis build (64 bit)