diff options
author | Howard Hinnant <hhinnant@apple.com> | 2010-06-03 16:42:57 +0000 |
---|---|---|
committer | Howard Hinnant <hhinnant@apple.com> | 2010-06-03 16:42:57 +0000 |
commit | d1803b6c87d867bc94baf6a8a46054a3e81904d0 (patch) | |
tree | e3d148967311ecc133be674a144f21bc356bde55 /libcxx | |
parent | b4bb6dc44d5ae4372f58b35b6707f30895aadce9 (diff) | |
download | bcm5719-llvm-d1803b6c87d867bc94baf6a8a46054a3e81904d0.tar.gz bcm5719-llvm-d1803b6c87d867bc94baf6a8a46054a3e81904d0.zip |
[util.smartptr.hash]
llvm-svn: 105393
Diffstat (limited to 'libcxx')
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 +} |