Browse Source

Merge pull request #437 from zrax/hsRef

Clean up ref-counting
Adam Johnson 11 years ago
parent
commit
d27f102166
  1. 104
      Sources/Plasma/CoreLib/hsRefCnt.cpp
  2. 84
      Sources/Plasma/CoreLib/hsRefCnt.h
  3. 6
      Sources/Plasma/FeatureLib/pfPython/cyAvatar.cpp
  4. 6
      Sources/Plasma/FeatureLib/pfPython/cyMisc.cpp
  5. 3
      Sources/Plasma/FeatureLib/pfPython/plPythonFileMod.cpp
  6. 2
      Sources/Plasma/FeatureLib/pfPython/pyAgeInfoStructGlue.cpp
  7. 2
      Sources/Plasma/FeatureLib/pfPython/pyAgeLinkStructGlue.cpp
  8. 119
      Sources/Plasma/FeatureLib/pfPython/pyAgeVault.cpp
  9. 13
      Sources/Plasma/FeatureLib/pfPython/pyDniInfoSource.cpp
  10. 12
      Sources/Plasma/FeatureLib/pfPython/pyGameScore.cpp
  11. 2
      Sources/Plasma/FeatureLib/pfPython/pyNetServerSessionInfo.h
  12. 4
      Sources/Plasma/FeatureLib/pfPython/pyNetServerSessionInfoGlue.cpp
  13. 144
      Sources/Plasma/FeatureLib/pfPython/pyVault.cpp
  14. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultAgeInfoListNodeGlue.cpp
  15. 15
      Sources/Plasma/FeatureLib/pfPython/pyVaultAgeInfoNode.cpp
  16. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultAgeInfoNodeGlue.cpp
  17. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultAgeLinkNode.cpp
  18. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultAgeLinkNodeGlue.cpp
  19. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultChronicleNodeGlue.cpp
  20. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultFolderNodeGlue.cpp
  21. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultImageNodeGlue.cpp
  22. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultMarkerGameNodeGlue.cpp
  23. 92
      Sources/Plasma/FeatureLib/pfPython/pyVaultNode.cpp
  24. 9
      Sources/Plasma/FeatureLib/pfPython/pyVaultNode.h
  25. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultNodeGlue.cpp
  26. 38
      Sources/Plasma/FeatureLib/pfPython/pyVaultNodeRef.cpp
  27. 11
      Sources/Plasma/FeatureLib/pfPython/pyVaultNodeRef.h
  28. 8
      Sources/Plasma/FeatureLib/pfPython/pyVaultNodeRefGlue.cpp
  29. 38
      Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerInfoListNode.cpp
  30. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerInfoListNodeGlue.cpp
  31. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerInfoNodeGlue.cpp
  32. 28
      Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerNode.cpp
  33. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerNodeGlue.cpp
  34. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultSDLNodeGlue.cpp
  35. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultSystemNodeGlue.cpp
  36. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultTextNoteNode.cpp
  37. 4
      Sources/Plasma/FeatureLib/pfPython/pyVaultTextNoteNodeGlue.cpp
  38. 2
      Sources/Plasma/NucleusLib/pnAsyncCoreExe/Private/Nt/pnAceNtInt.h
  39. 4
      Sources/Plasma/NucleusLib/pnAsyncCoreExe/Private/Win32/pnAceW32Thread.cpp
  40. 4
      Sources/Plasma/NucleusLib/pnNetCli/pnNcChannel.cpp
  41. 2
      Sources/Plasma/NucleusLib/pnNetProtocol/Private/pnNpCommon.cpp
  42. 2
      Sources/Plasma/NucleusLib/pnNetProtocol/Private/pnNpCommon.h
  43. 121
      Sources/Plasma/PubUtilLib/plAvatar/plAvatarClothing.cpp
  44. 3
      Sources/Plasma/PubUtilLib/plInputCore/plSceneInputInterface.cpp
  45. 39
      Sources/Plasma/PubUtilLib/plNetClient/plNetLinkingMgr.cpp
  46. 10
      Sources/Plasma/PubUtilLib/plNetClientComm/plNetClientComm.cpp
  47. 21
      Sources/Plasma/PubUtilLib/plNetCommon/plNetServerSessionInfo.cpp
  48. 2
      Sources/Plasma/PubUtilLib/plNetCommon/plNetServerSessionInfo.h
  49. 2
      Sources/Plasma/PubUtilLib/plNetGameLib/Intern.h
  50. 22
      Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglAuth.cpp
  51. 4
      Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglFile.cpp
  52. 4
      Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglGame.cpp
  53. 4
      Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglGateKeeper.cpp
  54. 2
      Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglTrans.cpp
  55. 2
      Sources/Plasma/PubUtilLib/plNetMessage/plNetCommonMessage.h
  56. 10
      Sources/Plasma/PubUtilLib/plPipeline/plFogEnvironment.cpp
  57. 3
      Sources/Plasma/PubUtilLib/plPipeline/plFogEnvironment.h
  58. 1037
      Sources/Plasma/PubUtilLib/plVault/plVaultClientApi.cpp
  59. 139
      Sources/Plasma/PubUtilLib/plVault/plVaultClientApi.h
  60. 6
      Sources/Plasma/PubUtilLib/plVault/plVaultNodeAccess.cpp

104
Sources/Plasma/CoreLib/hsRefCnt.cpp

@ -46,43 +46,101 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "hsExceptions.h" #include "hsExceptions.h"
#include "hsRefCnt.h" #include "hsRefCnt.h"
hsRefCnt::~hsRefCnt() #define REFCOUNT_DBG_NONE 0
{ #define REFCOUNT_DBG_REFS 1
#ifdef HS_DEBUGGING #define REFCOUNT_DBG_LEAKS 2
hsThrowIfFalse(fRefCnt == 1); #define REFCOUNT_DBG_ALL 3
#define REFCOUNT_DEBUGGING REFCOUNT_DBG_NONE
#if (REFCOUNT_DEBUGGING == REFCOUNT_DBG_LEAKS) || (REFCOUNT_DEBUGGING == REFCOUNT_DBG_ALL)
#include <unordered_set>
#include <mutex>
#include "plFormat.h"
// hsDebugMessage can get overridden to dump to a file :(
#ifdef _MSC_VER
# include "hsWindows.h"
# define _LeakDebug(message) OutputDebugString(message)
#else
# define _LeakDebug(message) fputs(message, stderr)
#endif #endif
}
void hsRefCnt::UnRef() struct _RefCountLeakCheck
{ {
#ifdef HS_DEBUGGING std::unordered_set<hsRefCnt *> m_refs;
hsThrowIfFalse(fRefCnt >= 1); unsigned m_added, m_removed;
std::mutex m_mutex;
~_RefCountLeakCheck()
{
std::lock_guard<std::mutex> lock(m_mutex);
_LeakDebug(plFormat("Refs tracked: {} created, {} destroyed\n",
m_added, m_removed).c_str());
if (m_refs.empty())
return;
_LeakDebug(plFormat(" {} objects leaked...\n", m_refs.size()).c_str());
for (hsRefCnt *ref : m_refs) {
_LeakDebug(plFormat(" 0x{_08x} {}: {} refs remain\n",
(uintptr_t)ref, typeid(*ref).name(), ref->RefCnt()).c_str());
}
}
static _RefCountLeakCheck *_instance()
{
static _RefCountLeakCheck s_instance;
return &s_instance;
}
static void add(hsRefCnt *ref)
{
_RefCountLeakCheck *this_p = _instance();
std::lock_guard<std::mutex> lock(this_p->m_mutex);
++this_p->m_added;
this_p->m_refs.insert(ref);
}
static void del(hsRefCnt *ref)
{
_RefCountLeakCheck *this_p = _instance();
std::lock_guard<std::mutex> lock(this_p->m_mutex);
++this_p->m_removed;
this_p->m_refs.erase(ref);
}
};
#endif #endif
if (fRefCnt == 1) // don't decrement if we call delete hsRefCnt::hsRefCnt(int initRefs)
delete this; : fRefCnt(initRefs)
else {
--fRefCnt; #if (REFCOUNT_DEBUGGING == REFCOUNT_DBG_LEAKS) || (REFCOUNT_DEBUGGING == REFCOUNT_DBG_ALL)
_RefCountLeakCheck::add(this);
#endif
} }
hsAtomicRefCnt::~hsAtomicRefCnt() hsRefCnt::~hsRefCnt()
{ {
#ifdef HS_DEBUGGING #ifdef HS_DEBUGGING
hsThrowIfFalse(fRefCnt == 1); hsThrowIfFalse(fRefCnt == 1);
#endif #endif
#if (REFCOUNT_DEBUGGING == REFCOUNT_DBG_LEAKS) || (REFCOUNT_DEBUGGING == REFCOUNT_DBG_ALL)
_RefCountLeakCheck::del(this);
#endif
} }
void hsAtomicRefCnt::UnRef(const char* tag) void hsRefCnt::UnRef(const char* tag)
{ {
#ifdef HS_DEBUGGING #ifdef HS_DEBUGGING
hsThrowIfFalse(fRefCnt >= 1); hsThrowIfFalse(fRefCnt >= 1);
#endif #endif
#ifdef REFCOUNT_DEBUGGING #if (REFCOUNT_DEBUGGING == REFCOUNT_DBG_REFS) || (REFCOUNT_DEBUGGING == REFCOUNT_DBG_ALL)
if (tag) if (tag)
DEBUG_MSG("Dec %p %s: %u", this, tag, prev - 1); DEBUG_MSG("Dec %p %s: %u", this, tag, fRefCnt - 1);
else else
DEBUG_MSG("Dec %p: %u", this, prev - 1); DEBUG_MSG("Dec %p: %u", this, fRefCnt - 1);
#endif #endif
if (fRefCnt == 1) // don't decrement if we call delete if (fRefCnt == 1) // don't decrement if we call delete
@ -91,21 +149,21 @@ void hsAtomicRefCnt::UnRef(const char* tag)
--fRefCnt; --fRefCnt;
} }
void hsAtomicRefCnt::Ref(const char* tag) void hsRefCnt::Ref(const char* tag)
{ {
#ifdef REFCOUNT_DEBUGGING #if (REFCOUNT_DEBUGGING == REFCOUNT_DBG_REFS) || (REFCOUNT_DEBUGGING == REFCOUNT_DBG_ALL)
if (tag) if (tag)
DEBUG_MSG("Inc %p %s: %u", this, tag, prev + 1); DEBUG_MSG("Inc %p %s: %u", this, tag, fRefCnt + 1);
else else
DEBUG_MSG("Inc %p: %u", this, prev + 1); DEBUG_MSG("Inc %p: %u", this, fRefCnt + 1);
#endif #endif
++fRefCnt; ++fRefCnt;
} }
void hsAtomicRefCnt::TransferRef(const char* oldTag, const char* newTag) void hsRefCnt::TransferRef(const char* oldTag, const char* newTag)
{ {
#ifdef REFCOUNT_DEBUGGING #if (REFCOUNT_DEBUGGING == REFCOUNT_DBG_REFS) || (REFCOUNT_DEBUGGING == REFCOUNT_DBG_ALL)
DEBUG_MSG("Inc %p %s: (xfer)", this, newTag); DEBUG_MSG("Inc %p %s: (xfer)", this, newTag);
DEBUG_MSG("Dec %p %s: (xfer)", this, oldTag); DEBUG_MSG("Dec %p %s: (xfer)", this, oldTag);
#endif #endif

84
Sources/Plasma/CoreLib/hsRefCnt.h

@ -46,15 +46,25 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
class hsRefCnt { class hsRefCnt {
private: private:
int fRefCnt; std::atomic<int> fRefCnt;
public: public:
hsRefCnt(int initRefs = 1) : fRefCnt(initRefs) {} hsRefCnt(int initRefs = 1);
virtual ~hsRefCnt(); virtual ~hsRefCnt();
inline int RefCnt() const { return fRefCnt; } inline int RefCnt() const { return fRefCnt; }
void UnRef(); void UnRef(const char* tag = nullptr);
inline void Ref() { ++fRefCnt; } void Ref(const char* tag = nullptr);
// Useless, but left here for debugging compatibility with AtomicRef
void TransferRef(const char* oldTag, const char* newTag);
// The stored reference count of an hsRefCnt-derived object should never
// be copied! Therefore, if you want a copyable hsRefCnt-based class, you
// should implement your own copy constructor / assignment operator.
hsRefCnt(const hsRefCnt &) = delete;
hsRefCnt &operator=(const hsRefCnt &) = delete;
}; };
#define hsRefCnt_SafeRef(obj) do { if (obj) (obj)->Ref(); } while (0) #define hsRefCnt_SafeRef(obj) do { if (obj) (obj)->Ref(); } while (0)
@ -68,23 +78,61 @@ public:
} while (0) } while (0)
// Thread-safe version. TODO: Evaluate whether this is fast enough to template <class _Ref>
// merge with hsRefCnt above. class hsRef
class hsAtomicRefCnt
{ {
private:
std::atomic<int> fRefCnt;
public: public:
hsAtomicRefCnt(int initRefs = 1) : fRefCnt(initRefs) { } hsRef() : fObj(nullptr) { }
virtual ~hsAtomicRefCnt(); hsRef(nullptr_t) : fObj(nullptr) { }
hsRef(_Ref *obj) : fObj(obj) { if (fObj) fObj->Ref(); }
hsRef(const hsRef<_Ref> &copy) : fObj(copy.fObj) { if (fObj) fObj->Ref(); }
hsRef(hsRef<_Ref> &&move) : fObj(move.fObj) { move.fObj = nullptr; }
~hsRef() { if (fObj) fObj->UnRef(); }
hsRef<_Ref> &operator=(_Ref *obj)
{
if (obj)
obj->Ref();
if (fObj)
fObj->UnRef();
fObj = obj;
return *this;
}
hsRef<_Ref> &operator=(const hsRef<_Ref> &copy) { return operator=(copy.fObj); }
hsRef<_Ref> &operator=(hsRef<_Ref> &&move)
{
if (fObj)
fObj->UnRef();
fObj = move.fObj;
move.fObj = nullptr;
return *this;
}
hsRef<_Ref> &operator=(nullptr_t)
{
if (fObj)
fObj->UnRef();
fObj = nullptr;
return *this;
}
bool operator==(const hsRef<_Ref> &other) const { return fObj == other.fObj; }
bool operator!=(const hsRef<_Ref> &other) const { return fObj != other.fObj; }
bool operator> (const hsRef<_Ref> &other) const { return fObj > other.fObj; }
bool operator< (const hsRef<_Ref> &other) const { return fObj < other.fObj; }
bool operator>=(const hsRef<_Ref> &other) const { return fObj >= other.fObj; }
bool operator<=(const hsRef<_Ref> &other) const { return fObj <= other.fObj; }
bool operator==(_Ref *other) const { return fObj == other; }
bool operator!=(_Ref *other) const { return fObj != other; }
_Ref &operator*() const { return *fObj; }
_Ref *const operator->() const { return fObj; }
operator _Ref *const() const { return fObj; }
inline int RefCnt() const { return fRefCnt; } private:
void UnRef(const char* tag = nullptr); _Ref *fObj;
void Ref(const char* tag = nullptr);
// Useless, but left here for debugging compatibility with AtomicRef
void TransferRef(const char* oldTag, const char* newTag);
}; };
#endif #endif

6
Sources/Plasma/FeatureLib/pfPython/cyAvatar.cpp

@ -1670,11 +1670,10 @@ void cyAvatar::ChangeAvatar(const char* genderName)
wchar_t wStr[MAX_PATH]; wchar_t wStr[MAX_PATH];
StrToUnicode(wStr, genderName, arrsize(wStr)); StrToUnicode(wStr, genderName, arrsize(wStr));
RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef(); hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode();
if (rvnPlr) { if (rvnPlr) {
VaultPlayerNode plr(rvnPlr); VaultPlayerNode plr(rvnPlr);
plr.SetAvatarShapeName(wStr); plr.SetAvatarShapeName(wStr);
rvnPlr->UnRef();
} }
#endif #endif
} }
@ -1691,11 +1690,10 @@ void cyAvatar::ChangePlayerName(const char* playerName)
wchar_t wStr[MAX_PATH]; wchar_t wStr[MAX_PATH];
StrToUnicode(wStr, playerName, arrsize(wStr)); StrToUnicode(wStr, playerName, arrsize(wStr));
RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef(); hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode();
if (rvnPlr) { if (rvnPlr) {
VaultPlayerNode plr(rvnPlr); VaultPlayerNode plr(rvnPlr);
plr.SetPlayerName(wStr); plr.SetPlayerName(wStr);
rvnPlr->UnRef();
} }
} }

6
Sources/Plasma/FeatureLib/pfPython/cyMisc.cpp

@ -2471,10 +2471,9 @@ int cyMisc::GetKILevel()
wchar_t wStr[MAX_PATH]; wchar_t wStr[MAX_PATH];
StrToUnicode(wStr, pfKIMsg::kChronicleKILevel, arrsize(wStr)); StrToUnicode(wStr, pfKIMsg::kChronicleKILevel, arrsize(wStr));
if (RelVaultNode * rvn = VaultFindChronicleEntryIncRef(wStr)) { if (hsRef<RelVaultNode> rvn = VaultFindChronicleEntry(wStr)) {
VaultChronicleNode chron(rvn); VaultChronicleNode chron(rvn);
result = wcstol(chron.GetEntryValue(), nil, 0); result = wcstol(chron.GetEntryValue(), nil, 0);
rvn->UnRef();
} }
return result; return result;
@ -2880,7 +2879,7 @@ void cyMisc::SetBehaviorNetFlags(pyKey & behKey, bool netForce, bool netProp)
void cyMisc::SendFriendInvite(const wchar_t email[], const wchar_t toName[]) void cyMisc::SendFriendInvite(const wchar_t email[], const wchar_t toName[])
{ {
if (RelVaultNode* pNode = VaultGetPlayerNodeIncRef()) if (hsRef<RelVaultNode> pNode = VaultGetPlayerNode())
{ {
VaultPlayerNode player(pNode); VaultPlayerNode player(pNode);
plUUID inviteUuid = player.GetInviteUuid(); plUUID inviteUuid = player.GetInviteUuid();
@ -2893,7 +2892,6 @@ void cyMisc::SendFriendInvite(const wchar_t email[], const wchar_t toName[])
} }
NetCommSendFriendInvite(email, toName, inviteUuid); NetCommSendFriendInvite(email, toName, inviteUuid);
pNode->UnRef();
} }
} }

3
Sources/Plasma/FeatureLib/pfPython/plPythonFileMod.cpp

@ -2079,11 +2079,10 @@ bool plPythonFileMod::MsgReceive(plMessage* msg)
case plVaultNotifyMsg::kRegisteredVisitAge: case plVaultNotifyMsg::kRegisteredVisitAge:
case plVaultNotifyMsg::kUnRegisteredOwnedAge: case plVaultNotifyMsg::kUnRegisteredOwnedAge:
case plVaultNotifyMsg::kUnRegisteredVisitAge: { case plVaultNotifyMsg::kUnRegisteredVisitAge: {
if (RelVaultNode * rvn = VaultGetNodeIncRef(vaultNotifyMsg->GetArgs()->GetInt(plNetCommon::VaultTaskArgs::kAgeLinkNode))) { if (hsRef<RelVaultNode> rvn = VaultGetNode(vaultNotifyMsg->GetArgs()->GetInt(plNetCommon::VaultTaskArgs::kAgeLinkNode))) {
Py_DECREF(ptuple); Py_DECREF(ptuple);
ptuple = PyTuple_New(1); ptuple = PyTuple_New(1);
PyTuple_SetItem(ptuple, 0, pyVaultAgeLinkNode::New(rvn)); PyTuple_SetItem(ptuple, 0, pyVaultAgeLinkNode::New(rvn));
rvn->UnRef();
} }
} }
break; break;

