aboutsummaryrefslogtreecommitdiffstats
path: root/amalgamate
diff options
context:
space:
mode:
authoripknHama <ipknhama@gmail.com>2014-12-12 01:38:57 +0900
committeripknHama <ipknhama@gmail.com>2014-12-12 01:38:57 +0900
commit966867a9ca8ca3dd9e783d628b8184563318d03c (patch)
tree27b86384181a400863580dab1b719ca3b01d2a91 /amalgamate
parentc2f75a7de1eaa9a0e1a5a97b5fc1ee60c8c3a642 (diff)
downloadcrow-966867a9ca8ca3dd9e783d628b8184563318d03c.tar.gz
crow-966867a9ca8ca3dd9e783d628b8184563318d03c.zip
change pointer to reference; fix up spaces
Diffstat (limited to 'amalgamate')
-rw-r--r--amalgamate/crow_all.h66
1 files changed, 54 insertions, 12 deletions
diff --git a/amalgamate/crow_all.h b/amalgamate/crow_all.h
index ba483ca..911d15d 100644
--- a/amalgamate/crow_all.h
+++ b/amalgamate/crow_all.h
@@ -5610,7 +5610,41 @@ template <typename F, typename Set>
struct empty_context
{
};
- }
+
+ } // namespace black_magic
+
+ namespace detail
+ {
+
+ template <class T, std::size_t N, class... Args>
+ struct get_index_of_element_from_tuple_by_type_impl
+ {
+ static constexpr auto value = N;
+ };
+
+ template <class T, std::size_t N, class... Args>
+ struct get_index_of_element_from_tuple_by_type_impl<T, N, T, Args...>
+ {
+ static constexpr auto value = N;
+ };
+
+ template <class T, std::size_t N, class U, class... Args>
+ struct get_index_of_element_from_tuple_by_type_impl<T, N, U, Args...>
+ {
+ static constexpr auto value = get_index_of_element_from_tuple_by_type_impl<T, N + 1, Args...>::value;
+ };
+
+ } // namespace detail
+
+ namespace utility
+ {
+ template <class T, class... Args>
+ T& get_element_by_type(std::tuple<Args...>& t)
+ {
+ return std::get<detail::get_index_of_element_from_tuple_by_type_impl<T, 0, Args...>::value>(t);
+ }
+
+ } // namespace utility
}
@@ -6035,7 +6069,7 @@ namespace crow
json_value = std::move(r.json_value);
code = r.code;
headers = std::move(r.headers);
- completed_ = r.completed_;
+ completed_ = r.completed_;
return *this;
}
@@ -7136,7 +7170,7 @@ namespace crow
boost::asio::io_service& io_service,
Handler* handler,
const std::string& server_name,
- std::tuple<Middlewares...>& middlewares
+ std::tuple<Middlewares...>* middlewares
)
: socket_(io_service),
handler_(handler),
@@ -7233,7 +7267,7 @@ namespace crow
ctx_ = detail::context<Middlewares...>();
req.middleware_context = (void*)&ctx_;
- detail::middleware_call_helper<0, decltype(ctx_), decltype(middlewares_), Middlewares...>(middlewares_, req, res, ctx_);
+ detail::middleware_call_helper<0, decltype(ctx_), decltype(*middlewares_), Middlewares...>(*middlewares_, req, res, ctx_);
if (!res.completed_)
{
@@ -7266,8 +7300,8 @@ namespace crow
detail::after_handlers_call_helper<
((int)sizeof...(Middlewares)-1),
decltype(ctx_),
- decltype(middlewares_)>
- (middlewares_, ctx_, req_, res);
+ decltype(*middlewares_)>
+ (*middlewares_, ctx_, req_, res);
}
//auto self = this->shared_from_this();
@@ -7514,7 +7548,7 @@ namespace crow
bool need_to_start_read_after_complete_{};
bool add_keep_alive_{};
- std::tuple<Middlewares...>& middlewares_;
+ std::tuple<Middlewares...>* middlewares_;
detail::context<Middlewares...> ctx_;
};
@@ -7551,12 +7585,13 @@ namespace crow
class Server
{
public:
- Server(Handler* handler, uint16_t port, uint16_t concurrency = 1)
+ Server(Handler* handler, uint16_t port, std::tuple<Middlewares...>* middlewares = nullptr, uint16_t concurrency = 1)
: acceptor_(io_service_, tcp::endpoint(asio::ip::address(), port)),
signals_(io_service_, SIGINT, SIGTERM),
handler_(handler),
concurrency_(concurrency),
- port_(port)
+ port_(port),
+ middlewares_(middlewares)
{
}
@@ -7649,8 +7684,7 @@ namespace crow
uint16_t port_;
unsigned int roundrobin_index_{};
- std::tuple<Middlewares...> middlewares_;
-
+ std::tuple<Middlewares...>* middlewares_;
};
}
@@ -7734,7 +7768,7 @@ namespace crow
void run()
{
validate();
- server_t server(this, port_, concurrency_);
+ server_t server(this, port_, &middlewares_, concurrency_);
server.run();
}
@@ -7754,11 +7788,19 @@ namespace crow
return ctx.template get<T>();
}
+ template <typename T>
+ T& get_middleware()
+ {
+ return utility::get_element_by_type<T, Middlewares...>(middlewares_);
+ }
+
private:
uint16_t port_ = 80;
uint16_t concurrency_ = 1;
Router router_;
+
+ std::tuple<Middlewares...> middlewares_;
};
template <typename ... Middlewares>
using App = Crow<Middlewares...>;