annotate DEPENDENCIES/generic/include/boost/spirit/home/qi/detail/unused_skipper.hpp @ 133:4acb5d8d80b6 tip

Don't fail environmental check if README.md exists (but .txt and no-suffix don't)
author Chris Cannam
date Tue, 30 Jul 2019 12:25:44 +0100
parents c530137014c0
children
rev   line source
Chris@16 1 // Copyright (c) 2001-2011 Hartmut Kaiser
Chris@16 2 //
Chris@16 3 // Distributed under the Boost Software License, Version 1.0. (See accompanying
Chris@16 4 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
Chris@16 5
Chris@16 6 #if !defined(BOOST_SPIRIT_QI_UNUSED_SKIPPER_JUL_25_2009_0921AM)
Chris@16 7 #define BOOST_SPIRIT_QI_UNUSED_SKIPPER_JUL_25_2009_0921AM
Chris@16 8
Chris@16 9 #if defined(_MSC_VER)
Chris@16 10 #pragma once
Chris@16 11 #endif
Chris@16 12
Chris@16 13 #include <boost/spirit/home/support/unused.hpp>
Chris@101 14 #include <boost/mpl/bool.hpp>
Chris@16 15
Chris@16 16 namespace boost { namespace spirit { namespace qi { namespace detail
Chris@16 17 {
Chris@16 18 template <typename Skipper>
Chris@16 19 struct unused_skipper : unused_type
Chris@16 20 {
Chris@16 21 unused_skipper(Skipper const& skipper_)
Chris@16 22 : skipper(skipper_) {}
Chris@16 23 Skipper const& skipper;
Chris@16 24
Chris@16 25 private:
Chris@16 26 // silence MSVC warning C4512: assignment operator could not be generated
Chris@16 27 unused_skipper& operator= (unused_skipper const&);
Chris@16 28 };
Chris@16 29
Chris@101 30 template <typename Skipper>
Chris@101 31 struct is_unused_skipper
Chris@101 32 : mpl::false_ {};
Chris@101 33
Chris@101 34 template <typename Skipper>
Chris@101 35 struct is_unused_skipper<unused_skipper<Skipper> >
Chris@101 36 : mpl::true_ {};
Chris@101 37
Chris@101 38 template <>
Chris@101 39 struct is_unused_skipper<unused_type>
Chris@101 40 : mpl::true_ {};
Chris@101 41
Chris@16 42 // If a surrounding lexeme[] directive was specified, the current
Chris@101 43 // skipper is of the type unused_skipper. In this case we
Chris@16 44 // re-activate the skipper which was active before the skip[]
Chris@16 45 // directive.
Chris@16 46 template <typename Skipper>
Chris@101 47 inline Skipper const&
Chris@16 48 get_skipper(unused_skipper<Skipper> const& u)
Chris@16 49 {
Chris@16 50 return u.skipper;
Chris@16 51 }
Chris@16 52
Chris@16 53 // If no surrounding lexeme[] directive was specified we keep what we got.
Chris@16 54 template <typename Skipper>
Chris@101 55 inline Skipper const&
Chris@16 56 get_skipper(Skipper const& u)
Chris@16 57 {
Chris@16 58 return u;
Chris@16 59 }
Chris@16 60
Chris@16 61 }}}}
Chris@16 62
Chris@16 63 #endif