2
0

CoreLuaAPI.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. //
  2. // Copyright (c) 2008-2013 the Urho3D project.
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to deal
  6. // in the Software without restriction, including without limitation the rights
  7. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. // copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  20. // THE SOFTWARE.
  21. //
  22. #pragma once
  23. #include "Context.h"
  24. #include "LuaScript.h"
  25. #include "ProcessUtils.h"
  26. #include "Variant.h"
  27. #include "Timer.h"
  28. namespace Urho3D
  29. {
  30. const char* GetPlatformCString()
  31. {
  32. static String platform = GetPlatform();
  33. return platform.CString();
  34. }
  35. Time* GetTime()
  36. {
  37. return GetLuaScriptContext()->GetSubsystem<Time>();
  38. }
  39. const Variant& FindVariant(const VariantMap* vmap, const char* key)
  40. {
  41. VariantMap::ConstIterator i = vmap->Find(ShortStringHash(key));
  42. return i != vmap->End() ? i->second_ : Variant::EMPTY;
  43. }
  44. int VariantMapGetInt(const VariantMap* vmap, const char* key)
  45. {
  46. return FindVariant(vmap, key).GetInt();
  47. }
  48. bool VariantMapGetBool(const VariantMap* vmap, const char* key)
  49. {
  50. return FindVariant(vmap, key).GetBool();
  51. }
  52. float VariantMapGetFloat(const VariantMap* vmap, const char* key)
  53. {
  54. return FindVariant(vmap, key).GetFloat();
  55. }
  56. const Vector2& VariantMapGetVector2(const VariantMap* vmap, const char* key)
  57. {
  58. return FindVariant(vmap, key).GetVector2();
  59. }
  60. const Vector3& VariantMapGetVector3(const VariantMap* vmap, const char* key)
  61. {
  62. return FindVariant(vmap, key).GetVector3();
  63. }
  64. const Vector4& VariantMapGetVector4(const VariantMap* vmap, const char* key)
  65. {
  66. return FindVariant(vmap, key).GetVector4();
  67. }
  68. const Quaternion& VariantMapGetQuaternion(const VariantMap* vmap, const char* key)
  69. {
  70. return FindVariant(vmap, key).GetQuaternion();
  71. }
  72. const Color& VariantMapGetColor(const VariantMap* vmap, const char* key)
  73. {
  74. return FindVariant(vmap, key).GetColor();
  75. }
  76. const String& VariantMapGetString(const VariantMap* vmap, const char* key)
  77. {
  78. return FindVariant(vmap, key).GetString();
  79. }
  80. const void* VariantMapGetPtr(const VariantMap* vmap, const char* key)
  81. {
  82. return FindVariant(vmap, key).GetPtr();
  83. }
  84. const ResourceRef& VariantMapGetResourceRef(const VariantMap* vmap, const char* key)
  85. {
  86. return FindVariant(vmap, key).GetResourceRef();
  87. }
  88. const ResourceRefList& VariantMapGetResourceRefList(const VariantMap* vmap, const char* key)
  89. {
  90. return FindVariant(vmap, key).GetResourceRefList();
  91. }
  92. const IntRect& VariantMapGetIntRect(const VariantMap* vmap, const char* key)
  93. {
  94. return FindVariant(vmap, key).GetIntRect();
  95. }
  96. const IntVector2& VariantMapGetIntVector2(const VariantMap* vmap, const char* key)
  97. {
  98. return FindVariant(vmap, key).GetIntVector2();
  99. }
  100. void VariantMapSetInt(VariantMap* vmap, const char* key, int value)
  101. {
  102. (*vmap)[ShortStringHash(key)] = value;
  103. }
  104. void VariantMapSetBool(VariantMap* vmap, const char* key, bool value)
  105. {
  106. (*vmap)[ShortStringHash(key)] = value;
  107. }
  108. void VariantMapSetFloat(VariantMap* vmap, const char* key, float value)
  109. {
  110. (*vmap)[ShortStringHash(key)] = value;
  111. }
  112. void VariantMapSetVector2(VariantMap* vmap, const char* key, const Vector2& value)
  113. {
  114. (*vmap)[ShortStringHash(key)] = value;
  115. }
  116. void VariantMapSetVector3(VariantMap* vmap, const char* key, const Vector3& value)
  117. {
  118. (*vmap)[ShortStringHash(key)] = value;
  119. }
  120. void VariantMapSetVector4(VariantMap* vmap, const char* key, const Vector4& value)
  121. {
  122. (*vmap)[ShortStringHash(key)] = value;
  123. }
  124. void VariantMapSetQuaternion(VariantMap* vmap, const char* key, const Quaternion& value)
  125. {
  126. (*vmap)[ShortStringHash(key)] = value;
  127. }
  128. void VariantMapSetColor(VariantMap* vmap, const char* key, const Color& value)
  129. {
  130. (*vmap)[ShortStringHash(key)] = value;
  131. }
  132. void VariantMapSetString(VariantMap* vmap, const char* key, const String& value)
  133. {
  134. (*vmap)[ShortStringHash(key)] = value;
  135. }
  136. void VariantMapSetPtr(VariantMap* vmap, const char* key, const void* value)
  137. {
  138. (*vmap)[ShortStringHash(key)] = value;
  139. }
  140. void VariantMapSetResourceRef(VariantMap* vmap, const char* key, const ResourceRef& value)
  141. {
  142. (*vmap)[ShortStringHash(key)] = value;
  143. }
  144. void VariantMapSetResourceRefList(VariantMap* vmap, const char* key, const ResourceRefList& value)
  145. {
  146. (*vmap)[ShortStringHash(key)] = value;
  147. }
  148. void VariantMapSetIntRect(VariantMap* vmap, const char* key, const IntRect& value)
  149. {
  150. (*vmap)[ShortStringHash(key)] = value;
  151. }
  152. void VariantMapSetIntVector2(VariantMap* vmap, const char* key, const IntVector2& value)
  153. {
  154. (*vmap)[ShortStringHash(key)] = value;
  155. }
  156. }