2014-07-08 09:50:38 +00:00
|
|
|
# Crow
|
2014-03-29 20:40:24 +00:00
|
|
|
|
2014-04-25 22:43:05 +00:00
|
|
|
Crow is C++ microframework for web. (inspired by Python Flask)
|
2014-04-18 22:12:56 +00:00
|
|
|
|
2014-09-13 17:24:55 +00:00
|
|
|
![Travis Build](https://travis-ci.org/ipkn/crow.svg?branch=master)
|
|
|
|
|
2014-08-03 18:09:00 +00:00
|
|
|
## Features
|
|
|
|
|
|
|
|
- Easy routing
|
|
|
|
- Similiar to Flask
|
|
|
|
- Type-safe Handlers (see Example)
|
|
|
|
- Fast built-in JSON parser (crow::json)
|
|
|
|
- [Mustache](http://mustache.github.io/) based templating library (crow::mustache)
|
2014-08-07 19:13:10 +00:00
|
|
|
- Header only
|
|
|
|
- Provide an amalgamated header file `crow_all.h' with every features
|
2014-09-10 23:04:14 +00:00
|
|
|
- Middleware support
|
2014-08-03 18:09:00 +00:00
|
|
|
|
|
|
|
## Still in development
|
|
|
|
- Built-in ORM
|
2014-04-18 22:12:56 +00:00
|
|
|
|
2014-07-08 09:50:38 +00:00
|
|
|
## Example
|
2014-07-08 02:59:58 +00:00
|
|
|
|
|
|
|
```c++
|
|
|
|
|
|
|
|
#include "crow.h"
|
|
|
|
#include "json.h"
|
|
|
|
|
|
|
|
#include <sstream>
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
2014-09-10 23:04:14 +00:00
|
|
|
crow::SimpleApp app;
|
2014-07-08 02:59:58 +00:00
|
|
|
|
|
|
|
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;
|
|
|
|
});
|
|
|
|
|
2014-08-03 18:09:00 +00:00
|
|
|
// argument
|
2014-07-08 02:59:58 +00:00
|
|
|
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();
|
|
|
|
}
|
|
|
|
```
|
2014-07-08 09:50:38 +00:00
|
|
|
|
|
|
|
## How to Build
|
|
|
|
|
2014-08-07 19:13:10 +00:00
|
|
|
If you just want to use crow, copy amalgamate/crow_all.h and include it.
|
|
|
|
|
2014-08-03 18:09:00 +00:00
|
|
|
### Requirements
|
|
|
|
|
|
|
|
- C++ compiler with good C++11 support (tested with g++>=4.8)
|
|
|
|
- boost library
|
2014-08-07 19:13:10 +00:00
|
|
|
- CMake
|
2014-08-03 18:09:00 +00:00
|
|
|
|
2014-08-07 19:13:10 +00:00
|
|
|
- Linking with tcmalloc/jemalloc is recommended for speed.
|
2014-07-09 07:18:23 +00:00
|
|
|
|
2014-08-07 19:13:10 +00:00
|
|
|
### Building (Tests, Examples)
|
2014-07-27 14:23:58 +00:00
|
|
|
|
2014-08-07 19:13:10 +00:00
|
|
|
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
|
2014-07-27 14:23:58 +00:00
|
|
|
|
2014-08-07 19:13:10 +00:00
|
|
|
#### 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
|
2014-08-03 18:09:00 +00:00
|
|
|
|
2014-10-14 08:48:35 +00:00
|
|
|
### Attributions
|
|
|
|
|
|
|
|
Crow uses the following libraries.
|
|
|
|
|
|
|
|
qs_parse
|
|
|
|
|
|
|
|
https://github.com/bartgrantham/qs_parse
|
|
|
|
|
|
|
|
Copyright (c) 2010 Bart Grantham
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|