NETVariant.h 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. #pragma once
  2. #include <Atomic/Core/Variant.h>
  3. namespace Atomic
  4. {
  5. /// Wraps a VariantMap as a RefCounted so we can easily send it to managed code
  6. /// For perfomance sensitive code, specialized marshaling should be used instead (for example physics event data)
  7. class NETVariantMap : public RefCounted
  8. {
  9. REFCOUNTED(NETVariantMap)
  10. public:
  11. NETVariantMap() : RefCounted()
  12. {
  13. }
  14. virtual ~NETVariantMap()
  15. {
  16. }
  17. bool GetBool(StringHash key) const
  18. {
  19. Variant* variant = vmap_[key];
  20. if (!variant)
  21. return 0;
  22. return variant->GetBool();
  23. }
  24. int GetInt(StringHash key) const
  25. {
  26. Variant* variant = vmap_[key];
  27. if (!variant)
  28. return 0;
  29. return variant->GetInt();
  30. }
  31. float GetFloat(StringHash key) const
  32. {
  33. Variant* variant = vmap_[key];
  34. if (!variant)
  35. return 0;
  36. return variant->GetFloat();
  37. }
  38. const Vector3& GetVector3(StringHash key) const
  39. {
  40. Variant* variant = vmap_[key];
  41. if (!variant)
  42. return Vector3::ZERO;
  43. return variant->GetVector3();
  44. }
  45. const Quaternion& GetQuaternion(StringHash key) const
  46. {
  47. Variant* variant = vmap_[key];
  48. if (!variant)
  49. return Quaternion::IDENTITY;
  50. return variant->GetQuaternion();
  51. }
  52. RefCounted* GetPtr(StringHash key) const
  53. {
  54. Variant* variant = vmap_[key];
  55. if (!variant)
  56. return 0;
  57. return variant->GetPtr();
  58. }
  59. const String& GetString(StringHash key) const
  60. {
  61. Variant* variant = vmap_[key];
  62. if (!variant)
  63. return String::EMPTY;
  64. return variant->GetString();
  65. }
  66. VariantType GetVariantType(StringHash key) const
  67. {
  68. Variant* variant = vmap_[key];
  69. if (!variant)
  70. return VAR_NONE;
  71. return variant->GetType();
  72. }
  73. bool Contains(StringHash key) const
  74. {
  75. return vmap_.Contains(key);
  76. }
  77. void CopySourceVariantMap(const VariantMap src) { vmap_ = src; }
  78. private:
  79. VariantMap vmap_;
  80. };
  81. }