| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 | // Boost token_iterator.hpp  -------------------------------------------------//// Copyright John R. Bandela 2001// Distributed under the Boost Software License, Version 1.0. (See// accompanying file LICENSE_1_0.txt or copy at// http://www.boost.org/LICENSE_1_0.txt)// See http://www.boost.org/libs/tokenizer for documentation.// Revision History:// 16 Jul 2003   John Bandela//      Allowed conversions from convertible base iterators// 03 Jul 2003   John Bandela//      Converted to new iterator adapter#ifndef BOOST_TOKENIZER_POLICY_JRB070303_HPP_#define BOOST_TOKENIZER_POLICY_JRB070303_HPP_#include <boost/assert.hpp>#include <boost/iterator/iterator_adaptor.hpp>#include <boost/iterator/minimum_category.hpp>#include <boost/token_functions.hpp>#include <utility>namespace boost{  template <class TokenizerFunc, class Iterator, class Type>  class token_iterator      : public iterator_facade<            token_iterator<TokenizerFunc, Iterator, Type>          , Type          , typename iterators::minimum_category<                forward_traversal_tag              , typename iterator_traversal<Iterator>::type            >::type          , const Type&        >  {#ifdef __DCC__       friend class boost::iterator_core_access; #else       friend class iterator_core_access; #endif        TokenizerFunc f_;      Iterator begin_;      Iterator end_;      bool valid_;      Type tok_;      void increment(){          BOOST_ASSERT(valid_);          valid_ = f_(begin_,end_,tok_);      }      const Type&  dereference() const {          BOOST_ASSERT(valid_);          return tok_;      }      template<class Other>      bool equal(const Other& a) const{          return (a.valid_ && valid_)              ?( (a.begin_==begin_) && (a.end_ == end_) )              :(a.valid_==valid_);      }      void initialize(){          if(valid_) return;          f_.reset();          valid_ = (begin_ != end_)?              f_(begin_,end_,tok_):false;      }  public:      token_iterator():begin_(),end_(),valid_(false),tok_() { }      token_iterator(TokenizerFunc f, Iterator begin, Iterator e = Iterator())          : f_(f),begin_(begin),end_(e),valid_(false),tok_(){ initialize(); }      token_iterator(Iterator begin, Iterator e = Iterator())            : f_(),begin_(begin),end_(e),valid_(false),tok_() {initialize();}      template<class OtherIter>      token_iterator(            token_iterator<TokenizerFunc, OtherIter,Type> const& t            , typename enable_if_convertible<OtherIter, Iterator>::type* = 0)            : f_(t.tokenizer_function()),begin_(t.base())            ,end_(t.end()),valid_(!t.at_end()),tok_(t.current_token()) {}      Iterator base()const{return begin_;}      Iterator end()const{return end_;}      TokenizerFunc tokenizer_function()const{return f_;}      Type current_token()const{return tok_;}      bool at_end()const{return !valid_;}  };    template <        class TokenizerFunc = char_delimiters_separator<char>,        class Iterator = std::string::const_iterator,        class Type = std::string    >    class token_iterator_generator {    private:    public:        typedef token_iterator<TokenizerFunc,Iterator,Type> type;    };    // Type has to be first because it needs to be explicitly specified    // because there is no way the function can deduce it.    template<class Type, class Iterator, class TokenizerFunc>        typename token_iterator_generator<TokenizerFunc,Iterator,Type>::type    make_token_iterator(Iterator begin, Iterator end,const TokenizerFunc& fun){        typedef typename            token_iterator_generator<TokenizerFunc,Iterator,Type>::type ret_type;        return ret_type(fun,begin,end);    }} // namespace boost#endif
 |