1e76eebc6SAndrew Rist/************************************************************** 2cdf0e10cSrcweir * 3e76eebc6SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4e76eebc6SAndrew Rist * or more contributor license agreements. See the NOTICE file 5e76eebc6SAndrew Rist * distributed with this work for additional information 6e76eebc6SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7e76eebc6SAndrew Rist * to you under the Apache License, Version 2.0 (the 8e76eebc6SAndrew Rist * "License"); you may not use this file except in compliance 9e76eebc6SAndrew Rist * with the License. You may obtain a copy of the License at 10e76eebc6SAndrew Rist * 11e76eebc6SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12e76eebc6SAndrew Rist * 13e76eebc6SAndrew Rist * Unless required by applicable law or agreed to in writing, 14e76eebc6SAndrew Rist * software distributed under the License is distributed on an 15e76eebc6SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16e76eebc6SAndrew Rist * KIND, either express or implied. See the License for the 17e76eebc6SAndrew Rist * specific language governing permissions and limitations 18e76eebc6SAndrew Rist * under the License. 19e76eebc6SAndrew Rist * 20e76eebc6SAndrew Rist *************************************************************/ 21cdf0e10cSrcweir 22cdf0e10cSrcweir#ifndef SYSTEM_STL_HASHSET 23cdf0e10cSrcweir#define SYSTEM_STL_HASHSET 24cdf0e10cSrcweir 25*dee715a7SHerbert Dürr#ifdef HAVE_STL_INCLUDE_PATH 26*dee715a7SHerbert Dürr // TODO: use computed include file name 27*dee715a7SHerbert Dürr #include_next <unordered_set> 28*dee715a7SHerbert Dürr#elif defined(_MSC_VER) 29*dee715a7SHerbert Dürr #include <../../VC/include/unordered_set> 30*dee715a7SHerbert Dürr #define STLP4_EMUBASE_NS ::std::tr1 31*dee715a7SHerbert Dürr#else // fall back to boost/tr1 32*dee715a7SHerbert Dürr #include <boost/tr1/tr1/unordered_set> 33*dee715a7SHerbert Dürr #define STLP4_EMUBASE_NS ::boost 34*dee715a7SHerbert Dürr#endif 35cdf0e10cSrcweir 36cdf0e10cSrcweir 37*dee715a7SHerbert Dürr#ifndef NO_STLPORT4_EMULATION 38cdf0e10cSrcweir 39cdf0e10cSrcweirnamespace std 40cdf0e10cSrcweir{ 41*dee715a7SHerbert Dürr#ifdef STLP4_EMUBASE_NS 42*dee715a7SHerbert Dürr using STLP4_EMUBASE_NS::hash; 43*dee715a7SHerbert Dürr using STLP4_EMUBASE_NS::unordered_set; 44*dee715a7SHerbert Dürr using STLP4_EMUBASE_NS::unordered_multiset; 45*dee715a7SHerbert Dürr #undef STLP4_EMUBASE_NS 46cdf0e10cSrcweir#endif 47cdf0e10cSrcweir 48*dee715a7SHerbert Dürr 49*dee715a7SHerbert Dürrtemplate< 50*dee715a7SHerbert Dürr typename __K, 51*dee715a7SHerbert Dürr typename __H = hash<__K>, 52*dee715a7SHerbert Dürr typename __E = equal_to<__K>, 53*dee715a7SHerbert Dürr typename __A = allocator<__K> > 54*dee715a7SHerbert Dürrclass hash_set 55*dee715a7SHerbert Dürr: public unordered_set<__K,__H,__E,__A> 56*dee715a7SHerbert Dürr{ 57*dee715a7SHerbert Dürr typedef unordered_set<__K,__H,__E,__A> _super; 58*dee715a7SHerbert Dürrpublic: 59*dee715a7SHerbert Dürr hash_set( void) {} 60*dee715a7SHerbert Dürr hash_set( size_t n) : _super(n) {} 61*dee715a7SHerbert Dürr void resize( size_t n) { _super::rehash( n); } 62*dee715a7SHerbert Dürr 63*dee715a7SHerbert Dürr#ifdef BOOST_TR1_UNORDERED_SET_INCLUDED // workaround pre-BOOST_UNORDERED_USE_MOVE problem 64*dee715a7SHerbert Dürr // in derived classes the copy assignment operator can only be declared implicitly if 65*dee715a7SHerbert Dürr // its base class's assignment operator has the canonical signature. 66*dee715a7SHerbert Dürr // boost's assignment operators don't have this canonical signature when move-semantics are enabled 67*dee715a7SHerbert Dürr hash_set& operator=( const hash_set& r) { hash_set c(r); this->swap(c); return *this; } 68cdf0e10cSrcweir#endif 69*dee715a7SHerbert Dürr 70*dee715a7SHerbert Dürrprivate: 71*dee715a7SHerbert Dürr // setting the hasher dynamically is not supported in the emulation! 72*dee715a7SHerbert Dürr hash_set( size_t, const __H&, const __E& rE=__E(), const __A& rA=__A()); // not implemented 73*dee715a7SHerbert Dürr}; 74*dee715a7SHerbert Dürr 75*dee715a7SHerbert Dürrtemplate< 76*dee715a7SHerbert Dürr typename __K, 77*dee715a7SHerbert Dürr typename __H = hash<__K>, 78*dee715a7SHerbert Dürr typename __E = equal_to<__K>, 79*dee715a7SHerbert Dürr typename __A = allocator<__K> > 80*dee715a7SHerbert Dürrclass hash_multiset 81*dee715a7SHerbert Dürr: public unordered_multiset<__K,__H,__E,__A> 82*dee715a7SHerbert Dürr{ 83*dee715a7SHerbert Dürr typedef unordered_multiset<__K,__H,__E,__A> _super; 84*dee715a7SHerbert Dürrpublic: 85*dee715a7SHerbert Dürr hash_multiset( void) {} 86*dee715a7SHerbert Dürr hash_multiset( size_t n) : _super( n) {} 87*dee715a7SHerbert Dürr void resize( size_t n) { _super::rehash( n); } 88*dee715a7SHerbert Dürr 89*dee715a7SHerbert Dürr#ifdef BOOST_TR1_UNORDERED_SET_INCLUDED // workaround pre-BOOST_UNORDERED_USE_MOVE problem 90*dee715a7SHerbert Dürr // in derived classes the copy assignment operator can only be declared implicitly if 91*dee715a7SHerbert Dürr // its base class's assignment operator has the canonical signature. 92*dee715a7SHerbert Dürr // boost's assignment operators don't have this canonical signature when move-semantics are enabled 93*dee715a7SHerbert Dürr hash_multiset& operator=( const hash_multiset& r) { hash_multiset c(r); this->swap(c); return *this; } 94*dee715a7SHerbert Dürr#endif 95*dee715a7SHerbert Dürr 96*dee715a7SHerbert Dürrprivate: 97*dee715a7SHerbert Dürr // setting the hasher dynamically is not supported in the emulation! 98*dee715a7SHerbert Dürr hash_multiset( size_t, const __H&, const __E& rE=__E(), const __A& rA=__A()); // not implemented 99*dee715a7SHerbert Dürr}; 100*dee715a7SHerbert Dürr 101*dee715a7SHerbert Dürr} // namespace std 102*dee715a7SHerbert Dürr 103*dee715a7SHerbert Dürr#endif // NO_STLPORT4_EMULATION 104*dee715a7SHerbert Dürr 105*dee715a7SHerbert Dürr#endif 106*dee715a7SHerbert Dürr 107