diff options
Diffstat (limited to 'mod/mod-builds.cxx')
-rw-r--r-- | mod/mod-builds.cxx | 73 |
1 files changed, 7 insertions, 66 deletions
diff --git a/mod/mod-builds.cxx b/mod/mod-builds.cxx index 81d4649..b11b3d7 100644 --- a/mod/mod-builds.cxx +++ b/mod/mod-builds.cxx @@ -27,6 +27,7 @@ #include <libbrep/build-package-odb.hxx> #include <mod/page.hxx> +#include <mod/utility.hxx> // wildcard_to_similar_to_pattern() #include <mod/module-options.hxx> using namespace std; @@ -57,77 +58,19 @@ init (scanner& s) { database_module::init (*options_, options_->build_db_retry ()); build_config_module::init (*options_); - } - - if (options_->root ().empty ()) - options_->root (dir_path ("/")); -} - -// Transform the wildcard to the SIMILAR TO-pattern. -// -static string -transform (const string& pattern) -{ - if (pattern.empty ()) - return "%"; - - string r; - for (const path_pattern_term& pt: path_pattern_iterator (pattern)) - { - switch (pt.type) - { - case path_pattern_term_type::question: r += '_'; break; - case path_pattern_term_type::star: r += '%'; break; - case path_pattern_term_type::bracket: - { - // Copy the bracket expression translating the inverse character, if - // present. - // - size_t n (r.size ()); - r.append (pt.begin, pt.end); - - if (r[n + 1] == '!') // ...[!... ? - r[n + 1] = '^'; - break; - } - case path_pattern_term_type::literal: - { - char c (get_literal (pt)); - - // Escape the special characters. - // - // Note that '.' is not a special character for SIMILAR TO. - // - switch (c) - { - case '\\': - case '%': - case '_': - case '|': - case '+': - case '{': - case '}': - case '(': - case ')': - case '[': - case ']': r += '\\'; break; - } - - r += c; - break; - } - } + if (options_->root ().empty ()) + options_->root (dir_path ("/")); } - - return r; } template <typename T, typename C> static inline query<T> match (const C qc, const string& pattern) { - return qc + "SIMILAR TO" + query<T>::_val (transform (pattern)); + return qc + + "SIMILAR TO" + + query<T>::_val (brep::wildcard_to_similar_to_pattern (pattern)); } // If tenant is absent, then query builds from all the public tenants. @@ -450,9 +393,7 @@ handle (request& rq, response& rs) // The 'action' attribute is optional in HTML5. While the standard // doesn't specify browser behavior explicitly for the case the // attribute is omitted, the only reasonable behavior is to default it - // to the current document URL. Note that we specify the function name - // using the "hidden" <input/> element since the action url must not - // contain the query part. + // to the current document URL. // s << FORM << TABLE(ID="filter", CLASS="proplist") |