summaryrefslogtreecommitdiff
path: root/asl/types
diff options
context:
space:
mode:
Diffstat (limited to 'asl/types')
-rw-r--r--asl/types/BUILD.bazel1
-rw-r--r--asl/types/function_ref.hpp5
2 files changed, 4 insertions, 2 deletions
diff --git a/asl/types/BUILD.bazel b/asl/types/BUILD.bazel
index 198d0a2..53905a3 100644
--- a/asl/types/BUILD.bazel
+++ b/asl/types/BUILD.bazel
@@ -97,6 +97,7 @@ cc_library(
],
deps = [
"//asl/base",
+ "//asl/memory",
],
visibility = ["//visibility:public"],
)
diff --git a/asl/types/function_ref.hpp b/asl/types/function_ref.hpp
index 8daa5bd..8d874f1 100644
--- a/asl/types/function_ref.hpp
+++ b/asl/types/function_ref.hpp
@@ -7,6 +7,7 @@
#include "asl/base/utility.hpp"
#include "asl/base/meta.hpp"
#include "asl/base/functional.hpp"
+#include "asl/memory/memory.hpp"
namespace asl
{
@@ -43,7 +44,7 @@ public:
&& same_as<invoke_result_t<T, Args...>, R>
)
// NOLINTNEXTLINE(*cast*)
- : m_obj{const_cast<void*>(reinterpret_cast<const void*>(&t))}
+ : m_obj{const_cast<void*>(reinterpret_cast<const void*>(address_of(t)))}
, m_invoke{invoke<un_ref_t<T>>}
{}
@@ -56,7 +57,7 @@ public:
)
{
// NOLINTNEXTLINE(*cast*)
- m_obj = const_cast<void*>(reinterpret_cast<const void*>(&t));
+ m_obj = const_cast<void*>(reinterpret_cast<const void*>(address_of(t)));
m_invoke = invoke<un_ref_t<T>>;
return *this;