enumeration_helper.h 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /************************************************************************************
  2. * *
  3. * Copyright (c) 2014 - 2018 Axel Menzel <info@rttr.org> *
  4. * *
  5. * This file is part of RTTR (Run Time Type Reflection) *
  6. * License: MIT License *
  7. * *
  8. * Permission is hereby granted, free of charge, to any person obtaining *
  9. * a copy of this software and associated documentation files (the "Software"), *
  10. * to deal in the Software without restriction, including without limitation *
  11. * the rights to use, copy, modify, merge, publish, distribute, sublicense, *
  12. * and/or sell copies of the Software, and to permit persons to whom the *
  13. * Software is furnished to do so, subject to the following conditions: *
  14. * *
  15. * The above copyright notice and this permission notice shall be included in *
  16. * all copies or substantial portions of the Software. *
  17. * *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR *
  19. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *
  20. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
  21. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
  22. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, *
  23. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE *
  24. * SOFTWARE. *
  25. * *
  26. *************************************************************************************/
  27. #ifndef RTTR_ENUMERATION_HELPER_H_
  28. #define RTTR_ENUMERATION_HELPER_H_
  29. #include "rttr/detail/base/core_prerequisites.h"
  30. #include "rttr/string_view.h"
  31. namespace rttr
  32. {
  33. class argument;
  34. class variant;
  35. namespace detail
  36. {
  37. /////////////////////////////////////////////////////////////////////////////////////////
  38. /*!
  39. * \brief Returns the corresponding name of the given enumeration value \p enum_value.
  40. * Otherwise an empty string is returned.
  41. */
  42. RTTR_API string_view get_enumeration_name(const argument& enum_value);
  43. /////////////////////////////////////////////////////////////////////////////////////////
  44. /*!
  45. * \brief Converts the given string \p from to its corresponding enumeration value.
  46. * The result is stored inside \p to.
  47. *
  48. * \remark The parameter \p to should contain a variant with \ref type object of the enumeration.
  49. * The result is stored then inside this variant.
  50. */
  51. RTTR_API bool to_enumeration(string_view from, argument& to);
  52. /////////////////////////////////////////////////////////////////////////////////////////
  53. /*!
  54. * \brief Converts the given variant \p var (containing an arithmetic type)
  55. * to its corresponding enumeration value.
  56. *
  57. * \remark The parameter \p to should contain a variant with \ref type object of the enumeration.
  58. * The result is stored then inside this variant.
  59. */
  60. RTTR_API bool to_enumeration(const variant& from, argument& to);
  61. /////////////////////////////////////////////////////////////////////////////////////////
  62. /*!
  63. * \brief Returns `true`, when the given argument \p arg contains a variant with a \ref type
  64. * object which represents an enumeration. Otherwise `false`.
  65. */
  66. RTTR_API bool is_variant_with_enum(const argument& arg);
  67. /////////////////////////////////////////////////////////////////////////////////////////
  68. } // end namespace detail
  69. } // end namespace rttr
  70. #endif // RTTR_ENUMERATION_HELPER_H_