2016-02-27 11:57:10 +02:00
|
|
|
//
|
|
|
|
// SqModule: API used to communicate with and register squirrel modules
|
|
|
|
//
|
|
|
|
|
|
|
|
//
|
2016-06-03 21:26:19 +03:00
|
|
|
// Copyright (c) 2016 Sandu Liviu Catalin (aka. S.L.C)
|
2016-02-27 11:57:10 +02:00
|
|
|
//
|
|
|
|
// This software is provided 'as-is', without any express or implied
|
|
|
|
// warranty. In no event will the authors be held liable for any damages
|
|
|
|
// arising from the use of this software.
|
|
|
|
//
|
|
|
|
// Permission is granted to anyone to use this software for any purpose,
|
|
|
|
// including commercial applications, and to alter it and redistribute it
|
|
|
|
// freely, subject to the following restrictions:
|
|
|
|
//
|
|
|
|
// 1. The origin of this software must not be misrepresented; you must not
|
|
|
|
// claim that you wrote the original software. If you use this software
|
|
|
|
// in a product, an acknowledgment in the product documentation would be
|
|
|
|
// appreciated but is not required.
|
|
|
|
//
|
|
|
|
// 2. Altered source versions must be plainly marked as such, and must not be
|
|
|
|
// misrepresented as being the original software.
|
|
|
|
//
|
|
|
|
// 3. This notice may not be removed or altered from any source
|
|
|
|
// distribution.
|
|
|
|
//
|
|
|
|
|
|
|
|
#if !defined(_SQ_MOD_H_)
|
|
|
|
#define _SQ_MOD_H_
|
|
|
|
|
2016-03-27 20:49:57 +03:00
|
|
|
#include <stddef.h>
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
#include "SqAPI.h"
|
|
|
|
#include "vcmp.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**< 64 bits integer types */
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
typedef __int64 SqInt64;
|
|
|
|
typedef unsigned __int64 SqUint64;
|
|
|
|
#else
|
|
|
|
typedef long long SqInt64;
|
|
|
|
typedef unsigned long long SqUint64;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
#define SQMOD_API_EXPORT extern "C" __declspec(dllexport)
|
|
|
|
#elif defined(__GNUC__)
|
|
|
|
#define SQMOD_API_EXPORT extern "C"
|
|
|
|
#else
|
|
|
|
#define SQMOD_API_EXPORT extern "C"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define SQMOD_HOST_NAME "SqModHost"
|
|
|
|
#define SQMOD_INITIALIZE_CMD 0xDABBAD00
|
|
|
|
#define SQMOD_LOAD_CMD 0xDEADBABE
|
|
|
|
#define SQMOD_TERMINATE_CMD 0xDEADC0DE
|
2016-09-02 14:11:39 +03:00
|
|
|
#define SQMOD_CLOSING_CMD 0xBAAAAAAD
|
2016-06-26 16:18:23 +03:00
|
|
|
#define SQMOD_RELEASED_CMD 0xDEADBEAF
|
2016-02-27 11:57:10 +02:00
|
|
|
#define SQMOD_API_VER 1
|
|
|
|
|
2016-03-10 05:57:13 +02:00
|
|
|
//primitive functions
|
2016-07-17 03:24:07 +03:00
|
|
|
typedef HSQUIRRELVM (*SqModAPI_GetSquirrelVM) (void);
|
2016-03-10 05:57:13 +02:00
|
|
|
//logging utilities
|
2016-07-17 03:24:07 +03:00
|
|
|
typedef void (*SqModAPI_LogMessage) (const SQChar * fmt, ...);
|
2016-03-10 05:57:13 +02:00
|
|
|
//script loading
|
2016-07-17 03:24:07 +03:00
|
|
|
typedef SQRESULT (*SqModAPI_LoadScript) (const SQChar * filepath, SQBool delay);
|
2016-02-27 11:57:10 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-06-03 21:26:19 +03:00
|
|
|
* Allows modules to interface with the plug-in API without linking of any sorts
|
2016-02-27 11:57:10 +02:00
|
|
|
*/
|
|
|
|
typedef struct
|
|
|
|
{
|
2016-03-10 05:57:13 +02:00
|
|
|
//primitive functions
|
2016-07-17 03:24:07 +03:00
|
|
|
SqModAPI_GetSquirrelVM GetSquirrelVM;
|
2016-03-10 05:57:13 +02:00
|
|
|
//logging utilities
|
2016-07-17 03:24:07 +03:00
|
|
|
SqModAPI_LogMessage LogDbg;
|
|
|
|
SqModAPI_LogMessage LogUsr;
|
|
|
|
SqModAPI_LogMessage LogScs;
|
|
|
|
SqModAPI_LogMessage LogInf;
|
|
|
|
SqModAPI_LogMessage LogWrn;
|
|
|
|
SqModAPI_LogMessage LogErr;
|
|
|
|
SqModAPI_LogMessage LogFtl;
|
|
|
|
SqModAPI_LogMessage LogSDbg;
|
|
|
|
SqModAPI_LogMessage LogSUsr;
|
|
|
|
SqModAPI_LogMessage LogSScs;
|
|
|
|
SqModAPI_LogMessage LogSInf;
|
|
|
|
SqModAPI_LogMessage LogSWrn;
|
|
|
|
SqModAPI_LogMessage LogSErr;
|
|
|
|
SqModAPI_LogMessage LogSFtl;
|
2016-03-10 05:57:13 +02:00
|
|
|
//script loading
|
2016-07-17 03:24:07 +03:00
|
|
|
SqModAPI_LoadScript LoadScript;
|
|
|
|
} sq_modapi, SQMODAPI, *HSQMODAPI;
|
2016-02-27 11:57:10 +02:00
|
|
|
|
2016-07-04 16:26:39 +03:00
|
|
|
#ifdef SQMOD_PLUGIN_API
|
|
|
|
|
|
|
|
//primitive functions
|
2016-07-17 03:24:07 +03:00
|
|
|
extern SqModAPI_GetSquirrelVM SqMod_GetSquirrelVM;
|
2016-07-04 16:26:39 +03:00
|
|
|
|
|
|
|
//logging utilities
|
2016-07-17 03:24:07 +03:00
|
|
|
extern SqModAPI_LogMessage SqMod_LogDbg;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogUsr;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogScs;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogInf;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogWrn;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogErr;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogFtl;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogSDbg;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogSUsr;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogSScs;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogSInf;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogSWrn;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogSErr;
|
|
|
|
extern SqModAPI_LogMessage SqMod_LogSFtl;
|
2016-07-04 16:26:39 +03:00
|
|
|
|
|
|
|
//script loading
|
2016-07-17 03:24:07 +03:00
|
|
|
extern SqModAPI_LoadScript SqMod_LoadScript;
|
2016-07-04 16:26:39 +03:00
|
|
|
|
|
|
|
#endif // SQMOD_PLUGIN_API
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-07-17 03:24:07 +03:00
|
|
|
* The structure exported by the host plug-in to import the module and squirrel API.
|
2016-02-27 11:57:10 +02:00
|
|
|
*/
|
2016-07-17 03:24:07 +03:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
unsigned int StructSize;
|
|
|
|
//base functions
|
|
|
|
int32_t (*PopulateModuleAPI) (HSQMODAPI api, size_t size);
|
|
|
|
int32_t (*PopulateSquirrelAPI) (HSQLIBAPI api, size_t size);
|
|
|
|
} sq_modexports, SQMODEXPORTS, *HSQMODEXPORTS;
|
2016-02-27 11:57:10 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Assign the functions from the specified API structure into the global functions.
|
|
|
|
*/
|
2016-07-17 03:24:07 +03:00
|
|
|
SQUIRREL_API uint8_t sqmod_api_expand(HSQMODAPI sqmodapi);
|
2016-02-27 11:57:10 +02:00
|
|
|
|
2016-07-04 16:26:39 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Assign the functions from the specified API structure into the global functions.
|
|
|
|
*/
|
2016-07-17 03:24:07 +03:00
|
|
|
SQUIRREL_API uint8_t sqlib_api_expand(HSQLIBAPI sqlibapi);
|
2016-07-04 16:26:39 +03:00
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-07-17 03:24:07 +03:00
|
|
|
* Undo changes done by sqmod_api_expand.
|
2016-02-27 11:57:10 +02:00
|
|
|
*/
|
2016-07-17 03:24:07 +03:00
|
|
|
SQUIRREL_API void sqmod_api_collapse();
|
2016-02-27 11:57:10 +02:00
|
|
|
|
2016-07-04 16:26:39 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-07-17 03:24:07 +03:00
|
|
|
* Undo changes done by sq_api_expand.
|
2016-07-04 16:26:39 +03:00
|
|
|
*/
|
2016-07-17 03:24:07 +03:00
|
|
|
SQUIRREL_API void sqlib_api_collapse();
|
2016-07-04 16:26:39 +03:00
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
} /*extern "C"*/
|
|
|
|
#endif
|
|
|
|
|
2016-07-17 03:24:07 +03:00
|
|
|
#endif /*_SQ_MOD_H_*/
|