]> git.lyx.org Git - lyx.git/commitdiff
Get rid of tr1 support
authorGeorg Baum <baum@lyx.org>
Tue, 23 Dec 2014 21:18:08 +0000 (22:18 +0100)
committerGeorg Baum <baum@lyx.org>
Tue, 23 Dec 2014 21:18:08 +0000 (22:18 +0100)
As discussed on the list. We don't need it anymore, either we have a modern
compiler that supports C++11, or we fall back to boost. I kept and adjusted
the regex #define, since we cannot use std regex completely yet.

CMakeLists.txt
boost/libs/CMakeLists.txt
configure.ac
development/cmake/config.h.cmake
src/support/bind.h
src/support/functional.h
src/support/regex.h
src/support/shared_ptr.h

index 86f6a018069511b087faf8c5e823a8acbe50ab2d..978e63c53659d57d20cecc97188f2d7986ea9f4c 100644 (file)
@@ -246,14 +246,12 @@ set(LYX_GCC11_MODE)
 if(UNIX OR MINGW)
        execute_process(COMMAND ${CMAKE_CXX_COMPILER} -dumpversion OUTPUT_VARIABLE GCC_VERSION)
        message(STATUS "Using GCC version ${GCC_VERSION}")
-       if(NOT GCC_VERSION VERSION_LESS 4.4)
-               set(LYX_USE_TR1 1)
-               # GCC <= 4.5 does not support regex: there are linker errors
-               # http://gcc.gnu.org/onlinedocs/libstdc++/manual/status.html#status.iso.tr1
-               # <regex> and <tr1/regex> in gcc are unusable in versions less than 4.9.0
+# disabled because of missing match_partial
+#      if(GCC_VERSION VERSION_LESS 4.9)
+               # <regex> in gcc is unusable in versions less than 4.9.0
                # see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=53631
-               set(LYX_USE_TR1_REGEX 0)
-       endif()
+               set(LYX_USE_STD_REGEX 0)
+#      endif()
        if (LYX_ENABLE_CXX11)
                find_package(CXX11Compiler)
                if(NOT CXX11COMPILER_FOUND)
@@ -262,10 +260,11 @@ if(UNIX OR MINGW)
                set(LYX_GCC11_MODE "${CXX11_FLAG}")
        endif()
 else()
-       if(MSVC10)
-               set(LYX_USE_TR1 1)
-               #set(LYX_USE_TR1_REGEX 1) #TODO should we use it in ECMAScript mode?
-       endif()
+# disabled because of missing match_partial
+       set(LYX_USE_STD_REGEX 0)
+#      if(MSVC10)
+#              set(LYX_USE_STD_REGEX 1) #TODO should we use it in ECMAScript mode?
+#      endif()
 endif()
 
 
@@ -641,7 +640,7 @@ if(LYX_EXTERNAL_BOOST)
                message(FATAL_ERROR "Boost not found" ${Boost_ERROR_REASON})
        endif()
 else()
-       if(LYX_USE_TR1_REGEX)
+       if(LYX_USE_STD_REGEX)
                set(Lyx_Boost_Libraries boost_signals)
        else()
                set(Lyx_Boost_Libraries boost_signals boost_regex)
index 67a68498afbddd0d95b1a4d4b654e7437bbc9273..2417d764af36f80f90f9fb77981f7315cc04f3af 100644 (file)
@@ -7,8 +7,8 @@
 project(boost)
 
 
-if(LYX_USE_TR1_REGEX)
-       message(STATUS "Using TR1 regex")
+if(LYX_USE_STD_REGEX)
+       message(STATUS "Using std regex")
 else()
        add_subdirectory(regex) 
 endif()
index 562eba4d9be4fc62c3c6c205bcc7b26f18146dcf..6a735b1a5ccf5e4be97b1b6cd1f9edff8cbb3f6a 100644 (file)
@@ -284,15 +284,15 @@ char * strerror(int n);
 #define BOOST_NO_WSTRING 1
 #define BOOST_SIGNALS_NO_DEPRECATION_WARNING 1
 
