2004-03-04 22:12:19 +00:00
|
|
|
// Boost string_algo library formatter.hpp header file ---------------------------//
|
|
|
|
|
2007-11-25 18:07:19 +00:00
|
|
|
// Copyright Pavol Droba 2002-2003.
|
|
|
|
//
|
|
|
|
// 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)
|
2004-03-04 22:12:19 +00:00
|
|
|
|
2007-11-25 18:07:19 +00:00
|
|
|
// See http://www.boost.org/ for updates, documentation, and revision history.
|
2004-03-04 22:12:19 +00:00
|
|
|
|
|
|
|
#ifndef BOOST_STRING_FORMATTER_HPP
|
|
|
|
#define BOOST_STRING_FORMATTER_HPP
|
|
|
|
|
|
|
|
#include <boost/detail/iterator.hpp>
|
2005-01-21 16:45:29 +00:00
|
|
|
#include <boost/range/value_type.hpp>
|
|
|
|
#include <boost/range/iterator_range.hpp>
|
2007-11-25 18:07:19 +00:00
|
|
|
#include <boost/range/as_literal.hpp>
|
2005-01-21 16:45:29 +00:00
|
|
|
|
2004-03-04 22:12:19 +00:00
|
|
|
#include <boost/algorithm/string/detail/formatter.hpp>
|
|
|
|
|
|
|
|
/*! \file
|
2004-07-15 21:48:25 +00:00
|
|
|
Defines Formatter generators. Formatter is a functor which formats
|
|
|
|
a string according to given parameters. A Formatter works
|
2004-03-04 22:12:19 +00:00
|
|
|
in conjunction with a Finder. A Finder can provide additional information
|
2004-07-15 21:48:25 +00:00
|
|
|
for a specific Formatter. An example of such a cooperation is regex_finder
|
2004-03-04 22:12:19 +00:00
|
|
|
and regex_formatter.
|
|
|
|
|
2004-07-15 21:48:25 +00:00
|
|
|
Formatters are used as pluggable components for replace facilities.
|
2004-03-04 22:12:19 +00:00
|
|
|
This header contains generator functions for the Formatters provided in this library.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace boost {
|
|
|
|
namespace algorithm {
|
|
|
|
|
2005-01-21 16:45:29 +00:00
|
|
|
// generic formatters ---------------------------------------------------------------//
|
2004-03-04 22:12:19 +00:00
|
|
|
|
|
|
|
//! Constant formatter
|
|
|
|
/*!
|
|
|
|
Construct the \c const_formatter. Const formatter always returns
|
|
|
|
the same value, regardless of the parameter.
|
|
|
|
|
|
|
|
\param Format A predefined value used as a result for formating
|
|
|
|
\return An instance of the \c const_formatter object.
|
|
|
|
*/
|
2005-04-12 16:50:42 +00:00
|
|
|
template<typename RangeT>
|
2007-11-25 18:07:19 +00:00
|
|
|
inline detail::const_formatF<
|
|
|
|
iterator_range<
|
|
|
|
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >
|
2005-04-12 16:50:42 +00:00
|
|
|
const_formatter(const RangeT& Format)
|
2004-03-04 22:12:19 +00:00
|
|
|
{
|
2007-11-25 18:07:19 +00:00
|
|
|
return detail::const_formatF<
|
|
|
|
iterator_range<
|
|
|
|
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >(as_literal(Format));
|
2004-03-04 22:12:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//! Identity formatter
|
|
|
|
/*!
|
|
|
|
Construct the \c identity_formatter. Identity formatter always returns
|
|
|
|
the parameter.
|
|
|
|
|
|
|
|
\return An instance of the \c identity_formatter object.
|
|
|
|
*/
|
2005-04-12 16:50:42 +00:00
|
|
|
template<typename RangeT>
|
2007-11-25 18:07:19 +00:00
|
|
|
inline detail::identity_formatF<
|
|
|
|
iterator_range<
|
|
|
|
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >
|
2004-03-04 22:12:19 +00:00
|
|
|
identity_formatter()
|
|
|
|
{
|
2007-11-25 18:07:19 +00:00
|
|
|
return detail::identity_formatF<
|
|
|
|
iterator_range<
|
|
|
|
BOOST_STRING_TYPENAME range_const_iterator<RangeT>::type> >();
|
2004-03-04 22:12:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//! Empty formatter
|
|
|
|
/*!
|
2005-01-21 16:45:29 +00:00
|
|
|
Construct the \c empty_formatter. Empty formatter always returns an empty
|
2004-03-04 22:12:19 +00:00
|
|
|
sequence.
|
|
|
|
|
|
|
|
\param Input container used to select a correct value_type for the
|
|
|
|
resulting empty_container<>.
|
|
|
|
\return An instance of the \c empty_formatter object.
|
|
|
|
*/
|
2005-04-12 16:50:42 +00:00
|
|
|
template<typename RangeT>
|
2004-03-04 22:12:19 +00:00
|
|
|
inline detail::empty_formatF<
|
2005-04-12 16:50:42 +00:00
|
|
|
BOOST_STRING_TYPENAME range_value<RangeT>::type>
|
|
|
|
empty_formatter(const RangeT&)
|
2004-03-04 22:12:19 +00:00
|
|
|
{
|
|
|
|
return detail::empty_formatF<
|
2005-04-12 16:50:42 +00:00
|
|
|
BOOST_STRING_TYPENAME range_value<RangeT>::type>();
|
2004-03-04 22:12:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace algorithm
|
|
|
|
|
|
|
|
// pull the names to the boost namespace
|
|
|
|
using algorithm::const_formatter;
|
|
|
|
using algorithm::identity_formatter;
|
|
|
|
using algorithm::empty_formatter;
|
|
|
|
|
|
|
|
} // namespace boost
|
|
|
|
|
|
|
|
|
|
|
|
#endif // BOOST_FORMATTER_HPP
|