summaryrefslogtreecommitdiffstats
path: root/indexlib/stringset.h
diff options
context:
space:
mode:
Diffstat (limited to 'indexlib/stringset.h')
-rw-r--r--indexlib/stringset.h161
1 files changed, 161 insertions, 0 deletions
diff --git a/indexlib/stringset.h b/indexlib/stringset.h
new file mode 100644
index 000000000..0043d7a13
--- /dev/null
+++ b/indexlib/stringset.h
@@ -0,0 +1,161 @@
+#ifndef LPC_STRINGSET_H1106061353_INCLUDE_GUARD_
+#define LPC_STRINGSET_H1106061353_INCLUDE_GUARD_
+
+/* This file is part of indexlib.
+ * Copyright (C) 2005 Luís Pedro Coelho <[email protected]>
+ *
+ * Indexlib is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License, version 2, as
+ * published by the Free Software Foundation and available as file
+ * GPL_V2 which is distributed along with indexlib.
+ *
+ * Indexlib 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 program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+ * MA 02110-1301, USA
+ *
+ * In addition, as a special exception, the copyright holders give
+ * permission to link the code of this program with any edition of
+ * the Qt library by Trolltech AS, Norway (or with modified versions
+ * of Qt that use the same license as Qt), and distribute linked
+ * combinations including the two. You must obey the GNU General
+ * Public License in all respects for all of the code used other than
+ * Qt. If you modify this file, you may extend this exception to
+ * your version of the file, but you are not obligated to do so. If
+ * you do not wish to do so, delete this exception statement from
+ * your version.
+ */
+
+
+#include "memvector.h"
+#include "stringarray.h"
+#include <iterator>
+#include <iostream>
+#include <utility>
+
+
+struct stringset {
+ public:
+ struct const_iterator : public std::iterator<STD_NAMESPACE_PREFIX random_access_iterator_tag,const char*> {
+ const char* operator*() const {
+ return mother_->strings_.get_cstr( mother_->ordered_[ idx_ ] );
+ }
+ unsigned id() const {
+ return mother_->ordered_[ idx_ ];
+ }
+ unsigned order() const {
+ return idx_;
+ }
+ const_iterator& operator ++() {
+ ++idx_;
+ return *this;
+ }
+ const_iterator& operator --() {
+ --idx_;
+ return *this;
+ }
+
+ const_iterator& operator +=( ptrdiff_t d ) {
+ idx_ += d;
+ return *this;
+ }
+ const_iterator& operator -=( ptrdiff_t d ) {
+ idx_ -= d;
+ return *this;
+ }
+ const_iterator& operator = ( const const_iterator& other ) {
+ mother_ = other.mother_;
+ idx_ = other.idx_;
+ return *this;
+ }
+ ptrdiff_t operator - ( const const_iterator& other ) const {
+ assert( mother_ == other.mother_ );
+ return idx_ - other.idx_;
+ }
+ bool operator < ( const const_iterator& other ) const {
+ assert( mother_ == other.mother_ );
+ return idx_ < other.idx_;
+ }
+
+ bool operator == ( const const_iterator& other ) const {
+ return mother_ == other.mother_ && idx_ == other.idx_;
+ }
+
+ bool operator != ( const const_iterator& other ) const {
+ return !( *this == other );
+ }
+ const_iterator():
+ mother_( 0 ),
+ idx_( 0 )
+ {
+ }
+ const_iterator( const const_iterator& other ):
+ mother_( other.mother_ ),
+ idx_( other.idx_ )
+ {
+ }
+ private:
+ friend std::ostream& operator << ( std::ostream& out, const const_iterator& other );
+ friend class stringset;
+ const_iterator( const stringset* m, unsigned i ):
+ mother_( m ),
+ idx_( i )
+ {
+ }
+
+ const stringset* mother_;
+ unsigned idx_;
+
+ };
+ friend class const_iterator;
+ public:
+ stringset( std::string );
+ bool count( const char* str ) const { return order_of( str ) != unsigned( -1 ); }
+ unsigned id_of( const char* str ) const {
+ unsigned order = order_of( str );
+ return order == unsigned( -1 ) ?
+ unsigned( -1 ):
+ ordered_[ order ];
+ }
+ unsigned order_of( const char* ) const;
+ unsigned add( std::string str ) { return add( str.c_str() ); }
+ unsigned add( const char* );
+
+ void clear();
+
+ /**
+ * Returns std::make_pair( find( word ), find( word + 'Z' ) ) which makes it easy
+ * to implement word* searches
+ */
+ std::pair<const_iterator, const_iterator> upper_lower( const char* ) const;
+
+ const_iterator begin() const { return const_iterator( this, 0 ); }
+ const_iterator end() const { return const_iterator( this, ordered_.size() ); }
+ bool empty() const { return !ordered_.size(); }
+ unsigned size() const { return ordered_.size(); }
+
+ static void remove( std::string );
+ const_iterator lower_bound( const char* ) const;
+ private:
+ stringarray strings_;
+ memvector<stringarray::index_type> ordered_;
+ memvector<stringarray::index_type> trie_;
+};
+
+inline
+stringset::const_iterator operator + ( stringset::const_iterator a, stringset::const_iterator::difference_type d ) {
+ return a += d;
+}
+
+inline
+std::ostream& operator << ( std::ostream& out, const stringset::const_iterator& other ) {
+ return out << "[ " << other.idx_ << " ]";
+}
+
+
+#endif /* LPC_STRINGSET_H1106061353_INCLUDE_GUARD_ */