defined baseProcHandle, baseProcUnit nonmatchings

This commit is contained in:
theo3
2020-08-24 18:59:54 -07:00
parent 1ee4ff43d0
commit 71ac906495
6 changed files with 88 additions and 15 deletions
@@ -0,0 +1,57 @@
#include "KingSystem/ActorSystem/actBaseProcUnit.h"
#include <prim/seadSafeString.h>
#include <prim/seadScopedLock.h>
#include "KingSystem/ActorSystem/actActorLinkConstDataAccess.h"
#include "KingSystem/ActorSystem/actBaseProc.h"
#include "KingSystem/Utils/Debug.h"
namespace ksys::act {
// NON_MATCHING: Equivalent but branches are off.
bool BaseProcUnit::setProc(BaseProc* proc) {
bool ret;
static constexpr const char* sStateNames[] = {"Init", "Calc", "Sleep", "Delete"};
auto lock = sead::makeScopedLock(mCS);
if (mProc)
mProc = nullptr;
if (mHandle == &BaseProcHandle::sDummyBaseProcHandle)
return false;
if (mHandle) {
if (mFlags != 1) {
sead::FixedSafeString<64> message;
if (proc)
message.format("%s, %d, %d, %s, ( %p:%p )", proc->getName().cstr(), mFlags,
proc->isInitialized(), sStateNames[u8(proc->getState())], this,
mHandle.load());
else
message.format("なし, %d, ?, ?, ( %p:%p )", mFlags, this, mHandle.load());
util::PrintDebug(message);
}
mProc = proc;
mFlags = 2;
ret = true;
} else {
sead::FixedSafeString<64> message;
if (proc)
message.format("%s, %d, %d, %s, ( %p:%p )", proc->getName().cstr(), mFlags,
proc->isInitialized(), sStateNames[u8(proc->getState())], this,
mHandle.load());
else
message.format("なし, %d, ?, ?, ( %p:%p )", mFlags, this, mHandle.load());
util::PrintDebug(message);
ret = false;
}
return ret;
}
bool BaseProcUnit::isParentHandleDefault() const {
return mHandle == &BaseProcHandle::sDummyBaseProcHandle;
}
} // namespace ksys::act