// Copyright (c) 2001 Daniel C. Nuffer // Copyright (c) 2001-2010 Hartmut Kaiser // // 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) #if !defined(BOOST_SPIRIT_ITERATOR_INPUT_ITERATOR_POLICY_MAR_16_2007_1156AM) #define BOOST_SPIRIT_ITERATOR_INPUT_ITERATOR_POLICY_MAR_16_2007_1156AM #include #include #include // for boost::detail::iterator_traits #include namespace boost { namespace spirit { namespace iterator_policies { namespace input_iterator_is_valid_test_ { /////////////////////////////////////////////////////////////////////// template inline bool token_is_valid(Token const& c) { return c ? true : false; } } /////////////////////////////////////////////////////////////////////////// // class input_iterator // Implementation of the InputPolicy used by multi_pass // // The input_iterator encapsulates an input iterator of type T /////////////////////////////////////////////////////////////////////////// struct input_iterator { /////////////////////////////////////////////////////////////////////// template class unique // : public detail::default_input_policy { private: typedef typename boost::detail::iterator_traits::value_type result_type; public: typedef typename boost::detail::iterator_traits::difference_type difference_type; typedef typename boost::detail::iterator_traits::difference_type distance_type; typedef typename boost::detail::iterator_traits::pointer pointer; typedef typename boost::detail::iterator_traits::reference reference; typedef result_type value_type; protected: unique() {} explicit unique(T x) {} void swap(unique&) {} public: template static void destroy(MultiPass&) {} template static typename MultiPass::reference get_input(MultiPass& mp) { return *mp.shared()->input_; } template static void advance_input(MultiPass& mp) { ++mp.shared()->input_; } // test, whether we reached the end of the underlying stream template static bool input_at_eof(MultiPass const& mp) { static T const end_iter; return mp.shared()->input_ == end_iter; } template static bool input_is_valid(MultiPass const& mp, value_type const& t) { using namespace input_iterator_is_valid_test_; return token_is_valid(t); } // no unique data elements }; /////////////////////////////////////////////////////////////////////// template struct shared { explicit shared(T const& input) : input_(input) {} T input_; }; }; }}} #endif