summaryrefslogtreecommitdiffstats
path: root/unordered.h
diff options
context:
space:
mode:
authorJosh Stone <jistone@redhat.com>2009-09-02 16:43:58 -0700
committerJosh Stone <jistone@redhat.com>2009-09-02 17:13:14 -0700
commit64deb08509bf9682e7d3b8141399c5603edb2df2 (patch)
tree08618088f11078f203a98c00c5ac225a69b68738 /unordered.h
parentaca66a36681ac7cbf7fcc2eac4dafc83d6559ef9 (diff)
downloadsystemtap-steved-64deb08509bf9682e7d3b8141399c5603edb2df2.tar.gz
systemtap-steved-64deb08509bf9682e7d3b8141399c5603edb2df2.tar.xz
systemtap-steved-64deb08509bf9682e7d3b8141399c5603edb2df2.zip
Provide backward-compatible unordered_map/set
We were defining our own stap_map with a ::type to let us use typedefs to use the new unordered_map if available, or hash_map otherwise. Since unordered_map is the future direction, I'm changing our code to use that directly. The backward-compatible version is a #define to hash_map, which has a compatible interface. While I'm at it, let's also define unordered_multimap, unordered_set, and unordered_multiset. * unordered.h: New. * dwflpp.h (stap_map): Removed. (cache typedefs): Use the unordered name now.
Diffstat (limited to 'unordered.h')
-rw-r--r--unordered.h56
1 files changed, 56 insertions, 0 deletions
diff --git a/unordered.h b/unordered.h
new file mode 100644
index 00000000..6204dbfb
--- /dev/null
+++ b/unordered.h
@@ -0,0 +1,56 @@
+// backward-compatible unordered containers
+// Copyright (C) 2009 Red Hat Inc.
+//
+// This file is part of systemtap, and is free software. You can
+// redistribute it and/or modify it under the terms of the GNU General
+// Public License (GPL); either version 2, or (at your option) any
+// later version.
+
+#ifndef UNORDERED_H
+#define UNORDERED_H
+
+#include "config.h"
+
+#if 0 // uncomment to force the old mode
+#undef HAVE_TR1_UNORDERED_MAP
+#define _BACKWARD_BACKWARD_WARNING_H 1 // defeat deprecation warning
+#endif
+
+#ifdef HAVE_TR1_UNORDERED_MAP
+
+#include <tr1/unordered_map>
+using std::tr1::unordered_map;
+using std::tr1::unordered_multimap;
+
+#include <tr1/unordered_set>
+using std::tr1::unordered_set;
+using std::tr1::unordered_multiset;
+
+#else
+
+#include <ext/hash_map>
+#define unordered_map __gnu_cxx::hash_map
+#define unordered_multimap __gnu_cxx::hash_multimap
+
+#include <ext/hash_set>
+#define unordered_set __gnu_cxx::hash_set
+#define unordered_multiset __gnu_cxx::hash_multiset
+
+// Hack in common hash functions for strings and raw pointers
+namespace __gnu_cxx
+{
+ template<class T> struct hash<T*> {
+ size_t operator() (T* p) const
+ { hash<long> h; return h(reinterpret_cast<long>(p)); }
+ };
+ template<> struct hash<std::string> {
+ size_t operator() (std::string const& s) const
+ { hash<const char*> h; return h(s.c_str()); }
+ };
+}
+
+#endif
+
+#endif // UNORDERED_H
+
+/* vim: set sw=2 ts=8 cino=>4,n-2,{2,^-2,t0,(0,u0,w1,M1 : */