NETCInterop.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #include <Atomic/Script/ScriptVariantMap.h>
  2. #include <Atomic/IPC/IPC.h>
  3. #include <Atomic/Graphics/VertexBuffer.h>
  4. #include <Atomic/Graphics/Viewport.h>
  5. #include <Atomic/Graphics/Graphics.h>
  6. #include "NETCore.h"
  7. #ifdef ATOMIC_PLATFORM_WINDOWS
  8. #define ATOMIC_EXPORT_API __declspec(dllexport)
  9. #else
  10. #define ATOMIC_EXPORT_API
  11. #endif
  12. // TODO: Split into separate module files
  13. namespace Atomic
  14. {
  15. extern "C"
  16. {
  17. ATOMIC_EXPORT_API ClassID csb_Atomic_RefCounted_GetClassID(RefCounted* refCounted)
  18. {
  19. if (!refCounted)
  20. return 0;
  21. return refCounted->GetClassID();
  22. }
  23. ATOMIC_EXPORT_API void csb_AtomicEngine_ReleaseRef(RefCounted* refCounted)
  24. {
  25. if (!refCounted)
  26. return;
  27. refCounted->ReleaseRef();
  28. }
  29. ATOMIC_EXPORT_API void csb_Atomic_AObject_SendEvent(Object* obj, const char* eventType, ScriptVariantMap* vmap)
  30. {
  31. obj->SendEvent(eventType, vmap ? vmap->GetVariantMap() : obj->GetEventDataMap());
  32. }
  33. ATOMIC_EXPORT_API ClassID csb_Atomic_NETCore_Initialize(NETCoreDelegates* delegates)
  34. {
  35. Context* context = new Context();
  36. NETCore* netCore = new NETCore(context, delegates);
  37. context->RegisterSubsystem(netCore);
  38. return netCore;
  39. }
  40. ATOMIC_EXPORT_API unsigned csb_Atomic_AtomicNET_StringToStringHash(const char* str)
  41. {
  42. unsigned hash = 0;
  43. if (!str)
  44. return hash;
  45. while (*str)
  46. {
  47. // Perform the actual hashing as case-insensitive
  48. char c = *str;
  49. hash = SDBMHash(hash, (unsigned char)tolower(c));
  50. ++str;
  51. }
  52. return hash;
  53. }
  54. ATOMIC_EXPORT_API void csb_Atomic_AtomicNET_ScriptVariantMapCopyVariantMap(ScriptVariantMap* svm, VariantMap* vm)
  55. {
  56. if (!svm)
  57. return;
  58. if (!vm)
  59. {
  60. svm->CopySourceVariantMap(Variant::emptyVariantMap);
  61. return;
  62. }
  63. svm->CopySourceVariantMap(*vm);
  64. }
  65. ATOMIC_EXPORT_API void* csb_Atomic_AtomicNET_ScriptVariantMap_GetVoidPtr(ScriptVariantMap* svm, const char* key)
  66. {
  67. if (!svm || !key || !strlen(key))
  68. return nullptr;
  69. return svm->GetVoidPtr(key);
  70. }
  71. // IPC
  72. ATOMIC_EXPORT_API void csb_Atomic_IPC_SendEventToBrokerWithEventData(IPC* ipc, const char* eventType, ScriptVariantMap* variantMap)
  73. {
  74. if (variantMap)
  75. ipc->SendEventToBroker(eventType, variantMap->GetVariantMap());
  76. else
  77. ipc->SendEventToBroker(eventType);
  78. }
  79. ATOMIC_EXPORT_API void* csb_Atomic_VertexBuffer_Lock(VertexBuffer* vb , unsigned start, unsigned count, bool discard)
  80. {
  81. if (!vb)
  82. return nullptr;
  83. return vb->Lock(start, count, discard);
  84. }
  85. ATOMIC_EXPORT_API void csb_Atomic_Graphics_SetShaderParameter_Matrix3x4(Graphics* graphics, const char* param, Matrix3x4* matrix)
  86. {
  87. if (!graphics || !param || !strlen(param))
  88. return;
  89. graphics->SetShaderParameter(param, *matrix);
  90. }
  91. ATOMIC_EXPORT_API void csb_Atomic_Graphics_SetShaderParameter_Color(Graphics* graphics, const char* param, Color* color)
  92. {
  93. if (!graphics || !param || !strlen(param) || !color)
  94. return;
  95. graphics->SetShaderParameter(param, *color);
  96. }
  97. ATOMIC_EXPORT_API void csb_Atomic_Viewport_SetRenderPath_RenderPath(Viewport* viewport, RenderPath* renderPath)
  98. {
  99. if (!viewport)
  100. return;
  101. viewport->SetRenderPath(renderPath);
  102. }
  103. }
  104. }