X-Git-Url: https://oss.titaniummirror.com/gitweb?a=blobdiff_plain;f=libstdc%2B%2B-v3%2Ftestsuite%2Futil%2Fnative_type%2Fnative_hash_set.hpp;fp=libstdc%2B%2B-v3%2Ftestsuite%2Futil%2Fnative_type%2Fnative_hash_set.hpp;h=d3f459624934ccb8acee1c9d3fd7e18eb29f2736;hb=6fed43773c9b0ce596dca5686f37ac3fc0fa11c0;hp=0000000000000000000000000000000000000000;hpb=27b11d56b743098deb193d510b337ba22dc52e5c;p=msp430-gcc.git diff --git a/libstdc++-v3/testsuite/util/native_type/native_hash_set.hpp b/libstdc++-v3/testsuite/util/native_type/native_hash_set.hpp new file mode 100644 index 00000000..d3f45962 --- /dev/null +++ b/libstdc++-v3/testsuite/util/native_type/native_hash_set.hpp @@ -0,0 +1,125 @@ +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2007, 2009 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library is free +// software; you can redistribute it and/or modify it under the terms +// of the GNU General Public License as published by the Free Software +// Foundation; either version 3, or (at your option) any later +// version. + +// This library is distributed in the hope that it will be useful, but +// WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// General Public License for more details. + +// You should have received a copy of the GNU General Public License +// along with this library; see the file COPYING3. If not see +// . + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file native_hash_set.hpp + * Contains an adapter to TR1 unordered containers. + */ + +#ifndef PB_DS_NATIVE_HASH_SET_HPP +#define PB_DS_NATIVE_HASH_SET_HPP + +#include +#include +#include +#include +#include +#include + +namespace __gnu_pbds +{ + namespace test + { +#define PB_DS_BASE_C_DEC \ + std::tr1::__unordered_set::other, Cache_Hash> + + template::type, + typename Eq_Fn = std::equal_to, + typename Less_Fn = std::less, + typename Allocator = std::allocator, bool Cache_Hash = false + > + class native_hash_set : public PB_DS_BASE_C_DEC + { + private: + typedef PB_DS_BASE_C_DEC base_type; + + public: + typedef native_hash_tag container_category; + + native_hash_set() : base_type(Init_Size) { } + + template + native_hash_set(It f, It l) : base_type(f, l) { } + + template + inline size_t + erase_if(Pred pred) + { + size_t ersd = 0; + bool done = false; + while (!done) + { + typename base_type::iterator b_it = base_type::begin(); + typename base_type::iterator e_it = base_type::end(); + done = true; + while (b_it != e_it) + { + if (pred(*b_it)) + { + ++ersd; + done = false; + base_type::erase(*b_it); + b_it = e_it; + } + else + ++b_it; + } + } + return ersd; + } + + static std::string + name() + { + return std::string("n_hash_set_") + + (Cache_Hash ? std::string("cah") : std::string("ncah")); + } + + static std::string + desc() + { + const std::string cache_hash_desc = + make_xml_tag("cache_hash_code", "value", + Cache_Hash ? std::string("true") : std::string("false")); + + return make_xml_tag("type", "value", "std_tr1_unordered_set", + cache_hash_desc); + } + }; + +#undef PB_DS_BASE_C_DEC + } // namespace test +} // namespace __gnu_pbds + +#endif