metadata_handler.h 3.7 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_METADATA_HANDLER_H_
  28. #define RTTR_METADATA_HANDLER_H_
  29. #include "rttr/detail/base/core_prerequisites.h"
  30. #include "rttr/detail/metadata/metadata.h"
  31. #include "rttr/variant.h"
  32. #include <array>
  33. namespace rttr
  34. {
  35. namespace detail
  36. {
  37. /*!
  38. * This class holds an index to possible meta data.
  39. * This can be also a name or the declaring type of a property or method.
  40. */
  41. template<std::size_t Metadata_Count>
  42. class metadata_handler
  43. {
  44. public:
  45. RTTR_FORCE_INLINE metadata_handler(std::array<metadata, Metadata_Count> new_data) : m_metadata_list(std::move(new_data)) { }
  46. RTTR_INLINE variant get_metadata(const variant& key) const
  47. {
  48. // I don't expect that many data, so we iterate from start to end
  49. for (const auto& item : m_metadata_list)
  50. {
  51. if (item.get_key() == key)
  52. return item.get_value();
  53. }
  54. return variant();
  55. }
  56. private:
  57. std::array<metadata, Metadata_Count> m_metadata_list;
  58. };
  59. /*!
  60. * We use the C++ idiom of empty base class optimization.
  61. * So a wrapper with no metadata, will increase its sizeof(T).
  62. */
  63. template<>
  64. class metadata_handler<0>
  65. {
  66. public:
  67. RTTR_FORCE_INLINE metadata_handler(std::array<metadata, 0>) {}
  68. RTTR_FORCE_INLINE void set_metadata(std::array<metadata, 0> new_data) { }
  69. RTTR_INLINE variant get_metadata(const variant& key) const { return variant(); }
  70. };
  71. } // end namespace detail
  72. } // end namespace rttr
  73. #endif // RTTR_METADATA_HANDLER_H_