registration_executer.h 3.4 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_REGISTRATION_EXECUTER_H_
  28. #define RTTR_REGISTRATION_EXECUTER_H_
  29. #include "rttr/detail/base/core_prerequisites.h"
  30. #include <functional>
  31. #include <vector>
  32. #include <utility>
  33. namespace rttr
  34. {
  35. namespace detail
  36. {
  37. /*!
  38. * The \ref registration_executer class will be used to delay the execution of a function call.
  39. *
  40. * The purpose of this class is to preserve the registration order during the manual register process.
  41. * For a certain key, which is ideally the *this* pointer, a function can be registered.
  42. * This function can be actually empty or not. For already registered keys the function can be overwritten.
  43. *
  44. * When an instance of a registration_executer object will be freed,
  45. * all the contained functions will be executed in the order of its registration.
  46. */
  47. class RTTR_API registration_executer
  48. {
  49. public:
  50. registration_executer();
  51. ~registration_executer();
  52. void add_registration_func(const void* key, std::function<void(void)> func = std::function<void(void)>());
  53. private:
  54. using item_type = std::pair<const void*, std::function<void(void)>>;
  55. using register_list = std::vector<item_type>;
  56. register_list m_list;
  57. };
  58. } // end namespace detail
  59. } // end namespace rttr
  60. #endif // RTTR_REGISTRATION_EXECUTER_H_