Skip to content
Snippets Groups Projects
README.md 1.57 KiB
Newer Older
  • Learn to ignore specific revisions
  • Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    mtxclient
    ---
    
    Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    [![Build Status](https://travis-ci.org/mujx/mtxclient.svg?branch=master)](https://travis-ci.org/mujx/mtxclient)
    
    [![Build status](https://ci.appveyor.com/api/projects/status/5hl7a6dc5s60xpxy/branch/master?svg=true)](https://ci.appveyor.com/project/mujx/mtxclient/branch/master)
    
    [![codecov](https://codecov.io/gh/mujx/mtxclient/branch/master/graph/badge.svg)](https://codecov.io/gh/mujx/mtxclient)
    
    Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    [![experimental](https://img.shields.io/badge/stability-experimental-orange.svg)](http://github.com/badges/stability-badges)
    
    Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    
    Client API library for the Matrix protocol, built on top of Boost.Asio.
    
    ## Build instructions
    
    ### Dependencies
    
    - Boost 1.66 (includes Boost.Beast)
    - OpenSSL
    
    Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    - CMake 3.1 or greater
    - Google Test (for testing)
    
    
    Boost and GTest will be built automatically by CMake if they're not found on  your system.
    
    
    Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    Below is an example which will build the library along with the tests & examples.
    
    
    Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    #### Linux 
    
    ```bash
    cmake -H. -Bbuild -DCMAKE_BUILD_TYPE=Debug
    cmake --build build
    ```
    
    #### macOS
    
    You will need to pass as argument (`-DOPENSSL_ROOT_DIR`) the installation root of openssl. 
    
    
    Konstantinos Sideris's avatar
    Konstantinos Sideris committed
    ```bash
    cmake -H. -Bbuild -DCMAKE_BUILD_TYPE=Debug -DOPENSSL_ROOT_DIR=/usr/local/opt/openssl
    cmake --build build
    ```
    
    You can toggle off the tests & examples by passing `-DBUILD_LIB_TESTS=OFF` &
    `-DBUILD_LIB_EXAMPLES=OFF` respectively.
    
    ## Running the tests
    
    In order to run the integration tests you'll need a local synapse instance. You
    can start an instance with docker by running the following
    
    ```bash
    make synapse
    ```
    then run the test suite
    
    ```bash
    make test 
    ```