CmHString.cpp 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. #include "CmPrerequisitesUtil.h"
  2. #include "CmHString.h"
  3. #include "CmStringTable.h"
  4. namespace CamelotFramework
  5. {
  6. HString::StringData::StringData()
  7. :mParameters(nullptr), mIsDirty(true), mStringPtr(nullptr)
  8. { }
  9. HString::StringData::~StringData()
  10. {
  11. mUpdateConn.disconnect();
  12. if(mParameters != nullptr)
  13. cm_deleteN(mParameters, mStringData->numParameters);
  14. }
  15. void HString::StringData::updateString()
  16. {
  17. LocalizedStringData* stringData = &StringTable::instance().getStringData(mStringData->commonData->identifier);
  18. // If common data changed re-apply the connections
  19. if(stringData->commonData != mStringData->commonData)
  20. {
  21. mUpdateConn.disconnect();
  22. mUpdateConn = stringData->commonData->onStringDataModified.connect(boost::bind(&HString::StringData::updateString, this));
  23. }
  24. mStringData = stringData;
  25. mIsDirty = true;
  26. onStringModified();
  27. }
  28. HString::HString()
  29. {
  30. mData = cm_shared_ptr<StringData>();
  31. mData->mStringData = &StringTable::instance().getStringData(L"");
  32. if(mData->mStringData->numParameters > 0)
  33. mData->mParameters = cm_newN<WString>(mData->mStringData->numParameters);
  34. mData->mUpdateConn = mData->mStringData->commonData->onStringDataModified.connect(boost::bind(&HString::StringData::updateString, mData.get()));
  35. }
  36. HString::HString(const WString& identifierString)
  37. {
  38. mData = cm_shared_ptr<StringData>();
  39. mData->mStringData = &StringTable::instance().getStringData(identifierString);
  40. if(mData->mStringData->numParameters > 0)
  41. mData->mParameters = cm_newN<WString>(mData->mStringData->numParameters);
  42. mData->mUpdateConn = mData->mStringData->commonData->onStringDataModified.connect(boost::bind(&HString::StringData::updateString, mData.get()));
  43. }
  44. HString::HString(const HString& copy)
  45. {
  46. mData = copy.mData;
  47. }
  48. HString::~HString()
  49. {
  50. }
  51. HString::operator const WString& () const
  52. {
  53. return getValue();
  54. }
  55. const WString& HString::getValue() const
  56. {
  57. if(mData->mIsDirty)
  58. {
  59. if(mData->mParameters != nullptr)
  60. {
  61. mData->mStringData->concatenateString(mData->mCachedString, mData->mParameters, mData->mStringData->numParameters);
  62. mData->mStringPtr = &mData->mCachedString;
  63. }
  64. else
  65. {
  66. mData->mStringPtr = &mData->mStringData->string;
  67. }
  68. mData->mIsDirty = false;
  69. }
  70. return *mData->mStringPtr;
  71. }
  72. void HString::setParameter(UINT32 idx, const WString& value)
  73. {
  74. mData->mParameters[idx] = value;
  75. mData->mIsDirty = true;
  76. mData->onStringModified();
  77. }
  78. boost::signals::connection HString::addOnStringModifiedCallback(boost::function<void()> callback) const
  79. {
  80. return mData->onStringModified.connect(callback);
  81. }
  82. const HString& HString::dummy()
  83. {
  84. static HString dummyVal;
  85. return dummyVal;
  86. }
  87. }