1// -*- C++ -*- 2 3// Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc. 4// 5// This file is part of the GNU ISO C++ Library. This library is free 6// software; you can redistribute it and/or modify it under the terms 7// of the GNU General Public License as published by the Free Software 8// Foundation; either version 3, or (at your option) any later 9// version. 10 11// This library is distributed in the hope that it will be useful, but 12// WITHOUT ANY WARRANTY; without even the implied warranty of 13// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14// General Public License for more details. 15 16// You should have received a copy of the GNU General Public License 17// along with this library; see the file COPYING3. If not see 18// <http://www.gnu.org/licenses/>. 19 20 21// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. 22 23// Permission to use, copy, modify, sell, and distribute this software 24// is hereby granted without fee, provided that the above copyright 25// notice appears in all copies, and that both that copyright notice 26// and this permission notice appear in supporting documentation. None 27// of the above authors, nor IBM Haifa Research Laboratories, make any 28// representation about the suitability of this software for any 29// purpose. It is provided "as is" without express or implied 30// warranty. 31 32/** 33 * @file native_set.hpp 34 * Contains an adapter to Dinkumware/SGI tree tables 35 */ 36 37#ifndef PB_DS_NATIVE_SET_HPP 38#define PB_DS_NATIVE_SET_HPP 39 40#include <ext/pb_ds/detail/standard_policies.hpp> 41#include <native_type/native_tree_tag.hpp> 42#include <io/xml.hpp> 43#include <string> 44 45namespace __gnu_pbds 46{ 47 namespace test 48 { 49 template<typename Key, class Cmp_Fn = std::less<Key>, 50 class Allocator = std::allocator<char> > 51 class native_set : public PB_DS_BASE_C_DEC 52 { 53 private: 54 typedef std::set<Key, Cmp_Fn, typename Allocator::template rebind<Key>::other> base_type; 55 56 public: 57 typedef native_tree_tag container_category; 58 59 typedef typename base_type::const_iterator const_iterator; 60 61 public: 62 native_set() : base_type() 63 { } 64 65 template<typename It> 66 native_set(It f, It l) : base_type(f, l) 67 { } 68 69 native_set(const_iterator f, const_iterator l) : base_type(f, l) 70 { } 71 72 static std::string 73 name() 74 { return ("n_set"); } 75 76 static std::string 77 desc() 78 { return (make_xml_tag("type", "value", "std_set")); } 79 }; 80 } // namespace test 81} // namespace __gnu_pbds 82 83#endif 84 85