unused_skipper.hpp 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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_QI_UNUSED_SKIPPER_JUL_25_2009_0921AM)
  6. #define BOOST_SPIRIT_QI_UNUSED_SKIPPER_JUL_25_2009_0921AM
  7. #if defined(_MSC_VER)
  8. #pragma once
  9. #endif
  10. #include <boost/spirit/home/support/unused.hpp>
  11. #include <boost/mpl/bool.hpp>
  12. namespace boost { namespace spirit { namespace qi { namespace detail
  13. {
  14. template <typename Skipper>
  15. struct unused_skipper : unused_type
  16. {
  17. unused_skipper(Skipper const& skipper_)
  18. : skipper(skipper_) {}
  19. Skipper const& skipper;
  20. // silence MSVC warning C4512: assignment operator could not be generated
  21. BOOST_DELETED_FUNCTION(unused_skipper& operator= (unused_skipper const&))
  22. };
  23. template <typename Skipper>
  24. struct is_unused_skipper
  25. : mpl::false_ {};
  26. template <typename Skipper>
  27. struct is_unused_skipper<unused_skipper<Skipper> >
  28. : mpl::true_ {};
  29. template <>
  30. struct is_unused_skipper<unused_type>
  31. : mpl::true_ {};
  32. // If a surrounding lexeme[] directive was specified, the current
  33. // skipper is of the type unused_skipper. In this case we
  34. // re-activate the skipper which was active before the skip[]
  35. // directive.
  36. template <typename Skipper>
  37. inline Skipper const&
  38. get_skipper(unused_skipper<Skipper> const& u)
  39. {
  40. return u.skipper;
  41. }
  42. // If no surrounding lexeme[] directive was specified we keep what we got.
  43. template <typename Skipper>
  44. inline Skipper const&
  45. get_skipper(Skipper const& u)
  46. {
  47. return u;
  48. }
  49. }}}}
  50. #endif