mirror of
https://github.com/rehlds/reapi.git
synced 2025-01-28 14:37:57 +03:00
s/get_member: Added support for members with entvars type
This commit is contained in:
parent
39e4ba8a81
commit
1d17078fd6
@ -895,6 +895,13 @@ cell set_member(AMX *amx, void* pdata, const member_t *member, cell* value, size
|
|||||||
set_member<edict_t *>(pdata, member->offset, pEdictValue, element);
|
set_member<edict_t *>(pdata, member->offset, pEdictValue, element);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
case MEMBER_EVARS:
|
||||||
|
{
|
||||||
|
// native set_member(_index, any:_member, _value, _elem);
|
||||||
|
entvars_t *pev = PEV(*value);
|
||||||
|
set_member<entvars_t *>(pdata, member->offset, pev, element);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
case MEMBER_VECTOR:
|
case MEMBER_VECTOR:
|
||||||
{
|
{
|
||||||
// native set_member(_index, any:_member, Float:_value[3], _elem);
|
// native set_member(_index, any:_member, Float:_value[3], _elem);
|
||||||
@ -978,15 +985,12 @@ cell set_member(AMX *amx, void* pdata, const member_t *member, cell* value, size
|
|||||||
set_member<TraceResult>(pdata, member->offset, *(TraceResult *)value, element);
|
set_member<TraceResult>(pdata, member->offset, *(TraceResult *)value, element);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
case MEMBER_ENTITY:
|
case MEMBER_ENTITY:
|
||||||
case MEMBER_EVARS:
|
|
||||||
case MEBMER_REBUYSTRUCT:
|
case MEBMER_REBUYSTRUCT:
|
||||||
case MEMBER_PMTRACE:
|
case MEMBER_PMTRACE:
|
||||||
case MEBMER_USERCMD:
|
case MEBMER_USERCMD:
|
||||||
AMXX_LogError(amx, AMX_ERR_NATIVE, "%s: member type %s (%s) is not supported", __FUNCTION__, member_t::getTypeString(member->type), member->name);
|
AMXX_LogError(amx, AMX_ERR_NATIVE, "%s: member type %s (%s) is not supported", __FUNCTION__, member_t::getTypeString(member->type), member->name);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1020,6 +1024,12 @@ cell get_member(AMX *amx, void* pdata, const member_t *member, cell* dest, size_
|
|||||||
edict_t *pEntity = get_member<edict_t *>(pdata, member->offset, element);
|
edict_t *pEntity = get_member<edict_t *>(pdata, member->offset, element);
|
||||||
return pEntity ? indexOfEdict(pEntity) : AMX_NULLENT;
|
return pEntity ? indexOfEdict(pEntity) : AMX_NULLENT;
|
||||||
}
|
}
|
||||||
|
case MEMBER_EVARS:
|
||||||
|
{
|
||||||
|
// native any:get_member(_index, any:_member, element);
|
||||||
|
entvars_t *pev = get_member<entvars_t *>(pdata, member->offset, element);
|
||||||
|
return pev ? indexOfEdict(pev) : AMX_NULLENT;
|
||||||
|
}
|
||||||
case MEMBER_VECTOR:
|
case MEMBER_VECTOR:
|
||||||
{
|
{
|
||||||
// native any:get_member(_index, any:_member, any:output[], element);
|
// native any:get_member(_index, any:_member, any:output[], element);
|
||||||
@ -1104,9 +1114,7 @@ cell get_member(AMX *amx, void* pdata, const member_t *member, cell* dest, size_
|
|||||||
pSignals[_State] = signal.GetState();
|
pSignals[_State] = signal.GetState();
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
case MEMBER_ENTITY:
|
case MEMBER_ENTITY:
|
||||||
case MEMBER_EVARS:
|
|
||||||
AMXX_LogError(amx, AMX_ERR_NATIVE, "%s: member type %s (%s) is not supported", __FUNCTION__, member_t::getTypeString(member->type), member->name);
|
AMXX_LogError(amx, AMX_ERR_NATIVE, "%s: member type %s (%s) is not supported", __FUNCTION__, member_t::getTypeString(member->type), member->name);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
case MEMBER_TRACERESULT:
|
case MEMBER_TRACERESULT:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user