mirror of
https://github.com/YGGverse/xash3d-fwgs.git
synced 2025-01-17 18:40:02 +00:00
engine: common: base_cmd: static-ize internal fuctions
This commit is contained in:
parent
5c1e06ae74
commit
115ed82c19
@ -17,10 +17,20 @@ GNU General Public License for more details.
|
|||||||
#include "base_cmd.h"
|
#include "base_cmd.h"
|
||||||
#include "cdll_int.h"
|
#include "cdll_int.h"
|
||||||
|
|
||||||
// TODO: use another hash function, as COM_HashKey depends on string length
|
|
||||||
#define HASH_SIZE 128 // 128 * 4 * 4 == 2048 bytes
|
#define HASH_SIZE 128 // 128 * 4 * 4 == 2048 bytes
|
||||||
|
|
||||||
|
typedef struct base_command_hashmap_s
|
||||||
|
{
|
||||||
|
base_command_t *basecmd; // base command: cvar, alias or command
|
||||||
|
const char *name; // key for searching
|
||||||
|
base_command_type_e type; // type for faster searching
|
||||||
|
struct base_command_hashmap_s *next;
|
||||||
|
} base_command_hashmap_t;
|
||||||
|
|
||||||
static base_command_hashmap_t *hashed_cmds[HASH_SIZE];
|
static base_command_hashmap_t *hashed_cmds[HASH_SIZE];
|
||||||
|
|
||||||
|
#define BaseCmd_HashKey( x ) COM_HashKey( name, HASH_SIZE )
|
||||||
|
|
||||||
/*
|
/*
|
||||||
============
|
============
|
||||||
BaseCmd_FindInBucket
|
BaseCmd_FindInBucket
|
||||||
@ -28,7 +38,7 @@ BaseCmd_FindInBucket
|
|||||||
Find base command in bucket
|
Find base command in bucket
|
||||||
============
|
============
|
||||||
*/
|
*/
|
||||||
base_command_hashmap_t *BaseCmd_FindInBucket( base_command_hashmap_t *bucket, base_command_type_e type, const char *name )
|
static base_command_hashmap_t *BaseCmd_FindInBucket( base_command_hashmap_t *bucket, base_command_type_e type, const char *name )
|
||||||
{
|
{
|
||||||
base_command_hashmap_t *i = bucket;
|
base_command_hashmap_t *i = bucket;
|
||||||
for( ; i && ( i->type != type || Q_stricmp( name, i->name ) ); // filter out
|
for( ; i && ( i->type != type || Q_stricmp( name, i->name ) ); // filter out
|
||||||
@ -44,9 +54,9 @@ BaseCmd_GetBucket
|
|||||||
Get bucket which contain basecmd by given name
|
Get bucket which contain basecmd by given name
|
||||||
============
|
============
|
||||||
*/
|
*/
|
||||||
base_command_hashmap_t *BaseCmd_GetBucket( const char *name )
|
static base_command_hashmap_t *BaseCmd_GetBucket( const char *name )
|
||||||
{
|
{
|
||||||
return hashed_cmds[ COM_HashKey( name, HASH_SIZE ) ];
|
return hashed_cmds[ BaseCmd_HashKey( name ) ];
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -73,7 +83,7 @@ BaseCmd_Find
|
|||||||
Find every type of base command and write into arguments
|
Find every type of base command and write into arguments
|
||||||
============
|
============
|
||||||
*/
|
*/
|
||||||
void BaseCmd_FindAll(const char *name, base_command_t **cmd, base_command_t **alias, base_command_t **cvar)
|
void BaseCmd_FindAll( const char *name, base_command_t **cmd, base_command_t **alias, base_command_t **cvar )
|
||||||
{
|
{
|
||||||
base_command_hashmap_t *base = BaseCmd_GetBucket( name );
|
base_command_hashmap_t *base = BaseCmd_GetBucket( name );
|
||||||
base_command_hashmap_t *i = base;
|
base_command_hashmap_t *i = base;
|
||||||
@ -101,7 +111,6 @@ void BaseCmd_FindAll(const char *name, base_command_t **cmd, base_command_t **al
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -159,7 +168,7 @@ Remove base command from hashmap
|
|||||||
*/
|
*/
|
||||||
void BaseCmd_Remove( base_command_type_e type, const char *name )
|
void BaseCmd_Remove( base_command_type_e type, const char *name )
|
||||||
{
|
{
|
||||||
uint hash = COM_HashKey( name, HASH_SIZE );
|
uint hash = BaseCmd_HashKey( name );
|
||||||
base_command_hashmap_t *i, *prev;
|
base_command_hashmap_t *i, *prev;
|
||||||
|
|
||||||
for( prev = NULL, i = hashed_cmds[hash]; i &&
|
for( prev = NULL, i = hashed_cmds[hash]; i &&
|
||||||
|
@ -17,8 +17,6 @@ GNU General Public License for more details.
|
|||||||
#ifndef BASE_CMD_H
|
#ifndef BASE_CMD_H
|
||||||
#define BASE_CMD_H
|
#define BASE_CMD_H
|
||||||
|
|
||||||
// TODO: Find cases when command hashmap works incorrect
|
|
||||||
// and maybe disable it
|
|
||||||
#define XASH_HASHED_VARS
|
#define XASH_HASHED_VARS
|
||||||
|
|
||||||
#ifdef XASH_HASHED_VARS
|
#ifdef XASH_HASHED_VARS
|
||||||
@ -33,18 +31,9 @@ typedef enum base_command_type
|
|||||||
|
|
||||||
typedef void base_command_t;
|
typedef void base_command_t;
|
||||||
|
|
||||||
typedef struct base_command_hashmap_s
|
|
||||||
{
|
|
||||||
base_command_t *basecmd; // base command: cvar, alias or command
|
|
||||||
const char *name; // key for searching
|
|
||||||
base_command_type_e type; // type for faster searching
|
|
||||||
struct base_command_hashmap_s *next;
|
|
||||||
} base_command_hashmap_t;
|
|
||||||
|
|
||||||
|
|
||||||
void BaseCmd_Init( void );
|
void BaseCmd_Init( void );
|
||||||
base_command_hashmap_t *BaseCmd_GetBucket( const char *name );
|
|
||||||
base_command_hashmap_t *BaseCmd_FindInBucket( base_command_hashmap_t *bucket, base_command_type_e type, const char *name );
|
|
||||||
base_command_t *BaseCmd_Find( base_command_type_e type, const char *name );
|
base_command_t *BaseCmd_Find( base_command_type_e type, const char *name );
|
||||||
void BaseCmd_FindAll( const char *name,
|
void BaseCmd_FindAll( const char *name,
|
||||||
base_command_t **cmd, base_command_t **alias, base_command_t **cvar );
|
base_command_t **cmd, base_command_t **alias, base_command_t **cvar );
|
||||||
|
Loading…
x
Reference in New Issue
Block a user