Generic.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. #ifndef CORE_GENERIC_H
  2. #define CORE_GENERIC_H
  3. #include "core/Matrix.h"
  4. #ifdef IMPORT_CORE
  5. #define GENERIC_PAIR(type, name) \
  6. type: \
  7. name, const type : name
  8. #define GENERIC_FLOAT_VECTOR(a, name) \
  9. _Generic((a), \
  10. GENERIC_PAIR(Vector2*, name##V2), \
  11. GENERIC_PAIR(Vector3*, name##V3), \
  12. GENERIC_PAIR(Vector4*, name##V4))
  13. #define GENERIC_VECTOR(a, name) \
  14. _Generic((a), \
  15. GENERIC_PAIR(Vector2*, name##V2), \
  16. GENERIC_PAIR(Vector3*, name##V3), \
  17. GENERIC_PAIR(Vector4*, name##V4), \
  18. GENERIC_PAIR(IntVector2*, name##IV2), \
  19. GENERIC_PAIR(IntVector3*, name##IV3), \
  20. GENERIC_PAIR(IntVector4*, name##IV4))
  21. #define GENERIC_FACTOR(b, type, base, factor) \
  22. type: \
  23. _Generic((b), GENERIC_PAIR(type, base), default: factor)
  24. #define addSet(a, b) GENERIC_VECTOR(a, addSet)(a, b)
  25. #define add(a, b, c) GENERIC_VECTOR(a, add)(a, b, c)
  26. #define subSet(a, b) GENERIC_VECTOR(a, subSet)(a, b)
  27. #define sub(a, b, c) GENERIC_VECTOR(a, sub)(a, b, c)
  28. #define mulSet(a, b) \
  29. _Generic((a), \
  30. Matrix *: mulSetMatrix, \
  31. Quaternion *: mulSetQ, \
  32. GENERIC_FACTOR(b, Vector2*, mulSetV2, mulSetV2F), \
  33. GENERIC_FACTOR(b, Vector3*, mulSetV3, mulSetV3F), \
  34. GENERIC_FACTOR(b, Vector4*, mulSetV4, mulSetV4F), \
  35. GENERIC_FACTOR(b, IntVector2*, mulSetIV2, mulSetIV2F), \
  36. GENERIC_FACTOR(b, IntVector3*, mulSetIV3, mulSetIV3F), \
  37. GENERIC_FACTOR(b, IntVector4*, mulSetIV4, mulSetIV4F))(a, b)
  38. #define mul(a, b, c) \
  39. _Generic((a), \
  40. Matrix *: mulMatrix, \
  41. Quaternion *: mulQ, \
  42. GENERIC_FACTOR(c, Vector2*, mulV2, mulV2F), \
  43. Vector3 *: _Generic((c), \
  44. Vector3 *: _Generic((b), \
  45. GENERIC_PAIR(Quaternion*, mulQV3), \
  46. GENERIC_PAIR(Matrix*, mulMatrixV3), \
  47. default: mulV3), \
  48. default: mulV3F), \
  49. GENERIC_FACTOR(c, Vector4*, mulV4, mulV4F), \
  50. GENERIC_FACTOR(c, IntVector2*, mulIV2, mulIV2F), \
  51. GENERIC_FACTOR(c, IntVector3*, mulIV3, mulIV3F), \
  52. GENERIC_FACTOR(c, IntVector4*, mulIV4, mulIV4F))(a, b, c)
  53. #define divSet(a, b) \
  54. _Generic((a), \
  55. GENERIC_FACTOR(b, Vector2*, divSetV2, divSetV2F), \
  56. GENERIC_FACTOR(b, Vector3*, divSetV3, divSetV3F), \
  57. GENERIC_FACTOR(b, Vector4*, divSetV4, divSetV4F), \
  58. GENERIC_FACTOR(b, IntVector2*, divSetIV2, divSetIV2F), \
  59. GENERIC_FACTOR(b, IntVector3*, divSetIV3, divSetIV3F), \
  60. GENERIC_FACTOR(b, IntVector4*, divSetIV4, divSetIV4F))(a, b)
  61. #define div(a, b, c) \
  62. _Generic((a), \
  63. GENERIC_FACTOR(c, Vector2*, divV2, divV2F), \
  64. GENERIC_FACTOR(c, Vector3*, divV3, divV3F), \
  65. GENERIC_FACTOR(c, Vector4*, divV4, divV4F), \
  66. GENERIC_FACTOR(c, IntVector2*, divIV2, divIV2F), \
  67. GENERIC_FACTOR(c, IntVector3*, divIV3, divIV3F), \
  68. GENERIC_FACTOR(c, IntVector4*, divIV4, divIV4F))(a, b, c)
  69. #define invertSet(a) GENERIC_VECTOR(a, invertSet)(a)
  70. #define invert(a, b) GENERIC_VECTOR(a, invert)(a, b)
  71. #define dot(a, b) GENERIC_FLOAT_VECTOR(a, dot)(a, b)
  72. #define squareLength(a) GENERIC_FLOAT_VECTOR(a, squareLength)(a)
  73. #define length(a) GENERIC_FLOAT_VECTOR(a, length)(a)
  74. #define normalize(a) GENERIC_FLOAT_VECTOR(a, normalize)(a)
  75. #define convert(a, b) \
  76. _Generic((a), \
  77. Vector2 *: convertIV2, \
  78. Vector3 *: convertIV3, \
  79. Vector4 *: convertIV4, \
  80. IntVector2 *: convertV2, \
  81. IntVector3 *: convertV3, \
  82. IntVector4 *: convertV4)(a, b)
  83. // #define toStringV2 coreToStringV2
  84. #endif
  85. #endif