Meta.cppm 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. module;
  2. export module Core.Meta;
  3. namespace Core {
  4. template<typename T>
  5. struct BaseRemovePointer final {
  6. using Type = T;
  7. };
  8. template<typename T>
  9. struct BaseRemovePointer<T*> final {
  10. using Type = T;
  11. };
  12. template<typename T>
  13. struct BaseRemoveReference final {
  14. using Type = T;
  15. };
  16. template<typename T>
  17. struct BaseRemoveReference<T&> final {
  18. using Type = T;
  19. };
  20. template<typename T>
  21. struct BaseRemoveReference<T&&> final {
  22. using Type = T;
  23. };
  24. template<typename A, typename B>
  25. struct BaseIsSame final {
  26. static constexpr bool value = false;
  27. };
  28. template<typename T>
  29. struct BaseIsSame<T, T> final {
  30. static constexpr bool value = true;
  31. };
  32. template<bool C, typename A, typename B>
  33. struct BaseIf final {
  34. using Type = A;
  35. };
  36. template<typename A, typename B>
  37. struct BaseIf<false, A, B> final {
  38. using Type = B;
  39. };
  40. }
  41. export namespace Core {
  42. template<typename T>
  43. concept Iterable = requires(T& t) {
  44. t.begin();
  45. t.end();
  46. };
  47. template<typename T>
  48. using RemovePointer = BaseRemovePointer<T>::Type;
  49. template<typename T>
  50. using RemoveReference = BaseRemoveReference<T>::Type;
  51. template<typename T, typename U>
  52. constexpr bool IsSame = BaseIsSame<T, U>::value;
  53. template<bool C, typename A, typename B>
  54. using If = BaseIf<C, A, B>::Type;
  55. template<typename T>
  56. constexpr RemoveReference<T>&& move(T&& t) {
  57. return static_cast<RemoveReference<T>&&>(t);
  58. }
  59. template<typename T>
  60. constexpr T&& forward(RemoveReference<T>& t) {
  61. return static_cast<T&&>(t);
  62. }
  63. template<typename T>
  64. constexpr T&& forward(RemoveReference<T>&& t) {
  65. return static_cast<T&&>(t);
  66. }
  67. template<typename T>
  68. void swap(T& a, T& b) noexcept {
  69. T tmp = Core::move(a);
  70. a = Core::move(b);
  71. b = Core::move(tmp);
  72. }
  73. }