summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSumit Bhardwaj <bhardwajs@outlook.com>2020-07-03 06:36:10 (GMT)
committerBrad King <brad.king@kitware.com>2020-08-27 15:12:25 (GMT)
commitd2f891288ac2b3b4fd96bb0ddf829869513c5e4a (patch)
tree7c2d67d23d5e049399515b99c5627885d017daef
parent09507da00a346289e1d9e257cceb2b2681ecd85b (diff)
downloadCMake-d2f891288ac2b3b4fd96bb0ddf829869513c5e4a.zip
CMake-d2f891288ac2b3b4fd96bb0ddf829869513c5e4a.tar.gz
CMake-d2f891288ac2b3b4fd96bb0ddf829869513c5e4a.tar.bz2
Implement cm::static_reference_cast by declval
Previously, cm::static_reference_cast used invoke_result_t and took the address of O::get. This is not in complete conformance with standard. This MR changes the implementation to use std::declval<O>.get() which is always well-defined.
-rw-r--r--Utilities/std/cmext/memory17
1 files changed, 9 insertions, 8 deletions
diff --git a/Utilities/std/cmext/memory b/Utilities/std/cmext/memory
index 50e79df..fa326f0 100644
--- a/Utilities/std/cmext/memory
+++ b/Utilities/std/cmext/memory
@@ -12,18 +12,19 @@
namespace cm {
-template <typename T, typename O,
- cm::enable_if_t<
- std::is_pointer<cm::invoke_result_t<decltype(&O::get), O>>::value,
- int> = 0>
+template <
+ typename T, typename O,
+ cm::enable_if_t<std::is_pointer<decltype(std::declval<O>().get())>::value,
+ int> = 0>
T& static_reference_cast(O& item)
{
return *(static_cast<T*>(item.get()));
}
-template <typename T, typename O,
- cm::enable_if_t<
- std::is_pointer<cm::invoke_result_t<decltype(&O::get), O>>::value,
- int> = 0>
+
+template <
+ typename T, typename O,
+ cm::enable_if_t<std::is_pointer<decltype(std::declval<O>().get())>::value,
+ int> = 0>
T& dynamic_reference_cast(O& item)
{
auto p = dynamic_cast<T*>(item.get());