-// TR1 regex not supported in GCC <= 4.5
-// <regex> and <tr1/regex> in gcc are unusable in versions less than 4.9.0
+// <regex> in gcc is unusable in versions less than 4.9.0
 // see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=53631
-// clang defines __GNUC__ but libc++ does not have tr1
-#ifndef LYX_USE_TR1
-#  if __GNUC__ == 4 && !defined(USE_LLVM_LIBCPP)
-#    define LYX_USE_TR1
-#  endif
-#endif
+// clang defines __GNUC__ but how do the versions match?
+// disabled because of missing match_partial
+//#ifndef LYX_USE_STD_REGEX
+//#  if (__GNUC__ == 4 && __GNUC_MINOR__ >= 9) || __GNUC__ > 4 || defined(USE_LLVM_LIBCPP)
+//#    define LYX_USE_STD_REGEX
+//#  endif
+//#endif
 
 #ifdef __CYGWIN__
 #  define NOMINMAX
index ab95cfa4fb41b4236c70f459760d7df4458c2b29..1c9456460e6830aa8f305edd00d2b76136d90db9 100644 (file)
@@ -54,8 +54,7 @@
 
 #cmakedefine LYX_MERGE_FILES 1
 
-#cmakedefine LYX_USE_TR1 1
-#cmakedefine LYX_USE_TR1_REGEX 1
+#cmakedefine LYX_USE_STD_REGEX 1
 
 // Define if callstack can be printed
 #cmakedefine LYX_CALLSTACK_PRINTING 1
index 1931b163ec2f140a2ef7398031928a111811ebee..08dd71a88598b4822455775286ba896a25da875e 100644 (file)
 
 #include "support/functional.h"
 
-#ifdef LYX_USE_TR1
-
-#define LYX_BIND_NS std::tr1
-
-namespace lyx
-{
-       using std::tr1::placeholders::_1;
-       using std::tr1::placeholders::_2;
-}
-
-#elif __cplusplus >= 201103L
+#if __cplusplus >= 201103L
 
 #define LYX_BIND_NS std
 
index bb60029611ec5c73b08c9202ee78819849c44645..b86551d6f609a49e2db107e1baa9f93b71660ef2 100644 (file)
 #ifndef LYX_FUNCTIONAL_H
 #define LYX_FUNCTIONAL_H
 
-#ifdef LYX_USE_TR1
-
-#include <functional>
-
-#ifdef __GNUC__
-#include <tr1/functional>
-#endif
-
-#define LYX_FUNCTIONAL_NS std::tr1
-
-#elif __cplusplus >= 201103L
+#if __cplusplus >= 201103L
 
 #include <functional>
 #define LYX_FUNCTIONAL_NS std
index eb3b679a8053711877c9029c4e2937fdbf10f89a..db365ca4e6c8d03004bdf555f274163b30034f08 100644 (file)
 #ifndef LYX_REGEXP_H
 #define LYX_REGEXP_H
 
-#if defined(LYX_USE_TR1) && defined(LYX_USE_TR1_REGEX)
+#if __cplusplus >= 201103L && defined(LYX_USE_STD_REGEX)
+#  include <regex>
 #  ifdef _MSC_VER
