diff --git a/README.md b/README.md index 883c1d1..e7fcb11 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,7 @@ A library for optional (nullable) objects for C++11. This is the reference imple Supported compilers ------------------- -Clang 3.2, G++ 4.7.2 (and probably later) +Clang 3.2+, G++ 4.6+ Usage diff --git a/optional.hpp b/optional.hpp index c6107fb..a787cc8 100644 --- a/optional.hpp +++ b/optional.hpp @@ -21,36 +21,45 @@ # define REQUIRES(...) typename enable_if<__VA_ARGS__::value, bool>::type = false # if defined __clang__ +# define OPTIONAL_HAS_USING 1 # if (__clang_major__ > 2) || (__clang_major__ == 2) && (__clang_minor__ >= 9) # define OPTIONAL_HAS_THIS_RVALUE_REFS 1 # else # define OPTIONAL_HAS_THIS_RVALUE_REFS 0 # endif # elif defined __GNUC__ -# if (__GNUC__ >= 4) && (__GNUC_MINOR__ > 8 || ((__GNUC_MINOR__ >= 8) && (__GNUC_PATCHLEVEL__ >= 1))) +# if (__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7)) +# define OPTIONAL_HAS_USING 1 +# else +# define OPTIONAL_HAS_USING 0 +# endif +# if (__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ > 8 || ((__GNUC_MINOR__ == 8) && (__GNUC_PATCHLEVEL__ >= 1)))) # define OPTIONAL_HAS_THIS_RVALUE_REFS 1 # else # define OPTIONAL_HAS_THIS_RVALUE_REFS 0 # endif # else # define OPTIONAL_HAS_THIS_RVALUE_REFS 0 +# define OPTIONAL_HAS_USING 0 # endif namespace std{ -# if (defined __GNUC__) && (__GNUC__ >= 4) && (__GNUC_MINOR__ >= 8) +# if (defined __GNUC__) && ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 8))) + // leave it; our metafunctions are already defined. +# elif (defined __clang__) && ((__clang_major__ > 3) || (__clang_major__ == 3) && (__clang_minor__ >= 3)) // leave it; our metafunctions are already defined. # else - -// the only bit GCC 4.7 and clang(?) don't have +# if OPTIONAL_HAS_USING +// the only bit GCC 4.7 and clang 3.2 don't have template using is_trivially_destructible = typename std::has_trivial_destructor; +# endif - -# if (defined __GNUC__) && (__GNUC__ >= 4) && (__GNUC_MINOR__ >= 7) +# if (defined __GNUC__) && ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7))) // leave it; remaining metafunctions are already defined. # elif defined __clang__ // leave it; remaining metafunctions are already defined. @@ -295,14 +304,16 @@ struct constexpr_optional_base ~constexpr_optional_base() = default; }; +# if OPTIONAL_HAS_USING template using OptionalBase = typename std::conditional< std::is_trivially_destructible::value, constexpr_optional_base, optional_base >::type; - - +# else +# define OptionalBase optional_base +# endif template class optional : private OptionalBase @@ -930,6 +941,8 @@ namespace std }; } - +#ifdef OptionalBase +# undef OptionalBase +#endif # endif //___OPTIONAL_HPP___