diff options
author | Karen Arutyunov <karen@codesynthesis.com> | 2017-04-22 01:30:16 +0300 |
---|---|---|
committer | Karen Arutyunov <karen@codesynthesis.com> | 2017-04-22 16:08:45 +0300 |
commit | 0e6d08495733ed268e1624ca6450a0f4ecccac33 (patch) | |
tree | 0d2f58c87a96ebca97f17b7c5697413fc9118908 /mod/mod-repository-root.cxx | |
parent | 7cde0aab8206a5d95091860a8c1114d625f5280a (diff) |
Add support for forced rebuild
Diffstat (limited to 'mod/mod-repository-root.cxx')
-rw-r--r-- | mod/mod-repository-root.cxx | 23 |
1 files changed, 19 insertions, 4 deletions
diff --git a/mod/mod-repository-root.cxx b/mod/mod-repository-root.cxx index e156308..d8d7c64 100644 --- a/mod/mod-repository-root.cxx +++ b/mod/mod-repository-root.cxx @@ -14,6 +14,7 @@ #include <mod/options> #include <mod/mod-build-log> #include <mod/mod-build-task> +#include <mod/mod-build-force> #include <mod/mod-build-result> #include <mod/mod-package-search> #include <mod/mod-package-details> @@ -61,6 +62,7 @@ namespace brep repository_details_ (make_shared<repository_details> ()), build_task_ (make_shared<build_task> ()), build_result_ (make_shared<build_result> ()), + build_force_ (make_shared<build_force> ()), build_log_ (make_shared<build_log> ()) { } @@ -97,6 +99,10 @@ namespace brep r.initialized_ ? r.build_result_ : make_shared<build_result> (*r.build_result_)), + build_force_ ( + r.initialized_ + ? r.build_force_ + : make_shared<build_force> (*r.build_force_)), build_log_ ( r.initialized_ ? r.build_log_ @@ -121,6 +127,7 @@ namespace brep append (r, repository_details_->options ()); append (r, build_task_->options ()); append (r, build_result_->options ()); + append (r, build_force_->options ()); append (r, build_log_->options ()); return r; } @@ -161,6 +168,7 @@ namespace brep sub_init (*repository_details_, "repository_details"); sub_init (*build_task_, "build_task"); sub_init (*build_result_, "build_result"); + sub_init (*build_force_, "build_force"); sub_init (*build_log_, "build_log"); // Parse own configuration options. @@ -235,10 +243,10 @@ namespace brep // if (lpath.empty ()) { - // Dispatch request handling to the repository_details, the build_task, - // the build_result or the package_search module depending on the - // function name passed as a first HTTP request parameter. The parameter - // should have no value specified. Example: cppget.org/?about + // Dispatch request handling to the repository_details, the + // package_search or the one of build_* modules depending on the function + // name passed as a first HTTP request parameter. The parameter should + // have no value specified. Example: cppget.org/?about // const name_values& params (rq.parameters ()); if (!params.empty () && !params.front ().value) @@ -273,6 +281,13 @@ namespace brep return handle (rp, "build_result"); } + else if (fn == "build-force") + { + if (handler_ == nullptr) + handler_.reset (new build_force (*build_force_)); + + return handle (rp, "build_force"); + } else throw invalid_request (400, "unknown function"); } |