From b726efcfd9462255d1ff2eedb9e9cdcb9f85b8b2 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Sat, 3 Mar 2018 17:44:29 +0200 Subject: Add url::traits::find(), checks whether string looks like URL --- libbutl/url.txx | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) (limited to 'libbutl/url.txx') diff --git a/libbutl/url.txx b/libbutl/url.txx index e511bed..3a2c387 100644 --- a/libbutl/url.txx +++ b/libbutl/url.txx @@ -182,6 +182,40 @@ LIBBUTL_MODEXPORT namespace butl //@@ MOD Clang needs this for some reason. return r; } + // url_traits + // + template + std::size_t url_traits:: + find (const string_type& s, std::size_t p) + { + if (p == string_type::npos) + p = s.find (':'); + + if (p == string_type::npos || + p < 2 || + p + 1 == s.size () || s[p + 1] != '/') + return string_type::npos; + + // Scan backwards for as long as it is a valid scheme. + // + std::size_t i (p); + + for (; i != 0; --i) + { + auto c (s[i - 1]); + if (!(alnum (c) || c == '+' || c == '-' || c == '.')) + break; + } + + if (i != p && !alpha (s[i])) // First must be alpha. + ++i; + + if (p - i < 2) + return string_type::npos; + + return i; + } + // basic_url // template @@ -209,7 +243,7 @@ LIBBUTL_MODEXPORT namespace butl //@@ MOD Clang needs this for some reason. // Extract scheme. // - for(char_type c; i != e && (c = *i) != ':'; ++i) + for (char_type c; i != e && (c = *i) != ':'; ++i) { if (!(i == b ? alpha (c) -- cgit v1.1