2
Sources/Plasma/FeatureLib/pfPython/pyAgeInfoStructGlue.cpp

@ -435,7 +435,7 @@ PLASMA_DEFAULT_TYPE(ptAgeInfoStructRef, "Class to hold AgeInfo struct data");
PyObject *pyAgeInfoStructRef::New(plAgeInfoStruct &info) PyObject *pyAgeInfoStructRef::New(plAgeInfoStruct &info)
{ {
ptAgeInfoStructRef *newObj = (ptAgeInfoStructRef*)ptAgeInfoStructRef_type.tp_new(&ptAgeInfoStructRef_type, NULL, NULL); ptAgeInfoStructRef *newObj = (ptAgeInfoStructRef*)ptAgeInfoStructRef_type.tp_new(&ptAgeInfoStructRef_type, NULL, NULL);
newObj->fThis->fAgeInfo = info; newObj->fThis->fAgeInfo.CopyFrom(&info);
return (PyObject*)newObj; return (PyObject*)newObj;
} }

2
Sources/Plasma/FeatureLib/pfPython/pyAgeLinkStructGlue.cpp

@ -366,7 +366,7 @@ PLASMA_DEFAULT_TYPE(ptAgeLinkStructRef, "Class to hold the data of the AgeLink s
PyObject *pyAgeLinkStructRef::New(plAgeLinkStruct &link) PyObject *pyAgeLinkStructRef::New(plAgeLinkStruct &link)
{ {
ptAgeLinkStructRef *newObj = (ptAgeLinkStructRef*)ptAgeLinkStructRef_type.tp_new(&ptAgeLinkStructRef_type, NULL, NULL); ptAgeLinkStructRef *newObj = (ptAgeLinkStructRef*)ptAgeLinkStructRef_type.tp_new(&ptAgeLinkStructRef_type, NULL, NULL);
newObj->fThis->fAgeLink = link; newObj->fThis->fAgeLink.CopyFrom(&link);
return (PyObject*)newObj; return (PyObject*)newObj;
} }

119
Sources/Plasma/FeatureLib/pfPython/pyAgeVault.cpp

@ -81,12 +81,9 @@ pyAgeVault::~pyAgeVault() {
PyObject* pyAgeVault::GetAgeInfo() PyObject* pyAgeVault::GetAgeInfo()
{ {
RelVaultNode * rvn = VaultGetAgeInfoNodeIncRef(); hsRef<RelVaultNode> rvn = VaultGetAgeInfoNode();
if (rvn) { if (rvn)
PyObject * result = pyVaultAgeInfoNode::New(rvn); return pyVaultAgeInfoNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -94,12 +91,9 @@ PyObject* pyAgeVault::GetAgeInfo()
PyObject* pyAgeVault::GetAgeDevicesFolder( void ) PyObject* pyAgeVault::GetAgeDevicesFolder( void )
{ {
RelVaultNode * rvn = VaultGetAgeDevicesFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAgeDevicesFolder();
if (rvn) { if (rvn)
PyObject * result = pyVaultFolderNode::New(rvn); return pyVaultFolderNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -107,12 +101,9 @@ PyObject* pyAgeVault::GetAgeDevicesFolder( void )
PyObject* pyAgeVault::GetSubAgesFolder( void ) PyObject* pyAgeVault::GetSubAgesFolder( void )
{ {
RelVaultNode * rvn = VaultGetAgeSubAgesFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAgeSubAgesFolder();
if (rvn) { if (rvn)
PyObject * result = pyVaultFolderNode::New(rvn); return pyVaultFolderNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -120,12 +111,9 @@ PyObject* pyAgeVault::GetSubAgesFolder( void )
PyObject* pyAgeVault::GetChronicleFolder( void ) PyObject* pyAgeVault::GetChronicleFolder( void )
{ {
RelVaultNode * rvn = VaultGetAgeChronicleFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAgeChronicleFolder();
if (rvn) { if (rvn)
PyObject * result = pyVaultFolderNode::New(rvn); return pyVaultFolderNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -133,12 +121,9 @@ PyObject* pyAgeVault::GetChronicleFolder( void )
PyObject* pyAgeVault::GetBookshelfFolder ( void ) PyObject* pyAgeVault::GetBookshelfFolder ( void )
{ {
RelVaultNode * rvn = VaultAgeGetBookshelfFolderIncRef(); hsRef<RelVaultNode> rvn = VaultAgeGetBookshelfFolder();
if (rvn) { if (rvn)
PyObject * result = pyVaultFolderNode::New(rvn); return pyVaultFolderNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -146,12 +131,9 @@ PyObject* pyAgeVault::GetBookshelfFolder ( void )
PyObject* pyAgeVault::GetPeopleIKnowAboutFolder( void ) PyObject* pyAgeVault::GetPeopleIKnowAboutFolder( void )
{ {
RelVaultNode * rvn = VaultGetAgePeopleIKnowAboutFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAgePeopleIKnowAboutFolder();
if (rvn) { if (rvn)
PyObject * result = pyVaultFolderNode::New(rvn); return pyVaultFolderNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -160,12 +142,9 @@ PyObject* pyAgeVault::GetPeopleIKnowAboutFolder( void )
PyObject* pyAgeVault::GetPublicAgesFolder(void) PyObject* pyAgeVault::GetPublicAgesFolder(void)
{ {
RelVaultNode * rvn = VaultGetAgePublicAgesFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAgePublicAgesFolder();
if (rvn) { if (rvn)
PyObject * result = pyVaultFolderNode::New(rvn); return pyVaultFolderNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -173,12 +152,9 @@ PyObject* pyAgeVault::GetPublicAgesFolder(void)
PyObject* pyAgeVault::GetSubAgeLink( const pyAgeInfoStruct & info ) PyObject* pyAgeVault::GetSubAgeLink( const pyAgeInfoStruct & info )
{ {
RelVaultNode * rvn = VaultFindAgeSubAgeLinkIncRef(info.GetAgeInfo()); hsRef<RelVaultNode> rvn = VaultFindAgeSubAgeLink(info.GetAgeInfo());
if (rvn) { if (rvn)
PyObject * result = pyVaultAgeLinkNode::New(rvn); return pyVaultAgeLinkNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -186,12 +162,10 @@ PyObject* pyAgeVault::GetSubAgeLink( const pyAgeInfoStruct & info )
plUUID pyAgeVault::GetAgeGuid( void ) plUUID pyAgeVault::GetAgeGuid( void )
{ {
RelVaultNode * rvn = VaultGetAgeInfoNodeIncRef(); hsRef<RelVaultNode> rvn = VaultGetAgeInfoNode();
if (rvn) { if (rvn) {
VaultAgeInfoNode ageInfo(rvn); VaultAgeInfoNode ageInfo(rvn);
plUUID uuid = ageInfo.GetAgeInstanceGuid(); return ageInfo.GetAgeInstanceGuid();
rvn->UnRef();
return uuid;
} }
return kNilUuid; return kNilUuid;
} }
@ -204,11 +178,8 @@ PyObject* pyAgeVault::FindChronicleEntry( const char * entryName )
wchar_t wEntryName[kMaxVaultNodeStringLength]; wchar_t wEntryName[kMaxVaultNodeStringLength];
StrToUnicode(wEntryName, entryName, arrsize(wEntryName)); StrToUnicode(wEntryName, entryName, arrsize(wEntryName));
if (RelVaultNode * rvn = VaultFindAgeChronicleEntryIncRef(wEntryName)) { if (hsRef<RelVaultNode> rvn = VaultFindAgeChronicleEntry(wEntryName))
PyObject * result = pyVaultChronicleNode::New(rvn); return pyVaultChronicleNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -235,10 +206,8 @@ void pyAgeVault::AddDevice( const char * deviceName, PyObject * cbObject, uint32
wchar_t wStr[MAX_PATH]; wchar_t wStr[MAX_PATH];
StrToUnicode(wStr, deviceName, arrsize(wStr)); StrToUnicode(wStr, deviceName, arrsize(wStr));
if (RelVaultNode * rvn = VaultAgeAddDeviceAndWaitIncRef(wStr)) { if (hsRef<RelVaultNode> rvn = VaultAgeAddDeviceAndWait(wStr))
cb->SetNode(rvn); cb->SetNode(rvn);
rvn->UnRef();
}
cb->VaultOperationComplete( cbContext, cb->GetNode() ? hsOK : hsFail); // cbHolder deletes itself here. cb->VaultOperationComplete( cbContext, cb->GetNode() ? hsOK : hsFail); // cbHolder deletes itself here.
} }
@ -266,11 +235,8 @@ PyObject * pyAgeVault::GetDevice( const char * deviceName )
wchar_t wStr[MAX_PATH]; wchar_t wStr[MAX_PATH];
StrToUnicode(wStr, deviceName, arrsize(wStr)); StrToUnicode(wStr, deviceName, arrsize(wStr));
if (RelVaultNode * rvn = VaultAgeGetDeviceIncRef(wStr)) { if (hsRef<RelVaultNode> rvn = VaultAgeGetDevice(wStr))
PyObject * result = pyVaultTextNoteNode::New(rvn); return pyVaultTextNoteNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }
@ -286,10 +252,8 @@ void pyAgeVault::SetDeviceInbox( const char * deviceName, const char * inboxName
wchar_t wInb[MAX_PATH]; wchar_t wInb[MAX_PATH];
StrToUnicode(wInb, inboxName, arrsize(wInb)); StrToUnicode(wInb, inboxName, arrsize(wInb));
if (RelVaultNode * rvn = VaultAgeSetDeviceInboxAndWaitIncRef(wDev, wInb)) { if (hsRef<RelVaultNode> rvn = VaultAgeSetDeviceInboxAndWait(wDev, wInb))
cb->SetNode(rvn); cb->SetNode(rvn);
rvn->UnRef();
}
cb->VaultOperationComplete( cbContext, cb->GetNode() ? hsOK : hsFail ); // cbHolder deletes itself here. cb->VaultOperationComplete( cbContext, cb->GetNode() ? hsOK : hsFail ); // cbHolder deletes itself here.
} }
@ -299,11 +263,8 @@ PyObject * pyAgeVault::GetDeviceInbox( const char * deviceName )
wchar_t wStr[MAX_PATH]; wchar_t wStr[MAX_PATH];
StrToUnicode(wStr, deviceName, arrsize(wStr)); StrToUnicode(wStr, deviceName, arrsize(wStr));
if (RelVaultNode * rvn = VaultAgeGetDeviceInboxIncRef(wStr)) { if (hsRef<RelVaultNode> rvn = VaultAgeGetDeviceInbox(wStr))
PyObject * result = pyVaultTextNoteNode::New(rvn); return pyVaultTextNoteNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }
@ -331,14 +292,10 @@ void pyAgeVault::UpdateAgeSDL( pySDLStateDataRecord & pyrec )
PyObject* pyAgeVault::FindNode( pyVaultNode* templateNode ) const PyObject* pyAgeVault::FindNode( pyVaultNode* templateNode ) const
{ {
if (RelVaultNode * rvn = VaultGetAgeNodeIncRef()) { if (hsRef<RelVaultNode> rvn = VaultGetAgeNode()) {
RelVaultNode * find = rvn->GetChildNodeIncRef(templateNode->fNode, 1); hsRef<RelVaultNode> find = rvn->GetChildNode(templateNode->fNode, 1);
rvn->UnRef(); if (find)
if (find) { return pyVaultNode::New(find);
PyObject * result = pyVaultNode::New(find);
find->UnRef();
return result;
}
} }
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;

13
Sources/Plasma/FeatureLib/pfPython/pyDniInfoSource.cpp

@ -71,7 +71,7 @@ PyObject* pyDniInfoSource::GetAgeCoords( void )
uint32_t pyDniInfoSource::GetAgeTime( void ) const uint32_t pyDniInfoSource::GetAgeTime( void ) const
{ {
RelVaultNode * node = VaultGetAgeInfoNodeIncRef(); hsRef<RelVaultNode> node = VaultGetAgeInfoNode();
if (!node) if (!node)
return 0; return 0;
@ -81,34 +81,29 @@ uint32_t pyDniInfoSource::GetAgeTime( void ) const
result = (uint32_t)utime->GetSecs(); result = (uint32_t)utime->GetSecs();
else else
result = 0; result = 0;
node->UnRef();
return result; return result;
} }
const char * pyDniInfoSource::GetAgeName( void ) const const char * pyDniInfoSource::GetAgeName( void ) const
{ {
RelVaultNode * node = VaultGetAgeInfoNodeIncRef(); hsRef<RelVaultNode> node = VaultGetAgeInfoNode();
if (!node) if (!node)
return ""; return "";
VaultAgeInfoNode ageInfo(node); VaultAgeInfoNode ageInfo(node);
fAgeName = StrDupToAnsi(ageInfo.GetAgeInstanceName()); fAgeName = StrDupToAnsi(ageInfo.GetAgeInstanceName());
node->UnRef();
return fAgeName; return fAgeName;
} }
plUUID pyDniInfoSource::GetAgeGuid( void ) const plUUID pyDniInfoSource::GetAgeGuid( void ) const
{ {
if (RelVaultNode * node = VaultGetAgeInfoNodeIncRef()) if (hsRef<RelVaultNode> node = VaultGetAgeInfoNode())
{ {
VaultAgeInfoNode ageInfo(node); VaultAgeInfoNode ageInfo(node);
plUUID uuid = ageInfo.GetAgeInstanceGuid(); return ageInfo.GetAgeInstanceGuid();
node->UnRef();
return uuid;
} }
return kNilUuid; return kNilUuid;

12
Sources/Plasma/FeatureLib/pfPython/pyGameScore.cpp

@ -125,11 +125,10 @@ void pyGameScore::SetPoints(int32_t numPoints, pyKey& rcvr)
void pyGameScore::CreateAgeScore(const plString& name, uint32_t type, int32_t points, pyKey& rcvr) void pyGameScore::CreateAgeScore(const plString& name, uint32_t type, int32_t points, pyKey& rcvr)
{ {
if (RelVaultNode* ageInfo = VaultGetAgeInfoNodeIncRef()) if (hsRef<RelVaultNode> ageInfo = VaultGetAgeInfoNode())
{ {
uint32_t ownerId = ageInfo->GetNodeId(); uint32_t ownerId = ageInfo->GetNodeId();
pfGameScore::Create(ownerId, name, type, points, rcvr.getKey()); pfGameScore::Create(ownerId, name, type, points, rcvr.getKey());
ageInfo->UnRef();
} else } else
hsAssert(false, "Age has no vault... Need to rewrite score python script?"); hsAssert(false, "Age has no vault... Need to rewrite score python script?");
} }
@ -141,11 +140,10 @@ void pyGameScore::CreateGlobalScore(const plString& name, uint32_t type, int32_t
void pyGameScore::CreatePlayerScore(const plString& name, uint32_t type, int32_t points, pyKey& rcvr) void pyGameScore::CreatePlayerScore(const plString& name, uint32_t type, int32_t points, pyKey& rcvr)
{ {
if (RelVaultNode* node = VaultGetPlayerInfoNodeIncRef()) if (hsRef<RelVaultNode> node = VaultGetPlayerInfoNode())
{ {
uint32_t ownerId = node->GetNodeId(); uint32_t ownerId = node->GetNodeId();
pfGameScore::Create(ownerId, name, type, points, rcvr.getKey()); pfGameScore::Create(ownerId, name, type, points, rcvr.getKey());
node->UnRef();
} else } else
hsAssert(false, "No PlayerInfo node... Need to rewrite python script?"); hsAssert(false, "No PlayerInfo node... Need to rewrite python script?");
} }
@ -157,11 +155,10 @@ void pyGameScore::CreateScore(uint32_t ownerId, const plString& name, uint32_t t
void pyGameScore::FindAgeScores(const plString& name, pyKey& rcvr) void pyGameScore::FindAgeScores(const plString& name, pyKey& rcvr)
{ {
if (RelVaultNode* ageInfo = VaultGetAgeInfoNodeIncRef()) if (hsRef<RelVaultNode> ageInfo = VaultGetAgeInfoNode())
{ {
uint32_t ownerId = ageInfo->GetNodeId(); uint32_t ownerId = ageInfo->GetNodeId();
pfGameScore::Find(ownerId, name, rcvr.getKey()); pfGameScore::Find(ownerId, name, rcvr.getKey());
ageInfo->UnRef();
} else } else
hsAssert(false, "Age has no vault... Need to rewrite score python script?"); hsAssert(false, "Age has no vault... Need to rewrite score python script?");
} }
@ -173,11 +170,10 @@ void pyGameScore::FindGlobalScores(const plString& name, pyKey& rcvr)
void pyGameScore::FindPlayerScores(const plString& name, pyKey& rcvr) void pyGameScore::FindPlayerScores(const plString& name, pyKey& rcvr)
{ {
if (RelVaultNode* node = VaultGetPlayerInfoNodeIncRef()) if (hsRef<RelVaultNode> node = VaultGetPlayerInfoNode())
{ {
uint32_t ownerId = node->GetNodeId(); uint32_t ownerId = node->GetNodeId();
pfGameScore::Find(ownerId, name, rcvr.getKey()); pfGameScore::Find(ownerId, name, rcvr.getKey());
node->UnRef();
} }
else else
hsAssert(false, "No PlayerInfo node.. Need to rewrite python script?"); hsAssert(false, "No PlayerInfo node.. Need to rewrite python script?");

2
Sources/Plasma/FeatureLib/pfPython/pyNetServerSessionInfo.h

@ -62,7 +62,7 @@ private:
protected: protected:
pyNetServerSessionInfo() {} pyNetServerSessionInfo() {}
pyNetServerSessionInfo( const plNetServerSessionInfo & info ): fInfo( info ) {} pyNetServerSessionInfo(const plNetServerSessionInfo & info) { fInfo.CopyFrom(&info); }
public: public:
// required functions for PyObject interoperability // required functions for PyObject interoperability

4
Sources/Plasma/FeatureLib/pfPython/pyNetServerSessionInfoGlue.cpp

@ -193,7 +193,7 @@ PYTHON_CLASS_NEW_IMPL(ptNetServerSessionInfo, pyNetServerSessionInfo)
PyObject *pyNetServerSessionInfo::New(const plNetServerSessionInfo &info) PyObject *pyNetServerSessionInfo::New(const plNetServerSessionInfo &info)
{ {
ptNetServerSessionInfo *newObj = (ptNetServerSessionInfo*)ptNetServerSessionInfo_type.tp_new(&ptNetServerSessionInfo_type, NULL, NULL); ptNetServerSessionInfo *newObj = (ptNetServerSessionInfo*)ptNetServerSessionInfo_type.tp_new(&ptNetServerSessionInfo_type, NULL, NULL);
newObj->fThis->fInfo = info; newObj->fThis->fInfo.CopyFrom(&info);
return (PyObject*)newObj; return (PyObject*)newObj;
} }
@ -354,7 +354,7 @@ PLASMA_DEFAULT_TYPE(ptNetServerSessionInfoRef, "Basic server session info class"
PyObject *pyNetServerSessionInfoRef::New(plNetServerSessionInfo &info) PyObject *pyNetServerSessionInfoRef::New(plNetServerSessionInfo &info)
{ {
ptNetServerSessionInfoRef *newObj = (ptNetServerSessionInfoRef*)ptNetServerSessionInfoRef_type.tp_new(&ptNetServerSessionInfoRef_type, NULL, NULL); ptNetServerSessionInfoRef *newObj = (ptNetServerSessionInfoRef*)ptNetServerSessionInfoRef_type.tp_new(&ptNetServerSessionInfoRef_type, NULL, NULL);
newObj->fThis->fInfo = info; newObj->fThis->fInfo.CopyFrom(&info);
return (PyObject*)newObj; return (PyObject*)newObj;
} }

144
Sources/Plasma/FeatureLib/pfPython/pyVault.cpp

@ -81,12 +81,9 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
//============================================================================ //============================================================================
static PyObject * GetFolder (unsigned folderType) { static PyObject * GetFolder (unsigned folderType) {
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef()) { if (hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode()) {
if (RelVaultNode * rvnFldr = rvnPlr->GetChildFolderNodeIncRef(folderType, 1)) { if (hsRef<RelVaultNode> rvnFldr = rvnPlr->GetChildFolderNode(folderType, 1))
result = pyVaultFolderNode::New(rvnFldr); result = pyVaultFolderNode::New(rvnFldr);
rvnFldr->UnRef();
}
rvnPlr->UnRef();
} }
return result; return result;
@ -95,12 +92,9 @@ static PyObject * GetFolder (unsigned folderType) {
//============================================================================ //============================================================================
static PyObject * GetPlayerInfoList (unsigned folderType) { static PyObject * GetPlayerInfoList (unsigned folderType) {
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef()) { if (hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode()) {
if (RelVaultNode * rvnFldr = rvnPlr->GetChildPlayerInfoListNodeIncRef(folderType, 1)) { if (hsRef<RelVaultNode> rvnFldr = rvnPlr->GetChildPlayerInfoListNode(folderType, 1))
result = pyVaultPlayerInfoListNode::New(rvnFldr); result = pyVaultPlayerInfoListNode::New(rvnFldr);
rvnFldr->UnRef();
}
rvnPlr->UnRef();
} }
return result; return result;
@ -109,12 +103,9 @@ static PyObject * GetPlayerInfoList (unsigned folderType) {
//============================================================================ //============================================================================
static PyObject * GetAgeInfoList (unsigned folderType) { static PyObject * GetAgeInfoList (unsigned folderType) {
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef()) { if (hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode()) {
if (RelVaultNode * rvnFldr = rvnPlr->GetChildAgeInfoListNodeIncRef(folderType, 1)) { if (hsRef<RelVaultNode> rvnFldr = rvnPlr->GetChildAgeInfoListNode(folderType, 1))
result = pyVaultAgeInfoListNode::New(rvnFldr); result = pyVaultAgeInfoListNode::New(rvnFldr);
rvnFldr->UnRef();
}
rvnPlr->UnRef();
} }
return result; return result;
@ -124,12 +115,9 @@ static PyObject * GetAgeInfoList (unsigned folderType) {
PyObject* pyVault::GetPlayerInfo() PyObject* pyVault::GetPlayerInfo()
{ {
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef()) { if (hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode()) {
if (RelVaultNode * rvnPlrInfo = rvnPlr->GetChildNodeIncRef(plVault::kNodeType_PlayerInfo, 1)) { if (hsRef<RelVaultNode> rvnPlrInfo = rvnPlr->GetChildNode(plVault::kNodeType_PlayerInfo, 1))
result = pyVaultPlayerInfoNode::New(rvnPlrInfo); result = pyVaultPlayerInfoNode::New(rvnPlrInfo);
rvnPlrInfo->UnRef();
}
rvnPlr->UnRef();
} }
// just return an empty node // just return an empty node
@ -208,36 +196,30 @@ PyObject* pyVault::GetKIUsage(void)
uint32_t markerGames = 0; uint32_t markerGames = 0;
for (;;) { for (;;) {
RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef(); hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode();
if (!rvnPlr) if (!rvnPlr)
break; break;
for (;;) { for (;;) {
RelVaultNode * rvnAgeJrnlz = rvnPlr->GetChildFolderNodeIncRef(plVault::kAgeJournalsFolder, 1); hsRef<RelVaultNode> rvnAgeJrnlz = rvnPlr->GetChildFolderNode(plVault::kAgeJournalsFolder, 1);
if (!rvnAgeJrnlz) if (!rvnAgeJrnlz)
break; break;
// Get child nodes up to two levels deep // Get child nodes up to two levels deep
ARRAY(RelVaultNode*) nodeArr; RelVaultNode::RefList nodeArr;
rvnAgeJrnlz->GetChildNodesIncRef(2, &nodeArr); rvnAgeJrnlz->GetChildNodes(2, &nodeArr);
RelVaultNode ** cur = nodeArr.Ptr(); for (const hsRef<RelVaultNode> &rvn : nodeArr) {
RelVaultNode ** end = nodeArr.Term();
for (; cur != end; ++cur) {
RelVaultNode * rvn = *cur;
if (rvn->GetNodeType() == plVault::kNodeType_Image) if (rvn->GetNodeType() == plVault::kNodeType_Image)
++pictures; ++pictures;
else if (rvn->GetNodeType() == plVault::kNodeType_TextNote) else if (rvn->GetNodeType() == plVault::kNodeType_TextNote)
++notes; ++notes;
else if (rvn->GetNodeType() == plVault::kNodeType_MarkerGame) else if (rvn->GetNodeType() == plVault::kNodeType_MarkerGame)
++markerGames; ++markerGames;
rvn->UnRef();
} }
rvnAgeJrnlz->UnRef();
break; break;
} }
rvnPlr->UnRef();
break; break;
} }
@ -303,11 +285,8 @@ PyObject* pyVault::GetLinkToMyNeighborhood() const
plAgeInfoStruct info; plAgeInfoStruct info;
info.SetAgeFilename(kNeighborhoodAgeFilename); info.SetAgeFilename(kNeighborhoodAgeFilename);
if (RelVaultNode * rvn = VaultGetOwnedAgeLinkIncRef(&info)) { if (hsRef<RelVaultNode> rvn = VaultGetOwnedAgeLink(&info))
PyObject * result = pyVaultAgeLinkNode::New(rvn); return pyVaultAgeLinkNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }
@ -317,11 +296,8 @@ PyObject* pyVault::GetLinkToCity() const
plAgeInfoStruct info; plAgeInfoStruct info;
info.SetAgeFilename(kCityAgeFilename); info.SetAgeFilename(kCityAgeFilename);
if (RelVaultNode * rvn = VaultGetOwnedAgeLinkIncRef(&info)) { if (hsRef<RelVaultNode> rvn = VaultGetOwnedAgeLink(&info))
PyObject * result = pyVaultAgeLinkNode::New(rvn); return pyVaultAgeLinkNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }
@ -330,11 +306,8 @@ PyObject* pyVault::GetLinkToCity() const
// Owned ages // Owned ages
PyObject* pyVault::GetOwnedAgeLink( const pyAgeInfoStruct & info ) PyObject* pyVault::GetOwnedAgeLink( const pyAgeInfoStruct & info )
{ {
if (RelVaultNode * rvnLink = VaultGetOwnedAgeLinkIncRef(info.GetAgeInfo())) { if (hsRef<RelVaultNode> rvnLink = VaultGetOwnedAgeLink(info.GetAgeInfo()))
PyObject * result = pyVaultAgeLinkNode::New(rvnLink); return pyVaultAgeLinkNode::New(rvnLink);
rvnLink->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -343,11 +316,8 @@ PyObject* pyVault::GetOwnedAgeLink( const pyAgeInfoStruct & info )
// Visit ages // Visit ages
PyObject* pyVault::GetVisitAgeLink( const pyAgeInfoStruct & info) PyObject* pyVault::GetVisitAgeLink( const pyAgeInfoStruct & info)
{ {
if (RelVaultNode * rvnLink = VaultGetVisitAgeLinkIncRef(info.GetAgeInfo())) { if (hsRef<RelVaultNode> rvnLink = VaultGetVisitAgeLink(info.GetAgeInfo()))
PyObject * result = pyVaultAgeLinkNode::New(rvnLink); return pyVaultAgeLinkNode::New(rvnLink);
rvnLink->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -361,11 +331,8 @@ PyObject* pyVault::FindChronicleEntry( const char * entryName )
wchar_t wEntryName[kMaxVaultNodeStringLength]; wchar_t wEntryName[kMaxVaultNodeStringLength];
StrToUnicode(wEntryName, entryName, arrsize(wEntryName)); StrToUnicode(wEntryName, entryName, arrsize(wEntryName));
if (RelVaultNode * rvn = VaultFindChronicleEntryIncRef(wEntryName)) { if (hsRef<RelVaultNode> rvn = VaultFindChronicleEntry(wEntryName))
PyObject * result = pyVaultChronicleNode::New(rvn); return pyVaultChronicleNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object // just return a None object
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -441,10 +408,9 @@ PyObject* pyVault::GetInviteFolder()
PyObject* pyVault::GetPsnlAgeSDL() const PyObject* pyVault::GetPsnlAgeSDL() const
{ {
PyObject * result = nil; PyObject * result = nil;
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
if (RelVaultNode * rvnFldr = VaultGetAgesIOwnFolderIncRef()) { if (hsRef<RelVaultNode> rvnFldr = VaultGetAgesIOwnFolder()) {
templateNode->ClearFieldFlags(); templateNode->ClearFieldFlags();
templateNode->SetNodeType(plVault::kNodeType_AgeInfo); templateNode->SetNodeType(plVault::kNodeType_AgeInfo);
@ -453,27 +419,22 @@ PyObject* pyVault::GetPsnlAgeSDL() const
StrToUnicode(str, kPersonalAgeFilename, arrsize(str)); StrToUnicode(str, kPersonalAgeFilename, arrsize(str));
ageInfo.SetAgeFilename(str); ageInfo.SetAgeFilename(str);
if (RelVaultNode * rvnInfo = rvnFldr->GetChildNodeIncRef(templateNode, 2)) { if (hsRef<RelVaultNode> rvnInfo = rvnFldr->GetChildNode(templateNode, 2)) {
templateNode->ClearFieldFlags(); templateNode->ClearFieldFlags();
templateNode->SetNodeType(plVault::kNodeType_SDL); templateNode->SetNodeType(plVault::kNodeType_SDL);
if (RelVaultNode * rvnSdl = rvnInfo->GetChildNodeIncRef(templateNode, 1)) { if (hsRef<RelVaultNode> rvnSdl = rvnInfo->GetChildNode(templateNode, 1)) {
VaultSDLNode sdl(rvnSdl); VaultSDLNode sdl(rvnSdl);
plStateDataRecord * rec = new plStateDataRecord; plStateDataRecord * rec = new plStateDataRecord;
if (sdl.GetStateDataRecord(rec, plSDL::kKeepDirty)) if (sdl.GetStateDataRecord(rec, plSDL::kKeepDirty))
result = pySDLStateDataRecord::New(rec); result = pySDLStateDataRecord::New(rec);
else else
delete rec; delete rec;
rvnSdl->UnRef();
} }
rvnInfo->UnRef();
} }
rvnFldr->UnRef();
} }
templateNode->UnRef();
if (!result) if (!result)
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
@ -486,10 +447,9 @@ void pyVault::UpdatePsnlAgeSDL( pySDLStateDataRecord & pyrec )
if ( !rec ) if ( !rec )
return; return;
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
if (RelVaultNode * rvnFldr = VaultGetAgesIOwnFolderIncRef()) { if (hsRef<RelVaultNode> rvnFldr = VaultGetAgesIOwnFolder()) {
templateNode->ClearFieldFlags(); templateNode->ClearFieldFlags();
templateNode->SetNodeType(plVault::kNodeType_AgeInfo); templateNode->SetNodeType(plVault::kNodeType_AgeInfo);
@ -498,22 +458,17 @@ void pyVault::UpdatePsnlAgeSDL( pySDLStateDataRecord & pyrec )
StrToUnicode(str, kPersonalAgeFilename, arrsize(str)); StrToUnicode(str, kPersonalAgeFilename, arrsize(str));
ageInfo.SetAgeFilename(str); ageInfo.SetAgeFilename(str);
if (RelVaultNode * rvnInfo = rvnFldr->GetChildNodeIncRef(templateNode, 2)) { if (hsRef<RelVaultNode> rvnInfo = rvnFldr->GetChildNode(templateNode, 2)) {
templateNode->ClearFieldFlags(); templateNode->ClearFieldFlags();
templateNode->SetNodeType(plVault::kNodeType_SDL); templateNode->SetNodeType(plVault::kNodeType_SDL);
if (RelVaultNode * rvnSdl = rvnInfo->GetChildNodeIncRef(templateNode, 1)) { if (hsRef<RelVaultNode> rvnSdl = rvnInfo->GetChildNode(templateNode, 1)) {
VaultSDLNode sdl(rvnSdl); VaultSDLNode sdl(rvnSdl);
sdl.SetStateDataRecord(rec, plSDL::kDirtyOnly | plSDL::kTimeStampOnRead); sdl.SetStateDataRecord(rec, plSDL::kDirtyOnly | plSDL::kTimeStampOnRead);
rvnSdl->UnRef();
} }
rvnInfo->UnRef();
} }
rvnFldr->UnRef();
} }
templateNode->UnRef();
} }
bool pyVault::InMyPersonalAge() const bool pyVault::InMyPersonalAge() const
@ -599,14 +554,12 @@ void _InvitePlayerToAge(ENetError result, void* state, void* param, RelVaultNode
void pyVault::InvitePlayerToAge( const pyAgeLinkStruct & link, uint32_t playerID ) void pyVault::InvitePlayerToAge( const pyAgeLinkStruct & link, uint32_t playerID )
{ {
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_TextNote); templateNode->SetNodeType(plVault::kNodeType_TextNote);
VaultTextNoteNode visitAcc(templateNode); VaultTextNoteNode visitAcc(templateNode);
visitAcc.SetNoteType(plVault::kNoteType_Visit); visitAcc.SetNoteType(plVault::kNoteType_Visit);
visitAcc.SetVisitInfo(*link.GetAgeLink()->GetAgeInfo()); visitAcc.SetVisitInfo(*link.GetAgeLink()->GetAgeInfo());
VaultCreateNode(templateNode, (FVaultCreateNodeCallback)_InvitePlayerToAge, nil, (void*)playerID); VaultCreateNode(templateNode, (FVaultCreateNodeCallback)_InvitePlayerToAge, nil, (void*)playerID);
templateNode->UnRef();
} }
//============================================================================ //============================================================================
@ -622,24 +575,19 @@ void pyVault::UnInvitePlayerToAge( const char * str, uint32_t playerID )
plUUID guid(str); plUUID guid(str);
info.SetAgeInstanceGuid(&guid); info.SetAgeInstanceGuid(&guid);
if (RelVaultNode * rvnLink = VaultGetOwnedAgeLinkIncRef(&info)) { if (hsRef<RelVaultNode> rvnLink = VaultGetOwnedAgeLink(&info)) {
if (RelVaultNode * rvnInfo = rvnLink->GetChildNodeIncRef(plVault::kNodeType_AgeInfo, 1)) { if (hsRef<RelVaultNode> rvnInfo = rvnLink->GetChildNode(plVault::kNodeType_AgeInfo, 1)) {
VaultAgeInfoNode ageInfo(rvnInfo); VaultAgeInfoNode ageInfo(rvnInfo);
ageInfo.CopyTo(&info); ageInfo.CopyTo(&info);
rvnInfo->UnRef();
} }
rvnLink->UnRef();
} }
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_TextNote); templateNode->SetNodeType(plVault::kNodeType_TextNote);
VaultTextNoteNode visitAcc(templateNode); VaultTextNoteNode visitAcc(templateNode);
visitAcc.SetNoteType(plVault::kNoteType_UnVisit); visitAcc.SetNoteType(plVault::kNoteType_UnVisit);
visitAcc.SetVisitInfo(info); visitAcc.SetVisitInfo(info);
VaultCreateNode(templateNode, (FVaultCreateNodeCallback)_UninvitePlayerToAge, nil, (void*)playerID); VaultCreateNode(templateNode, (FVaultCreateNodeCallback)_UninvitePlayerToAge, nil, (void*)playerID);
templateNode->UnRef();
} }
//============================================================================ //============================================================================
@ -696,12 +644,8 @@ bool pyVault::SetAgePublic( const pyAgeInfoStruct * ageInfo, bool makePublic )
PyObject* pyVault::GetGlobalInbox() PyObject* pyVault::GetGlobalInbox()
{ {
PyObject * result = nil; if (hsRef<RelVaultNode> rvnGlobalInbox = VaultGetGlobalInbox())
if (RelVaultNode * rvnGlobalInbox = VaultGetGlobalInboxIncRef()) { return pyVaultFolderNode::New(rvnGlobalInbox);
result = pyVaultFolderNode::New(rvnGlobalInbox);
rvnGlobalInbox->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }
@ -712,11 +656,8 @@ PyObject* pyVault::GetGlobalInbox()
PyObject* pyVault::FindNode( pyVaultNode* templateNode ) const PyObject* pyVault::FindNode( pyVaultNode* templateNode ) const
{ {
// See if we already have a matching node locally // See if we already have a matching node locally
if (RelVaultNode * rvn = VaultGetNodeIncRef(templateNode->GetNode())) { if (hsRef<RelVaultNode> rvn = VaultGetNode(templateNode->GetNode()))
PyObject * result = pyVaultNode::New(rvn); return pyVaultNode::New(rvn);
rvn->UnRef();
return result;
}
// See if a matching node exists on the server // See if a matching node exists on the server
ARRAY(unsigned) nodeIds; ARRAY(unsigned) nodeIds;
@ -726,11 +667,8 @@ PyObject* pyVault::FindNode( pyVaultNode* templateNode ) const
// Only fetch the first matching node since this function returns a single node // Only fetch the first matching node since this function returns a single node
VaultFetchNodesAndWait(&nodeIds[0], 1); VaultFetchNodesAndWait(&nodeIds[0], 1);
// If we fetched it successfully then it'll be in our local node cache now // If we fetched it successfully then it'll be in our local node cache now
if (RelVaultNode * rvn = VaultGetNodeIncRef(nodeIds[0])) { if (hsRef<RelVaultNode> rvn = VaultGetNode(nodeIds[0]))
PyObject * result = pyVaultNode::New(rvn); return pyVaultNode::New(rvn);
rvn->UnRef();
return result;
}
} }
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;

4
Sources/Plasma/FeatureLib/pfPython/pyVaultAgeInfoListNodeGlue.cpp

@ -111,11 +111,7 @@ PLASMA_DEFAULT_TYPE_WBASE(ptVaultAgeInfoListNode, pyVaultFolderNode, "Params: n=
PyObject *pyVaultAgeInfoListNode::New(RelVaultNode* nfsNode) PyObject *pyVaultAgeInfoListNode::New(RelVaultNode* nfsNode)
{ {
ptVaultAgeInfoListNode *newObj = (ptVaultAgeInfoListNode*)ptVaultAgeInfoListNode_type.tp_new(&ptVaultAgeInfoListNode_type, NULL, NULL); ptVaultAgeInfoListNode *newObj = (ptVaultAgeInfoListNode*)ptVaultAgeInfoListNode_type.tp_new(&ptVaultAgeInfoListNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

15
Sources/Plasma/FeatureLib/pfPython/pyVaultAgeInfoNode.cpp

@ -89,20 +89,16 @@ static PyObject * GetChildFolder (RelVaultNode * node, unsigned type) {
//============================================================================ //============================================================================
static PyObject * GetChildPlayerInfoList (RelVaultNode * node, unsigned type) { static PyObject * GetChildPlayerInfoList (RelVaultNode * node, unsigned type) {
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvn = node->GetChildPlayerInfoListNodeIncRef(type, 1)) { if (hsRef<RelVaultNode> rvn = node->GetChildPlayerInfoListNode(type, 1))
result = pyVaultPlayerInfoListNode::New(rvn); result = pyVaultPlayerInfoListNode::New(rvn);
rvn->UnRef();
}
return result; return result;
} }
//============================================================================ //============================================================================
static PyObject * GetChildAgeInfoList (RelVaultNode * node, unsigned type) { static PyObject * GetChildAgeInfoList (RelVaultNode * node, unsigned type) {
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvn = node->GetChildAgeInfoListNodeIncRef(type, 1)) { if (hsRef<RelVaultNode> rvn = node->GetChildAgeInfoListNode(type, 1))
result = pyVaultAgeInfoListNode::New(rvn); result = pyVaultAgeInfoListNode::New(rvn);
rvn->UnRef();
}
return result; return result;
} }
@ -173,11 +169,8 @@ PyObject * pyVaultAgeInfoNode::GetParentAgeLink () const
if (!fNode) if (!fNode)
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
if (RelVaultNode * rvn = fNode->GetParentAgeLinkIncRef()) { if (hsRef<RelVaultNode> rvn = fNode->GetParentAgeLink())
PyObject * result = pyVaultAgeLinkNode::New(rvn); return pyVaultAgeLinkNode::New(rvn);
rvn->UnRef();
return result;
}
// just return a None object. // just return a None object.
PYTHON_RETURN_NONE PYTHON_RETURN_NONE

4
Sources/Plasma/FeatureLib/pfPython/pyVaultAgeInfoNodeGlue.cpp

@ -287,11 +287,7 @@ PLASMA_DEFAULT_TYPE_WBASE(ptVaultAgeInfoNode, pyVaultNode, "Params: n=0\nPlasma
PyObject *pyVaultAgeInfoNode::New(RelVaultNode* nfsNode) PyObject *pyVaultAgeInfoNode::New(RelVaultNode* nfsNode)
{ {
ptVaultAgeInfoNode *newObj = (ptVaultAgeInfoNode*)ptVaultAgeInfoNode_type.tp_new(&ptVaultAgeInfoNode_type, NULL, NULL); ptVaultAgeInfoNode *newObj = (ptVaultAgeInfoNode*)ptVaultAgeInfoNode_type.tp_new(&ptVaultAgeInfoNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultAgeLinkNode.cpp

@ -82,10 +82,8 @@ PyObject* pyVaultAgeLinkNode::GetAgeInfo() const
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvn = fNode->GetChildNodeIncRef(plVault::kNodeType_AgeInfo, 1)) { if (hsRef<RelVaultNode> rvn = fNode->GetChildNode(plVault::kNodeType_AgeInfo, 1))
result = pyVaultAgeInfoNode::New(rvn); result = pyVaultAgeInfoNode::New(rvn);
rvn->UnRef();
}
if (result) if (result)
return result; return result;

4
Sources/Plasma/FeatureLib/pfPython/pyVaultAgeLinkNodeGlue.cpp

@ -200,11 +200,7 @@ PLASMA_DEFAULT_TYPE_WBASE(ptVaultAgeLinkNode, pyVaultNode, "Params: n=0\nPlasma
PyObject *pyVaultAgeLinkNode::New(RelVaultNode* nfsNode) PyObject *pyVaultAgeLinkNode::New(RelVaultNode* nfsNode)
{ {
ptVaultAgeLinkNode *newObj = (ptVaultAgeLinkNode*)ptVaultAgeLinkNode_type.tp_new(&ptVaultAgeLinkNode_type, NULL, NULL); ptVaultAgeLinkNode *newObj = (ptVaultAgeLinkNode*)ptVaultAgeLinkNode_type.tp_new(&ptVaultAgeLinkNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultChronicleNodeGlue.cpp

@ -190,11 +190,7 @@ PLASMA_DEFAULT_TYPE_WBASE(ptVaultChronicleNode, pyVaultNode, "Params: n=0\nPlasm
PyObject *pyVaultChronicleNode::New(RelVaultNode* nfsNode) PyObject *pyVaultChronicleNode::New(RelVaultNode* nfsNode)
{ {
ptVaultChronicleNode *newObj = (ptVaultChronicleNode*)ptVaultChronicleNode_type.tp_new(&ptVaultChronicleNode_type, NULL, NULL); ptVaultChronicleNode *newObj = (ptVaultChronicleNode*)ptVaultChronicleNode_type.tp_new(&ptVaultChronicleNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultFolderNodeGlue.cpp

@ -191,11 +191,7 @@ PYTHON_EXPOSE_TYPE_DEFINITION(ptVaultFolderNode, pyVaultFolderNode);
PyObject *pyVaultFolderNode::New(RelVaultNode* nfsNode) PyObject *pyVaultFolderNode::New(RelVaultNode* nfsNode)
{ {
ptVaultFolderNode *newObj = (ptVaultFolderNode*)ptVaultFolderNode_type.tp_new(&ptVaultFolderNode_type, NULL, NULL); ptVaultFolderNode *newObj = (ptVaultFolderNode*)ptVaultFolderNode_type.tp_new(&ptVaultFolderNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultImageNodeGlue.cpp

@ -219,11 +219,7 @@ PLASMA_DEFAULT_TYPE_WBASE(ptVaultImageNode, pyVaultNode, "Params: n=0\nPlasma va
PyObject *pyVaultImageNode::New(RelVaultNode* nfsNode) PyObject *pyVaultImageNode::New(RelVaultNode* nfsNode)
{ {
ptVaultImageNode *newObj = (ptVaultImageNode*)ptVaultImageNode_type.tp_new(&ptVaultImageNode_type, NULL, NULL); ptVaultImageNode *newObj = (ptVaultImageNode*)ptVaultImageNode_type.tp_new(&ptVaultImageNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultMarkerGameNodeGlue.cpp

@ -114,11 +114,7 @@ PLASMA_DEFAULT_TYPE_WBASE(ptVaultMarkerGameNode, pyVaultNode, "Params: n=0\nPlas
PyObject *pyVaultMarkerGameNode::New(RelVaultNode* nfsNode) PyObject *pyVaultMarkerGameNode::New(RelVaultNode* nfsNode)
{ {
ptVaultMarkerGameNode *newObj = (ptVaultMarkerGameNode*)ptVaultMarkerGameNode_type.tp_new(&ptVaultMarkerGameNode_type, NULL, NULL); ptVaultMarkerGameNode *newObj = (ptVaultMarkerGameNode*)ptVaultMarkerGameNode_type.tp_new(&ptVaultMarkerGameNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

92
Sources/Plasma/FeatureLib/pfPython/pyVaultNode.cpp

@ -94,7 +94,6 @@ static void CDECL LogDumpProc (
pyVaultNode::pyVaultNodeOperationCallback::pyVaultNodeOperationCallback(PyObject * cbObject) pyVaultNode::pyVaultNodeOperationCallback::pyVaultNodeOperationCallback(PyObject * cbObject)
: fCbObject( cbObject ) : fCbObject( cbObject )
, fNode(nil)
, fPyNodeRef(nil) , fPyNodeRef(nil)
, fContext(0) , fContext(0)
{ {
@ -158,21 +157,16 @@ void pyVaultNode::pyVaultNodeOperationCallback::VaultOperationComplete( uint32_t
} }
void pyVaultNode::pyVaultNodeOperationCallback::SetNode (RelVaultNode * rvn) { void pyVaultNode::pyVaultNodeOperationCallback::SetNode (RelVaultNode * rvn) {
if (rvn) fNode = rvn;
rvn->Ref();
SWAP(rvn, fNode);
if (rvn)
rvn->UnRef();
} }
RelVaultNode * pyVaultNode::pyVaultNodeOperationCallback::GetNode () { hsRef<RelVaultNode> pyVaultNode::pyVaultNodeOperationCallback::GetNode() const {
return fNode; return fNode;
} }
// only for python glue, do NOT call // only for python glue, do NOT call
pyVaultNode::pyVaultNode() pyVaultNode::pyVaultNode()
: fNode(nil) : fCreateAgeName(nil)
, fCreateAgeName(nil)
{ {
} }
@ -181,19 +175,15 @@ pyVaultNode::pyVaultNode( RelVaultNode* nfsNode )
: fNode(nfsNode) : fNode(nfsNode)
, fCreateAgeName(nil) , fCreateAgeName(nil)
{ {
if (fNode)
fNode->Ref("pyVaultNode");
} }
pyVaultNode::~pyVaultNode() pyVaultNode::~pyVaultNode()
{ {
if (fNode)
fNode->UnRef("pyVaultNode");
free(fCreateAgeName); free(fCreateAgeName);
} }
RelVaultNode* pyVaultNode::GetNode() const hsRef<RelVaultNode> pyVaultNode::GetNode() const
{ {
return fNode; return fNode;
} }
@ -202,8 +192,8 @@ RelVaultNode* pyVaultNode::GetNode() const
// override the equals to operator // override the equals to operator
bool pyVaultNode::operator==(const pyVaultNode &vaultNode) const bool pyVaultNode::operator==(const pyVaultNode &vaultNode) const
{ {
RelVaultNode* ours = GetNode(); hsRef<RelVaultNode> ours = GetNode();
RelVaultNode* theirs = vaultNode.GetNode(); hsRef<RelVaultNode> theirs = vaultNode.GetNode();
if (ours == nil && theirs == nil) if (ours == nil && theirs == nil)
return true; return true;
if (ours == nil || theirs == nil) if (ours == nil || theirs == nil)
@ -270,17 +260,13 @@ PyObject* pyVaultNode::GetCreatorNode( void )
PyObject * result = nil; PyObject * result = nil;
if (fNode) if (fNode)
{ {
RelVaultNode * templateNode = new RelVaultNode; hsRef<RelVaultNode> templateNode = new RelVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_PlayerInfo); templateNode->SetNodeType(plVault::kNodeType_PlayerInfo);
VaultPlayerInfoNode plrInfo(templateNode); VaultPlayerInfoNode plrInfo(templateNode);
plrInfo.SetPlayerId(fNode->GetCreatorId()); plrInfo.SetPlayerId(fNode->GetCreatorId());
if (RelVaultNode * rvn = VaultGetNodeIncRef(templateNode)) { if (hsRef<RelVaultNode> rvn = VaultGetNode(templateNode))
result = pyVaultPlayerInfoNode::New(rvn); result = pyVaultPlayerInfoNode::New(rvn);
rvn->UnRef();
}
templateNode->UnRef();
} }
if (result) if (result)
@ -417,20 +403,16 @@ PyObject* pyVaultNode::AddNode(pyVaultNode* pynode, PyObject* cbObject, uint32_t
// Block here until node is created and fetched =( // Block here until node is created and fetched =(
ASSERT(pynode->GetNode()->GetNodeType()); ASSERT(pynode->GetNode()->GetNodeType());
ENetError result; ENetError result;
RelVaultNode * newNode = VaultCreateNodeAndWaitIncRef( hsRef<RelVaultNode> newNode = VaultCreateNodeAndWait(
pynode->GetNode(), pynode->GetNode(),
&result &result
); );
if (newNode) { if (newNode)
newNode->Ref();
pynode->fNode->UnRef();
pynode->fNode = newNode; pynode->fNode = newNode;
} else
else {
hsResult = hsFail; hsResult = hsFail;
} }
}
PyObject* nodeRef = cb->fPyNodeRef = pyVaultNodeRef::New(fNode, pynode->fNode); PyObject* nodeRef = cb->fPyNodeRef = pyVaultNodeRef::New(fNode, pynode->fNode);
Py_INCREF(nodeRef); // The callback steals the ref, according to Eric... Py_INCREF(nodeRef); // The callback steals the ref, according to Eric...
@ -468,10 +450,9 @@ void pyVaultNode::LinkToNode(int nodeID, PyObject* cbObject, uint32_t cbContext)
// Hack the callbacks until vault notification is in place // Hack the callbacks until vault notification is in place
cb->VaultOperationStarted( cbContext ); cb->VaultOperationStarted( cbContext );
if (RelVaultNode * rvn = VaultGetNodeIncRef(nodeID)) { if (hsRef<RelVaultNode> rvn = VaultGetNode(nodeID)) {
cb->SetNode(rvn); cb->SetNode(rvn);
cb->fPyNodeRef = pyVaultNodeRef::New(fNode, rvn); cb->fPyNodeRef = pyVaultNodeRef::New(fNode, rvn);
rvn->UnRef();
} }
VaultAddChildNode(fNode->GetNodeId(), VaultAddChildNode(fNode->GetNodeId(),
@ -535,11 +516,9 @@ void pyVaultNode::Save(PyObject* cbObject, uint32_t cbContext)
// otherwise just ignore the save request since vault nodes are now auto-saved. // otherwise just ignore the save request since vault nodes are now auto-saved.
if (!fNode->GetNodeId() && fNode->GetNodeType()) { if (!fNode->GetNodeId() && fNode->GetNodeType()) {
ENetError result; ENetError result;
if (RelVaultNode * node = VaultCreateNodeAndWaitIncRef(fNode, &result)) { if (hsRef<RelVaultNode> node = VaultCreateNodeAndWait(fNode, &result))
fNode->UnRef();
fNode = node; fNode = node;
} }
}
pyVaultNodeOperationCallback * cb = new pyVaultNodeOperationCallback( cbObject ); pyVaultNodeOperationCallback * cb = new pyVaultNodeOperationCallback( cbObject );
cb->SetNode(fNode); cb->SetNode(fNode);
cb->VaultOperationStarted( cbContext ); cb->VaultOperationStarted( cbContext );
@ -559,11 +538,9 @@ void pyVaultNode::ForceSave()
{ {
if (!fNode->GetNodeId() && fNode->GetNodeType()) { if (!fNode->GetNodeId() && fNode->GetNodeType()) {
ENetError result; ENetError result;
if (RelVaultNode * node = VaultCreateNodeAndWaitIncRef(fNode, &result)) { if (hsRef<RelVaultNode> node = VaultCreateNodeAndWait(fNode, &result))
fNode->UnRef();
fNode = node; fNode = node;
} }
}
else else
VaultForceSaveNodeAndWait(fNode); VaultForceSaveNodeAndWait(fNode);
} }
@ -578,11 +555,9 @@ void pyVaultNode::SendTo(uint32_t destClientNodeID, PyObject* cbObject, uint32_t
// If the node doesn't have an id, then use it as a template to create the node in the vault, // If the node doesn't have an id, then use it as a template to create the node in the vault,
if (!fNode->GetNodeId() && fNode->GetNodeType()) { if (!fNode->GetNodeId() && fNode->GetNodeType()) {
ENetError result; ENetError result;
if (RelVaultNode * node = VaultCreateNodeAndWaitIncRef(fNode, &result)) { if (hsRef<RelVaultNode> node = VaultCreateNodeAndWait(fNode, &result))
fNode->UnRef();
fNode = node; fNode = node;
} }
}
// Hack the callbacks until vault notification is in place // Hack the callbacks until vault notification is in place
cb->VaultOperationStarted( cbContext ); cb->VaultOperationStarted( cbContext );
@ -608,17 +583,13 @@ PyObject* pyVaultNode::GetChildNodeRefList()
// fill in the elements list of this folder // fill in the elements list of this folder
if (fNode) if (fNode)
{ {
ARRAY(RelVaultNode*) nodes; RelVaultNode::RefList nodes;
fNode->GetChildNodesIncRef( fNode->GetChildNodes(1, &nodes);
1,
&nodes
);
for (unsigned i = 0; i < nodes.Count(); ++i) { for (const hsRef<RelVaultNode> &node : nodes) {
PyObject* elementObj = pyVaultNodeRef::New(fNode, nodes[i]); PyObject* elementObj = pyVaultNodeRef::New(fNode, node);
PyList_Append(pyEL, elementObj); PyList_Append(pyEL, elementObj);
Py_DECREF(elementObj); Py_DECREF(elementObj);
nodes[i]->UnRef();
} }
} }
@ -656,14 +627,10 @@ PyObject * pyVaultNode::GetNode2( uint32_t nodeID ) const
PyObject * result = nil; PyObject * result = nil;
if ( fNode ) if ( fNode )
{ {
RelVaultNode * templateNode = new RelVaultNode; hsRef<RelVaultNode> templateNode = new RelVaultNode;
templateNode->Ref();
templateNode->SetNodeId(nodeID); templateNode->SetNodeId(nodeID);
if (RelVaultNode * rvn = fNode->GetChildNodeIncRef(templateNode, 1)) { if (hsRef<RelVaultNode> rvn = fNode->GetChildNode(templateNode, 1))
result = pyVaultNodeRef::New(fNode, rvn); result = pyVaultNodeRef::New(fNode, rvn);
rvn->UnRef();
}
templateNode->UnRef();
} }
if (result) if (result)
@ -677,10 +644,8 @@ PyObject* pyVaultNode::FindNode( pyVaultNode * templateNode )
PyObject * result = nil; PyObject * result = nil;
if ( fNode && templateNode->fNode ) if ( fNode && templateNode->fNode )
{ {
if (RelVaultNode * rvn = fNode->GetChildNodeIncRef(templateNode->fNode, 1)) { if (hsRef<RelVaultNode> rvn = fNode->GetChildNode(templateNode->fNode, 1))
result = pyVaultNode::New(rvn); result = pyVaultNode::New(rvn);
rvn->UnRef();
}
} }
if (result) if (result)
@ -694,17 +659,12 @@ PyObject * pyVaultNode::GetChildNode (unsigned nodeId) {
if (!fNode) if (!fNode)
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
RelVaultNode * templateNode = new RelVaultNode; hsRef<RelVaultNode> templateNode = new RelVaultNode;
templateNode->Ref();
templateNode->SetNodeId(nodeId); templateNode->SetNodeId(nodeId);
RelVaultNode * rvn = fNode->GetChildNodeIncRef(templateNode, 1); hsRef<RelVaultNode> rvn = fNode->GetChildNode(templateNode, 1);
templateNode->UnRef();
if (rvn) { if (rvn)
PyObject * result = pyVaultNode::New(rvn); return pyVaultNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }

9
Sources/Plasma/FeatureLib/pfPython/pyVaultNode.h

@ -50,6 +50,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "HeadSpin.h" #include "HeadSpin.h"
#include "pyGlueHelpers.h" #include "pyGlueHelpers.h"
#include "hsRefCnt.h"
struct RelVaultNode; struct RelVaultNode;
class plMipmap; class plMipmap;
@ -82,7 +83,7 @@ public:
struct pyVaultNodeOperationCallback struct pyVaultNodeOperationCallback
{ {
PyObject * fCbObject; PyObject * fCbObject;
RelVaultNode * fNode; hsRef<RelVaultNode> fNode;
PyObject * fPyNodeRef; PyObject * fPyNodeRef;
uint32_t fContext; uint32_t fContext;
@ -94,10 +95,10 @@ public:
void VaultOperationComplete(int resultCode) { VaultOperationComplete(fContext, resultCode); } void VaultOperationComplete(int resultCode) { VaultOperationComplete(fContext, resultCode); }
void SetNode (RelVaultNode * rvn); void SetNode (RelVaultNode * rvn);
RelVaultNode * GetNode (); hsRef<RelVaultNode> GetNode() const;
}; };
RelVaultNode * fNode; hsRef<RelVaultNode> fNode;
mutable char * fCreateAgeName; mutable char * fCreateAgeName;
protected: protected:
@ -118,7 +119,7 @@ public:
static void AddPlasmaClasses(PyObject *m); static void AddPlasmaClasses(PyObject *m);
RelVaultNode * GetNode() const; hsRef<RelVaultNode> GetNode() const;
// override the equals to operator // override the equals to operator
bool operator==(const pyVaultNode &vaultNode) const; bool operator==(const pyVaultNode &vaultNode) const;

4
Sources/Plasma/FeatureLib/pfPython/pyVaultNodeGlue.cpp

@ -541,11 +541,7 @@ PYTHON_EXPOSE_TYPE_DEFINITION(ptVaultNode, pyVaultNode);
PyObject *pyVaultNode::New(RelVaultNode* nfsNode) PyObject *pyVaultNode::New(RelVaultNode* nfsNode)
{ {
ptVaultNode *newObj = (ptVaultNode*)ptVaultNode_type.tp_new(&ptVaultNode_type, NULL, NULL); ptVaultNode *newObj = (ptVaultNode*)ptVaultNode_type.tp_new(&ptVaultNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

38
Sources/Plasma/FeatureLib/pfPython/pyVaultNodeRef.cpp

@ -65,22 +65,20 @@ pyVaultNodeRef::pyVaultNodeRef(RelVaultNode * parent, RelVaultNode * child)
: fParent(parent) : fParent(parent)
, fChild(child) , fChild(child)
{ {
fParent->Ref();
fChild->Ref();
} }
pyVaultNodeRef::pyVaultNodeRef(int) pyVaultNodeRef::pyVaultNodeRef(int)
: fParent(nil)
, fChild(nil)
{ {
} }
pyVaultNodeRef::~pyVaultNodeRef() hsRef<RelVaultNode> pyVaultNodeRef::GetParentNode() const
{ {
if (fParent) return fParent;
fParent->UnRef(); }
if (fChild)
fChild->UnRef(); hsRef<RelVaultNode> pyVaultNodeRef::GetChildNode() const
{
return fChild;
} }
@ -113,10 +111,8 @@ unsigned pyVaultNodeRef::GetSaverID () {
return 0; return 0;
unsigned saverId = 0; unsigned saverId = 0;
if (RelVaultNode * child = VaultGetNodeIncRef(fChild->GetNodeId())) { if (hsRef<RelVaultNode> child = VaultGetNode(fChild->GetNodeId()))
saverId = child->GetRefOwnerId(fParent->GetNodeId()); saverId = child->GetRefOwnerId(fParent->GetNodeId());
child->UnRef();
}
return saverId; return saverId;
} }
@ -124,36 +120,30 @@ PyObject * pyVaultNodeRef::GetSaver () {
if (!fParent || !fChild) if (!fParent || !fChild)
return 0; return 0;
RelVaultNode * saver = nil; hsRef<RelVaultNode> saver;
if (RelVaultNode * child = VaultGetNodeIncRef(fChild->GetNodeId())) { if (hsRef<RelVaultNode> child = VaultGetNode(fChild->GetNodeId())) {
if (unsigned saverId = child->GetRefOwnerId(fParent->GetNodeId())) { if (unsigned saverId = child->GetRefOwnerId(fParent->GetNodeId())) {
// Find the player info node representing the saver // Find the player info node representing the saver
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_PlayerInfo); templateNode->SetNodeType(plVault::kNodeType_PlayerInfo);
VaultPlayerInfoNode access(templateNode); VaultPlayerInfoNode access(templateNode);
access.SetPlayerId(saverId); access.SetPlayerId(saverId);
saver = VaultGetNodeIncRef(templateNode); saver = VaultGetNode(templateNode);
if (!saver) { if (!saver) {
ARRAY(unsigned) nodeIds; ARRAY(unsigned) nodeIds;
VaultFindNodesAndWait(templateNode, &nodeIds); VaultFindNodesAndWait(templateNode, &nodeIds);
if (nodeIds.Count() > 0) { if (nodeIds.Count() > 0) {
VaultFetchNodesAndWait(nodeIds.Ptr(), nodeIds.Count()); VaultFetchNodesAndWait(nodeIds.Ptr(), nodeIds.Count());
saver = VaultGetNodeIncRef(nodeIds[0]); saver = VaultGetNode(nodeIds[0]);
} }
} }
templateNode->UnRef();
} }
child->UnRef();
} }
if (!saver) if (!saver)
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
PyObject * result = pyVaultPlayerInfoNode::New(saver); return pyVaultPlayerInfoNode::New(saver);
saver->UnRef();
return result;
} }
bool pyVaultNodeRef::BeenSeen () { bool pyVaultNodeRef::BeenSeen () {

11
Sources/Plasma/FeatureLib/pfPython/pyVaultNodeRef.h

@ -50,13 +50,14 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "HeadSpin.h" #include "HeadSpin.h"
#include "pyGlueHelpers.h" #include "pyGlueHelpers.h"
#include "hsRefCnt.h"
struct RelVaultNode; struct RelVaultNode;
class pyVaultNodeRef class pyVaultNodeRef
{ {
RelVaultNode * fParent; hsRef<RelVaultNode> fParent;
RelVaultNode * fChild; hsRef<RelVaultNode> fChild;
protected: protected:
// should only be created from C++ side // should only be created from C++ side
@ -64,10 +65,8 @@ protected:
pyVaultNodeRef(int =0 ); pyVaultNodeRef(int =0 );
public: public:
~pyVaultNodeRef(); hsRef<RelVaultNode> GetParentNode() const;
hsRef<RelVaultNode> GetChildNode() const;
RelVaultNode * GetParentNode () const { return fParent; }
RelVaultNode * GetChildNode () const { return fChild; }
// required functions for PyObject interoperability // required functions for PyObject interoperability
PYTHON_EXPOSE_TYPE; // so we can subclass PYTHON_EXPOSE_TYPE; // so we can subclass

8
Sources/Plasma/FeatureLib/pfPython/pyVaultNodeRefGlue.cpp

@ -125,16 +125,8 @@ PYTHON_EXPOSE_TYPE_DEFINITION(ptVaultNodeRef, pyVaultNodeRef);
PyObject *pyVaultNodeRef::New(RelVaultNode * parent, RelVaultNode * child) PyObject *pyVaultNodeRef::New(RelVaultNode * parent, RelVaultNode * child)
{ {
ptVaultNodeRef *newObj = (ptVaultNodeRef*)ptVaultNodeRef_type.tp_new(&ptVaultNodeRef_type, NULL, NULL); ptVaultNodeRef *newObj = (ptVaultNodeRef*)ptVaultNodeRef_type.tp_new(&ptVaultNodeRef_type, NULL, NULL);
if (newObj->fThis->fParent)
newObj->fThis->fParent->UnRef();
if (newObj->fThis->fChild)
newObj->fThis->fChild->UnRef();
newObj->fThis->fParent = parent; newObj->fThis->fParent = parent;
newObj->fThis->fChild = child; newObj->fThis->fChild = child;
if (newObj->fThis->fParent)
newObj->fThis->fParent->Ref();
if (newObj->fThis->fChild)
newObj->fThis->fChild->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

38
Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerInfoListNode.cpp

@ -79,17 +79,13 @@ bool pyVaultPlayerInfoListNode::HasPlayer( uint32_t playerID )
if (!fNode) if (!fNode)
return false; return false;
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_PlayerInfo); templateNode->SetNodeType(plVault::kNodeType_PlayerInfo);
VaultPlayerInfoNode access(templateNode); VaultPlayerInfoNode access(templateNode);
access.SetPlayerId(playerID); access.SetPlayerId(playerID);
RelVaultNode * rvn = fNode->GetChildNodeIncRef(templateNode, 1); hsRef<RelVaultNode> rvn = fNode->GetChildNode(templateNode, 1);
if (rvn)
rvn->UnRef();
templateNode->UnRef();
return (rvn != nil); return (rvn != nil);
} }
@ -97,10 +93,9 @@ bool pyVaultPlayerInfoListNode::HasPlayer( uint32_t playerID )
static void IAddPlayer_NodesFound(ENetError result, void* param, unsigned nodeIdCount, const unsigned nodeIds[]) static void IAddPlayer_NodesFound(ENetError result, void* param, unsigned nodeIdCount, const unsigned nodeIds[])
{ {
NetVaultNode* parent = static_cast<NetVaultNode*>(param); hsRef<NetVaultNode> parent = static_cast<NetVaultNode*>(param);
if (nodeIdCount) if (nodeIdCount)
VaultAddChildNode(parent->GetNodeId(), nodeIds[0], VaultGetPlayerId(), nullptr, nullptr); VaultAddChildNode(parent->GetNodeId(), nodeIds[0], VaultGetPlayerId(), nullptr, nullptr);
parent->UnRef();
} }
void pyVaultPlayerInfoListNode::AddPlayer( uint32_t playerID ) void pyVaultPlayerInfoListNode::AddPlayer( uint32_t playerID )
@ -108,8 +103,7 @@ void pyVaultPlayerInfoListNode::AddPlayer( uint32_t playerID )
if (HasPlayer(playerID) || !fNode) if (HasPlayer(playerID) || !fNode)
return; return;
NetVaultNode* templateNode = new NetVaultNode(); hsRef<NetVaultNode> templateNode = new NetVaultNode();
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_PlayerInfo); templateNode->SetNodeType(plVault::kNodeType_PlayerInfo);
VaultPlayerInfoNode access(templateNode); VaultPlayerInfoNode access(templateNode);
access.SetPlayerId(playerID); access.SetPlayerId(playerID);
@ -120,10 +114,8 @@ void pyVaultPlayerInfoListNode::AddPlayer( uint32_t playerID )
// So, if we know about this node, we can take it easy. If not, we lazy load it. // So, if we know about this node, we can take it easy. If not, we lazy load it.
if (nodeIds.Count()) if (nodeIds.Count())
VaultAddChildNode(fNode->GetNodeId(), nodeIds[0], VaultGetPlayerId(), nullptr, nullptr); VaultAddChildNode(fNode->GetNodeId(), nodeIds[0], VaultGetPlayerId(), nullptr, nullptr);
else { else
fNode->Ref(); VaultFindNodes(templateNode, IAddPlayer_NodesFound, (NetVaultNode *)fNode);
VaultFindNodes(templateNode, IAddPlayer_NodesFound, fNode);
}
} }
void pyVaultPlayerInfoListNode::RemovePlayer( uint32_t playerID ) void pyVaultPlayerInfoListNode::RemovePlayer( uint32_t playerID )
@ -131,18 +123,13 @@ void pyVaultPlayerInfoListNode::RemovePlayer( uint32_t playerID )
if (!fNode) if (!fNode)
return; return;
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_PlayerInfo); templateNode->SetNodeType(plVault::kNodeType_PlayerInfo);
VaultPlayerInfoNode access(templateNode); VaultPlayerInfoNode access(templateNode);
access.SetPlayerId(playerID); access.SetPlayerId(playerID);
if (RelVaultNode * rvn = fNode->GetChildNodeIncRef(templateNode, 1)) { if (hsRef<RelVaultNode> rvn = fNode->GetChildNode(templateNode, 1))
VaultRemoveChildNode(fNode->GetNodeId(), rvn->GetNodeId(), nil, nil); VaultRemoveChildNode(fNode->GetNodeId(), rvn->GetNodeId(), nil, nil);
rvn->UnRef();
}
templateNode->UnRef();
} }
PyObject * pyVaultPlayerInfoListNode::GetPlayer( uint32_t playerID ) PyObject * pyVaultPlayerInfoListNode::GetPlayer( uint32_t playerID )
@ -150,19 +137,14 @@ PyObject * pyVaultPlayerInfoListNode::GetPlayer( uint32_t playerID )
if (!fNode) if (!fNode)
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
NetVaultNode * templateNode = new NetVaultNode; hsRef<NetVaultNode> templateNode = new NetVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_PlayerInfo); templateNode->SetNodeType(plVault::kNodeType_PlayerInfo);
VaultPlayerInfoNode access(templateNode); VaultPlayerInfoNode access(templateNode);
access.SetPlayerId(playerID); access.SetPlayerId(playerID);
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvn = fNode->GetChildNodeIncRef(templateNode, 1)) { if (hsRef<RelVaultNode> rvn = fNode->GetChildNode(templateNode, 1))
result = pyVaultPlayerInfoNode::New(rvn); result = pyVaultPlayerInfoNode::New(rvn);
rvn->UnRef();
}
templateNode->UnRef();
if (!result) if (!result)
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;

4
Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerInfoListNodeGlue.cpp

@ -179,11 +179,7 @@ PLASMA_DEFAULT_TYPE_WBASE(ptVaultPlayerInfoListNode, pyVaultFolderNode, "Params:
PyObject *pyVaultPlayerInfoListNode::New(RelVaultNode* nfsNode) PyObject *pyVaultPlayerInfoListNode::New(RelVaultNode* nfsNode)
{ {
ptVaultPlayerInfoListNode *newObj = (ptVaultPlayerInfoListNode*)ptVaultPlayerInfoListNode_type.tp_new(&ptVaultPlayerInfoListNode_type, NULL, NULL); ptVaultPlayerInfoListNode *newObj = (ptVaultPlayerInfoListNode*)ptVaultPlayerInfoListNode_type.tp_new(&ptVaultPlayerInfoListNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerInfoNodeGlue.cpp

@ -171,11 +171,7 @@ PYTHON_CLASS_NEW_IMPL(ptVaultPlayerInfoNode, pyVaultPlayerInfoNode)
PyObject *pyVaultPlayerInfoNode::New(RelVaultNode* nfsNode) PyObject *pyVaultPlayerInfoNode::New(RelVaultNode* nfsNode)
{ {
ptVaultPlayerInfoNode *newObj = (ptVaultPlayerInfoNode*)ptVaultPlayerInfoNode_type.tp_new(&ptVaultPlayerInfoNode_type, NULL, NULL); ptVaultPlayerInfoNode *newObj = (ptVaultPlayerInfoNode*)ptVaultPlayerInfoNode_type.tp_new(&ptVaultPlayerInfoNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

28
Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerNode.cpp

@ -65,12 +65,9 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
//============================================================================ //============================================================================
static PyObject * GetPlayerVaultFolder (unsigned folderType) { static PyObject * GetPlayerVaultFolder (unsigned folderType) {
PyObject * result = nil; PyObject * result = nil;
if (RelVaultNode * rvnPlr = VaultGetPlayerNodeIncRef()) { if (hsRef<RelVaultNode> rvnPlr = VaultGetPlayerNode()) {
if (RelVaultNode * rvnFldr = rvnPlr->GetChildFolderNodeIncRef(folderType, 1)) { if (hsRef<RelVaultNode> rvnFldr = rvnPlr->GetChildFolderNode(folderType, 1))
result = pyVaultFolderNode::New(rvnFldr); result = pyVaultFolderNode::New(rvnFldr);
rvnFldr->UnRef();
}
rvnPlr->UnRef();
} }
return result; return result;
@ -172,11 +169,8 @@ PyObject *pyVaultPlayerNode::GetAgesIOwnFolder()
PyObject *pyVaultPlayerNode::GetPlayerInfo() PyObject *pyVaultPlayerNode::GetPlayerInfo()
{ {
if (RelVaultNode * rvn = VaultGetPlayerInfoNodeIncRef()) { if (hsRef<RelVaultNode> rvn = VaultGetPlayerInfoNode())
PyObject * result = pyVaultPlayerInfoNode::New(rvn); return pyVaultPlayerInfoNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }
@ -221,11 +215,8 @@ void pyVaultPlayerNode::RemoveOwnedAgeLink(const char* ageFilename)
PyObject *pyVaultPlayerNode::GetVisitAgeLink(const pyAgeInfoStruct *info) PyObject *pyVaultPlayerNode::GetVisitAgeLink(const pyAgeInfoStruct *info)
{ {
if (RelVaultNode * rvn = VaultGetVisitAgeLinkIncRef(info->GetAgeInfo())) { if (hsRef<RelVaultNode> rvn = VaultGetVisitAgeLink(info->GetAgeInfo()))
PyObject * result = pyVaultAgeLinkNode::New(rvn); return pyVaultAgeLinkNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }
@ -242,11 +233,8 @@ PyObject *pyVaultPlayerNode::FindChronicleEntry(const char *entryName)
{ {
wchar_t wStr[MAX_PATH]; wchar_t wStr[MAX_PATH];
StrToUnicode(wStr, entryName, arrsize(wStr)); StrToUnicode(wStr, entryName, arrsize(wStr));
if (RelVaultNode * rvn = VaultFindChronicleEntryIncRef(wStr)) { if (hsRef<RelVaultNode> rvn = VaultFindChronicleEntry(wStr))
PyObject * result = pyVaultChronicleNode::New(rvn); return pyVaultChronicleNode::New(rvn);
rvn->UnRef();
return result;
}
PYTHON_RETURN_NONE; PYTHON_RETURN_NONE;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultPlayerNodeGlue.cpp

@ -321,11 +321,7 @@ PYTHON_CLASS_NEW_IMPL(ptVaultPlayerNode, pyVaultPlayerNode)
PyObject *pyVaultPlayerNode::New(RelVaultNode* nfsNode) PyObject *pyVaultPlayerNode::New(RelVaultNode* nfsNode)
{ {
ptVaultPlayerNode *newObj = (ptVaultPlayerNode*)ptVaultPlayerNode_type.tp_new(&ptVaultPlayerNode_type, NULL, NULL); ptVaultPlayerNode *newObj = (ptVaultPlayerNode*)ptVaultPlayerNode_type.tp_new(&ptVaultPlayerNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultSDLNodeGlue.cpp

@ -129,11 +129,7 @@ PYTHON_CLASS_NEW_IMPL(ptVaultSDLNode, pyVaultSDLNode)
PyObject *pyVaultSDLNode::New(RelVaultNode* nfsNode) PyObject *pyVaultSDLNode::New(RelVaultNode* nfsNode)
{ {
ptVaultSDLNode *newObj = (ptVaultSDLNode*)ptVaultSDLNode_type.tp_new(&ptVaultSDLNode_type, NULL, NULL); ptVaultSDLNode *newObj = (ptVaultSDLNode*)ptVaultSDLNode_type.tp_new(&ptVaultSDLNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultSystemNodeGlue.cpp

@ -70,11 +70,7 @@ PYTHON_CLASS_NEW_IMPL(ptVaultSystemNode, pyVaultSystemNode)
PyObject *pyVaultSystemNode::New(RelVaultNode* nfsNode) PyObject *pyVaultSystemNode::New(RelVaultNode* nfsNode)
{ {
ptVaultSystemNode *newObj = (ptVaultSystemNode*)ptVaultSystemNode_type.tp_new(&ptVaultSystemNode_type, NULL, NULL); ptVaultSystemNode *newObj = (ptVaultSystemNode*)ptVaultSystemNode_type.tp_new(&ptVaultSystemNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultTextNoteNode.cpp

@ -228,10 +228,8 @@ void pyVaultTextNoteNode::SetDeviceInbox( const char * devName, PyObject * cbObj
wchar_t wDev[MAX_PATH]; wchar_t wDev[MAX_PATH];
StrToUnicode(wDev, devName, arrsize(wDev)); StrToUnicode(wDev, devName, arrsize(wDev));
if (RelVaultNode * rvn = VaultAgeSetDeviceInboxAndWaitIncRef(wDev, DEFAULT_DEVICE_INBOX)) { if (hsRef<RelVaultNode> rvn = VaultAgeSetDeviceInboxAndWait(wDev, DEFAULT_DEVICE_INBOX))
cb->SetNode(rvn); cb->SetNode(rvn);
rvn->UnRef();
}
cb->VaultOperationComplete( cbContext, cb->GetNode() ? hsOK : hsFail ); // cbHolder deletes itself here. cb->VaultOperationComplete( cbContext, cb->GetNode() ? hsOK : hsFail ); // cbHolder deletes itself here.
} }

4
Sources/Plasma/FeatureLib/pfPython/pyVaultTextNoteNodeGlue.cpp

@ -318,11 +318,7 @@ PYTHON_CLASS_NEW_IMPL(ptVaultTextNoteNode, pyVaultTextNoteNode)
PyObject *pyVaultTextNoteNode::New(RelVaultNode* nfsNode) PyObject *pyVaultTextNoteNode::New(RelVaultNode* nfsNode)
{ {
ptVaultTextNoteNode *newObj = (ptVaultTextNoteNode*)ptVaultTextNoteNode_type.tp_new(&ptVaultTextNoteNode_type, NULL, NULL); ptVaultTextNoteNode *newObj = (ptVaultTextNoteNode*)ptVaultTextNoteNode_type.tp_new(&ptVaultTextNoteNode_type, NULL, NULL);
if (newObj->fThis->fNode)
newObj->fThis->fNode->UnRef();
newObj->fThis->fNode = nfsNode; newObj->fThis->fNode = nfsNode;
if (newObj->fThis->fNode)
newObj->fThis->fNode->Ref();
return (PyObject*)newObj; return (PyObject*)newObj;
} }

2
Sources/Plasma/NucleusLib/pnAsyncCoreExe/Private/Nt/pnAceNtInt.h

@ -88,7 +88,7 @@ public:
BOOL TryEnter () { return TryEnterCriticalSection(&m_handle); } BOOL TryEnter () { return TryEnterCriticalSection(&m_handle); }
}; };
class CNtWaitHandle : public hsAtomicRefCnt { class CNtWaitHandle : public hsRefCnt {
HANDLE m_event; HANDLE m_event;
public: public:

4
Sources/Plasma/NucleusLib/pnAsyncCoreExe/Private/Win32/pnAceW32Thread.cpp

@ -57,7 +57,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
* *
***/ ***/
struct AsyncThreadTaskList : hsAtomicRefCnt { struct AsyncThreadTaskList : hsRefCnt {
ENetError error; ENetError error;
AsyncThreadTaskList (); AsyncThreadTaskList ();
~AsyncThreadTaskList (); ~AsyncThreadTaskList ();
@ -81,7 +81,7 @@ static HANDLE s_taskPort;
//=========================================================================== //===========================================================================
AsyncThreadTaskList::AsyncThreadTaskList () AsyncThreadTaskList::AsyncThreadTaskList ()
: hsAtomicRefCnt(0), error(kNetSuccess) : hsRefCnt(0), error(kNetSuccess)
{ {
PerfAddCounter(kAsyncPerfThreadTaskListCount, 1); PerfAddCounter(kAsyncPerfThreadTaskListCount, 1);
} }

4
Sources/Plasma/NucleusLib/pnNetCli/pnNcChannel.cpp

@ -73,8 +73,8 @@ private:
hsMutex m_critsect; hsMutex m_critsect;
}; };
struct NetMsgChannel : hsAtomicRefCnt { struct NetMsgChannel : hsRefCnt {
NetMsgChannel() : hsAtomicRefCnt(0) { } NetMsgChannel() : hsRefCnt(0) { }
uint32_t m_protocol; uint32_t m_protocol;
bool m_server; bool m_server;

2
Sources/Plasma/NucleusLib/pnNetProtocol/Private/pnNpCommon.cpp

@ -315,7 +315,7 @@ void NetVaultNode::DeallocNodeFields () {
//============================================================================ //============================================================================
NetVaultNode::NetVaultNode () NetVaultNode::NetVaultNode ()
: hsAtomicRefCnt(0), fieldFlags(0), dirtyFlags(0) : hsRefCnt(0), fieldFlags(0), dirtyFlags(0)
, nodeId(0), createTime(0), modifyTime(0) , nodeId(0), createTime(0), modifyTime(0)
, createAgeName(nil), creatorId(0) , createAgeName(nil), creatorId(0)
, nodeType(0) , nodeType(0)

2
Sources/Plasma/NucleusLib/pnNetProtocol/Private/pnNpCommon.h

@ -157,7 +157,7 @@ struct NetGameRank {
// NetVaultNode // NetVaultNode
//============================================================================ //============================================================================
// Threaded apps: App is responsible for locking node->critsect before accessing *any* field in this struct // Threaded apps: App is responsible for locking node->critsect before accessing *any* field in this struct
struct NetVaultNode : hsAtomicRefCnt { struct NetVaultNode : hsRefCnt {
enum RwOptions { enum RwOptions {
kRwDirtyOnly = 1<<0, // READ : No meaning kRwDirtyOnly = 1<<0, // READ : No meaning
// WRITE: Only write fields marked dirty // WRITE: Only write fields marked dirty

121
Sources/Plasma/PubUtilLib/plAvatar/plAvatarClothing.cpp

@ -802,15 +802,15 @@ bool plClothingOutfit::IReadFromVault()
WearDefaultClothing(); WearDefaultClothing();
RelVaultNode * rvn = VaultGetAvatarOutfitFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAvatarOutfitFolder();
if (!rvn) if (!rvn)
return false; return false;
ARRAY(RelVaultNode*) nodes; RelVaultNode::RefList nodes;
rvn->GetChildNodesIncRef(plVault::kNodeType_SDL, 1, &nodes); rvn->GetChildNodes(plVault::kNodeType_SDL, 1, &nodes);
for (unsigned i = 0; i < nodes.Count(); ++i) { for (const hsRef<RelVaultNode> &node : nodes) {
VaultSDLNode sdl(nodes[i]); VaultSDLNode sdl(node);
if (sdl.GetSDLDataLength()) { if (sdl.GetSDLDataLength()) {
hsRAMStream ram; hsRAMStream ram;
ram.Write(sdl.GetSDLDataLength(), sdl.GetSDLData()); ram.Write(sdl.GetSDLDataLength(), sdl.GetSDLData());
@ -831,13 +831,11 @@ bool plClothingOutfit::IReadFromVault()
delete sdlDataRec; delete sdlDataRec;
} }
} }
nodes[i]->UnRef();
} }
fSynchClients = true; // set true if the next synch should be bcast fSynchClients = true; // set true if the next synch should be bcast
ForceUpdate(true); ForceUpdate(true);
rvn->UnRef();
return true; return true;
} }
@ -857,8 +855,8 @@ void plClothingOutfit::WriteToVault()
if (!fVaultSaveEnabled) if (!fVaultSaveEnabled)
return; return;
RelVaultNode * rvn; hsRef<RelVaultNode> rvn = VaultGetAvatarOutfitFolder();
if (nil == (rvn = VaultGetAvatarOutfitFolderIncRef())) if (!rvn)
return; return;
ARRAY(plStateDataRecord*) SDRs; ARRAY(plStateDataRecord*) SDRs;
@ -874,7 +872,6 @@ void plClothingOutfit::WriteToVault()
SDRs.Add(appearanceStateDesc->GetStateDataRecord(0)); SDRs.Add(appearanceStateDesc->GetStateDataRecord(0));
WriteToVault(SDRs); WriteToVault(SDRs);
rvn->UnRef();
} }
void plClothingOutfit::WriteToVault(const ARRAY(plStateDataRecord*) & SDRs) void plClothingOutfit::WriteToVault(const ARRAY(plStateDataRecord*) & SDRs)
@ -883,8 +880,8 @@ void plClothingOutfit::WriteToVault(const ARRAY(plStateDataRecord*) & SDRs)
if (fAvatar->GetTarget(0) != plNetClientApp::GetInstance()->GetLocalPlayer()) if (fAvatar->GetTarget(0) != plNetClientApp::GetInstance()->GetLocalPlayer())
return; return;
RelVaultNode * rvn; hsRef<RelVaultNode> rvn = VaultGetAvatarOutfitFolder();
if (nil == (rvn = VaultGetAvatarOutfitFolderIncRef())) if (!rvn)
return; return;
ARRAY(plStateDataRecord*) morphs; ARRAY(plStateDataRecord*) morphs;
@ -906,12 +903,12 @@ void plClothingOutfit::WriteToVault(const ARRAY(plStateDataRecord*) & SDRs)
} }
} }
ARRAY(RelVaultNode*) templates; RelVaultNode::RefList templates;
ARRAY(RelVaultNode*) actuals; RelVaultNode::RefList actuals;
ARRAY(RelVaultNode*) nodes; RelVaultNode::RefList nodes;
// Get all existing clothing SDRs // Get all existing clothing SDRs
rvn->GetChildNodesIncRef(plVault::kNodeType_SDL, 1, &nodes); // REF: Find rvn->GetChildNodes(plVault::kNodeType_SDL, 1, &nodes); // REF: Find
const ARRAY(plStateDataRecord*) * arrs[] = { const ARRAY(plStateDataRecord*) * arrs[] = {
&SDRs, &SDRs,
@ -922,55 +919,41 @@ void plClothingOutfit::WriteToVault(const ARRAY(plStateDataRecord*) & SDRs)
// Write all SDL to to the outfit folder, reusing existing nodes and creating new ones as necessary // Write all SDL to to the outfit folder, reusing existing nodes and creating new ones as necessary
for (unsigned i = 0; i < arr->Count(); ++i) { for (unsigned i = 0; i < arr->Count(); ++i) {
RelVaultNode * node; hsRef<RelVaultNode> node;
if (nodes.Count()) { if (!nodes.empty()) {
node = nodes[0]; node = nodes.front();
nodes.DeleteUnordered(0); nodes.pop_front();
node->Ref(); // REF: Work
node->UnRef(); // REF: Find
} }
else { else {
RelVaultNode * templateNode = new RelVaultNode; node = new RelVaultNode;
templateNode->SetNodeType(plVault::kNodeType_SDL); node->SetNodeType(plVault::kNodeType_SDL);
templates.Add(templateNode); templates.push_back(node);
node = templateNode;
node->Ref(); // REF: Create
node->Ref(); // REF: Work
} }
VaultSDLNode sdl(node); VaultSDLNode sdl(node);
sdl.SetStateDataRecord((*arr)[i], 0); sdl.SetStateDataRecord((*arr)[i], 0);
node->UnRef(); // REF: Work
} }
} }
// Delete any leftover nodes // Delete any leftover nodes
for (unsigned i = 0; i < nodes.Count(); ++i) { for (const hsRef<RelVaultNode> &node : nodes)
VaultDeleteNode(nodes[i]->GetNodeId()); VaultDeleteNode(node->GetNodeId());
nodes[i]->UnRef(); // REF: Array
}
// Create actual new nodes from their templates // Create actual new nodes from their templates
for (unsigned i = 0; i < templates.Count(); ++i) { for (const hsRef<RelVaultNode> &temp : templates) {
ENetError result; ENetError result;
if (RelVaultNode * actual = VaultCreateNodeAndWaitIncRef(templates[i], &result)) { if (hsRef<RelVaultNode> actual = VaultCreateNodeAndWait(temp, &result))
actuals.Add(actual); actuals.push_back(actual);
}
templates[i]->UnRef(); // REF: Create
} }
// Add new nodes to outfit folder // Add new nodes to outfit folder
for (unsigned i = 0; i < actuals.Count(); ++i) { for (const hsRef<RelVaultNode> &act : actuals)
VaultAddChildNodeAndWait(rvn->GetNodeId(), actuals[i]->GetNodeId(), NetCommGetPlayer()->playerInt); VaultAddChildNodeAndWait(rvn->GetNodeId(), act->GetNodeId(), NetCommGetPlayer()->playerInt);
actuals[i]->UnRef(); // REF: Create
}
// Cleanup morph SDRs // Cleanup morph SDRs
for (unsigned i = 0; i < morphs.Count(); ++i) { for (unsigned i = 0; i < morphs.Count(); ++i) {
delete morphs[i]; delete morphs[i];
} }
rvn->UnRef();
} }
// XXX HACK. DON'T USE (this function exists for the temp console command Clothing.SwapClothTexHACK) // XXX HACK. DON'T USE (this function exists for the temp console command Clothing.SwapClothTexHACK)
@ -1483,29 +1466,25 @@ bool plClothingOutfit::WriteToFile(const plFileName &filename)
if (!filename.IsValid()) if (!filename.IsValid())
return false; return false;
RelVaultNode* rvn = VaultGetAvatarOutfitFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAvatarOutfitFolder();
if (!rvn) if (!rvn)
return false; return false;
hsUNIXStream S; hsUNIXStream S;
if (!S.Open(filename, "wb")) { if (!S.Open(filename, "wb"))
rvn->UnRef();
return false; return false;
}
S.WriteByte(fGroup); S.WriteByte(fGroup);
ARRAY(RelVaultNode*) nodes; RelVaultNode::RefList nodes;
rvn->GetChildNodesIncRef(plVault::kNodeType_SDL, 1, &nodes); rvn->GetChildNodes(plVault::kNodeType_SDL, 1, &nodes);
S.WriteLE32(nodes.Count()); S.WriteLE32(nodes.size());
for (size_t i = 0; i < nodes.Count(); i++) { for (const hsRef<RelVaultNode> &node : nodes) {
VaultSDLNode sdl(nodes[i]); VaultSDLNode sdl(node);
S.WriteLE32(sdl.GetSDLDataLength()); S.WriteLE32(sdl.GetSDLDataLength());
if (sdl.GetSDLDataLength()) if (sdl.GetSDLDataLength())
S.Write(sdl.GetSDLDataLength(), sdl.GetSDLData()); S.Write(sdl.GetSDLDataLength(), sdl.GetSDLData());
nodes[i]->UnRef();
} }
rvn->UnRef();
S.Close(); S.Close();
return true; return true;
@ -1626,14 +1605,14 @@ plClothingElement *plClothingMgr::FindElementByName(const plString &name) const
void plClothingMgr::AddItemsToCloset(hsTArray<plClosetItem> &items) void plClothingMgr::AddItemsToCloset(hsTArray<plClosetItem> &items)
{ {
RelVaultNode * rvn = VaultGetAvatarClosetFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAvatarClosetFolder();
if (!rvn) if (!rvn)
return; return;
hsTArray<plClosetItem> closet; hsTArray<plClosetItem> closet;
GetClosetItems(closet); GetClosetItems(closet);
ARRAY(RelVaultNode*) templates; RelVaultNode::RefList templates;
for (unsigned i = 0; i < items.GetCount(); ++i) { for (unsigned i = 0; i < items.GetCount(); ++i) {
bool match = false; bool match = false;
@ -1651,44 +1630,40 @@ void plClothingMgr::AddItemsToCloset(hsTArray<plClosetItem> &items)
plStateDataRecord rec(plClothingSDLModifier::GetClothingItemSDRName()); plStateDataRecord rec(plClothingSDLModifier::GetClothingItemSDRName());
plClothingSDLModifier::PutSingleItemIntoSDR(&items[i], &rec); plClothingSDLModifier::PutSingleItemIntoSDR(&items[i], &rec);
RelVaultNode * templateNode = new RelVaultNode; hsRef<RelVaultNode> templateNode = new RelVaultNode;
templateNode->Ref();
templateNode->SetNodeType(plVault::kNodeType_SDL); templateNode->SetNodeType(plVault::kNodeType_SDL);
VaultSDLNode sdl(templateNode); VaultSDLNode sdl(templateNode);
sdl.SetStateDataRecord(&rec); sdl.SetStateDataRecord(&rec);
templates.Add(templateNode); templates.push_back(templateNode);
} }
for (unsigned i = 0; i < templates.Count(); ++i) { for (const hsRef<RelVaultNode> &temp : templates) {
ENetError result; ENetError result;
if (RelVaultNode * actual = VaultCreateNodeAndWaitIncRef(templates[i], &result)) { if (hsRef<RelVaultNode> actual = VaultCreateNodeAndWait(temp, &result)) {
VaultAddChildNodeAndWait( VaultAddChildNodeAndWait(
rvn->GetNodeId(), rvn->GetNodeId(),
actual->GetNodeId(), actual->GetNodeId(),
NetCommGetPlayer()->playerInt NetCommGetPlayer()->playerInt
); );
actual->UnRef(); // REF: Create
} }
templates[i]->UnRef(); // REF: Create
} }
rvn->UnRef();
} }
void plClothingMgr::GetClosetItems(hsTArray<plClosetItem> &out) void plClothingMgr::GetClosetItems(hsTArray<plClosetItem> &out)
{ {
RelVaultNode * rvn = VaultGetAvatarClosetFolderIncRef(); hsRef<RelVaultNode> rvn = VaultGetAvatarClosetFolder();
if (!rvn) if (!rvn)
return; return;
ARRAY(RelVaultNode*) nodes; RelVaultNode::RefList nodes;
rvn->GetChildNodesIncRef(plVault::kNodeType_SDL, 1, &nodes); rvn->GetChildNodes(plVault::kNodeType_SDL, 1, &nodes);
out.SetCount(nodes.Count()); out.SetCount(nodes.size());
for (unsigned i = 0; i < nodes.Count(); ++i) { auto iter = nodes.begin();
VaultSDLNode sdl(nodes[i]); for (unsigned i = 0; i < nodes.size(); ++i, ++iter) {
VaultSDLNode sdl(*iter);
plStateDataRecord * rec = new plStateDataRecord; plStateDataRecord * rec = new plStateDataRecord;
if (sdl.GetStateDataRecord(rec, 0)) if (sdl.GetStateDataRecord(rec, 0))
plClothingSDLModifier::HandleSingleSDR(rec, nil, &out[i]); plClothingSDLModifier::HandleSingleSDR(rec, nil, &out[i]);
@ -1701,8 +1676,6 @@ void plClothingMgr::GetClosetItems(hsTArray<plClosetItem> &out)
out.Remove(i); out.Remove(i);
} }
} }
rvn->UnRef();
} }
void plClothingMgr::GetAllWithSameMesh(plClothingItem *item, hsTArray<plClothingItem*> &out) void plClothingMgr::GetAllWithSameMesh(plClothingItem *item, hsTArray<plClothingItem*> &out)

3
Sources/Plasma/PubUtilLib/plInputCore/plSceneInputInterface.cpp

@ -858,7 +858,7 @@ void plSceneInputInterface::ILinkOffereeToAge()
return; return;
} }
} }
else if (RelVaultNode * linkNode = VaultGetOwnedAgeLinkIncRef(&info)) { else if (hsRef<RelVaultNode> linkNode = VaultGetOwnedAgeLink(&info)) {
// We have the age in our AgesIOwnFolder. If its volatile, dump it for the new one. // We have the age in our AgesIOwnFolder. If its volatile, dump it for the new one.
VaultAgeLinkNode linkAcc(linkNode); VaultAgeLinkNode linkAcc(linkNode);
if (linkAcc.GetVolatile()) { if (linkAcc.GetVolatile()) {
@ -868,7 +868,6 @@ void plSceneInputInterface::ILinkOffereeToAge()
VaultRegisterOwnedAgeAndWait(&link); VaultRegisterOwnedAgeAndWait(&link);
} }
} }
linkNode->UnRef();
} }
if (!fSpawnPoint.IsEmpty()) { if (!fSpawnPoint.IsEmpty()) {

39
Sources/Plasma/PubUtilLib/plNetClient/plNetLinkingMgr.cpp

@ -513,13 +513,13 @@ bool plNetLinkingMgr::IProcessVaultNotifyMsg(plVaultNotifyMsg* msg)
return false; return false;
plAgeLinkStruct* cur = GetAgeLink(); plAgeLinkStruct* cur = GetAgeLink();
RelVaultNode* cVaultLink = nil; hsRef<RelVaultNode> cVaultLink;
switch (msg->GetType()) switch (msg->GetType())
{ {
case plVaultNotifyMsg::kRegisteredChildAgeLink: case plVaultNotifyMsg::kRegisteredChildAgeLink:
case plVaultNotifyMsg::kRegisteredOwnedAge: case plVaultNotifyMsg::kRegisteredOwnedAge:
case plVaultNotifyMsg::kRegisteredSubAgeLink: case plVaultNotifyMsg::kRegisteredSubAgeLink:
cVaultLink = VaultGetNodeIncRef(msg->GetArgs()->GetInt(plNetCommon::VaultTaskArgs::kAgeLinkNode)); cVaultLink = VaultGetNode(msg->GetArgs()->GetInt(plNetCommon::VaultTaskArgs::kAgeLinkNode));
break; break;
default: default:
return false; return false;
@ -531,18 +531,15 @@ bool plNetLinkingMgr::IProcessVaultNotifyMsg(plVaultNotifyMsg* msg)
// It's very useful though... // It's very useful though...
VaultAgeLinkNode accLink(cVaultLink); VaultAgeLinkNode accLink(cVaultLink);
accLink.CopyTo(cur); accLink.CopyTo(cur);
if (RelVaultNode* rvnInfo = cVaultLink->GetChildNodeIncRef(plVault::kNodeType_AgeInfo, 1)) if (hsRef<RelVaultNode> rvnInfo = cVaultLink->GetChildNode(plVault::kNodeType_AgeInfo, 1))
{ {
VaultAgeInfoNode accInfo(rvnInfo); VaultAgeInfoNode accInfo(rvnInfo);
accInfo.CopyTo(cur->GetAgeInfo()); accInfo.CopyTo(cur->GetAgeInfo());
rvnInfo->UnRef();
} }
IDoLink(fDeferredLink); IDoLink(fDeferredLink);
fDeferredLink = nil; fDeferredLink = nil;
return true; return true;
cVaultLink->UnRef();
} }
return false; return false;
@ -778,7 +775,7 @@ void plNetLinkingMgr::IPostProcessLink( void )
bool psnl = (info->GetAgeFilename().CompareI(kPersonalAgeFilename) == 0); bool psnl = (info->GetAgeFilename().CompareI(kPersonalAgeFilename) == 0);
// Update our online status // Update our online status
if (RelVaultNode* rvnInfo = VaultGetPlayerInfoNodeIncRef()) { if (hsRef<RelVaultNode> rvnInfo = VaultGetPlayerInfoNode()) {
VaultPlayerInfoNode accInfo(rvnInfo); VaultPlayerInfoNode accInfo(rvnInfo);
wchar_t ageInstName[MAX_PATH]; wchar_t ageInstName[MAX_PATH];
plUUID ageInstGuid = *info->GetAgeInstanceGuid(); plUUID ageInstGuid = *info->GetAgeInstanceGuid();
@ -786,7 +783,6 @@ void plNetLinkingMgr::IPostProcessLink( void )
accInfo.SetAgeInstName(ageInstName); accInfo.SetAgeInstName(ageInstName);
accInfo.SetAgeInstUuid(ageInstGuid); accInfo.SetAgeInstUuid(ageInstGuid);
accInfo.SetOnline(true); accInfo.SetOnline(true);
rvnInfo->UnRef();
} }
switch (link->GetLinkingRules()) { switch (link->GetLinkingRules()) {
@ -797,8 +793,8 @@ void plNetLinkingMgr::IPostProcessLink( void )
break; break;
{ // Ensure we're in the AgeOwners folder { // Ensure we're in the AgeOwners folder
RelVaultNode* fldr = VaultGetAgeAgeOwnersFolderIncRef(); hsRef<RelVaultNode> fldr = VaultGetAgeAgeOwnersFolder();
RelVaultNode* info = VaultGetPlayerInfoNodeIncRef(); hsRef<RelVaultNode> info = VaultGetPlayerInfoNode();
if (fldr && info) if (fldr && info)
if (!fldr->IsParentOf(info->GetNodeId(), 1)) if (!fldr->IsParentOf(info->GetNodeId(), 1))
@ -809,11 +805,6 @@ void plNetLinkingMgr::IPostProcessLink( void )
nil, nil,
nil nil
); );
if (fldr)
fldr->UnRef();
if (info)
info->UnRef();
} }
} }
break; break;
@ -824,8 +815,8 @@ void plNetLinkingMgr::IPostProcessLink( void )
break; break;
{ // Ensure we're in the CanVisit folder { // Ensure we're in the CanVisit folder
RelVaultNode* fldr = VaultGetAgeCanVisitFolderIncRef(); hsRef<RelVaultNode> fldr = VaultGetAgeCanVisitFolder();
RelVaultNode* info = VaultGetPlayerInfoNodeIncRef(); hsRef<RelVaultNode> info = VaultGetPlayerInfoNode();
if (fldr && info) if (fldr && info)
if (!fldr->IsParentOf(info->GetNodeId(), 1)) if (!fldr->IsParentOf(info->GetNodeId(), 1))
@ -836,11 +827,6 @@ void plNetLinkingMgr::IPostProcessLink( void )
nil, nil,
nil nil
); );
if (fldr)
fldr->UnRef();
if (info)
info->UnRef();
} }
} }
break; break;
@ -873,16 +859,15 @@ uint8_t plNetLinkingMgr::IPreProcessLink(void)
#if 0 #if 0
// Appear offline until we're done linking // Appear offline until we're done linking
if (RelVaultNode * rvnInfo = VaultGetPlayerInfoNodeIncRef()) { if (hsRef<RelVaultNode> rvnInfo = VaultGetPlayerInfoNode()) {
VaultPlayerInfoNode accInfo(rvnInfo); VaultPlayerInfoNode accInfo(rvnInfo);
accInfo.SetAgeInstName(nil); accInfo.SetAgeInstName(nil);
accInfo.SetAgeInstUuid(kNilUuid); accInfo.SetAgeInstUuid(kNilUuid);
accInfo.SetOnline(false); accInfo.SetOnline(false);
rvnInfo->UnRef();
} }
#else #else
// Update our online status // Update our online status
if (RelVaultNode * rvnInfo = VaultGetPlayerInfoNodeIncRef()) { if (hsRef<RelVaultNode> rvnInfo = VaultGetPlayerInfoNode()) {
VaultPlayerInfoNode accInfo(rvnInfo); VaultPlayerInfoNode accInfo(rvnInfo);
wchar_t ageInstName[MAX_PATH]; wchar_t ageInstName[MAX_PATH];
plUUID ageInstGuid = *GetAgeLink()->GetAgeInfo()->GetAgeInstanceGuid(); plUUID ageInstGuid = *GetAgeLink()->GetAgeInfo()->GetAgeInstanceGuid();
@ -890,7 +875,6 @@ uint8_t plNetLinkingMgr::IPreProcessLink(void)
accInfo.SetAgeInstName(ageInstName); accInfo.SetAgeInstName(ageInstName);
accInfo.SetAgeInstUuid(ageInstGuid); accInfo.SetAgeInstUuid(ageInstGuid);
accInfo.SetOnline(true); accInfo.SetOnline(true);
rvnInfo->UnRef();
} }
#endif #endif
@ -984,7 +968,7 @@ uint8_t plNetLinkingMgr::IPreProcessLink(void)
success = kLinkDeferred; success = kLinkDeferred;
break; break;
} }
else if (RelVaultNode* linkNode = VaultGetOwnedAgeLinkIncRef(&ageInfo)) { else if (hsRef<RelVaultNode> linkNode = VaultGetOwnedAgeLink(&ageInfo)) {
// We have the age in our AgesIOwnFolder. If its volatile, dump it for the new one. // We have the age in our AgesIOwnFolder. If its volatile, dump it for the new one.
VaultAgeLinkNode linkAcc(linkNode); VaultAgeLinkNode linkAcc(linkNode);
if (linkAcc.GetVolatile()) { if (linkAcc.GetVolatile()) {
@ -1035,7 +1019,6 @@ uint8_t plNetLinkingMgr::IPreProcessLink(void)
break; break;
} }
} }
linkNode->UnRef();
} }
} }

10
Sources/Plasma/PubUtilLib/plNetClientComm/plNetClientComm.cpp

@ -275,10 +275,9 @@ static void PlayerInitCallback (
// Ensure the city link has the required spawn points // Ensure the city link has the required spawn points
plAgeInfoStruct info; plAgeInfoStruct info;
info.SetAgeFilename(kCityAgeFilename); info.SetAgeFilename(kCityAgeFilename);
if (RelVaultNode * rvn = VaultGetOwnedAgeLinkIncRef(&info)) { if (hsRef<RelVaultNode> rvn = VaultGetOwnedAgeLink(&info)) {
VaultAgeLinkNode acc(rvn); VaultAgeLinkNode acc(rvn);
acc.AddSpawnPoint(plSpawnPointInfo(kCityFerryTerminalLinkTitle, kCityFerryTerminalLinkSpawnPtName)); acc.AddSpawnPoint(plSpawnPointInfo(kCityFerryTerminalLinkTitle, kCityFerryTerminalLinkSpawnPtName));
rvn->UnRef();
} }
VaultProcessPlayerInbox(); VaultProcessPlayerInbox();
@ -1119,14 +1118,12 @@ void NetCommSetActivePlayer (//--> plNetCommActivePlayerMsg
unsigned playerInt = 0; unsigned playerInt = 0;
if (s_player) { if (s_player) {
if (RelVaultNode* rvn = VaultGetPlayerInfoNodeIncRef()) { if (hsRef<RelVaultNode> rvn = VaultGetPlayerInfoNode()) {
VaultPlayerInfoNode pInfo(rvn); VaultPlayerInfoNode pInfo(rvn);
pInfo.SetAgeInstName(nil); pInfo.SetAgeInstName(nil);
pInfo.SetAgeInstUuid(kNilUuid); pInfo.SetAgeInstUuid(kNilUuid);
pInfo.SetOnline(false); pInfo.SetOnline(false);
NetCliAuthVaultNodeSave(rvn, nil, nil); NetCliAuthVaultNodeSave(rvn, nil, nil);
rvn->UnRef();
} }
VaultCull(s_player->playerInt); VaultCull(s_player->playerInt);
@ -1321,10 +1318,9 @@ void NetCommUpgradeVisitorToExplorer (
void NetCommSetCCRLevel ( void NetCommSetCCRLevel (
unsigned ccrLevel unsigned ccrLevel
) { ) {
if (RelVaultNode * rvnInfo = VaultGetPlayerInfoNodeIncRef()) { if (hsRef<RelVaultNode> rvnInfo = VaultGetPlayerInfoNode()) {
VaultPlayerInfoNode pInfo(rvnInfo); VaultPlayerInfoNode pInfo(rvnInfo);
pInfo.SetCCRLevel(ccrLevel); pInfo.SetCCRLevel(ccrLevel);
rvnInfo->UnRef();
} }
NetCliAuthSetCCRLevel(ccrLevel); NetCliAuthSetCCRLevel(ccrLevel);

21
Sources/Plasma/PubUtilLib/plNetCommon/plNetServerSessionInfo.cpp

@ -132,6 +132,20 @@ bool plAgeInfoStruct::IsEqualTo( const plAgeInfoStruct * other ) const
return match; return match;
} }
void plAgeInfoStruct::CopyFrom(const plAgeInfoStruct * other)
{
hsAssert(other, "CopyFrom called with null struct");
fFlags = other->fFlags;
fAgeFilename = other->fAgeFilename;
fAgeInstanceName = other->fAgeInstanceName;
fAgeInstanceGuid = other->fAgeInstanceGuid;
fAgeUserDefinedName = other->fAgeUserDefinedName;
fAgeDescription = other->fAgeDescription;
fAgeSequenceNumber = other->fAgeSequenceNumber;
fAgeLanguage = other->fAgeLanguage;
}
void plAgeInfoStruct::CopyFrom( const plVaultAgeInfoNode * node ) void plAgeInfoStruct::CopyFrom( const plVaultAgeInfoNode * node )
{ {
hsAssert(false, "eric, port me"); hsAssert(false, "eric, port me");
@ -441,7 +455,12 @@ void plAgeLinkStruct::CopyFrom( const plAgeLinkStruct * other )
{ {
if ( other ) if ( other )
{ {
*this=*other; fFlags = other->fFlags;
fAgeInfo.CopyFrom(&other->fAgeInfo);
fLinkingRules = other->fLinkingRules;
fSpawnPoint = other->fSpawnPoint;
fAmCCR = other->fAmCCR;
fParentAgeFilename = other->fParentAgeFilename;
} }
else else
{ {

2
Sources/Plasma/PubUtilLib/plNetCommon/plNetServerSessionInfo.h

@ -112,7 +112,7 @@ public:
void Clear(); void Clear();
void UpdateFlags() const; void UpdateFlags() const;
void CopyFrom( const plAgeInfoStruct * other ) { *this=*other; } void CopyFrom( const plAgeInfoStruct * other );
void CopyFrom( const plVaultAgeInfoNode * node ); void CopyFrom( const plVaultAgeInfoNode * node );
void CopyFrom(const struct NetAgeInfo & info); void CopyFrom(const struct NetAgeInfo & info);
bool IsEqualTo( const plAgeInfoStruct * other ) const; bool IsEqualTo( const plAgeInfoStruct * other ) const;

2
Sources/Plasma/PubUtilLib/plNetGameLib/Intern.h

@ -287,7 +287,7 @@ enum ENetTransState {
kTransStateComplete, kTransStateComplete,
}; };
struct NetTrans : hsAtomicRefCnt { struct NetTrans : hsRefCnt {
LINK(NetTrans) m_link; LINK(NetTrans) m_link;
ENetTransState m_state; ENetTransState m_state;
ENetError m_result; ENetError m_result;

22
Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglAuth.cpp

@ -57,7 +57,7 @@ namespace Ngl { namespace Auth {
* *
***/ ***/
struct CliAuConn : hsAtomicRefCnt { struct CliAuConn : hsRefCnt {
CliAuConn (); CliAuConn ();
~CliAuConn (); ~CliAuConn ();
@ -726,7 +726,7 @@ struct VaultFetchNodeTrans : NetAuthTrans {
FNetCliAuthVaultNodeFetched m_callback; FNetCliAuthVaultNodeFetched m_callback;
void * m_param; void * m_param;
NetVaultNode * m_node; hsRef<NetVaultNode> m_node;
VaultFetchNodeTrans ( VaultFetchNodeTrans (
unsigned nodeId, unsigned nodeId,
@ -751,14 +751,13 @@ struct VaultFindNodeTrans : NetAuthTrans {
FNetCliAuthVaultNodeFind m_callback; FNetCliAuthVaultNodeFind m_callback;
void * m_param; void * m_param;
NetVaultNode * m_node; hsRef<NetVaultNode> m_node;
VaultFindNodeTrans ( VaultFindNodeTrans (
NetVaultNode * templateNode, NetVaultNode * templateNode,
FNetCliAuthVaultNodeFind callback, FNetCliAuthVaultNodeFind callback,
void * param void * param
); );
~VaultFindNodeTrans ();
bool Send (); bool Send ();
@ -774,7 +773,7 @@ struct VaultFindNodeTrans : NetAuthTrans {
//============================================================================ //============================================================================
struct VaultCreateNodeTrans : NetAuthTrans { struct VaultCreateNodeTrans : NetAuthTrans {
NetVaultNode * m_templateNode; hsRef<NetVaultNode> m_templateNode;
FNetCliAuthVaultNodeCreated m_callback; FNetCliAuthVaultNodeCreated m_callback;
void * m_param; void * m_param;
@ -1589,7 +1588,7 @@ static unsigned CliAuConnPingTimerProc (void * param) {
//============================================================================ //============================================================================
CliAuConn::CliAuConn () CliAuConn::CliAuConn ()
: hsAtomicRefCnt(0), reconnectTimer(nil), reconnectStartMs(0) : hsRefCnt(0), reconnectTimer(nil), reconnectStartMs(0)
, pingTimer(nil), pingSendTimeMs(0), lastHeardTimeMs(0) , pingTimer(nil), pingSendTimeMs(0), lastHeardTimeMs(0)
, sock(nil), cli(nil), seq(0), serverChallenge(0) , sock(nil), cli(nil), seq(0), serverChallenge(0)
, cancelId(nil), abandoned(false) , cancelId(nil), abandoned(false)
@ -3940,8 +3939,6 @@ void VaultFetchNodeTrans::Post () {
m_param, m_param,
m_node m_node
); );
if (m_node)
m_node->UnRef("Recv");
} }
//============================================================================ //============================================================================
@ -3954,7 +3951,6 @@ bool VaultFetchNodeTrans::Recv (
if (IS_NET_SUCCESS(reply.result)) { if (IS_NET_SUCCESS(reply.result)) {
m_node = new NetVaultNode; m_node = new NetVaultNode;
m_node->Read_LCS(reply.nodeBuffer, reply.nodeBytes, 0); m_node->Read_LCS(reply.nodeBuffer, reply.nodeBytes, 0);
m_node->Ref("Recv");
} }
m_result = reply.result; m_result = reply.result;
@ -3980,12 +3976,6 @@ VaultFindNodeTrans::VaultFindNodeTrans (
, m_param(param) , m_param(param)
, m_node(templateNode) , m_node(templateNode)
{ {
m_node->Ref();
}
//============================================================================
VaultFindNodeTrans::~VaultFindNodeTrans () {
m_node->UnRef();
} }
//============================================================================ //============================================================================
@ -4056,7 +4046,6 @@ VaultCreateNodeTrans::VaultCreateNodeTrans (
, m_param(param) , m_param(param)
, m_nodeId(0) , m_nodeId(0)
{ {
m_templateNode->Ref();
} }
//============================================================================ //============================================================================
@ -4086,7 +4075,6 @@ void VaultCreateNodeTrans::Post () {
m_param, m_param,
m_nodeId m_nodeId
); );
m_templateNode->UnRef();
} }
//============================================================================ //============================================================================

4
Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglFile.cpp

@ -60,7 +60,7 @@ namespace Ngl { namespace File {
* *
***/ ***/
struct CliFileConn : hsAtomicRefCnt { struct CliFileConn : hsRefCnt {
LINK(CliFileConn) link; LINK(CliFileConn) link;
hsReaderWriterLock sockLock; // to protect the socket pointer so we don't nuke it while using it hsReaderWriterLock sockLock; // to protect the socket pointer so we don't nuke it while using it
AsyncSocket sock; AsyncSocket sock;
@ -581,7 +581,7 @@ static void AsyncLookupCallback (
//============================================================================ //============================================================================
CliFileConn::CliFileConn () CliFileConn::CliFileConn ()
: hsAtomicRefCnt(0), sock(nil), seq(0), cancelId(nil), abandoned(false) : hsRefCnt(0), sock(nil), seq(0), cancelId(nil), abandoned(false)
, buildId(0), serverType(0) , buildId(0), serverType(0)
, reconnectTimer(nil), reconnectStartMs(0), connectStartMs(0) , reconnectTimer(nil), reconnectStartMs(0), connectStartMs(0)
, numImmediateDisconnects(0), numFailedConnects(0) , numImmediateDisconnects(0), numFailedConnects(0)

4
Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglGame.cpp

@ -55,7 +55,7 @@ namespace Ngl { namespace Game {
* *
***/ ***/
struct CliGmConn : hsAtomicRefCnt { struct CliGmConn : hsRefCnt {
LINK(CliGmConn) link; LINK(CliGmConn) link;
CCritSect critsect; CCritSect critsect;
@ -415,7 +415,7 @@ static unsigned CliGmConnPingTimerProc (void * param) {
//============================================================================ //============================================================================
CliGmConn::CliGmConn () CliGmConn::CliGmConn ()
: hsAtomicRefCnt(0), sock(nil), cancelId(nil), cli(nil) : hsRefCnt(0), sock(nil), cancelId(nil), cli(nil)
, seq(0), abandoned(false) , seq(0), abandoned(false)
, pingTimer(nil), pingSendTimeMs(0), lastHeardTimeMs(0) , pingTimer(nil), pingSendTimeMs(0), lastHeardTimeMs(0)
{ {

4
Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglGateKeeper.cpp

@ -56,7 +56,7 @@ namespace Ngl { namespace GateKeeper {
* *
***/ ***/
struct CliGkConn : hsAtomicRefCnt { struct CliGkConn : hsRefCnt {
CliGkConn (); CliGkConn ();
~CliGkConn (); ~CliGkConn ();
@ -525,7 +525,7 @@ static unsigned CliGkConnPingTimerProc (void * param) {
//============================================================================ //============================================================================
CliGkConn::CliGkConn () CliGkConn::CliGkConn ()
: hsAtomicRefCnt(0), reconnectTimer(nil), reconnectStartMs(0) : hsRefCnt(0), reconnectTimer(nil), reconnectStartMs(0)
, pingTimer(nil), pingSendTimeMs(0), lastHeardTimeMs(0) , pingTimer(nil), pingSendTimeMs(0), lastHeardTimeMs(0)
, sock(nil), cli(nil), seq(0), serverChallenge(0) , sock(nil), cli(nil), seq(0), serverChallenge(0)
, cancelId(nil), abandoned(false) , cancelId(nil), abandoned(false)

2
Sources/Plasma/PubUtilLib/plNetGameLib/Private/plNglTrans.cpp

@ -117,7 +117,7 @@ static void CancelTrans_CS (NetTrans * trans, ENetError error) {
//============================================================================ //============================================================================
NetTrans::NetTrans (ENetProtocol protocol, ETransType transType) NetTrans::NetTrans (ENetProtocol protocol, ETransType transType)
: hsAtomicRefCnt(0) : hsRefCnt(0)
, m_state(kTransStateWaitServerConnect) , m_state(kTransStateWaitServerConnect)
, m_result(kNetPending) , m_result(kNetPending)
, m_transId(0) , m_transId(0)

2
Sources/Plasma/PubUtilLib/plNetMessage/plNetCommonMessage.h

@ -48,7 +48,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
// //
// refcntable data // refcntable data
// //
class plNetCommonMessageData : public hsAtomicRefCnt class plNetCommonMessageData : public hsRefCnt
{ {
private: private:
char *fData; // sent char *fData; // sent

10
Sources/Plasma/PubUtilLib/plPipeline/plFogEnvironment.cpp

@ -71,6 +71,16 @@ plFogEnvironment::~plFogEnvironment()
{ {
} }
plFogEnvironment &plFogEnvironment::operator=(const plFogEnvironment &copy)
{
fType = copy.fType;
fStart = copy.fStart;
fEnd = copy.fEnd;
fDensity = copy.fDensity;
fColor = copy.fColor;
return *this;
}
//// Set ///////////////////////////////////////////////////////////////////// //// Set /////////////////////////////////////////////////////////////////////
void plFogEnvironment::Set( float start, float end, float density, const hsColorRGBA *color ) void plFogEnvironment::Set( float start, float end, float density, const hsColorRGBA *color )

3
Sources/Plasma/PubUtilLib/plPipeline/plFogEnvironment.h

@ -85,6 +85,9 @@ class plFogEnvironment : public hsKeyedObject
plFogEnvironment( FogType type, float end, float density, hsColorRGBA &color ); plFogEnvironment( FogType type, float end, float density, hsColorRGBA &color );
~plFogEnvironment(); ~plFogEnvironment();
plFogEnvironment(const plFogEnvironment &copy) { operator=(copy); }
plFogEnvironment &operator=(const plFogEnvironment &copy);
// Sets the parameters for linear fog // Sets the parameters for linear fog
void Set( float start, float end, float density, const hsColorRGBA *color = nil ); void Set( float start, float end, float density, const hsColorRGBA *color = nil );

1037
Sources/Plasma/PubUtilLib/plVault/plVaultClientApi.cpp

File diff suppressed because it is too large Load Diff

139
Sources/Plasma/PubUtilLib/plVault/plVaultClientApi.h

@ -94,6 +94,8 @@ void VaultUnregisterCallback (VaultCallback * cb);
* *
***/ ***/
struct RelVaultNode : NetVaultNode { struct RelVaultNode : NetVaultNode {
typedef std::list<hsRef<RelVaultNode>> RefList;
struct IRelVaultNode * state; struct IRelVaultNode * state;
RelVaultNode (); RelVaultNode ();
@ -127,50 +129,50 @@ struct RelVaultNode : NetVaultNode {
); );
// returns first matching node found // returns first matching node found
RelVaultNode * GetParentNodeIncRef ( hsRef<RelVaultNode> GetParentNode (
NetVaultNode * templateNode, NetVaultNode * templateNode,
unsigned maxDepth unsigned maxDepth
); );
RelVaultNode * GetChildNodeIncRef ( hsRef<RelVaultNode> GetChildNode (
NetVaultNode * templateNode, NetVaultNode * templateNode,
unsigned maxDepth unsigned maxDepth
); );
RelVaultNode * GetChildNodeIncRef ( hsRef<RelVaultNode> GetChildNode (
unsigned nodeType, unsigned nodeType,
unsigned maxDepth unsigned maxDepth
); );
RelVaultNode * GetChildFolderNodeIncRef ( hsRef<RelVaultNode> GetChildFolderNode (
unsigned folderType, unsigned folderType,
unsigned maxDepth unsigned maxDepth
); );
RelVaultNode * GetChildPlayerInfoListNodeIncRef ( hsRef<RelVaultNode> GetChildPlayerInfoListNode (
unsigned folderType, unsigned folderType,
unsigned maxDepth unsigned maxDepth
); );
RelVaultNode * GetChildAgeInfoListNodeIncRef ( hsRef<RelVaultNode> GetChildAgeInfoListNode (
unsigned folderType, unsigned folderType,
unsigned maxDepth unsigned maxDepth
); );
// returns all matching nodes found // returns all matching nodes found
void GetChildNodesIncRef ( void GetChildNodes (
unsigned maxDepth, unsigned maxDepth,
ARRAY(RelVaultNode*) * nodes RefList * nodes
); );
void GetChildNodesIncRef ( void GetChildNodes (
NetVaultNode * templateNode, NetVaultNode * templateNode,
unsigned maxDepth, unsigned maxDepth,
ARRAY(RelVaultNode*) * nodes RefList * nodes
); );
void GetChildNodesIncRef ( void GetChildNodes (
unsigned nodeType, unsigned nodeType,
unsigned maxDepth, unsigned maxDepth,
ARRAY(RelVaultNode*) * nodes RefList * nodes
); );
void GetChildFolderNodesIncRef ( void GetChildFolderNodes (
unsigned folderType, unsigned folderType,
unsigned maxDepth, unsigned maxDepth,
ARRAY(RelVaultNode*) * nodes RefList * nodes
); );
unsigned GetRefOwnerId (unsigned parentId); unsigned GetRefOwnerId (unsigned parentId);
@ -183,7 +185,7 @@ struct RelVaultNode : NetVaultNode {
void PrintTree (FStateDump dumpProc, unsigned level); void PrintTree (FStateDump dumpProc, unsigned level);
// AgeInfoNode-specific (and it checks!) // AgeInfoNode-specific (and it checks!)
RelVaultNode * GetParentAgeLinkIncRef (); hsRef<RelVaultNode> GetParentAgeLink ();
}; };
@ -204,12 +206,9 @@ void VaultUpdate ();
* *
***/ ***/
RelVaultNode * VaultGetNodeIncRef ( hsRef<RelVaultNode> VaultGetNode(unsigned nodeId);
unsigned nodeId hsRef<RelVaultNode> VaultGetNode(NetVaultNode * templateNode);
);
RelVaultNode * VaultGetNodeIncRef (
NetVaultNode * templateNode
);
// VaultAddChildNode will download the child node if necessary // VaultAddChildNode will download the child node if necessary
// the parent exists locally before making the callback. // the parent exists locally before making the callback.
typedef void (*FVaultAddChildNodeCallback)( typedef void (*FVaultAddChildNodeCallback)(
@ -272,11 +271,11 @@ void VaultCreateNode ( // non-blocking
void * state, void * state,
void * param void * param
); );
RelVaultNode * VaultCreateNodeAndWaitIncRef ( // block until completion. returns node. nil --> failure hsRef<RelVaultNode> VaultCreateNodeAndWait ( // block until completion. returns node. nil --> failure
plVault::NodeTypes nodeType, plVault::NodeTypes nodeType,
ENetError * result ENetError * result
); );
RelVaultNode * VaultCreateNodeAndWaitIncRef ( // block until completion. returns node. nil --> failure hsRef<RelVaultNode> VaultCreateNodeAndWait ( // block until completion. returns node. nil --> failure
NetVaultNode * templateNode, NetVaultNode * templateNode,
ENetError * result ENetError * result
); );
@ -303,7 +302,7 @@ void VaultLocalFindNodes (
NetVaultNode * templateNode, NetVaultNode * templateNode,
ARRAY(unsigned) * nodeIds ARRAY(unsigned) * nodeIds
); );
void VaultFetchNodesAndWait ( // Use VaultGetNodeIncRef to access the fetched nodes void VaultFetchNodesAndWait ( // Use VaultGetNode to access the fetched nodes
const unsigned nodeIds[], const unsigned nodeIds[],
unsigned count, unsigned count,
bool force = false bool force = false
@ -330,32 +329,32 @@ void VaultInitAge (
* *
***/ ***/
unsigned VaultGetPlayerId (); unsigned VaultGetPlayerId();
RelVaultNode * VaultGetPlayerNodeIncRef (); hsRef<RelVaultNode> VaultGetPlayerNode();
RelVaultNode * VaultGetPlayerInfoNodeIncRef (); hsRef<RelVaultNode> VaultGetPlayerInfoNode();
RelVaultNode * VaultGetAvatarOutfitFolderIncRef (); hsRef<RelVaultNode> VaultGetAvatarOutfitFolder();
RelVaultNode * VaultGetAvatarClosetFolderIncRef (); hsRef<RelVaultNode> VaultGetAvatarClosetFolder();
bool VaultGetLinkToMyNeighborhood (plAgeLinkStruct * link); bool VaultGetLinkToMyNeighborhood(plAgeLinkStruct * link);
bool VaultGetLinkToMyPersonalAge (plAgeLinkStruct * link); bool VaultGetLinkToMyPersonalAge(plAgeLinkStruct * link);
bool VaultGetLinkToCity (plAgeLinkStruct * link); bool VaultGetLinkToCity(plAgeLinkStruct * link);
RelVaultNode * VaultGetAgesIOwnFolderIncRef (); hsRef<RelVaultNode> VaultGetAgesIOwnFolder();
RelVaultNode * VaultGetAgesICanVisitFolderIncRef (); hsRef<RelVaultNode> VaultGetAgesICanVisitFolder();
RelVaultNode * VaultGetPlayerInboxFolderIncRef (); hsRef<RelVaultNode> VaultGetPlayerInboxFolder();
RelVaultNode * VaultGetOwnedAgeLinkIncRef (const plAgeInfoStruct * info); hsRef<RelVaultNode> VaultGetOwnedAgeLink(const plAgeInfoStruct * info);
RelVaultNode * VaultGetOwnedAgeInfoIncRef (const plAgeInfoStruct * info); hsRef<RelVaultNode> VaultGetOwnedAgeInfo(const plAgeInfoStruct * info);
bool VaultGetOwnedAgeLink (const plAgeInfoStruct * info, plAgeLinkStruct * link); bool VaultGetOwnedAgeLink(const plAgeInfoStruct * info, plAgeLinkStruct * link);
bool VaultAddOwnedAgeSpawnPoint (const plUUID& ageInstId, const plSpawnPointInfo & spawnPt); bool VaultAddOwnedAgeSpawnPoint(const plUUID& ageInstId, const plSpawnPointInfo & spawnPt);
bool VaultSetOwnedAgePublicAndWait (const plAgeInfoStruct * info, bool publicOrNot); bool VaultSetOwnedAgePublicAndWait(const plAgeInfoStruct * info, bool publicOrNot);
RelVaultNode * VaultGetVisitAgeLinkIncRef (const plAgeInfoStruct * info); hsRef<RelVaultNode> VaultGetVisitAgeLink(const plAgeInfoStruct * info);
bool VaultGetVisitAgeLink (const plAgeInfoStruct * info, class plAgeLinkStruct * link); bool VaultGetVisitAgeLink(const plAgeInfoStruct * info, class plAgeLinkStruct * link);
bool VaultRegisterOwnedAgeAndWait (const plAgeLinkStruct * link); bool VaultRegisterOwnedAgeAndWait(const plAgeLinkStruct * link);
void VaultRegisterOwnedAge(const plAgeLinkStruct* link); void VaultRegisterOwnedAge(const plAgeLinkStruct* link);
bool VaultRegisterVisitAgeAndWait (const plAgeLinkStruct * link); bool VaultRegisterVisitAgeAndWait(const plAgeLinkStruct * link);
void VaultRegisterVisitAge (const plAgeLinkStruct* link); void VaultRegisterVisitAge(const plAgeLinkStruct* link);
bool VaultUnregisterOwnedAgeAndWait (const plAgeInfoStruct * info); bool VaultUnregisterOwnedAgeAndWait(const plAgeInfoStruct * info);
bool VaultUnregisterVisitAgeAndWait (const plAgeInfoStruct * info); bool VaultUnregisterVisitAgeAndWait(const plAgeInfoStruct * info);
RelVaultNode * VaultFindChronicleEntryIncRef (const wchar_t entryName[], int entryType = -1); hsRef<RelVaultNode> VaultFindChronicleEntry(const wchar_t entryName[], int entryType = -1);
bool VaultHasChronicleEntry (const wchar_t entryName[], int entryType = -1); bool VaultHasChronicleEntry(const wchar_t entryName[], int entryType = -1);
// if entry of same name and type already exists, value is updated // if entry of same name and type already exists, value is updated
void VaultAddChronicleEntryAndWait ( void VaultAddChronicleEntryAndWait (
const wchar_t entryName[], const wchar_t entryName[],
@ -390,32 +389,32 @@ void VaultProcessPlayerInbox ();
#define DEFAULT_DEVICE_INBOX L"DevInbox" #define DEFAULT_DEVICE_INBOX L"DevInbox"
RelVaultNode * VaultGetAgeNodeIncRef (); hsRef<RelVaultNode> VaultGetAgeNode();
RelVaultNode * VaultGetAgeInfoNodeIncRef (); hsRef<RelVaultNode> VaultGetAgeInfoNode();
RelVaultNode * VaultGetAgeChronicleFolderIncRef (); hsRef<RelVaultNode> VaultGetAgeChronicleFolder();
RelVaultNode * VaultGetAgeDevicesFolderIncRef (); hsRef<RelVaultNode> VaultGetAgeDevicesFolder();
RelVaultNode * VaultGetAgeSubAgesFolderIncRef (); hsRef<RelVaultNode> VaultGetAgeSubAgesFolder();
RelVaultNode * VaultGetAgeChildAgesFolderIncRef (); hsRef<RelVaultNode> VaultGetAgeChildAgesFolder();
RelVaultNode * VaultGetAgeAgeOwnersFolderIncRef (); hsRef<RelVaultNode> VaultGetAgeAgeOwnersFolder();
RelVaultNode * VaultGetAgeCanVisitFolderIncRef (); hsRef<RelVaultNode> VaultGetAgeCanVisitFolder();
RelVaultNode * VaultGetAgePeopleIKnowAboutFolderIncRef (); hsRef<RelVaultNode> VaultGetAgePeopleIKnowAboutFolder();
RelVaultNode * VaultGetAgePublicAgesFolderIncRef (); hsRef<RelVaultNode> VaultGetAgePublicAgesFolder();
RelVaultNode * VaultAgeGetBookshelfFolderIncRef (); hsRef<RelVaultNode> VaultAgeGetBookshelfFolder();
RelVaultNode * VaultFindAgeSubAgeLinkIncRef (const plAgeInfoStruct * info); hsRef<RelVaultNode> VaultFindAgeSubAgeLink(const plAgeInfoStruct * info);
RelVaultNode * VaultFindAgeChildAgeLinkIncRef (const plAgeInfoStruct * info); hsRef<RelVaultNode> VaultFindAgeChildAgeLink(const plAgeInfoStruct * info);
RelVaultNode * VaultFindAgeChronicleEntryIncRef (const wchar_t entryName[], int entryType = -1); hsRef<RelVaultNode> VaultFindAgeChronicleEntry(const wchar_t entryName[], int entryType = -1);
// if entry of same name and type already exists, value is updated // if entry of same name and type already exists, value is updated
void VaultAddAgeChronicleEntry ( void VaultAddAgeChronicleEntry (
const wchar_t entryName[], const wchar_t entryName[],
int entryType, int entryType,
const wchar_t entryValue[] const wchar_t entryValue[]
); );
RelVaultNode * VaultAgeAddDeviceAndWaitIncRef (const wchar_t deviceName[]); // blocks until completion hsRef<RelVaultNode> VaultAgeAddDeviceAndWait(const wchar_t deviceName[]); // blocks until completion
void VaultAgeRemoveDevice (const wchar_t deviceName[]); void VaultAgeRemoveDevice (const wchar_t deviceName[]);
bool VaultAgeHasDevice (const wchar_t deviceName[]); bool VaultAgeHasDevice (const wchar_t deviceName[]);
RelVaultNode * VaultAgeGetDeviceIncRef (const wchar_t deviceName[]); hsRef<RelVaultNode> VaultAgeGetDevice(const wchar_t deviceName[]);
RelVaultNode * VaultAgeSetDeviceInboxAndWaitIncRef (const wchar_t deviceName[], const wchar_t inboxName[]); // blocks until completion hsRef<RelVaultNode> VaultAgeSetDeviceInboxAndWait(const wchar_t deviceName[], const wchar_t inboxName[]); // blocks until completion
RelVaultNode * VaultAgeGetDeviceInboxIncRef (const wchar_t deviceName[]); hsRef<RelVaultNode> VaultAgeGetDeviceInbox(const wchar_t deviceName[]);
void VaultClearDeviceInboxMap (); void VaultClearDeviceInboxMap ();
bool VaultAgeGetAgeSDL (class plStateDataRecord * out); bool VaultAgeGetAgeSDL (class plStateDataRecord * out);
@ -423,7 +422,7 @@ void VaultAgeUpdateAgeSDL (const class plStateDataRecord * rec);
unsigned VaultAgeGetAgeTime (); unsigned VaultAgeGetAgeTime ();
RelVaultNode * VaultGetSubAgeLinkIncRef (const plAgeInfoStruct * info); hsRef<RelVaultNode> VaultGetSubAgeLink(const plAgeInfoStruct * info);
bool VaultAgeGetSubAgeLink ( bool VaultAgeGetSubAgeLink (
const plAgeInfoStruct * info, const plAgeInfoStruct * info,
plAgeLinkStruct * link plAgeLinkStruct * link
@ -494,7 +493,7 @@ void VaultCull (
* *
***/ ***/
RelVaultNode * VaultGetSystemNodeIncRef (); hsRef<RelVaultNode> VaultGetSystemNode();
RelVaultNode * VaultGetGlobalInboxIncRef (); hsRef<RelVaultNode> VaultGetGlobalInbox();
#endif // def CLIENT #endif // def CLIENT

6
Sources/Plasma/PubUtilLib/plVault/plVaultNodeAccess.cpp

@ -435,14 +435,12 @@ struct MatchesSpawnPointName
//============================================================================ //============================================================================
#ifdef CLIENT #ifdef CLIENT
bool VaultAgeLinkNode::CopyTo (plAgeLinkStruct * link) { bool VaultAgeLinkNode::CopyTo (plAgeLinkStruct * link) {
if (RelVaultNode * me = VaultGetNodeIncRef(base->GetNodeId())) { if (hsRef<RelVaultNode> me = VaultGetNode(base->GetNodeId())) {
if (RelVaultNode * info = me->GetChildNodeIncRef(plVault::kNodeType_AgeInfo, 1)) { if (hsRef<RelVaultNode> info = me->GetChildNode(plVault::kNodeType_AgeInfo, 1)) {
VaultAgeInfoNode access(info); VaultAgeInfoNode access(info);
access.CopyTo(link->GetAgeInfo()); access.CopyTo(link->GetAgeInfo());
me->UnRef();
return true; return true;
} }
me->UnRef();
} }
link->Clear(); link->Clear();
return false; return false;

Loading…
Cancel
Save