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. // IMPORTANT: methods here are prefaced with csi_ instead of csb_, the later being automatically generated bindings
  14. namespace Atomic
  15. {
  16. extern "C"
  17. {
  18. ATOMIC_EXPORT_API ClassID csi_Atomic_RefCounted_GetClassID(RefCounted* refCounted)
  19. {
  20. if (!refCounted)
  21. return 0;
  22. return refCounted->GetClassID();
  23. }
  24. ATOMIC_EXPORT_API void csi_AtomicEngine_ReleaseRef(RefCounted* refCounted)
  25. {
  26. if (!refCounted)
  27. return;
  28. refCounted->ReleaseRef();
  29. }
  30. ATOMIC_EXPORT_API const char* csi_Atomic_AObject_GetTypeName(Object* self)
  31. {
  32. static String returnValue;
  33. returnValue = self->GetTypeName();
  34. return returnValue.CString();
  35. }
  36. ATOMIC_EXPORT_API int csi_Atomic_RefCounted_Refs(RefCounted* self)
  37. {
  38. return self->Refs();
  39. }
  40. ATOMIC_EXPORT_API void csi_Atomic_AObject_SendEvent(Object* obj, const char* eventType, ScriptVariantMap* vmap)
  41. {
  42. obj->SendEvent(eventType, vmap ? vmap->GetVariantMap() : obj->GetEventDataMap());
  43. }
  44. ATOMIC_EXPORT_API ClassID csi_Atomic_NETCore_Initialize(NETCoreDelegates* delegates)
  45. {
  46. Context* context = new Context();
  47. NETCore* netCore = new NETCore(context, delegates);
  48. context->RegisterSubsystem(netCore);
  49. return netCore;
  50. }
  51. ATOMIC_EXPORT_API unsigned csi_Atomic_AtomicNET_StringToStringHash(const char* str)
  52. {
  53. unsigned hash = 0;
  54. if (!str)
  55. return hash;
  56. while (*str)
  57. {
  58. // Perform the actual hashing as case-insensitive
  59. char c = *str;
  60. hash = SDBMHash(hash, (unsigned char)tolower(c));
  61. ++str;
  62. }
  63. return hash;
  64. }
  65. ATOMIC_EXPORT_API void csi_Atomic_AtomicNET_ScriptVariantMapCopyVariantMap(ScriptVariantMap* svm, VariantMap* vm)
  66. {
  67. if (!svm)
  68. return;
  69. if (!vm)
  70. {
  71. svm->CopySourceVariantMap(Variant::emptyVariantMap);
  72. return;
  73. }
  74. svm->CopySourceVariantMap(*vm);
  75. }
  76. ATOMIC_EXPORT_API void* csi_Atomic_AtomicNET_ScriptVariantMap_GetVoidPtr(ScriptVariantMap* svm, const char* key)
  77. {
  78. if (!svm || !key || !strlen(key))
  79. return nullptr;
  80. return svm->GetVoidPtr(key);
  81. }
  82. // IPC
  83. ATOMIC_EXPORT_API void csi_Atomic_IPC_SendEventToBrokerWithEventData(IPC* ipc, const char* eventType, ScriptVariantMap* variantMap)
  84. {
  85. if (variantMap)
  86. ipc->SendEventToBroker(eventType, variantMap->GetVariantMap());
  87. else
  88. ipc->SendEventToBroker(eventType);
  89. }
  90. ATOMIC_EXPORT_API void* csi_Atomic_VertexBuffer_Lock(VertexBuffer* vb , unsigned start, unsigned count, bool discard)
  91. {
  92. if (!vb)
  93. return nullptr;
  94. return vb->Lock(start, count, discard);
  95. }
  96. ATOMIC_EXPORT_API void csi_Atomic_Graphics_SetShaderParameter_Matrix3x4(Graphics* graphics, const char* param, Matrix3x4* matrix)
  97. {
  98. if (!graphics || !param || !strlen(param))
  99. return;
  100. graphics->SetShaderParameter(param, *matrix);
  101. }
  102. }
  103. }