blob: 93341b5e00fcea4e3cc498b41345427c7e108ad1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
/* +------------------------------------+
* | Inspire Internet Relay Chat Daemon |
* +------------------------------------+
*
* InspIRCd: (C) 2002-2009 InspIRCd Development Team
* See: http://wiki.inspircd.org/Credits
*
* This program is free but copyrighted software; see
* the file COPYING for details.
*
* ---------------------------------------------------
*/
#ifndef INSPIRCD_HASHMAP_H
#define INSPIRCD_HASHMAP_H
#include "inspircd_config.h"
/** Where hash_map is varies from compiler to compiler
* as it is not standard unless we have tr1.
*/
#ifndef WIN32
#ifdef HASHMAP_DEPRECATED
// GCC4+ has deprecated hash_map and uses tr1. But of course, uses a different include to MSVC. FOR FUCKS SAKE.
#include <tr1/unordered_map>
#define HAS_TR1_UNORDERED
#else
#include <ext/hash_map>
/** Oddball linux namespace for hash_map */
#define nspace __gnu_cxx
#define BEGIN_HASHMAP_NAMESPACE namespace nspace {
#define END_HASHMAP_NAMESPACE }
#endif
#else
#if _MSC_VER >= 1600
// New MSVC has tr1. Just to make things fucked up, though, MSVC and GCC use different includes! FFS.
#include <unordered_map>
#define HAS_TR1_UNORDERED
#define HASHMAP_DEPRECATED
#else
/** Oddball windows namespace for hash_map */
#include <hash_map>
#define nspace stdext
using stdext::hash_map;
#define BEGIN_HASHMAP_NAMESPACE namespace nspace {
#define END_HASHMAP_NAMESPACE }
#endif
#endif
// tr1: restoring sanity to our headers. now if only compiler vendors could agree on a FUCKING INCLUDE FILE.
#ifdef HAS_TR1_UNORDERED
#define hash_map unordered_map
#define nspace std::tr1
#define BEGIN_HASHMAP_NAMESPACE namespace std { namespace tr1 {
#define END_HASHMAP_NAMESPACE } }
#endif
#endif
|