rttr_cast.h 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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_RTTR_CAST_H_
  28. #define RTTR_RTTR_CAST_H_
  29. namespace rttr
  30. {
  31. /*!
  32. * \brief Casts the given \p object of type \p Source_Type to an object of type \p Target_Type.
  33. *
  34. * When the given the given \p object is an instance of type \p Target_Type, then this function will cast the pointer to the \p TargetType;
  35. * otherwise it will return a `nullptr`. If \p object is already a `nullptr` then it will also return a `nullptr`.
  36. *
  37. * \remark Both class types must contain the macro \ref RTTR_ENABLE in the class declaration.
  38. * \p Source_Type and \p Target_Type must be both pointer types.
  39. *
  40. *
  41. * \return A pointer of type \p Target_Type
  42. */
  43. template<typename Target_Type, typename Source_Type>
  44. Target_Type rttr_cast(Source_Type object) RTTR_NOEXCEPT;
  45. }
  46. #include "rttr/detail/impl/rttr_cast_impl.h"
  47. #endif // RTTR_RTTR_CAST_H_