added amb1383 - data value to filter functions
--HG-- extra : convert_revision : svn%3A39bc706e-5318-0410-9160-8a85361fbb7c/trunk%401861
This commit is contained in:
parent
f50509abf0
commit
38012bf3e6
@ -41,16 +41,19 @@ public:
|
|||||||
edict_t *pEdict = gameents->BaseEntityToEdict(reinterpret_cast<CBaseEntity *>(pEntity));
|
edict_t *pEdict = gameents->BaseEntityToEdict(reinterpret_cast<CBaseEntity *>(pEntity));
|
||||||
m_pFunc->PushCell(engine->IndexOfEdict(pEdict));
|
m_pFunc->PushCell(engine->IndexOfEdict(pEdict));
|
||||||
m_pFunc->PushCell(contentsMask);
|
m_pFunc->PushCell(contentsMask);
|
||||||
|
m_pFunc->PushCell(m_Data);
|
||||||
m_pFunc->Execute(&res);
|
m_pFunc->Execute(&res);
|
||||||
|
|
||||||
return (res) ? true : false;
|
return (res) ? true : false;
|
||||||
}
|
}
|
||||||
void SetFunctionPtr(IPluginFunction *pFunc)
|
void SetFunctionPtr(IPluginFunction *pFunc, cell_t data)
|
||||||
{
|
{
|
||||||
m_pFunc = pFunc;
|
m_pFunc = pFunc;
|
||||||
|
m_Data = data;
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
IPluginFunction *m_pFunc;
|
IPluginFunction *m_pFunc;
|
||||||
|
cell_t m_Data;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Used for the global trace version */
|
/* Used for the global trace version */
|
||||||
@ -105,13 +108,24 @@ static cell_t smn_TRTraceRayFilter(IPluginContext *pContext, const cell_t *param
|
|||||||
{
|
{
|
||||||
cell_t *startaddr, *endaddr;
|
cell_t *startaddr, *endaddr;
|
||||||
IPluginFunction *pFunc;
|
IPluginFunction *pFunc;
|
||||||
|
cell_t data;
|
||||||
|
|
||||||
pFunc = pContext->GetFunctionById(params[5]);
|
pFunc = pContext->GetFunctionById(params[5]);
|
||||||
if (!pFunc)
|
if (!pFunc)
|
||||||
{
|
{
|
||||||
return pContext->ThrowNativeError("Invalid function id (%X)", params[5]);
|
return pContext->ThrowNativeError("Invalid function id (%X)", params[5]);
|
||||||
}
|
}
|
||||||
g_SMTraceFilter.SetFunctionPtr(pFunc);
|
|
||||||
|
if (params[0] >= 6)
|
||||||
|
{
|
||||||
|
data = params[6];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
data = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_SMTraceFilter.SetFunctionPtr(pFunc, data);
|
||||||
pContext->LocalToPhysAddr(params[1], &startaddr);
|
pContext->LocalToPhysAddr(params[1], &startaddr);
|
||||||
pContext->LocalToPhysAddr(params[2], &endaddr);
|
pContext->LocalToPhysAddr(params[2], &endaddr);
|
||||||
|
|
||||||
@ -192,6 +206,7 @@ static cell_t smn_TRTraceRayFilterEx(IPluginContext *pContext, const cell_t *par
|
|||||||
{
|
{
|
||||||
IPluginFunction *pFunc;
|
IPluginFunction *pFunc;
|
||||||
cell_t *startaddr, *endaddr;
|
cell_t *startaddr, *endaddr;
|
||||||
|
cell_t data;
|
||||||
|
|
||||||
pFunc = pContext->GetFunctionById(params[5]);
|
pFunc = pContext->GetFunctionById(params[5]);
|
||||||
if (!pFunc)
|
if (!pFunc)
|
||||||
@ -205,7 +220,16 @@ static cell_t smn_TRTraceRayFilterEx(IPluginContext *pContext, const cell_t *par
|
|||||||
CSMTraceFilter smfilter;
|
CSMTraceFilter smfilter;
|
||||||
Ray_t ray;
|
Ray_t ray;
|
||||||
|
|
||||||
smfilter.SetFunctionPtr(pFunc);
|
if (params[0] >= 6)
|
||||||
|
{
|
||||||
|
data = params[6];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
data = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
smfilter.SetFunctionPtr(pFunc, data);
|
||||||
StartVec.Init(sp_ctof(startaddr[0]), sp_ctof(startaddr[1]), sp_ctof(startaddr[2]));
|
StartVec.Init(sp_ctof(startaddr[0]), sp_ctof(startaddr[1]), sp_ctof(startaddr[2]));
|
||||||
|
|
||||||
switch (params[4])
|
switch (params[4])
|
||||||
|
@ -110,6 +110,8 @@ enum RayType
|
|||||||
RayType_Infinite /**< The trace ray will go from the start position to infinity using a direction vector. */
|
RayType_Infinite /**< The trace ray will go from the start position to infinity using a direction vector. */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
funcenum TraceEntityFilter
|
||||||
|
{
|
||||||
/**
|
/**
|
||||||
* Called on entity filtering.
|
* Called on entity filtering.
|
||||||
*
|
*
|
||||||
@ -117,7 +119,18 @@ enum RayType
|
|||||||
* @param contentsMask Contents Mask.
|
* @param contentsMask Contents Mask.
|
||||||
* @return True to allow the current entity to be hit, otherwise false.
|
* @return True to allow the current entity to be hit, otherwise false.
|
||||||
*/
|
*/
|
||||||
functag TraceEntityFilter bool:public(entity, contentsMask);
|
bool:public(entity, contentsMask),
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called on entity filtering.
|
||||||
|
*
|
||||||
|
* @param entity Entity index.
|
||||||
|
* @param contentsMask Contents Mask.
|
||||||
|
* @param data Data value, if used.
|
||||||
|
* @return True to allow the current entity to be hit, otherwise false.
|
||||||
|
*/
|
||||||
|
bool:public(entity, contentsMask, any:data),
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the contents mask and the entity index at the given position.
|
* Get the contents mask and the entity index at the given position.
|
||||||
@ -151,14 +164,23 @@ native TR_TraceRay(const Float:pos[3], const Float:vec[3], flags, RayType:rtype)
|
|||||||
/**
|
/**
|
||||||
* Starts up a new trace ray using a global trace result and a customized trace ray filter.
|
* Starts up a new trace ray using a global trace result and a customized trace ray filter.
|
||||||
*
|
*
|
||||||
|
* Calling TR_TraceRayFilter or TR_TraceRayFilterEx from inside a filter function is
|
||||||
|
* currently not allowed and may not work.
|
||||||
|
*
|
||||||
* @param pos Starting position of the ray.
|
* @param pos Starting position of the ray.
|
||||||
* @param vec Depending on RayType, it will be used as the ending point, or the direction angle.
|
* @param vec Depending on RayType, it will be used as the ending point, or the direction angle.
|
||||||
* @param flags Trace flags.
|
* @param flags Trace flags.
|
||||||
* @param rtype Method to calculate the ray direction.
|
* @param rtype Method to calculate the ray direction.
|
||||||
* @param filter Function to use as a filter.
|
* @param filter Function to use as a filter.
|
||||||
|
* @param data Arbitrary data value to pass through to the filter function.
|
||||||
* @noreturn
|
* @noreturn
|
||||||
*/
|
*/
|
||||||
native TR_TraceRayFilter(const Float:pos[3], const Float:vec[3], flags, RayType:rtype, TraceEntityFilter:filter);
|
native TR_TraceRayFilter(const Float:pos[3],
|
||||||
|
const Float:vec[3],
|
||||||
|
flags,
|
||||||
|
RayType:rtype,
|
||||||
|
TraceEntityFilter:filter,
|
||||||
|
any:data=0);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts up a new trace ray using a new trace result.
|
* Starts up a new trace ray using a new trace result.
|
||||||
@ -167,23 +189,30 @@ native TR_TraceRayFilter(const Float:pos[3], const Float:vec[3], flags, RayType:
|
|||||||
* @param vec Depending on RayType, it will be used as the ending point, or the direction angle.
|
* @param vec Depending on RayType, it will be used as the ending point, or the direction angle.
|
||||||
* @param flags Trace flags.
|
* @param flags Trace flags.
|
||||||
* @param rtype Method to calculate the ray direction.
|
* @param rtype Method to calculate the ray direction.
|
||||||
* @return Ray trace handle.
|
* @return Ray trace handle, which must be closed via CloseHandle().
|
||||||
* @note Traces are closed with CloseHandle().
|
|
||||||
*/
|
*/
|
||||||
native Handle:TR_TraceRayEx(const Float:pos[3], const Float:vec[3], flags, RayType:rtype);
|
native Handle:TR_TraceRayEx(const Float:pos[3], const Float:vec[3], flags, RayType:rtype);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts up a new trace ray using a new trace result and a customized trace ray filter.
|
* Starts up a new trace ray using a new trace result and a customized trace ray filter.
|
||||||
*
|
*
|
||||||
|
* Calling TR_TraceRayFilter or TR_TraceRayFilterEx from inside a filter function is
|
||||||
|
* currently not allowed and may not work.
|
||||||
|
*
|
||||||
* @param pos Starting position of the ray.
|
* @param pos Starting position of the ray.
|
||||||
* @param vec Depending on RayType, it will be used as the ending point, or the direction angle.
|
* @param vec Depending on RayType, it will be used as the ending point, or the direction angle.
|
||||||
* @param flags Trace flags.
|
* @param flags Trace flags.
|
||||||
* @param rtype Method to calculate the ray direction.
|
* @param rtype Method to calculate the ray direction.
|
||||||
* @param filter Function to use as a filter.
|
* @param filter Function to use as a filter.
|
||||||
* @return Ray trace handle.
|
* @param data Arbitrary data value to pass through to the filter function.
|
||||||
* @note Traces are closed with CloseHandle().
|
* @return Ray trace handle, which must be closed via CloseHandle().
|
||||||
*/
|
*/
|
||||||
native Handle:TR_TraceRayFilterEx(const Float:pos[3], const Float:vec[3], flags, RayType:rtype, TraceEntityFilter:filter);
|
native Handle:TR_TraceRayFilterEx(const Float:pos[3],
|
||||||
|
const Float:vec[3],
|
||||||
|
flags,
|
||||||
|
RayType:rtype,
|
||||||
|
TraceEntityFilter:filter,
|
||||||
|
any:data=0);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the time fraction from a trace result (1.0 means no collision).
|
* Returns the time fraction from a trace result (1.0 means no collision).
|
||||||
|
Loading…
Reference in New Issue
Block a user