#ifndef BOOST_ARCHIVE_ITERATORS_ESCAPE_HPP #define BOOST_ARCHIVE_ITERATORS_ESCAPE_HPP // MS compatible compilers support #pragma once #if defined(_MSC_VER) && (_MSC_VER >= 1020) # pragma once #endif /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // escape.hpp // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com . // Use, modification and distribution is subject to 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 for updates, documentation, and revision history. #include #include // for BOOST_DEDUCED_TYPENAME #include #include namespace boost { namespace archive { namespace iterators { /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // insert escapes into text template class escape : public boost::iterator_adaptor< Derived, Base, BOOST_DEDUCED_TYPENAME boost::iterator_value::type, single_pass_traversal_tag, BOOST_DEDUCED_TYPENAME boost::iterator_value::type >{ typedef BOOST_DEDUCED_TYPENAME boost::iterator_value::type base_value_type; typedef BOOST_DEDUCED_TYPENAME boost::iterator_reference::type reference_type; friend class boost::iterator_core_access; typedef BOOST_DEDUCED_TYPENAME boost::iterator_adaptor< Derived, Base, base_value_type, single_pass_traversal_tag, base_value_type > super_t; typedef escape this_t; bool equal(const this_t & rhs) const { return NULL == m_bnext && NULL == m_bend && this->base_reference() == rhs.base_reference() ; } //Access the value referred to reference_type dereference() const { return m_current_value; } void increment(){ if(++m_bnext < m_bend){ m_current_value = *m_bnext; return; } ++(this->base_reference()); m_bnext = NULL; m_bend = NULL; m_current_value = (static_cast(this))->fill(m_bnext, m_bend); } // buffer to handle pending characters const base_value_type *m_bnext; const base_value_type *m_bend; BOOST_DEDUCED_TYPENAME boost::iterator_value::type m_current_value; bool m_full; public: escape(Base base) : super_t(base), m_bnext(NULL), m_bend(NULL) { m_current_value = static_cast(this)->fill(m_bnext, m_bend); } }; } // namespace iterators } // namespace archive } // namespace boost #endif // BOOST_ARCHIVE_ITERATORS_ESCAPE_HPP