Changes imported from Abseil "staging" branch:
- d5a5960a133967e4af02836d304884cd6cbd6e46 Adjusting time tests for flakiness by Gennadiy Civil <misterg@google.com> - ccb8535fdc92c3c99bfa2795e75d3fbdcb134571 Internal-only tweak. by Jorg Brown <jorg@google.com> - 4c03dd9e54bd4645e7e7a8dfb3c590f5b0654884 Fix comment on some C++11 type traits backport. by Xiaoyi Zhang <zhangxy@google.com> - 43cd12d2304464163e33ae932fbb842a869213dd Allow intrinsic int128 to be set for __ppc64__ targets. by Abseil Team <absl-team@google.com> - 789e9c13de67ef3c7ba09c765c3484621897b6bb Update README.md description of 'types' library to be con... by Abseil Team <absl-team@google.com> - 8be10d7683c90b85244ddc67360a7ca2dfffdf01 Update comment on move constructors' noexcept specificati... by Xiaoyi Zhang <zhangxy@google.com> GitOrigin-RevId: d5a5960a133967e4af02836d304884cd6cbd6e46 Change-Id: I743efee47b9e65f46a44d9ab80ccd62cfd0c1301
This commit is contained in:
parent
cc4bed2d74
commit
d732f2014b
7 changed files with 56 additions and 16 deletions
|
|
@ -135,8 +135,11 @@ struct negation : std::integral_constant<bool, !T::value> {};
|
|||
//
|
||||
// Determines whether the passed type `T` is trivially destructable.
|
||||
//
|
||||
// This metafunction is designed to be a drop-in replacement for the C++17
|
||||
// `std::is_trivially_destructible()` metafunction.
|
||||
// This metafunction is designed to be a drop-in replacement for the C++11
|
||||
// `std::is_trivially_destructible()` metafunction for platforms that have
|
||||
// incomplete C++11 support (such as libstdc++ 4.x). On any platforms that do
|
||||
// fully support C++11, we check whether this yields the same result as the std
|
||||
// implementation.
|
||||
//
|
||||
// NOTE: the extensions (__has_trivial_xxx) are implemented in gcc (version >=
|
||||
// 4.3) and clang. Since we are supporting libstdc++ > 4.7, they should always
|
||||
|
|
@ -157,8 +160,11 @@ struct is_trivially_destructible
|
|||
//
|
||||
// Determines whether the passed type `T` is trivially default constructible.
|
||||
//
|
||||
// This metafunction is designed to be a drop-in replacement for the C++17
|
||||
// `std::is_trivially_default_constructible()` metafunction.
|
||||
// This metafunction is designed to be a drop-in replacement for the C++11
|
||||
// `std::is_trivially_default_constructible()` metafunction for platforms that
|
||||
// have incomplete C++11 support (such as libstdc++ 4.x). On any platforms that
|
||||
// do fully support C++11, we check whether this yields the same result as the
|
||||
// std implementation.
|
||||
//
|
||||
// NOTE: according to the C++ standard, Section: 20.15.4.3 [meta.unary.prop]
|
||||
// "The predicate condition for a template specialization is_constructible<T,
|
||||
|
|
@ -199,8 +205,11 @@ struct is_trivially_default_constructible
|
|||
//
|
||||
// Determines whether the passed type `T` is trivially copy constructible.
|
||||
//
|
||||
// This metafunction is designed to be a drop-in replacement for the C++17
|
||||
// `std::is_trivially_copy_constructible()` metafunction.
|
||||
// This metafunction is designed to be a drop-in replacement for the C++11
|
||||
// `std::is_trivially_copy_constructible()` metafunction for platforms that have
|
||||
// incomplete C++11 support (such as libstdc++ 4.x). On any platforms that do
|
||||
// fully support C++11, we check whether this yields the same result as the std
|
||||
// implementation.
|
||||
//
|
||||
// NOTE: `T obj(declval<const T&>());` needs to be well-formed and not call any
|
||||
// nontrivial operation. Nontrivally destructible types will cause the
|
||||
|
|
@ -221,8 +230,11 @@ struct is_trivially_copy_constructible
|
|||
//
|
||||
// Determines whether the passed type `T` is trivially copy assignable.
|
||||
//
|
||||
// This metafunction is designed to be a drop-in replacement for the C++17
|
||||
// `std::is_trivially_copy_assignable()` metafunction.
|
||||
// This metafunction is designed to be a drop-in replacement for the C++11
|
||||
// `std::is_trivially_copy_assignable()` metafunction for platforms that have
|
||||
// incomplete C++11 support (such as libstdc++ 4.x). On any platforms that do
|
||||
// fully support C++11, we check whether this yields the same result as the std
|
||||
// implementation.
|
||||
//
|
||||
// NOTE: `is_assignable<T, U>::value` is `true` if the expression
|
||||
// `declval<T>() = declval<U>()` is well-formed when treated as an unevaluated
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue