Crow/README.md

116 lines
2.3 KiB
Markdown
Raw Normal View History

# 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-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
## 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();
}
```
## 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-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