9
3

unused_delimiter.hpp 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // Copyright (c) 2001-2011 Hartmut Kaiser
  2. //
  3. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. #if !defined(BOOST_SPIRIT_KARMA_UNUSED_DELIMITER_MAR_15_2009_0923PM)
  6. #define BOOST_SPIRIT_KARMA_UNUSED_DELIMITER_MAR_15_2009_0923PM
  7. #if defined(_MSC_VER)
  8. #pragma once
  9. #endif
  10. #include <boost/spirit/home/support/unused.hpp>
  11. namespace boost { namespace spirit { namespace karma { namespace detail
  12. {
  13. template <typename Delimiter>
  14. struct unused_delimiter : unused_type
  15. {
  16. unused_delimiter(Delimiter const& delim)
  17. : delimiter(delim) {}
  18. Delimiter const& delimiter;
  19. // silence MSVC warning C4512: assignment operator could not be generated
  20. BOOST_DELETED_FUNCTION(unused_delimiter& operator= (unused_delimiter const&))
  21. };
  22. // If a surrounding verbatim[] directive was specified, the current
  23. // delimiter is of the type unused_delimiter. In this case we
  24. // re-activate the delimiter which was active before the verbatim[]
  25. // directive.
  26. template <typename Delimiter, typename Default>
  27. inline Delimiter const&
  28. get_delimiter(unused_delimiter<Delimiter> const& u, Default const&)
  29. {
  30. return u.delimiter;
  31. }
  32. // If no surrounding verbatim[] directive was specified we activate
  33. // a single space as the delimiter to use.
  34. template <typename Delimiter, typename Default>
  35. inline Default const&
  36. get_delimiter(Delimiter const&, Default const& d)
  37. {
  38. return d;
  39. }
  40. }}}}
  41. #endif