aboutsummaryrefslogtreecommitdiff
path: root/lib/dvb
diff options
context:
space:
mode:
authorAndreas Oberritter <obi@saftware.de>2009-08-15 16:27:29 +0200
committerAndreas Oberritter <obi@saftware.de>2009-08-15 16:27:29 +0200
commit18b167b6191812d54675b26733182b5d3ab15ca0 (patch)
tree47d2f8bbcbf970b655d4df9e97d5c95246ecbae3 /lib/dvb
parent0579c059ee9337a47c76a8a7a3bbf6fc6fdba9ce (diff)
downloadenigma2-18b167b6191812d54675b26733182b5d3ab15ca0.tar.gz
enigma2-18b167b6191812d54675b26733182b5d3ab15ca0.zip
prepare for deprecation of <ext/hash_map>, but leave new code disabled, because it requires compilation with -std=c++0x, which in turn requires g++ >= 4.3
Diffstat (limited to 'lib/dvb')
-rw-r--r--lib/dvb/epgcache.h22
1 files changed, 21 insertions, 1 deletions
diff --git a/lib/dvb/epgcache.h b/lib/dvb/epgcache.h
index dfd19482..7d1b163f 100644
--- a/lib/dvb/epgcache.h
+++ b/lib/dvb/epgcache.h
@@ -6,10 +6,23 @@
#ifndef SWIG
+/* Test for gcc >= maj.min, as per __GNUC_PREREQ in glibc */
+#if defined (__GNUC__) && defined (__GNUC_MINOR__)
+#define __GNUC_PREREQ(maj, min) \
+ ((__GNUC__ << 16) + __GNUC_MINOR__ >= ((maj) << 16) + (min))
+#else
+#define __GNUC_PREREQ(maj, min) 0
+#endif
+
#include <vector>
#include <list>
+#if 0 && __GNUC_PREREQ(4,3)
+#include <unordered_map>
+#include <unordered_set>
+#else
#include <ext/hash_map>
#include <ext/hash_set>
+#endif
#include <errno.h>
@@ -92,7 +105,14 @@ struct hash_uniqueEPGKey
};
#define tidMap std::set<__u32>
-#if defined(__GNUC__) && ((__GNUC__ == 3 && __GNUC_MINOR__ >= 1) || __GNUC__ == 4 ) // check if gcc version >= 3.1
+#if 0 && __GNUC_PREREQ(4,3)
+ #define eventCache std::unordered_map<uniqueEPGKey, std::pair<eventMap, timeMap>, hash_uniqueEPGKey, uniqueEPGKey::equal>
+ #ifdef ENABLE_PRIVATE_EPG
+ #define contentTimeMap std::unordered_map<time_t, std::pair<time_t, __u16> >
+ #define contentMap std::unordered_map<int, contentTimeMap >
+ #define contentMaps std::unordered_map<uniqueEPGKey, contentMap, hash_uniqueEPGKey, uniqueEPGKey::equal >
+ #endif
+#elif __GNUC_PREREQ(3,1)
#define eventCache __gnu_cxx::hash_map<uniqueEPGKey, std::pair<eventMap, timeMap>, hash_uniqueEPGKey, uniqueEPGKey::equal>
#ifdef ENABLE_PRIVATE_EPG
#define contentTimeMap __gnu_cxx::hash_map<time_t, std::pair<time_t, __u16> >