-#    include <regex>
 #    define match_partial _Match_partial
 namespace lyx {
   // inheriting 'private' to see which functions are used and if there are
   // other ECMAScrip defaults
-  class regex : private std::tr1::regex
+  class regex : private std::regex
   {
   public:
     regex() {}
-    regex(const regex& rhs) : std::tr1::regex(rhs) {}
+    regex(const regex& rhs) : std::regex(rhs) {}
     template<class T>
-    regex(T t) : std::tr1::regex(t, std::tr1::regex_constants::grep) {}
+    regex(T t) : std::regex(t, std::regex_constants::grep) {}
     template<class T>
-    void assign(T t) { std::tr1::regex::assign(t, std::tr1::regex_constants::grep); }
+    void assign(T t) { std::regex::assign(t, std::regex_constants::grep); }
     template<class T, class V>
-    void assign(T t, V v) { std::tr1::regex::assign(t, v); }
-    const std::tr1::regex& toTr1() const { return *this; }
+    void assign(T t, V v) { std::regex::assign(t, v); }
+    const std::regex& toStd() const { return *this; }
   };
   template<class T>
-  bool regex_match(T t, const regex& r) { return std::tr1::regex_match(t, r.toTr1()); }
+  bool regex_match(T t, const regex& r) { return std::regex_match(t, r.toStd()); }
   template<class T, class V>
-  bool regex_match(T t, V v, const regex& r) { return std::tr1::regex_match(t, v, r.toTr1()); }
+  bool regex_match(T t, V v, const regex& r) { return std::regex_match(t, v, r.toStd()); }
   template<class T, class V, class U, class H>
-  bool regex_match(T t, V v, H h, const regex& r, U u) { return std::tr1::regex_match(t, v, h, r.toTr1(), u); }
+  bool regex_match(T t, V v, H h, const regex& r, U u) { return std::regex_match(t, v, h, r.toStd(), u); }
   template<class T, class V>
-  std::string regex_replace(T t, const regex& r, V v) { return std::tr1::regex_replace(t, r.toTr1(), v); }
+  std::string regex_replace(T t, const regex& r, V v) { return std::regex_replace(t, r.toStd(), v); }
   //template<class T, class V, class U, class H>
-  //std::string regex_replace(T t, V v, U u, const regex& r, H h) { return std::tr1::regex_replace(t, v, u, r.toTr1(), h); }
+  //std::string regex_replace(T t, V v, U u, const regex& r, H h) { return std::regex_replace(t, v, u, r.toStd(), h); }
   template<class T>
-  bool regex_search(T t, const regex& r) { return std::tr1::regex_search(t, r.toTr1()); }
+  bool regex_search(T t, const regex& r) { return std::regex_search(t, r.toStd()); }
   template<class T, class V>
-  bool regex_search(T t, V v, const regex& r) { return std::tr1::regex_search(t, v, r.toTr1()); }
+  bool regex_search(T t, V v, const regex& r) { return std::regex_search(t, v, r.toStd()); }
   template<class T, class V, class U>
-  bool regex_search(T t, V v, U u, const regex& r) { return std::tr1::regex_search(t, v, u, r.toTr1()); }
+  bool regex_search(T t, V v, U u, const regex& r) { return std::regex_search(t, v, u, r.toStd()); }
 
-  struct sregex_iterator : std::tr1::sregex_iterator
+  struct sregex_iterator : std::sregex_iterator
   {
     sregex_iterator() {}
     template<class T, class V>
-    sregex_iterator(T t, V v, const regex& r) : std::tr1::sregex_iterator(t, v, r.toTr1()) {}
+    sregex_iterator(T t, V v, const regex& r) : std::sregex_iterator(t, v, r.toStd()) {}
   };
 }
 #  else
-#    include <tr1/regex>
-//   TODO no match_partial in TR1, how to replace?
-#  endif
-#  define LR_NS std::tr1
-namespace lyx {
-using LR_NS::regex;
-using LR_NS::regex_match;
-using LR_NS::sregex_iterator;
-}
-#elif LYX_USE_TR1_REGEX
-#  include <regex>
 // <regex> in gcc is unusable in versions less than 4.9.0
 // see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=53631
 // TODO no match_partial in std, how to replace?
@@ -77,7 +66,8 @@ using LR_NS::regex;
 using LR_NS::regex_match;
 using LR_NS::sregex_iterator;
 }
-#else 
+#  endif
+#else
 #  include <boost/regex.hpp>
 #  define LR_NS boost
 namespace lyx {
index 874a6cde91d0b874d20b50bb4672c44e6fe19d42..04dfc501a633e45ddf16fedce1b24a587b562044 100644 (file)
 #ifndef LYX_SHARED_PTR_H
 #define LYX_SHARED_PTR_H
 
-#ifdef LYX_USE_TR1
-
-#include <memory>
-
-#ifdef __GNUC__
-#include <tr1/memory>
-#endif
-
-#define LYX_SHAREDPTR_NS std::tr1
-
-#elif __cplusplus >= 201103L
+#if __cplusplus >= 201103L
 
 #include <memory>
 #define LYX_SHAREDPTR_NS std