2016-12-18 04:43:04 +00:00
|
|
|
/*
|
|
|
|
===========================================================================
|
|
|
|
Copyright (C) 1999-2005 Id Software, Inc.
|
|
|
|
|
|
|
|
This file is part of Quake III Arena source code.
|
|
|
|
|
|
|
|
Quake III Arena source code is free software; you can redistribute it
|
|
|
|
and/or modify it under the terms of the GNU General Public License as
|
|
|
|
published by the Free Software Foundation; either version 2 of the License,
|
|
|
|
or (at your option) any later version.
|
|
|
|
|
|
|
|
Quake III Arena source code is distributed in the hope that it will be
|
|
|
|
useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with Quake III Arena source code; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
===========================================================================
|
|
|
|
*/
|
|
|
|
//
|
|
|
|
|
|
|
|
// g_public.h -- engine calls and types exposed to the game module
|
|
|
|
// A user mod should never modify this file
|
|
|
|
|
|
|
|
#define GAME_API_VERSION 8
|
|
|
|
|
|
|
|
// entity->svFlags
|
|
|
|
// the server does not know how to interpret most of the values
|
|
|
|
// in entityStates (level eType), so the game must explicitly flag
|
|
|
|
// special server behaviors
|
|
|
|
#define SVF_NOCLIENT 0x00000001 // don't send entity to clients, even if it has effects
|
|
|
|
#define SVF_CLIENTMASK 0x00000002 // send to a specific subset of clients
|
|
|
|
#define SVF_BOT 0x00000008 // set if the entity is a bot
|
|
|
|
#define SVF_BROADCAST 0x00000020 // send to all connected clients
|
|
|
|
#define SVF_PORTAL 0x00000040 // merge a second pvs at origin2 into snapshots
|
|
|
|
#define SVF_USE_CURRENT_ORIGIN 0x00000080 // entity->r.currentOrigin instead of entity->s.origin
|
|
|
|
// for link position (missiles and movers)
|
|
|
|
#define SVF_SINGLECLIENT 0x00000100 // only send to a single client (entityShared_t->singleClient)
|
|
|
|
#define SVF_NOSERVERINFO 0x00000200 // don't send CS_SERVERINFO updates to this client
|
|
|
|
// so that it can be updated for ping tools without
|
|
|
|
// lagging clients
|
|
|
|
#define SVF_CAPSULE 0x00000400 // use capsule for collision detection instead of bbox
|
|
|
|
#define SVF_NOTSINGLECLIENT 0x00000800 // send entity to everyone but one client
|
|
|
|
// (entityShared_t->singleClient)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//===============================================================
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
entityState_t s; // communicated by server to clients
|
|
|
|
|
|
|
|
qboolean linked; // qfalse if not in any good cluster
|
|
|
|
int linkcount;
|
|
|
|
|
|
|
|
int svFlags; // SVF_NOCLIENT, SVF_BROADCAST, etc
|
|
|
|
|
|
|
|
// only send to this client when SVF_SINGLECLIENT is set
|
|
|
|
// if SVF_CLIENTMASK is set, use as bitmask of clients to send to
|
|
|
|
// (maxclients must be <= 32, up to the mod to enforce this)
|
|
|
|
int singleClient;
|
|
|
|
|
|
|
|
qboolean bmodel; // if false, assume an explicit mins / maxs bounding box
|
|
|
|
// only set by trap_SetBrushModel
|
|
|
|
vec3_t mins, maxs;
|
|
|
|
int contents; // CONTENTS_TRIGGER, CONTENTS_SOLID, CONTENTS_BODY, etc
|
|
|
|
// a non-solid entity should set to 0
|
|
|
|
|
|
|
|
vec3_t absmin, absmax; // derived from mins/maxs and origin + rotation
|
|
|
|
|
|
|
|
// currentOrigin will be used for all collision detection and world linking.
|
|
|
|
// it will not necessarily be the same as the trajectory evaluation for the current
|
|
|
|
// time, because each entity must be moved one at a time after time is advanced
|
|
|
|
// to avoid simultanious collision issues
|
|
|
|
vec3_t currentOrigin;
|
|
|
|
vec3_t currentAngles;
|
|
|
|
|
|
|
|
// when a trace call is made and passEntityNum != ENTITYNUM_NONE,
|
|
|
|
// an ent will be excluded from testing if:
|
|
|
|
// ent->s.number == passEntityNum (don't interact with self)
|
|
|
|
// ent->s.ownerNum = passEntityNum (don't interact with your own missiles)
|
|
|
|
// entity[ent->s.ownerNum].ownerNum = passEntityNum (don't interact with other missiles from owner)
|
|
|
|
int ownerNum;
|
|
|
|
} entityShared_t;
|
|
|
|
|
|
|
|
|
|
|
|
// the server looks at a sharedEntity, which is the start of the game's gentity_t structure
|
|
|
|
typedef struct {
|
|
|
|
entityState_t s; // communicated by server to clients
|
|
|
|
entityShared_t r; // shared by both the server system and game
|
|
|
|
} sharedEntity_t;
|
|
|
|
|
|
|
|
// the actual contents of a gentity_t are the game's business,
|
|
|
|
// provided the first two elements EXACTLY MATCH sharedEntity_t
|
|
|
|
typedef struct gentity_s gentity_t;
|
|
|
|
|
|
|
|
|
|
|
|
//===============================================================
|
|
|
|
|
|
|
|
//
|
|
|
|
// system traps provided by the main engine
|
|
|
|
//
|
|
|
|
typedef enum {
|
|
|
|
//============== general Quake services ==================
|
|
|
|
|
|
|
|
G_PRINT, // ( const char *string );
|
|
|
|
// print message on the local console
|
|
|
|
|
|
|
|
G_ERROR, // ( const char *string );
|
|
|
|
// abort the game
|
|
|
|
|
|
|
|
G_MILLISECONDS, // ( void );
|
|
|
|
// get current time for profiling reasons
|
|
|
|
// this should NOT be used for any game related tasks,
|
|
|
|
// because it is not journaled
|
|
|
|
|
|
|
|
// console variable interaction
|
|
|
|
G_CVAR_REGISTER, // ( vmCvar_t *vmCvar, const char *varName, const char *defaultValue, int flags );
|
|
|
|
G_CVAR_UPDATE, // ( vmCvar_t *vmCvar );
|
|
|
|
G_CVAR_SET, // ( const char *var_name, const char *value );
|
|
|
|
G_CVAR_VARIABLE_INTEGER_VALUE, // ( const char *var_name );
|
|
|
|
G_CVAR_VARIABLE_STRING_BUFFER, // ( const char *var_name, char *buffer, int bufsize );
|
|
|
|
|
|
|
|
// ClientCommand and ServerCommand parameter access
|
|
|
|
G_ARGC, // ( void );
|
|
|
|
G_ARGV, // ( int n, char *buffer, int bufferLength );
|
|
|
|
|
|
|
|
G_FS_FOPEN_FILE, // ( const char *qpath, fileHandle_t *file, fsMode_t mode );
|
|
|
|
G_FS_READ, // ( void *buffer, int len, fileHandle_t f );
|
|
|
|
G_FS_WRITE, // ( const void *buffer, int len, fileHandle_t f );
|
|
|
|
G_FS_FCLOSE_FILE, // ( fileHandle_t f );
|
|
|
|
|
|
|
|
G_SEND_CONSOLE_COMMAND, // ( const char *text );
|
|
|
|
// add commands to the console as if they were typed in
|
|
|
|
// for map changing, etc
|
|
|
|
|
|
|
|
|
|
|
|
//=========== server specific functionality =============
|
|
|
|
|
|
|
|
G_LOCATE_GAME_DATA, // ( gentity_t *gEnts, int numGEntities, int sizeofGEntity_t,
|
|
|
|
// playerState_t *clients, int sizeofGameClient );
|
|
|
|
// the game needs to let the server system know where and how big the gentities
|
|
|
|
// are, so it can look at them directly without going through an interface
|
|
|
|
|
|
|
|
G_DROP_CLIENT, // ( int clientNum, const char *reason );
|
|
|
|
// kick a client off the server with a message
|
|
|
|
|
|
|
|
G_SEND_SERVER_COMMAND, // ( int clientNum, const char *fmt, ... );
|
|
|
|
// reliably sends a command string to be interpreted by the given
|
|
|
|
// client. If clientNum is -1, it will be sent to all clients
|
|
|
|
|
|
|
|
G_SET_CONFIGSTRING, // ( int num, const char *string );
|
|
|
|
// config strings hold all the index strings, and various other information
|
|
|
|
// that is reliably communicated to all clients
|
|
|
|
// All of the current configstrings are sent to clients when
|
|
|
|
// they connect, and changes are sent to all connected clients.
|
|
|
|
// All confgstrings are cleared at each level start.
|
|
|
|
|
|
|
|
G_GET_CONFIGSTRING, // ( int num, char *buffer, int bufferSize );
|
|
|
|
|
|
|
|
G_GET_USERINFO, // ( int num, char *buffer, int bufferSize );
|
|
|
|
// userinfo strings are maintained by the server system, so they
|
|
|
|
// are persistant across level loads, while all other game visible
|
|
|
|
// data is completely reset
|
|
|
|
|
|
|
|
G_SET_USERINFO, // ( int num, const char *buffer );
|
|
|
|
|
|
|
|
G_GET_SERVERINFO, // ( char *buffer, int bufferSize );
|
|
|
|
// the serverinfo info string has all the cvars visible to server browsers
|
|
|
|
|
|
|
|
G_SET_BRUSH_MODEL, // ( gentity_t *ent, const char *name );
|
|
|
|
// sets mins and maxs based on the brushmodel name
|
|
|
|
|
|
|
|
G_TRACE, // ( trace_t *results, const vec3_t start, const vec3_t mins, const vec3_t maxs, const vec3_t end, int passEntityNum, int contentmask );
|
|
|
|
// collision detection against all linked entities
|
|
|
|
|
|
|
|
G_POINT_CONTENTS, // ( const vec3_t point, int passEntityNum );
|
|
|
|
// point contents against all linked entities
|
|
|
|
|
|
|
|
G_IN_PVS, // ( const vec3_t p1, const vec3_t p2 );
|
|
|
|
|
|
|
|
G_IN_PVS_IGNORE_PORTALS, // ( const vec3_t p1, const vec3_t p2 );
|
|
|
|
|
|
|
|
G_ADJUST_AREA_PORTAL_STATE, // ( gentity_t *ent, qboolean open );
|
|
|
|
|
|
|
|
G_AREAS_CONNECTED, // ( int area1, int area2 );
|
|
|
|
|
|
|
|
G_LINKENTITY, // ( gentity_t *ent );
|
|
|
|
// an entity will never be sent to a client or used for collision
|
|
|
|
// if it is not passed to linkentity. If the size, position, or
|
|
|
|
// solidity changes, it must be relinked.
|
|
|
|
|
|
|
|
G_UNLINKENTITY, // ( gentity_t *ent );
|
|
|
|
// call before removing an interactive entity
|
|
|
|
|
|
|
|
G_ENTITIES_IN_BOX, // ( const vec3_t mins, const vec3_t maxs, gentity_t **list, int maxcount );
|
|
|
|
// EntitiesInBox will return brush models based on their bounding box,
|
|
|
|
// so exact determination must still be done with EntityContact
|
|
|
|
|
|
|
|
G_ENTITY_CONTACT, // ( const vec3_t mins, const vec3_t maxs, const gentity_t *ent );
|
|
|
|
// perform an exact check against inline brush models of non-square shape
|
|
|
|
|
|
|
|
// access for bots to get and free a server client (FIXME?)
|
|
|
|
G_BOT_ALLOCATE_CLIENT, // ( void );
|
|
|
|
|
|
|
|
G_BOT_FREE_CLIENT, // ( int clientNum );
|
|
|
|
|
|
|
|
G_GET_USERCMD, // ( int clientNum, usercmd_t *cmd )
|
|
|
|
|
|
|
|
G_GET_ENTITY_TOKEN, // qboolean ( char *buffer, int bufferSize )
|
|
|
|
// Retrieves the next string token from the entity spawn text, returning
|
|
|
|
// false when all tokens have been parsed.
|
|
|
|
// This should only be done at GAME_INIT time.
|
|
|
|
|
|
|
|
G_FS_GETFILELIST,
|
|
|
|
G_DEBUG_POLYGON_CREATE,
|
|
|
|
G_DEBUG_POLYGON_DELETE,
|
|
|
|
G_REAL_TIME,
|
|
|
|
DO_NOT_WANT_G_SNAPVECTOR,
|
|
|
|
|
|
|
|
G_TRACECAPSULE, // ( trace_t *results, const vec3_t start, const vec3_t mins, const vec3_t maxs, const vec3_t end, int passEntityNum, int contentmask );
|
|
|
|
G_ENTITY_CONTACTCAPSULE, // ( const vec3_t mins, const vec3_t maxs, const gentity_t *ent );
|
|
|
|
|
|
|
|
// 1.32
|
|
|
|
G_FS_SEEK,
|
|
|
|
|
|
|
|
BOTLIB_SETUP = 200, // ( void );
|
|
|
|
BOTLIB_SHUTDOWN, // ( void );
|
|
|
|
BOTLIB_LIBVAR_SET,
|
|
|
|
BOTLIB_LIBVAR_GET,
|
|
|
|
BOTLIB_PC_ADD_GLOBAL_DEFINE,
|
|
|
|
BOTLIB_START_FRAME,
|
|
|
|
BOTLIB_LOAD_MAP,
|
|
|
|
BOTLIB_UPDATENTITY,
|
|
|
|
BOTLIB_TEST,
|
|
|
|
|
|
|
|
BOTLIB_GET_SNAPSHOT_ENTITY, // ( int client, int ent );
|
|
|
|
BOTLIB_GET_CONSOLE_MESSAGE, // ( int client, char *message, int size );
|
|
|
|
BOTLIB_USER_COMMAND, // ( int client, usercmd_t *ucmd );
|
|
|
|
|
|
|
|
BOTLIB_AAS_ENABLE_ROUTING_AREA = 300,
|
|
|
|
BOTLIB_AAS_BBOX_AREAS,
|
|
|
|
BOTLIB_AAS_AREA_INFO,
|
|
|
|
BOTLIB_AAS_ENTITY_INFO,
|
|
|
|
|
|
|
|
BOTLIB_AAS_INITIALIZED,
|
|
|
|
BOTLIB_AAS_PRESENCE_TYPE_BOUNDING_BOX,
|
|
|
|
BOTLIB_AAS_TIME,
|
|
|
|
|
|
|
|
BOTLIB_AAS_POINT_AREA_NUM,
|
|
|
|
BOTLIB_AAS_TRACE_AREAS,
|
|
|
|
|
|
|
|
BOTLIB_AAS_POINT_CONTENTS,
|
|
|
|
BOTLIB_AAS_NEXT_BSP_ENTITY,
|
|
|
|
BOTLIB_AAS_VALUE_FOR_BSP_EPAIR_KEY,
|
|
|
|
BOTLIB_AAS_VECTOR_FOR_BSP_EPAIR_KEY,
|
|
|
|
BOTLIB_AAS_FLOAT_FOR_BSP_EPAIR_KEY,
|
|
|
|
BOTLIB_AAS_INT_FOR_BSP_EPAIR_KEY,
|
|
|
|
|
|
|
|
BOTLIB_AAS_AREA_REACHABILITY,
|
|
|
|
|
|
|
|
BOTLIB_AAS_AREA_TRAVEL_TIME_TO_GOAL_AREA,
|
|
|
|
|
|
|
|
BOTLIB_AAS_SWIMMING,
|
|
|
|
BOTLIB_AAS_PREDICT_CLIENT_MOVEMENT,
|
|
|
|
|
|
|
|
BOTLIB_EA_SAY = 400,
|
|
|
|
BOTLIB_EA_SAY_TEAM,
|
|
|
|
BOTLIB_EA_COMMAND,
|
|
|
|
|
|
|
|
BOTLIB_EA_ACTION,
|
|
|
|
BOTLIB_EA_GESTURE,
|
|
|
|
BOTLIB_EA_TALK,
|
|
|
|
BOTLIB_EA_ATTACK,
|
|
|
|
BOTLIB_EA_USE,
|
|
|
|
BOTLIB_EA_RESPAWN,
|
|
|
|
BOTLIB_EA_CROUCH,
|
|
|
|
BOTLIB_EA_MOVE_UP,
|
|
|
|
BOTLIB_EA_MOVE_DOWN,
|
|
|
|
BOTLIB_EA_MOVE_FORWARD,
|
|
|
|
BOTLIB_EA_MOVE_BACK,
|
|
|
|
BOTLIB_EA_MOVE_LEFT,
|
|
|
|
BOTLIB_EA_MOVE_RIGHT,
|
|
|
|
|
|
|
|
BOTLIB_EA_SELECT_WEAPON,
|
|
|
|
BOTLIB_EA_JUMP,
|
|
|
|
BOTLIB_EA_DELAYED_JUMP,
|
|
|
|
BOTLIB_EA_MOVE,
|
|
|
|
BOTLIB_EA_VIEW,
|
|
|
|
|
|
|
|
BOTLIB_EA_END_REGULAR,
|
|
|
|
BOTLIB_EA_GET_INPUT,
|
|
|
|
BOTLIB_EA_RESET_INPUT,
|
|
|
|
|
|
|
|
|
|
|
|
BOTLIB_AI_LOAD_CHARACTER = 500,
|
|
|
|
BOTLIB_AI_FREE_CHARACTER,
|
|
|
|
BOTLIB_AI_CHARACTERISTIC_FLOAT,
|
|
|
|
BOTLIB_AI_CHARACTERISTIC_BFLOAT,
|
|
|
|
BOTLIB_AI_CHARACTERISTIC_INTEGER,
|
|
|
|
BOTLIB_AI_CHARACTERISTIC_BINTEGER,
|
|
|
|
BOTLIB_AI_CHARACTERISTIC_STRING,
|
|
|
|
|
|
|
|
BOTLIB_AI_ALLOC_CHAT_STATE,
|
|
|
|
BOTLIB_AI_FREE_CHAT_STATE,
|
|
|
|
BOTLIB_AI_QUEUE_CONSOLE_MESSAGE,
|
|
|
|
BOTLIB_AI_REMOVE_CONSOLE_MESSAGE,
|
|
|
|
BOTLIB_AI_NEXT_CONSOLE_MESSAGE,
|
|
|
|
BOTLIB_AI_NUM_CONSOLE_MESSAGE,
|
|
|
|
BOTLIB_AI_INITIAL_CHAT,
|
|
|
|
BOTLIB_AI_REPLY_CHAT,
|
|
|
|
BOTLIB_AI_CHAT_LENGTH,
|
|
|
|
BOTLIB_AI_ENTER_CHAT,
|
|
|
|
BOTLIB_AI_STRING_CONTAINS,
|
|
|
|
BOTLIB_AI_FIND_MATCH,
|
|
|
|
BOTLIB_AI_MATCH_VARIABLE,
|
|
|
|
BOTLIB_AI_UNIFY_WHITE_SPACES,
|
|
|
|
BOTLIB_AI_REPLACE_SYNONYMS,
|
|
|
|
BOTLIB_AI_LOAD_CHAT_FILE,
|
|
|
|
BOTLIB_AI_SET_CHAT_GENDER,
|
|
|
|
BOTLIB_AI_SET_CHAT_NAME,
|
|
|
|
|
|
|
|
BOTLIB_AI_RESET_GOAL_STATE,
|
|
|
|
BOTLIB_AI_RESET_AVOID_GOALS,
|
|
|
|
BOTLIB_AI_PUSH_GOAL,
|
|
|
|
BOTLIB_AI_POP_GOAL,
|
|
|
|
BOTLIB_AI_EMPTY_GOAL_STACK,
|
|
|
|
BOTLIB_AI_DUMP_AVOID_GOALS,
|
|
|
|
BOTLIB_AI_DUMP_GOAL_STACK,
|
|
|
|
BOTLIB_AI_GOAL_NAME,
|
|
|
|
BOTLIB_AI_GET_TOP_GOAL,
|
|
|
|
BOTLIB_AI_GET_SECOND_GOAL,
|
|
|
|
BOTLIB_AI_CHOOSE_LTG_ITEM,
|
|
|
|
BOTLIB_AI_CHOOSE_NBG_ITEM,
|
|
|
|
BOTLIB_AI_TOUCHING_GOAL,
|
|
|
|
BOTLIB_AI_ITEM_GOAL_IN_VIS_BUT_NOT_VISIBLE,
|
|
|
|
BOTLIB_AI_GET_LEVEL_ITEM_GOAL,
|
|
|
|
BOTLIB_AI_AVOID_GOAL_TIME,
|
|
|
|
BOTLIB_AI_INIT_LEVEL_ITEMS,
|
|
|
|
BOTLIB_AI_UPDATE_ENTITY_ITEMS,
|
|
|
|
BOTLIB_AI_LOAD_ITEM_WEIGHTS,
|
|
|
|
BOTLIB_AI_FREE_ITEM_WEIGHTS,
|
|
|
|
BOTLIB_AI_SAVE_GOAL_FUZZY_LOGIC,
|
|
|
|
BOTLIB_AI_ALLOC_GOAL_STATE,
|
|
|
|
BOTLIB_AI_FREE_GOAL_STATE,
|
|
|
|
|
|
|
|
BOTLIB_AI_RESET_MOVE_STATE,
|
|
|
|
BOTLIB_AI_MOVE_TO_GOAL,
|
|
|
|
BOTLIB_AI_MOVE_IN_DIRECTION,
|
|
|
|
BOTLIB_AI_RESET_AVOID_REACH,
|
|
|
|
BOTLIB_AI_RESET_LAST_AVOID_REACH,
|
|
|
|
BOTLIB_AI_REACHABILITY_AREA,
|
|
|
|
BOTLIB_AI_MOVEMENT_VIEW_TARGET,
|
|
|
|
BOTLIB_AI_ALLOC_MOVE_STATE,
|
|
|
|
BOTLIB_AI_FREE_MOVE_STATE,
|
|
|
|
BOTLIB_AI_INIT_MOVE_STATE,
|
|
|
|
|
|
|
|
BOTLIB_AI_CHOOSE_BEST_FIGHT_WEAPON,
|
|
|
|
BOTLIB_AI_GET_WEAPON_INFO,
|
|
|
|
BOTLIB_AI_LOAD_WEAPON_WEIGHTS,
|
|
|
|
BOTLIB_AI_ALLOC_WEAPON_STATE,
|
|
|
|
BOTLIB_AI_FREE_WEAPON_STATE,
|
|
|
|
BOTLIB_AI_RESET_WEAPON_STATE,
|
|
|
|
|
|
|
|
BOTLIB_AI_GENETIC_PARENTS_AND_CHILD_SELECTION,
|
|
|
|
BOTLIB_AI_INTERBREED_GOAL_FUZZY_LOGIC,
|
|
|
|
BOTLIB_AI_MUTATE_GOAL_FUZZY_LOGIC,
|
|
|
|
BOTLIB_AI_GET_NEXT_CAMP_SPOT_GOAL,
|
|
|
|
BOTLIB_AI_GET_MAP_LOCATION_GOAL,
|
|
|
|
BOTLIB_AI_NUM_INITIAL_CHATS,
|
|
|
|
BOTLIB_AI_GET_CHAT_MESSAGE,
|
|
|
|
BOTLIB_AI_REMOVE_FROM_AVOID_GOALS,
|
|
|
|
BOTLIB_AI_PREDICT_VISIBLE_POSITION,
|
|
|
|
|
|
|
|
BOTLIB_AI_SET_AVOID_GOAL_TIME,
|
|
|
|
BOTLIB_AI_ADD_AVOID_SPOT,
|
|
|
|
BOTLIB_AAS_ALTERNATIVE_ROUTE_GOAL,
|
|
|
|
BOTLIB_AAS_PREDICT_ROUTE,
|
|
|
|
BOTLIB_AAS_POINT_REACHABILITY_AREA_INDEX,
|
|
|
|
|
|
|
|
BOTLIB_PC_LOAD_SOURCE,
|
|
|
|
BOTLIB_PC_FREE_SOURCE,
|
|
|
|
BOTLIB_PC_READ_TOKEN,
|
2017-06-22 05:15:47 +00:00
|
|
|
BOTLIB_PC_SOURCE_FILE_AND_LINE,
|
2016-12-18 04:43:04 +00:00
|
|
|
|
2017-06-22 05:15:47 +00:00
|
|
|
// engine extensions
|
|
|
|
// the mod should _never_ use these symbols
|
|
|
|
G_EXT_GETVALUE = 700,
|
2017-10-03 17:11:10 +00:00
|
|
|
G_EXT_LOCATEINTEROPDATA,
|
|
|
|
G_EXT_CVAR_SETRANGE,
|
|
|
|
G_EXT_CVAR_SETHELP,
|
2017-11-10 19:21:03 +00:00
|
|
|
G_EXT_CMD_SETHELP,
|
|
|
|
G_EXT_ERROR2
|
2016-12-18 04:43:04 +00:00
|
|
|
} gameImport_t;
|
|
|
|
|
|
|
|
|
|
|
|
void trap_Printf( const char *fmt );
|
|
|
|
void trap_Error( const char *fmt );
|
|
|
|
int trap_Milliseconds( void );
|
|
|
|
int trap_RealTime( qtime_t *qtime );
|
|
|
|
int trap_Argc( void );
|
|
|
|
void trap_Argv( int n, char *buffer, int bufferLength );
|
|
|
|
void trap_Args( char *buffer, int bufferLength );
|
|
|
|
int trap_FS_FOpenFile( const char *qpath, fileHandle_t *f, fsMode_t mode );
|
|
|
|
void trap_FS_Read( void *buffer, int len, fileHandle_t f );
|
|
|
|
void trap_FS_Write( const void *buffer, int len, fileHandle_t f );
|
|
|
|
void trap_FS_FCloseFile( fileHandle_t f );
|
|
|
|
int trap_FS_GetFileList( const char *path, const char *extension, char *listbuf, int bufsize );
|
|
|
|
int trap_FS_Seek( fileHandle_t f, long offset, fsOrigin_t origin );
|
|
|
|
void trap_Cvar_Register( vmCvar_t *cvar, const char *var_name, const char *value, int flags );
|
|
|
|
void trap_Cvar_Update( vmCvar_t *cvar );
|
|
|
|
void trap_Cvar_Set( const char *var_name, const char *value );
|
|
|
|
int trap_Cvar_VariableIntegerValue( const char *var_name );
|
|
|
|
float trap_Cvar_VariableValue( const char *var_name );
|
|
|
|
void trap_Cvar_VariableStringBuffer( const char *var_name, char *buffer, int bufsize );
|
|
|
|
void trap_LocateGameData( gentity_t *gEnts, int numGEntities, int sizeofGEntity_t, playerState_t *gameClients, int sizeofGameClient );
|
|
|
|
void trap_DropClient( int clientNum, const char *reason );
|
|
|
|
void trap_SendServerCommand( int clientNum, const char *text );
|
|
|
|
void trap_SetConfigstring( int num, const char *string );
|
|
|
|
void trap_GetConfigstring( int num, char *buffer, int bufferSize );
|
|
|
|
void trap_GetUserinfo( int num, char *buffer, int bufferSize );
|
|
|
|
void trap_SetUserinfo( int num, const char *buffer );
|
|
|
|
void trap_GetServerinfo( char *buffer, int bufferSize );
|
|
|
|
void trap_SetBrushModel( gentity_t *ent, const char *name );
|
|
|
|
void trap_Trace( trace_t *results, const vec3_t start, const vec3_t mins, const vec3_t maxs, const vec3_t end, int passEntityNum, int contentmask );
|
|
|
|
int trap_PointContents( const vec3_t point, int passEntityNum );
|
|
|
|
qboolean trap_InPVS( const vec3_t p1, const vec3_t p2 );
|
|
|
|
qboolean trap_InPVSIgnorePortals( const vec3_t p1, const vec3_t p2 );
|
|
|
|
void trap_AdjustAreaPortalState( gentity_t *ent, qboolean open );
|
|
|
|
qboolean trap_AreasConnected( int area1, int area2 );
|
|
|
|
void trap_LinkEntity( gentity_t *ent );
|
|
|
|
void trap_UnlinkEntity( gentity_t *ent );
|
|
|
|
int trap_EntitiesInBox( const vec3_t mins, const vec3_t maxs, int *entityList, int maxcount );
|
|
|
|
qboolean trap_EntityContact( const vec3_t mins, const vec3_t maxs, const gentity_t *ent );
|
|
|
|
int trap_BotAllocateClient( void );
|
|
|
|
void trap_BotFreeClient( int clientNum );
|
|
|
|
void trap_GetUsercmd( int clientNum, usercmd_t *cmd );
|
|
|
|
qboolean trap_GetEntityToken( char *buffer, int bufferSize );
|
|
|
|
|
|
|
|
int trap_DebugPolygonCreate(int color, int numPoints, vec3_t *points);
|
|
|
|
void trap_DebugPolygonDelete(int id);
|
|
|
|
|
|
|
|
int trap_BotLibSetup( void );
|
|
|
|
int trap_BotLibShutdown( void );
|
|
|
|
int trap_BotLibVarSet(char *var_name, char *value);
|
|
|
|
int trap_BotLibVarGet(char *var_name, char *value, int size);
|
|
|
|
int trap_BotLibDefine(char *string);
|
|
|
|
int trap_BotLibStartFrame(float time);
|
|
|
|
int trap_BotLibLoadMap(const char *mapname);
|
|
|
|
int trap_BotLibUpdateEntity(int ent, void /* struct bot_updateentity_s */ *bue);
|
|
|
|
int trap_BotLibTest(int parm0, char *parm1, vec3_t parm2, vec3_t parm3);
|
|
|
|
|
|
|
|
int trap_BotGetSnapshotEntity( int clientNum, int sequence );
|
|
|
|
int trap_BotGetServerCommand(int clientNum, char *message, int size);
|
|
|
|
void trap_BotUserCommand(int client, usercmd_t *ucmd);
|
|
|
|
|
|
|
|
int trap_AAS_BBoxAreas(vec3_t absmins, vec3_t absmaxs, int *areas, int maxareas);
|
|
|
|
int trap_AAS_AreaInfo( int areanum, void /* struct aas_areainfo_s */ *info );
|
|
|
|
void trap_AAS_EntityInfo(int entnum, void /* struct aas_entityinfo_s */ *info);
|
|
|
|
|
|
|
|
int trap_AAS_Initialized(void);
|
|
|
|
void trap_AAS_PresenceTypeBoundingBox(int presencetype, vec3_t mins, vec3_t maxs);
|
|
|
|
float trap_AAS_Time(void);
|
|
|
|
|
|
|
|
int trap_AAS_PointAreaNum(vec3_t point);
|
|
|
|
int trap_AAS_PointReachabilityAreaIndex(vec3_t point);
|
|
|
|
int trap_AAS_TraceAreas(vec3_t start, vec3_t end, int *areas, vec3_t *points, int maxareas);
|
|
|
|
|
|
|
|
int trap_AAS_PointContents(vec3_t point);
|
|
|
|
int trap_AAS_NextBSPEntity(int ent);
|
|
|
|
int trap_AAS_ValueForBSPEpairKey(int ent, char *key, char *value, int size);
|
|
|
|
int trap_AAS_VectorForBSPEpairKey(int ent, char *key, vec3_t v);
|
|
|
|
int trap_AAS_FloatForBSPEpairKey(int ent, char *key, float *value);
|
|
|
|
int trap_AAS_IntForBSPEpairKey(int ent, char *key, int *value);
|
|
|
|
|
|
|
|
int trap_AAS_AreaReachability(int areanum);
|
|
|
|
|
|
|
|
int trap_AAS_AreaTravelTimeToGoalArea( int areanum, const vec3_t origin, int goalareanum, int travelflags );
|
|
|
|
int trap_AAS_EnableRoutingArea( int areanum, int enable );
|
|
|
|
int trap_AAS_PredictRoute(void /*struct aas_predictroute_s*/ *route, int areanum, vec3_t origin,
|
|
|
|
int goalareanum, int travelflags, int maxareas, int maxtime,
|
|
|
|
int stopevent, int stopcontents, int stoptfl, int stopareanum);
|
|
|
|
|
|
|
|
int trap_AAS_AlternativeRouteGoals(vec3_t start, int startareanum, vec3_t goal, int goalareanum, int travelflags,
|
|
|
|
void /*struct aas_altroutegoal_s*/ *altroutegoals, int maxaltroutegoals,
|
|
|
|
int type);
|
|
|
|
int trap_AAS_Swimming(vec3_t origin);
|
|
|
|
int trap_AAS_PredictClientMovement(void /* aas_clientmove_s */ *move, int entnum, vec3_t origin, int presencetype, int onground, vec3_t velocity, vec3_t cmdmove, int cmdframes, int maxframes, float frametime, int stopevent, int stopareanum, int visualize);
|
|
|
|
|
|
|
|
|
|
|
|
void trap_EA_Say( int client, const char* s );
|
|
|
|
void trap_EA_SayTeam( int client, const char* s );
|
|
|
|
void trap_EA_Command( int client, const char* command );
|
|
|
|
|
|
|
|
void trap_EA_Action(int client, int action);
|
|
|
|
void trap_EA_Gesture(int client);
|
|
|
|
void trap_EA_Talk(int client);
|
|
|
|
void trap_EA_Attack(int client);
|
|
|
|
void trap_EA_Use(int client);
|
|
|
|
void trap_EA_Respawn(int client);
|
|
|
|
void trap_EA_Crouch(int client);
|
|
|
|
void trap_EA_MoveUp(int client);
|
|
|
|
void trap_EA_MoveDown(int client);
|
|
|
|
void trap_EA_MoveForward(int client);
|
|
|
|
void trap_EA_MoveBack(int client);
|
|
|
|
void trap_EA_MoveLeft(int client);
|
|
|
|
void trap_EA_MoveRight(int client);
|
|
|
|
void trap_EA_SelectWeapon(int client, int weapon);
|
|
|
|
void trap_EA_Jump(int client);
|
|
|
|
void trap_EA_DelayedJump(int client);
|
|
|
|
void trap_EA_Move(int client, vec3_t dir, float speed);
|
|
|
|
void trap_EA_View(int client, vec3_t viewangles);
|
|
|
|
|
|
|
|
void trap_EA_EndRegular(int client, float thinktime);
|
|
|
|
void trap_EA_GetInput(int client, float thinktime, void /* struct bot_input_s */ *input);
|
|
|
|
void trap_EA_ResetInput(int client);
|
|
|
|
|
|
|
|
|
|
|
|
int trap_BotLoadCharacter(char *charfile, float skill);
|
|
|
|
void trap_BotFreeCharacter(int character);
|
|
|
|
float trap_Characteristic_Float(int character, int index);
|
|
|
|
float trap_Characteristic_BFloat(int character, int index, float min, float max);
|
|
|
|
int trap_Characteristic_Integer(int character, int index);
|
|
|
|
int trap_Characteristic_BInteger(int character, int index, int min, int max);
|
|
|
|
void trap_Characteristic_String(int character, int index, char *buf, int size);
|
|
|
|
|
|
|
|
int trap_BotAllocChatState(void);
|
|
|
|
void trap_BotFreeChatState(int handle);
|
|
|
|
void trap_BotQueueConsoleMessage(int chatstate, int type, char *message);
|
|
|
|
void trap_BotRemoveConsoleMessage(int chatstate, int handle);
|
|
|
|
int trap_BotNextConsoleMessage(int chatstate, void /* struct bot_consolemessage_s */ *cm);
|
|
|
|
int trap_BotNumConsoleMessages(int chatstate);
|
|
|
|
void trap_BotInitialChat(int chatstate, char *type, int mcontext, char *var0, char *var1, char *var2, char *var3, char *var4, char *var5, char *var6, char *var7 );
|
|
|
|
int trap_BotNumInitialChats(int chatstate, char *type);
|
|
|
|
int trap_BotReplyChat(int chatstate, char *message, int mcontext, int vcontext, char *var0, char *var1, char *var2, char *var3, char *var4, char *var5, char *var6, char *var7 );
|
|
|
|
int trap_BotChatLength(int chatstate);
|
|
|
|
void trap_BotEnterChat(int chatstate, int client, int sendto);
|
|
|
|
void trap_BotGetChatMessage(int chatstate, char *buf, int size);
|
|
|
|
int trap_StringContains(char *str1, char *str2, int casesensitive);
|
|
|
|
int trap_BotFindMatch(char *str, void /* struct bot_match_s */ *match, unsigned long int context);
|
|
|
|
void trap_BotMatchVariable(void /* struct bot_match_s */ *match, int variable, char *buf, int size);
|
|
|
|
void trap_UnifyWhiteSpaces(char *string);
|
|
|
|
void trap_BotReplaceSynonyms(char *string, unsigned long int context);
|
|
|
|
int trap_BotLoadChatFile(int chatstate, char *chatfile, char *chatname);
|
|
|
|
void trap_BotSetChatGender(int chatstate, int gender);
|
|
|
|
void trap_BotSetChatName(int chatstate, char *name, int client);
|
|
|
|
void trap_BotResetGoalState(int goalstate);
|
|
|
|
void trap_BotRemoveFromAvoidGoals(int goalstate, int number);
|
|
|
|
void trap_BotResetAvoidGoals(int goalstate);
|
|
|
|
void trap_BotPushGoal(int goalstate, void /* struct bot_goal_s */ *goal);
|
|
|
|
void trap_BotPopGoal(int goalstate);
|
|
|
|
void trap_BotEmptyGoalStack(int goalstate);
|
|
|
|
void trap_BotDumpAvoidGoals(int goalstate);
|
|
|
|
void trap_BotDumpGoalStack(int goalstate);
|
|
|
|
void trap_BotGoalName(int number, char *name, int size);
|
|
|
|
int trap_BotGetTopGoal(int goalstate, void /* struct bot_goal_s */ *goal);
|
|
|
|
int trap_BotGetSecondGoal(int goalstate, void /* struct bot_goal_s */ *goal);
|
|
|
|
int trap_BotChooseLTGItem(int goalstate, vec3_t origin, int *inventory, int travelflags);
|
|
|
|
int trap_BotChooseNBGItem(int goalstate, vec3_t origin, int *inventory, int travelflags, void /* struct bot_goal_s */ *ltg, float maxtime);
|
|
|
|
int trap_BotTouchingGoal(vec3_t origin, void /* struct bot_goal_s */ *goal);
|
|
|
|
int trap_BotItemGoalInVisButNotVisible(int viewer, vec3_t eye, vec3_t viewangles, void /* struct bot_goal_s */ *goal);
|
|
|
|
int trap_BotGetNextCampSpotGoal(int num, void /* struct bot_goal_s */ *goal);
|
|
|
|
int trap_BotGetMapLocationGoal(char *name, void /* struct bot_goal_s */ *goal);
|
|
|
|
int trap_BotGetLevelItemGoal(int index, const char* classname, void /* struct bot_goal_s */ *goal);
|
|
|
|
float trap_BotAvoidGoalTime(int goalstate, int number);
|
|
|
|
void trap_BotSetAvoidGoalTime(int goalstate, int number, float avoidtime);
|
|
|
|
void trap_BotInitLevelItems(void);
|
|
|
|
void trap_BotUpdateEntityItems(void);
|
|
|
|
int trap_BotLoadItemWeights(int goalstate, char *filename);
|
|
|
|
void trap_BotFreeItemWeights(int goalstate);
|
|
|
|
void trap_BotInterbreedGoalFuzzyLogic(int parent1, int parent2, int child);
|
|
|
|
void trap_BotSaveGoalFuzzyLogic(int goalstate, char *filename);
|
|
|
|
void trap_BotMutateGoalFuzzyLogic(int goalstate, float range);
|
|
|
|
int trap_BotAllocGoalState(int state);
|
|
|
|
void trap_BotFreeGoalState(int handle);
|
|
|
|
|
|
|
|
void trap_BotResetMoveState(int movestate);
|
|
|
|
void trap_BotMoveToGoal(void /* struct bot_moveresult_s */ *result, int movestate, void /* struct bot_goal_s */ *goal, int travelflags);
|
|
|
|
int trap_BotMoveInDirection(int movestate, vec3_t dir, float speed, int type);
|
|
|
|
void trap_BotResetAvoidReach(int movestate);
|
|
|
|
void trap_BotResetLastAvoidReach(int movestate);
|
|
|
|
int trap_BotReachabilityArea(vec3_t origin, int testground);
|
|
|
|
int trap_BotMovementViewTarget(int movestate, void /* struct bot_goal_s */ *goal, int travelflags, float lookahead, vec3_t target);
|
|
|
|
int trap_BotPredictVisiblePosition(vec3_t origin, int areanum, void /* struct bot_goal_s */ *goal, int travelflags, vec3_t target);
|
|
|
|
int trap_BotAllocMoveState(void);
|
|
|
|
void trap_BotFreeMoveState(int handle);
|
|
|
|
void trap_BotInitMoveState(int handle, void /* struct bot_initmove_s */ *initmove);
|
|
|
|
void trap_BotAddAvoidSpot(int movestate, const vec3_t origin, float radius, int type);
|
|
|
|
|
|
|
|
int trap_BotChooseBestFightWeapon(int weaponstate, int *inventory);
|
|
|
|
void trap_BotGetWeaponInfo(int weaponstate, int weapon, void /* struct weaponinfo_s */ *weaponinfo);
|
|
|
|
int trap_BotLoadWeaponWeights(int weaponstate, char *filename);
|
|
|
|
int trap_BotAllocWeaponState(void);
|
|
|
|
void trap_BotFreeWeaponState(int weaponstate);
|
|
|
|
void trap_BotResetWeaponState(int weaponstate);
|
|
|
|
|
|
|
|
int trap_GeneticParentsAndChildSelection(int numranks, float *ranks, int *parent1, int *parent2, int *child);
|
|
|
|
|
|
|
|
|
|
|
|
// yet another retarded trap we're stuck with >:(
|
|
|
|
#if !defined(Q3_VM)
|
|
|
|
void shit_SendConsoleCommand( int ignored, const char *text );
|
|
|
|
#endif
|
|
|
|
#define trap_SendConsoleCommand( x ) shit_SendConsoleCommand( 2, x )
|
|
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// functions exported by the game subsystem, ie calls INTO the mod BY the engine
|
|
|
|
//
|
|
|
|
typedef enum {
|
|
|
|
GAME_INIT, // ( int levelTime, int randomSeed, int restart );
|
|
|
|
// init and shutdown will be called every single level
|
|
|
|
// The game should call G_GET_ENTITY_TOKEN to parse through all the
|
|
|
|
// entity configuration text and spawn gentities.
|
|
|
|
|
2017-01-11 13:24:58 +00:00
|
|
|
GAME_SHUTDOWN, // (int restart);
|
2016-12-18 04:43:04 +00:00
|
|
|
|
|
|
|
GAME_CLIENT_CONNECT, // ( int clientNum, qboolean firstTime, qboolean isBot );
|
|
|
|
// return NULL if the client is allowed to connect, otherwise return
|
|
|
|
// a text string with the reason for denial
|
|
|
|
|
|
|
|
GAME_CLIENT_BEGIN, // ( int clientNum );
|
|
|
|
|
|
|
|
GAME_CLIENT_USERINFO_CHANGED, // ( int clientNum );
|
|
|
|
|
|
|
|
GAME_CLIENT_DISCONNECT, // ( int clientNum );
|
|
|
|
|
|
|
|
GAME_CLIENT_COMMAND, // ( int clientNum );
|
|
|
|
|
|
|
|
GAME_CLIENT_THINK, // ( int clientNum );
|
|
|
|
|
|
|
|
GAME_RUN_FRAME, // ( int levelTime );
|
|
|
|
|
|
|
|
GAME_CONSOLE_COMMAND, // ( void );
|
|
|
|
// ConsoleCommand will be called when a command has been issued
|
|
|
|
// that is not recognized as a builtin function.
|
|
|
|
// The game can issue trap_argc() / trap_argv() commands to get the command
|
|
|
|
// and parameters. Return qfalse if the game doesn't recognize it as a command.
|
|
|
|
|
|
|
|
BOTAI_START_FRAME // ( int time );
|
|
|
|
} gameExport_t;
|
|
|
|
|