2016-02-21 00:25:00 +02:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
#include "Core.hpp"
|
|
|
|
#include "Logger.hpp"
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
#include <sqstdstring.h>
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
namespace SqMod {
|
|
|
|
|
2016-03-24 09:32:44 +02:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
extern void EnableReload(Int32 header, Object & payload);
|
|
|
|
extern void DisableReload();
|
|
|
|
extern bool ReloadEnabled();
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
static Object & GetBlip(Int32 id) { return _Core->GetBlip(id).mObj; }
|
|
|
|
static Object & GetCheckpoint(Int32 id) { return _Core->GetCheckpoint(id).mObj; }
|
|
|
|
static Object & GetForcefield(Int32 id) { return _Core->GetForcefield(id).mObj; }
|
|
|
|
static Object & GetKeybind(Int32 id) { return _Core->GetKeybind(id).mObj; }
|
|
|
|
static Object & GetObject(Int32 id) { return _Core->GetObject(id).mObj; }
|
|
|
|
static Object & GetPickup(Int32 id) { return _Core->GetPickup(id).mObj; }
|
|
|
|
static Object & GetPlayer(Int32 id) { return _Core->GetPlayer(id).mObj; }
|
|
|
|
static Object & GetSprite(Int32 id) { return _Core->GetSprite(id).mObj; }
|
|
|
|
static Object & GetTextdraw(Int32 id) { return _Core->GetTextdraw(id).mObj; }
|
|
|
|
static Object & GetVehicle(Int32 id) { return _Core->GetVehicle(id).mObj; }
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
static bool DelBlip(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelBlip(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelCheckpoint(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelCheckpoint(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelForcefield(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelForcefield(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelKeybind(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelKeybind(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelObject(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelObject(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelPickup(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelPickup(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelSprite(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelSprite(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelTextdraw(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelTextdraw(id, header, payload);
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
static bool DelVehicle(Int32 id, Int32 header, Object & payload)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
|
|
|
return _Core->DelVehicle(id, header, payload);
|
|
|
|
}
|
2016-02-21 00:25:00 +02:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
2016-03-22 04:12:25 +02:00
|
|
|
static void BindEvent(Int32 id, Object & env, Function & func)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
2016-03-22 04:12:25 +02:00
|
|
|
_Core->BindEvent(id, env, func);
|
2016-03-12 22:51:44 +02:00
|
|
|
}
|
2016-02-21 00:25:00 +02:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
2016-03-12 22:51:44 +02:00
|
|
|
static Int32 GetState()
|
|
|
|
{
|
|
|
|
return _Core->GetState();
|
|
|
|
}
|
|
|
|
|
|
|
|
static void SetState(Int32 value)
|
|
|
|
{
|
|
|
|
return _Core->SetState(value);
|
|
|
|
}
|
2016-02-21 00:25:00 +02:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
2016-03-12 22:51:44 +02:00
|
|
|
static CSStr GetOption(CSStr name)
|
|
|
|
{
|
|
|
|
return _Core->GetOption(name);
|
|
|
|
}
|
|
|
|
|
|
|
|
static CSStr GetOptionOr(CSStr name, CSStr value)
|
|
|
|
{
|
|
|
|
return _Core->GetOption(name, value);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void SetOption(CSStr name, CSStr value)
|
|
|
|
{
|
|
|
|
return _Core->SetOption(name, value);
|
|
|
|
}
|
2016-02-21 00:25:00 +02:00
|
|
|
|
2016-03-24 09:32:44 +02:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
static void SetReload(bool toggle)
|
|
|
|
{
|
|
|
|
if (toggle)
|
|
|
|
{
|
|
|
|
EnableReload(0, NullObject());
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
DisableReload();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
static void SetReloadBecause(Int32 header, Object & payload)
|
|
|
|
{
|
|
|
|
EnableReload(header, payload);
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
static bool IsReloading()
|
|
|
|
{
|
|
|
|
return ReloadEnabled();
|
|
|
|
}
|
|
|
|
|
2016-02-21 00:25:00 +02:00
|
|
|
// ================================================================================================
|
|
|
|
void Register_Core(HSQUIRRELVM vm)
|
|
|
|
{
|
|
|
|
RootTable(vm)
|
2016-03-11 20:04:26 +02:00
|
|
|
.Bind(_SC("SqCore"), Table(vm)
|
2016-02-21 00:25:00 +02:00
|
|
|
.Func(_SC("Bind"), &BindEvent)
|
2016-03-24 09:32:44 +02:00
|
|
|
.Func(_SC("Reload"), &SetReload)
|
|
|
|
.Func(_SC("ReloadBecause"), &SetReloadBecause)
|
|
|
|
.Func(_SC("Reloading"), &IsReloading)
|
2016-02-21 00:25:00 +02:00
|
|
|
.Func(_SC("GetState"), &GetState)
|
|
|
|
.Func(_SC("SetState"), &SetState)
|
|
|
|
.Func(_SC("GetOption"), &GetOption)
|
2016-03-11 20:04:26 +02:00
|
|
|
.Func(_SC("GetOptionOr"), &GetOptionOr)
|
2016-02-21 00:25:00 +02:00
|
|
|
.Func(_SC("SetOption"), &SetOption)
|
|
|
|
.Func(_SC("GetBlip"), &GetBlip)
|
|
|
|
.Func(_SC("GetCheckpoint"), &GetCheckpoint)
|
|
|
|
.Func(_SC("GetForcefield"), &GetForcefield)
|
|
|
|
.Func(_SC("GetKeybind"), &GetKeybind)
|
|
|
|
.Func(_SC("GetObject"), &GetObject)
|
|
|
|
.Func(_SC("GetPickup"), &GetPickup)
|
|
|
|
.Func(_SC("GetPlayer"), &GetPlayer)
|
|
|
|
.Func(_SC("GetSprite"), &GetSprite)
|
|
|
|
.Func(_SC("GetTextdraw"), &GetTextdraw)
|
|
|
|
.Func(_SC("GetVehicle"), &GetVehicle)
|
|
|
|
.Func(_SC("DestroyBlip"), &DelBlip)
|
|
|
|
.Func(_SC("DestroyCheckpoint"), &DelCheckpoint)
|
|
|
|
.Func(_SC("DestroyForcefield"), &DelForcefield)
|
|
|
|
.Func(_SC("DestroyKeybind"), &DelKeybind)
|
|
|
|
.Func(_SC("DestroyObject"), &DelObject)
|
|
|
|
.Func(_SC("DestroyPickup"), &DelPickup)
|
|
|
|
.Func(_SC("DestroySprite"), &DelSprite)
|
|
|
|
.Func(_SC("DestroyTextdraw"), &DelTextdraw)
|
|
|
|
.Func(_SC("DestroyVehicle"), &DelVehicle)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
template < Uint8 L, bool S > static SQInteger LogBasicMessage(HSQUIRRELVM vm)
|
|
|
|
{
|
|
|
|
const Int32 top = sq_gettop(vm);
|
2016-03-10 05:57:13 +02:00
|
|
|
// Was the message value specified?
|
2016-02-21 00:25:00 +02:00
|
|
|
if (top <= 1)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
2016-03-10 05:57:13 +02:00
|
|
|
return sq_throwerror(vm, "Missing message value");
|
2016-03-12 22:51:44 +02:00
|
|
|
}
|
2016-03-10 05:57:13 +02:00
|
|
|
// Do we have enough values to call the format function?
|
2016-02-21 00:25:00 +02:00
|
|
|
else if (top > 2)
|
|
|
|
{
|
2016-03-10 05:57:13 +02:00
|
|
|
SStr msg = NULL;
|
2016-02-21 00:25:00 +02:00
|
|
|
SQInteger len = 0;
|
2016-03-10 05:57:13 +02:00
|
|
|
// Attempt to generate the specified string format
|
|
|
|
SQRESULT ret = sqstd_format(vm, 2, &len, &msg);
|
|
|
|
// Did the format failed?
|
|
|
|
if (SQ_FAILED(ret))
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
2016-03-10 05:57:13 +02:00
|
|
|
return ret; // Propagate the exception
|
2016-03-12 22:51:44 +02:00
|
|
|
}
|
2016-03-10 05:57:13 +02:00
|
|
|
// Log the resulted string value
|
|
|
|
_Log->Message(L, S, "%s", msg);
|
2016-02-21 00:25:00 +02:00
|
|
|
}
|
|
|
|
else
|
2016-03-10 05:57:13 +02:00
|
|
|
{
|
|
|
|
// Attempt to retrieve the value from the stack as a string
|
|
|
|
Var< CSStr > msg(vm, 2);
|
|
|
|
// See if the obtained value is a valid string
|
|
|
|
if (!msg.value)
|
2016-03-12 22:51:44 +02:00
|
|
|
{
|
2016-03-10 05:57:13 +02:00
|
|
|
return sq_throwerror(vm, "Unable to retrieve the value");
|
2016-03-12 22:51:44 +02:00
|
|
|
}
|
2016-03-10 05:57:13 +02:00
|
|
|
// Log the resulted string value
|
|
|
|
_Log->Message(L, S, "%s", msg.value);
|
|
|
|
}
|
|
|
|
// This function does not return a value
|
|
|
|
return 1;
|
2016-02-21 00:25:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// ================================================================================================
|
|
|
|
void Register_Log(HSQUIRRELVM vm)
|
|
|
|
{
|
|
|
|
RootTable(vm)
|
2016-02-23 05:23:56 +02:00
|
|
|
.Bind(_SC("SqLog"), Table(vm)
|
2016-02-21 00:25:00 +02:00
|
|
|
.SquirrelFunc(_SC("Dbg"), &LogBasicMessage< LL_DBG, false >)
|
|
|
|
.SquirrelFunc(_SC("Usr"), &LogBasicMessage< LL_USR, false >)
|
|
|
|
.SquirrelFunc(_SC("Scs"), &LogBasicMessage< LL_SCS, false >)
|
|
|
|
.SquirrelFunc(_SC("Inf"), &LogBasicMessage< LL_INF, false >)
|
|
|
|
.SquirrelFunc(_SC("Wrn"), &LogBasicMessage< LL_WRN, false >)
|
|
|
|
.SquirrelFunc(_SC("Err"), &LogBasicMessage< LL_ERR, false >)
|
|
|
|
.SquirrelFunc(_SC("Ftl"), &LogBasicMessage< LL_FTL, false >)
|
|
|
|
.SquirrelFunc(_SC("SDbg"), &LogBasicMessage< LL_DBG, true >)
|
|
|
|
.SquirrelFunc(_SC("SUsr"), &LogBasicMessage< LL_USR, true >)
|
|
|
|
.SquirrelFunc(_SC("SScs"), &LogBasicMessage< LL_SCS, true >)
|
|
|
|
.SquirrelFunc(_SC("SInf"), &LogBasicMessage< LL_INF, true >)
|
|
|
|
.SquirrelFunc(_SC("SWrn"), &LogBasicMessage< LL_WRN, true >)
|
|
|
|
.SquirrelFunc(_SC("SErr"), &LogBasicMessage< LL_ERR, true >)
|
|
|
|
.SquirrelFunc(_SC("SFtl"), &LogBasicMessage< LL_FTL, true >)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // Namespace:: SqMod
|