X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fsupport%2Fregex.h;h=96498708fcee8047a44ab9ada5c369bfbb7c2f53;hb=7b0f9d95248820bc70b820dd6b558de4a6713bae;hp=94140a53eaebb1a1af53d8b171f5c9b5c4ac515a;hpb=08317ecc0b56a5174270ec0fe0dc87cb4dea6a8e;p=lyx.git diff --git a/src/support/regex.h b/src/support/regex.h index 94140a53ea..96498708fc 100644 --- a/src/support/regex.h +++ b/src/support/regex.h @@ -12,76 +12,22 @@ #ifndef LYX_REGEXP_H #define LYX_REGEXP_H -#if defined(LYX_USE_CXX11) && defined(LYX_USE_STD_REGEX) +#ifdef 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; @@ -91,10 +37,20 @@ namespace regex_constants { using namespace LR_NS::regex_constants; using LR_NS::regex_constants::match_flag_type; -} +} // namespace regex_constants -} +} // namespace lyx #undef LR_NS +#ifdef LYX_USE_STD_REGEX +// Match Begin and End of String when using ECMAScript (default std::regex) +#define REGEX_BOS "^" +#define REGEX_EOS "$" +#else +// Match Begin and End of String when using Perl RE (default boost::regex) +#define REGEX_BOS "\\`" +#define REGEX_EOS "\\'" +#endif + #endif