summaryrefslogtreecommitdiffstats
path: root/libcxx
diff options
context:
space:
mode:
authorHoward Hinnant <hhinnant@apple.com>2010-06-03 16:42:57 +0000
committerHoward Hinnant <hhinnant@apple.com>2010-06-03 16:42:57 +0000
commitd1803b6c87d867bc94baf6a8a46054a3e81904d0 (patch)
treee3d148967311ecc133be674a144f21bc356bde55 /libcxx
parentb4bb6dc44d5ae4372f58b35b6707f30895aadce9 (diff)
downloadbcm5719-llvm-d1803b6c87d867bc94baf6a8a46054a3e81904d0.tar.gz
bcm5719-llvm-d1803b6c87d867bc94baf6a8a46054a3e81904d0.zip
[util.smartptr.hash]
llvm-svn: 105393
Diffstat (limited to 'libcxx')
-rw-r--r--libcxx/include/functional11
-rw-r--r--libcxx/include/memory36
-rw-r--r--libcxx/src/mutex.cpp2
-rw-r--r--libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_shared_ptr.pass.cpp1
-rw-r--r--libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_unique_ptr.pass.cpp1
-rw-r--r--libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/pack_arguments.pass.cpp21
6 files changed, 61 insertions, 11 deletions
diff --git a/libcxx/include/functional b/libcxx/include/functional
index 57112a25584..e645a55e7af 100644
--- a/libcxx/include/functional
+++ b/libcxx/include/functional
@@ -1834,16 +1834,7 @@ struct hash<long double>
}
};
-template<class _Tp>
-struct hash<_Tp*>
- : public unary_function<_Tp*, size_t>
-{
- size_t operator()(_Tp* __v) const
- {
- const size_t* const __p = reinterpret_cast<const size_t*>(&__v);
- return *__p;
- }
-};
+// struct hash<T*> in <memory>
_LIBCPP_END_NAMESPACE_STD
diff --git a/libcxx/include/memory b/libcxx/include/memory
index 10122c7a0ba..8af5ed766d7 100644
--- a/libcxx/include/memory
+++ b/libcxx/include/memory
@@ -2463,6 +2463,31 @@ inline _LIBCPP_INLINE_VISIBILITY
bool
operator>=(const unique_ptr<_T1, _D1>& __x, const unique_ptr<_T2, _D2>& __y) {return !(__x < __y);}
+template <class> struct hash;
+
+template<class _Tp>
+struct hash<_Tp*>
+ : public unary_function<_Tp*, size_t>
+{
+ size_t operator()(_Tp* __v) const
+ {
+ const size_t* const __p = reinterpret_cast<const size_t*>(&__v);
+ return *__p;
+ }
+};
+
+template <class _Tp, class _Dp>
+struct hash<unique_ptr<_Tp, _Dp> >
+{
+ typedef unique_ptr<_Tp, _Dp> argument_type;
+ typedef size_t result_type;
+ result_type operator()(const argument_type& __ptr) const
+ {
+ typedef typename argument_type::pointer pointer;
+ return hash<pointer>()(__ptr.get());
+ }
+};
+
struct __destruct_n
{
private:
@@ -3785,6 +3810,17 @@ public:
template <class _Up> friend class shared_ptr;
};
+template <class _Tp>
+struct hash<shared_ptr<_Tp> >
+{
+ typedef shared_ptr<_Tp> argument_type;
+ typedef size_t result_type;
+ result_type operator()(const argument_type& __ptr) const
+ {
+ return hash<_Tp*>()(__ptr.get());
+ }
+};
+
//enum class
struct pointer_safety
{
diff --git a/libcxx/src/mutex.cpp b/libcxx/src/mutex.cpp
index 7ea734968a5..1f8160d0a58 100644
--- a/libcxx/src/mutex.cpp
+++ b/libcxx/src/mutex.cpp
@@ -235,7 +235,7 @@ __call_once(volatile unsigned long& flag, void* arg, void(*func)(void*))
pthread_mutex_lock(&mut);
flag = 0ul;
pthread_mutex_unlock(&mut);
- pthread_cond_signal(&cv);
+ pthread_cond_broadcast(&cv);
throw;
}
}
diff --git a/libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_shared_ptr.pass.cpp b/libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_shared_ptr.pass.cpp
new file mode 100644
index 00000000000..9912d1b8f22
--- /dev/null
+++ b/libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_shared_ptr.pass.cpp
@@ -0,0 +1 @@
+//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // <memory> // template <class T> // struct hash<shared_ptr<T>> // { // typedef shared_ptr<T> argument_type; // typedef size_t result_type; // size_t operator()(const shared_ptr<T>& p) const; // }; #include <memory> #include <cassert> int main() { int* ptr = new int; std::shared_ptr<int> p(ptr); std::hash<std::shared_ptr<int> > f; std::size_t h = f(p); assert(h == std::hash<int*>()(ptr)); } \ No newline at end of file
diff --git a/libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_unique_ptr.pass.cpp b/libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_unique_ptr.pass.cpp
new file mode 100644
index 00000000000..0541e57a8a2
--- /dev/null
+++ b/libcxx/test/utilities/memory/util.smartptr/util.smartptr.hash/hash_unique_ptr.pass.cpp
@@ -0,0 +1 @@
+//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // <memory> // template <class T, class D> // struct hash<unique_ptr<T, D>> // { // typedef unique_ptr<T, D> argument_type; // typedef size_t result_type; // size_t operator()(const unique_ptr<T, D>& p) const; // }; #include <memory> #include <cassert> int main() { int* ptr = new int; std::unique_ptr<int> p(ptr); std::hash<std::unique_ptr<int> > f; std::size_t h = f(p); assert(h == std::hash<int*>()(ptr)); } \ No newline at end of file
diff --git a/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/pack_arguments.pass.cpp b/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/pack_arguments.pass.cpp
new file mode 100644
index 00000000000..6b7f1891a62
--- /dev/null
+++ b/libcxx/test/utilities/tuple/tuple.tuple/tuple.creation/pack_arguments.pass.cpp
@@ -0,0 +1,21 @@
+//===----------------------------------------------------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+// <tuple>
+
+// template<class... Types>
+// tuple<ATypes...> pack_arguments(Types&&... t);
+
+
+#include <tuple>
+
+int main()
+{
+#error pack_arguments not implemented
+}
OpenPOWER on IntegriCloud