A Fast and Easy to use microframework for the web.
Go to file
ipkn daa3c82087 improve performance by 2x
change to io_service per CPU model
2014-08-17 05:35:21 -04:00
amalgamate Fixes #14, long polling leak removed. 2014-08-11 06:27:21 +09:00
cmake tcmalloc linking added 2014-08-14 19:22:02 -04:00
examples improve performance by 2x 2014-08-17 05:35:21 -04:00
http-parser@5b951d74bd now crow becomes completely header only 2014-08-07 08:31:27 +09:00
include improve performance by 2x 2014-08-17 05:35:21 -04:00
tests now crow becomes completely header only 2014-08-07 08:31:27 +09:00
.gitignore cmake update, added template test 2014-08-07 04:46:28 +09:00
.gitmodules accept connections, print http request parsed information 2014-04-01 01:51:50 +09:00
CMakeLists.txt tcmalloc linking added 2014-08-14 19:22:02 -04:00
LICENSE Update LICENSE 2014-04-20 03:55:41 +09:00
README.md Update README.md 2014-08-08 04:13:10 +09:00

Crow

Crow is C++ microframework for web. (inspired by Python Flask)

Features

  • Easy routing
    • Similiar to Flask
    • Type-safe Handlers (see Example)
  • Fast built-in JSON parser (crow::json)
  • Mustache based templating library (crow::mustache)
  • Header only
  • Provide an amalgamated header file `crow_all.h' with every features

Still in development

  • Built-in ORM
  • Middleware support

Example


#include "crow.h"
#include "json.h"

#include <sstream>

int main()
{
    crow::Crow app;

    CROW_ROUTE(app, "/about")
    ([](){
        return "About Crow example.";
    });

    // simple json response
    CROW_ROUTE(app, "/json")
    ([]{
        crow::json::wvalue x;
        x["message"] = "Hello, World!";
        return x;
    });

    // argument
    CROW_ROUTE(app,"/hello/<int>")
    ([](int count){
        if (count > 100)
            return crow::response(400);
        std::ostringstream os;
        os << count << " bottles of beer!";
        return crow::response(os.str());
    });

    // Compile error with message "Handler type is mismatched with URL paramters"
    //CROW_ROUTE(app,"/another/<int>")
    //([](int a, int b){
        //return crow::response(500);
    //});

    // more json example
    CROW_ROUTE(app, "/add_json")
    ([](const crow::request& req){
        auto x = crow::json::load(req.body);
        if (!x)
            return crow::response(400);
        int sum = x["a"].i()+x["b"].i();
        std::ostringstream os;
        os << sum;
        return crow::response{os.str()};
    });

    app.port(18080)
        .multithreaded()
        .run();
}

How to Build

If you just want to use crow, copy amalgamate/crow_all.h and include it.

Requirements

  • C++ compiler with good C++11 support (tested with g++>=4.8)

  • boost library

  • CMake

  • Linking with tcmalloc/jemalloc is recommended for speed.

Building (Tests, Examples)

Out-of-source build with CMake is recommended.

mkdir build
cd build
cmake ..
make

You can run tests with following commands:

ctest

Installing missing dependencies

Ubuntu

sudo apt-get install build-essential libtcmalloc-minimal4 && sudo ln -s /usr/lib/libtcmalloc_minimal.so.4 /usr/lib/libtcmalloc_minimal.so

OSX

brew install boost google-perftools