mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-01-18 19:47:15 +01:00
Further optimize instance retrieval.
More risky changes but the current constraints should allow it.
This commit is contained in:
parent
b0bbb05631
commit
bb991181de
@ -90,7 +90,7 @@ public:
|
||||
sq_push(v, -2);
|
||||
sq_rawset(v, -4);
|
||||
}
|
||||
sq_pushstring(v, className.c_str(), -1);
|
||||
sq_pushstring(v, className.c_str(), static_cast<SQInteger>(className.size()));
|
||||
auto** ud = reinterpret_cast<ClassData<C>**>(sq_newuserdata(v, sizeof(ClassData<C>*)));
|
||||
*ud = new ClassData<C>;
|
||||
sq_setreleasehook(v, -1, &cleanup_hook);
|
||||
|
@ -237,16 +237,17 @@ public:
|
||||
}
|
||||
|
||||
static C* GetInstance(HSQUIRRELVM vm, SQInteger idx, bool nullAllowed = false) {
|
||||
AbstractStaticClassData* classType = nullptr;
|
||||
//AbstractStaticClassData* classType = nullptr;
|
||||
AbstractStaticClassData* classType = StaticClassTypeTag<C>::Get();
|
||||
std::pair<C*, SharedPtr<std::unordered_map<C*, HSQOBJECT>> >* instance = nullptr;
|
||||
if (hasClassData(vm)) /* type checking only done if the value has type data else it may be enum */
|
||||
//if (hasClassData(vm)) /* type checking only done if the value has type data else it may be enum */
|
||||
if (classType!=nullptr) /* type checking only done if the value has type data else it may be enum */
|
||||
{
|
||||
if (nullAllowed && sq_gettype(vm, idx) == OT_NULL) {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
//classType = getStaticClassData().Lock().Get();
|
||||
classType = StaticClassTypeTag<C>::Get();
|
||||
|
||||
#if !defined (SCRAT_NO_ERROR_CHECKING)
|
||||
if (SQ_FAILED(sq_getinstanceup(vm, idx, (SQUserPointer*)&instance, classType))) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user