attr.hpp 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /*=============================================================================
  2. Copyright (c) 2001-2011 Hartmut Kaiser
  3. Copyright (c) 2001-2014 Joel de Guzman
  4. Copyright (c) 2013 Agustin Berge
  5. Distributed under the Boost Software License, Version 1.0. (See accompanying
  6. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  7. ==============================================================================*/
  8. #ifndef BOOST_SPIRIT_X3_ATTR_JUL_23_2008_0956AM
  9. #define BOOST_SPIRIT_X3_ATTR_JUL_23_2008_0956AM
  10. #include <boost/spirit/home/x3/core/parser.hpp>
  11. #include <boost/spirit/home/x3/support/unused.hpp>
  12. #include <boost/spirit/home/x3/support/traits/container_traits.hpp>
  13. #include <boost/spirit/home/x3/support/traits/move_to.hpp>
  14. #include <boost/type_traits/is_same.hpp>
  15. #include <boost/type_traits/remove_cv.hpp>
  16. #include <boost/type_traits/remove_reference.hpp>
  17. #include <algorithm>
  18. #include <cstddef>
  19. #include <string>
  20. #include <utility>
  21. namespace boost { namespace spirit { namespace x3
  22. {
  23. template <typename Value>
  24. struct attr_parser : parser<attr_parser<Value>>
  25. {
  26. typedef Value attribute_type;
  27. static bool const has_attribute =
  28. !is_same<unused_type, attribute_type>::value;
  29. static bool const handles_container =
  30. traits::is_container<attribute_type>::value;
  31. attr_parser(Value const& value)
  32. : value_(value) {}
  33. attr_parser(Value&& value)
  34. : value_(std::move(value)) {}
  35. template <typename Iterator, typename Context
  36. , typename RuleContext, typename Attribute>
  37. bool parse(Iterator& /* first */, Iterator const& /* last */
  38. , Context const& /* context */, RuleContext&, Attribute& attr_) const
  39. {
  40. // $$$ Change to copy_to once we have it $$$
  41. traits::move_to(value_, attr_);
  42. return true;
  43. }
  44. Value value_;
  45. // silence MSVC warning C4512: assignment operator could not be generated
  46. attr_parser& operator= (attr_parser const&) = delete;
  47. };
  48. template <typename Value, std::size_t N>
  49. struct attr_parser<Value[N]> : parser<attr_parser<Value[N]>>
  50. {
  51. typedef Value attribute_type[N];
  52. static bool const has_attribute =
  53. !is_same<unused_type, attribute_type>::value;
  54. static bool const handles_container = true;
  55. attr_parser(Value const (&value)[N])
  56. {
  57. std::copy(value + 0, value + N, value_ + 0);
  58. }
  59. attr_parser(Value (&&value)[N])
  60. {
  61. std::move(value + 0, value + N, value_ + 0);
  62. }
  63. template <typename Iterator, typename Context
  64. , typename RuleContext, typename Attribute>
  65. bool parse(Iterator& /* first */, Iterator const& /* last */
  66. , Context const& /* context */, RuleContext&, Attribute& attr_) const
  67. {
  68. // $$$ Change to copy_to once we have it $$$
  69. traits::move_to(value_ + 0, value_ + N, attr_);
  70. return true;
  71. }
  72. Value value_[N];
  73. // silence MSVC warning C4512: assignment operator could not be generated
  74. attr_parser& operator= (attr_parser const&) = delete;
  75. };
  76. template <typename Value>
  77. struct get_info<attr_parser<Value>>
  78. {
  79. typedef std::string result_type;
  80. std::string operator()(attr_parser<Value> const& /*p*/) const
  81. {
  82. return "attr";
  83. }
  84. };
  85. struct attr_gen
  86. {
  87. template <typename Value>
  88. attr_parser<typename remove_cv<
  89. typename remove_reference<Value>::type>::type>
  90. operator()(Value&& value) const
  91. {
  92. return { std::forward<Value>(value) };
  93. }
  94. template <typename Value, std::size_t N>
  95. attr_parser<typename remove_cv<Value>::type[N]>
  96. operator()(Value (&value)[N]) const
  97. {
  98. return { value };
  99. }
  100. template <typename Value, std::size_t N>
  101. attr_parser<typename remove_cv<Value>::type[N]>
  102. operator()(Value (&&value)[N]) const
  103. {
  104. return { value };
  105. }
  106. };
  107. auto const attr = attr_gen{};
  108. }}}
  109. #endif