argument_wrapper.h 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  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_ARGUMENT_WRAPPER_H_
  28. #define RTTR_ARGUMENT_WRAPPER_H_
  29. #include "rttr/detail/base/core_prerequisites.h"
  30. #include <memory>
  31. #include <type_traits>
  32. namespace rttr
  33. {
  34. namespace detail
  35. {
  36. /*!
  37. * This class holds the address to any given data in m_data.
  38. *
  39. * What kind of data it holds, depends on the operation it will be used for.
  40. * That means there will be also kind of check what kind of data it contains.
  41. * The caller has to make sure the data it will forward, matches the expected data in the invoke function.
  42. */
  43. struct argument_wrapper
  44. {
  45. argument_wrapper() : m_data(nullptr) {}
  46. template<typename T, typename Tp = typename std::enable_if<!std::is_same<T, argument_wrapper>::value, T>::type>
  47. argument_wrapper(T&& data) : m_data(const_cast<void*>(reinterpret_cast<const void*>(std::addressof(data)))) {}
  48. template<typename T>
  49. T& get_value() const
  50. {
  51. using raw_type = typename std::remove_reference<T>::type;
  52. return (*reinterpret_cast<raw_type*>(const_cast<void *>(m_data)));
  53. }
  54. void* m_data;
  55. };
  56. } // end namespace detail
  57. } // end namespace rttr
  58. #endif // RTTR_ARGUMENT_WRAPPER_H_