1 // system.h -- general definitions for gold -*- C++ -*- 2 3 // Copyright (C) 2006-2014 Free Software Foundation, Inc. 4 // Written by Ian Lance Taylor <iant@google.com>. 5 6 // This file is part of gold. 7 8 // This program is free software; you can redistribute it and/or modify 9 // it under the terms of the GNU General Public License as published by 10 // the Free Software Foundation; either version 3 of the License, or 11 // (at your option) any later version. 12 13 // This program is distributed in the hope that it will be useful, 14 // but WITHOUT ANY WARRANTY; without even the implied warranty of 15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 // GNU General Public License for more details. 17 18 // You should have received a copy of the GNU General Public License 19 // along with this program; if not, write to the Free Software 20 // Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, 21 // MA 02110-1301, USA. 22 23 #ifndef SYSTEM_H 24 #define SYSTEM_H 1 25 26 #ifndef ENABLE_NLS 27 // The Solaris version of locale.h always includes libintl.h. If we 28 // have been configured with --disable-nls then ENABLE_NLS will not 29 // be defined and the dummy definitions of bindtextdomain (et al) 30 // below will conflict with the definitions in libintl.h. So we 31 // define these values to prevent the bogus inclusion of libintl.h. 32 # define _LIBINTL_H 33 # define _LIBGETTEXT_H 34 #endif 35 36 #ifdef ENABLE_NLS 37 // On some systems, things go awry when <libintl.h> comes after <clocale>. 38 # include <libintl.h> 39 # include <clocale> 40 # define _(String) gettext (String) 41 # ifdef gettext_noop 42 # define N_(String) gettext_noop (String) 43 # else 44 # define N_(String) (String) 45 # endif 46 #else 47 // Include <clocale> first to avoid conflicts with these macros. 48 # include <clocale> 49 # define gettext(Msgid) (Msgid) 50 # define dgettext(Domainname, Msgid) (Msgid) 51 # define dcgettext(Domainname, Msgid, Category) (Msgid) 52 # define textdomain(Domainname) do {} while (0) /* nothing */ 53 # define bindtextdomain(Domainname, Dirname) do {} while (0) /* nothing */ 54 # define _(String) (String) 55 # define N_(String) (String) 56 #endif 57 58 // Figure out how to get a hash set and a hash map. 59 60 #if defined(HAVE_UNORDERED_SET) && defined(HAVE_UNORDERED_MAP) 61 62 #include <unordered_set> 63 #include <unordered_map> 64 65 // We need a template typedef here. 66 67 #define Unordered_set std::unordered_set 68 #define Unordered_map std::unordered_map 69 #define Unordered_multimap std::unordered_multimap 70 71 #define reserve_unordered_map(map, n) ((map)->rehash(n)) 72 73 #elif defined(HAVE_TR1_UNORDERED_SET) && defined(HAVE_TR1_UNORDERED_MAP) \ 74 && defined(HAVE_TR1_UNORDERED_MAP_REHASH) 75 76 #include <tr1/unordered_set> 77 #include <tr1/unordered_map> 78 79 // We need a template typedef here. 80 81 #define Unordered_set std::tr1::unordered_set 82 #define Unordered_map std::tr1::unordered_map 83 #define Unordered_multimap std::tr1::unordered_multimap 84 85 #define reserve_unordered_map(map, n) ((map)->rehash(n)) 86 87 #ifndef HAVE_TR1_HASH_OFF_T 88 // The library does not support hashes of off_t values. Add support 89 // here. This is likely to be specific to libstdc++. This issue 90 // arises with GCC 4.1.x when compiling in 32-bit mode with a 64-bit 91 // off_t type. 92 namespace std { namespace tr1 { 93 template<> 94 struct hash<off_t> : public std::unary_function<off_t, std::size_t> 95 { 96 std::size_t 97 operator()(off_t val) const 98 { return static_cast<std::size_t>(val); } 99 }; 100 } } // Close namespaces. 101 #endif // !defined(HAVE_TR1_HASH_OFF_T) 102 103 #elif defined(HAVE_EXT_HASH_MAP) && defined(HAVE_EXT_HASH_SET) 104 105 #include <ext/hash_map> 106 #include <ext/hash_set> 107 #include <string> 108 109 #define Unordered_set __gnu_cxx::hash_set 110 #define Unordered_map __gnu_cxx::hash_map 111 #define Unordered_multimap __gnu_cxx::hash_multimap 112 113 namespace __gnu_cxx 114 { 115 116 template<> 117 struct hash<std::string> 118 { 119 size_t 120 operator()(std::string s) const 121 { return __stl_hash_string(s.c_str()); } 122 }; 123 124 template<typename T> 125 struct hash<T*> 126 { 127 size_t 128 operator()(T* p) const 129 { return reinterpret_cast<size_t>(p); } 130 }; 131 132 } 133 134 #define reserve_unordered_map(map, n) ((map)->resize(n)) 135 136 #else 137 138 // The fallback is to just use set and map. 139 140 #include <set> 141 #include <map> 142 143 #define Unordered_set std::set 144 #define Unordered_map std::map 145 #define Unordered_multimap std::multimap 146 147 #define reserve_unordered_map(map, n) 148 149 #endif 150 151 #ifndef HAVE_PREAD 152 extern "C" ssize_t pread(int, void*, size_t, off_t); 153 #endif 154 155 #ifndef HAVE_FTRUNCATE 156 extern "C" int ftruncate(int, off_t); 157 #endif 158 159 #ifndef HAVE_FFSLL 160 extern "C" int ffsll(long long); 161 #endif 162 163 #if !HAVE_DECL_MEMMEM 164 extern "C" void *memmem(const void *, size_t, const void *, size_t); 165 #endif 166 167 #if !HAVE_DECL_STRNDUP 168 extern "C" char *strndup(const char *, size_t); 169 #endif 170 171 #endif // !defined(SYSTEM_H) 172