![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /usr/include/boost/spirit/home/support/iterators/detail/ |
Upload File : |
// Copyright (c) 2001 Daniel C. Nuffer // Copyright (c) 2001-2011 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 <boost/spirit/home/support/iterators/multi_pass_fwd.hpp> #include <boost/spirit/home/support/iterators/detail/multi_pass.hpp> #include <boost/assert.hpp> #include <iterator> // for std::iterator_traits namespace boost { namespace spirit { namespace iterator_policies { namespace input_iterator_is_valid_test_ { /////////////////////////////////////////////////////////////////////// template <typename Token> 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 <typename T> class unique // : public detail::default_input_policy { private: typedef typename std::iterator_traits<T>::value_type result_type; public: typedef typename std::iterator_traits<T>::difference_type difference_type; typedef typename std::iterator_traits<T>::difference_type distance_type; typedef typename std::iterator_traits<T>::pointer pointer; typedef typename std::iterator_traits<T>::reference reference; typedef result_type value_type; protected: unique() {} explicit unique(T x) {} void swap(unique&) {} public: template <typename MultiPass> static void destroy(MultiPass&) {} template <typename MultiPass> static typename MultiPass::reference get_input(MultiPass& mp) { return *mp.shared()->input_; } template <typename MultiPass> static void advance_input(MultiPass& mp) { ++mp.shared()->input_; } // test, whether we reached the end of the underlying stream template <typename MultiPass> static bool input_at_eof(MultiPass const& mp) { static T const end_iter; return mp.shared()->input_ == end_iter; } template <typename MultiPass> 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 <typename T> struct shared { explicit shared(T const& input) : input_(input) {} T input_; }; }; }}} #endif