X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fsupport%2Fregex.h;h=fd6f1e5ceac19f6c9e5cf5f955c9462c5477a648;hb=f16b2cab75752e7b0fbec5520e231b068eb29072;hp=94140a53eaebb1a1af53d8b171f5c9b5c4ac515a;hpb=08317ecc0b56a5174270ec0fe0dc87cb4dea6a8e;p=lyx.git diff --git a/src/support/regex.h b/src/support/regex.h index 94140a53ea..fd6f1e5cea 100644 --- a/src/support/regex.h +++ b/src/support/regex.h @@ -14,74 +14,20 @@ #if defined(LYX_USE_CXX11) && defined(LYX_USE_STD_REGEX) # include -# ifdef _MSC_VER -namespace lyx { - // inheriting 'private' to see which functions are used and if there are - // other ECMAScript defaults - // FIXME: Is this really needed? - // If yes, then the MSVC regex implementation is not standard-conforming. - class regex : private std::regex - { - public: - regex() {} - regex(const regex& rhs) : std::regex(rhs) {} - template - regex(T t) : std::regex(t, std::regex_constants::grep) {} - template - void assign(T t) { std::regex::assign(t, std::regex_constants::grep); } - template - void assign(T t, V v) { std::regex::assign(t, v); } - const std::regex& toStd() const { return *this; } - }; - template - bool regex_match(T t, const regex& r) { return std::regex_match(t, r.toStd()); } - template - bool regex_match(T t, std::smatch& m, const regex& r) { return std::regex_match(t, m, r.toStd()); } - template - bool regex_match(T t, V v, std::smatch& m, const regex& r) { return std::regex_match(t, v, m, r.toStd()); } - template - std::string regex_replace(T t, const regex& r, V v) { return std::regex_replace(t, r.toStd(), v); } - template - T regex_replace(T t, V v, U u, const regex& r, H h) { return std::regex_replace(t, v, u, r.toStd(), h); } - template - bool regex_search(T t, const regex& r) { return std::regex_search(t, r.toStd()); } - template - bool regex_search(T t, std::smatch& m, const regex& r) { return std::regex_search(t, m, r.toStd()); } - template - bool regex_search(T t, V v, std::smatch& m, const regex& r) { return std::regex_search(t, v, m, r.toStd()); } - - struct sregex_iterator : std::sregex_iterator - { - sregex_iterator() {} - template - sregex_iterator(T t, V v, const regex& r) : std::sregex_iterator(t, v, r.toStd()) {} - }; -} -# else // in gcc is unusable in versions less than 4.9.0 // see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=53631 # define LR_NS std -namespace lyx { -using LR_NS::regex; -using LR_NS::regex_match; -using LR_NS::regex_replace; -using LR_NS::regex_search; -using LR_NS::sregex_iterator; -} -# endif #else # include # define LR_NS boost +#endif + namespace lyx { using LR_NS::regex; using LR_NS::regex_match; using LR_NS::regex_replace; using LR_NS::regex_search; using LR_NS::sregex_iterator; -} -#endif - -namespace lyx { using LR_NS::smatch; using LR_NS::basic_regex; using LR_NS::regex_error;