Nuclide
Software Development Kit for id Technology (BETA)
api.h
1/*
2 * Copyright (c) 2016-2025 Vera Visions LLC.
3 *
4 * Permission to use, copy, modify, and distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
7 *
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
13 * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
14 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15*/
16
17#define bool float
18#define true 1
19#define false 0
20
37typedef struct
38{
42 string NameForNum(int ammoID);
46 int NumForName(string ammoName);
50 int MaxForName(string ammoName);
54 int MaxForNum(int ammoID);
55} ammoAPI_t;
56
67typedef struct
68{
73 string GetString(string cvarName);
78 int GetInteger(string cvarName);
83 float GetFloat(string cvarName);
88 bool GetBool(string cvarName);
93 vector GetVector(string cvarName);
98 void SetString(string cvarName, string setValue);
103 void SetInteger(string cvarName, int setValue);
108 void SetBool(string cvarName, bool setValue);
113 void SetFloat(string cvarName, float setValue);
118 void SetVector(string cvarName, vector setValue);
119} cvarAPI_t;
120
124typedef struct
125{
130 string GetString(string serverKey);
135 int GetInteger(string serverKey);
140 float GetFloat(string serverKey);
145 bool GetBool(string serverKey);
150 vector GetVector(string serverKey);
155 void SetString(string serverKey, string setValue);
160 void SetInteger(string serverKey, int setValue);
165 void SetBool(string serverKey, bool setValue);
170 void SetFloat(string serverKey, float setValue);
175 void SetVector(string serverKey, vector setValue);
177
181typedef struct
182{
188 string GetString(entity clientEnt, string userKey);
194 int GetInteger(entity clientEnt, string userKey);
200 float GetFloat(entity clientEnt, string userKey);
206 bool GetBool(entity clientEnt, string userKey);
212 vector GetVector(entity clientEnt, string userKey);
218 void SetString(entity clientEnt, string userKey, string setValue);
224 void SetInteger(entity clientEnt, string userKey, int setValue);
230 void SetBool(entity clientEnt, string userKey, bool setValue);
236 void SetFloat(entity clientEnt, string userKey, float setValue);
242 void SetVector(entity clientEnt, string userKey, vector setValue);
244
248typedef struct
249{
253 string Type(string weaponDef);
257 int StartAmmo(string weaponDef);
261 int MaxAmmo(string weaponDef);
265 bool IsSemiAuto(string weaponDef);
266
270 string InventoryType(string weaponDef);
274 float FireTime(string weaponDef);
278 int ClipSize(string weaponDef);
282 string Class(string weaponDef);
286 bool IsClipOnly(string weaponDef);
290 bool IsDetonationTimed(string weaponDef);
292
296typedef struct
297{
303 int TeamCount(void);
306 int OpenTeamCount(void);
310 vector Color(int teamID);
314 string Name(int teamID);
318 int Score(int teamID);
322 string SpawnPoint(int teamID);
326 int NumPlayers(int teamID);
330 int NumAlivePlayers(int teamID);
334 int NumDeadPlayers(int teamID);
338 int TotalDeaths(int teamID);
343 int TotalFrags(int teamID);
347 bool Valid(int teamID);
348
352 void AddScore(int teamID, int addedScore);
356 void SetScore(int teamID, int scoreValue);
360 entity RandomPlayer(int teamID);
361
362
369 void SetUp(int teamID, string teamTitle, vector teamColor, bool openTeam);
370
371
377 void AddClass(int teamID, string classType);
378
379
383 int TotalClasses(int teamID);
384
389 string ClassForIndex(int teamID, int classIndex);
390
397 void SetSpawnPoint(int teamID, string spawnPointEntityClassname);
398} teamAPI_t;
399
403typedef struct
404{
410 string GetString(string defName, string keyName);
416 int GetInteger(string defName, string keyName);
422 float GetFloat(string defName, string keyName);
428 bool GetBool(string defName, string keyName);
434 vector GetVector(string defName, string keyName);
439typedef struct
440{
447 float Model(string pathToModel);
448
456 float Sound(string soundDef);
457
466 float Particle(string particleEffect);
467
474 bool Entity(string className);
479typedef struct
480{
481 void Play(string soundDef, float level = 75, float pitch = 100, float volume = 100, float channel = CHAN_AUTO);
482} soundAPI_t;
485typedef string decl;
488typedef struct
489{
492 decl New(void);
493
499 string GetString(decl declHandle, string keyName);
505 int GetInteger(decl declHandle, string keyName);
511 float GetFloat(decl declHandle, string keyName);
517 bool GetBool(decl declHandle, string keyName);
523 vector GetVector(decl declHandle, string keyName);
524
531 void AddKey(decl declHandle, string keyName, string setValue);
532
537 void RemoveKey(decl declHandle, string keyName);
538
542 void Delete(decl declHandle);
543} declAPI_t;
544
545declAPI_t declManager; // end of shared
547
548void
549setorigin_safe(entity target, vector testorg)
550{
551 for (int i = 0; i < 16; i++) {
552 tracebox(testorg, target.mins, target.maxs, testorg, MOVE_NORMAL, target);
553
554 if (!trace_startsolid) {
555 break;
556 }
557
558 testorg[2] += 1.0;
559 }
560
561 setorigin(target, testorg);
562}
563
564__variant
565linkToSharedProgs(string funcName)
566{
567 static void empty(void)
568 {
569 print("Called unimplemented shared API call.\n");
570 breakpoint();
571 }
572
573 float func = externvalue( 0, funcName);
574
575 if (func) {
576 return ((__variant)func);
577 } else {
578 return (empty);
579 }
580}
581
582void
583_shared_main(void)
584{
585 ammo.NameForNum = linkToSharedProgs("SHPF_ammo_NameForNum");
586 ammo.NumForName = linkToSharedProgs("SHPF_ammo_NumForName");
587 ammo.MaxForName = linkToSharedProgs("SHPF_ammo_MaxForName");
588 ammo.MaxForNum = linkToSharedProgs("SHPF_ammo_MaxForNum");
589
590 cvars.SetString = linkToSharedProgs("SHPF_cvars_SetString");
591 cvars.SetBool = linkToSharedProgs("SHPF_cvars_SetBool");
592 cvars.SetInteger = linkToSharedProgs("SHPF_cvars_SetInteger");
593 cvars.SetFloat = linkToSharedProgs("SHPF_cvars_SetFloat");
594 cvars.SetVector = linkToSharedProgs("SHPF_cvars_SetVector");
595 cvars.GetString = linkToSharedProgs("SHPF_cvars_GetString");
596 cvars.GetInteger = linkToSharedProgs("SHPF_cvars_GetInteger");
597 cvars.GetBool = linkToSharedProgs("SHPF_cvars_GetBool");
598 cvars.GetFloat = linkToSharedProgs("SHPF_cvars_GetFloat");
599 cvars.GetVector = linkToSharedProgs("SHPF_cvars_GetVector");
600
601 declManager.New = linkToSharedProgs("SHPF_declManager_New");
602 declManager.GetFloat = linkToSharedProgs("SHPF_declManager_GetFloat");
603 declManager.GetString = linkToSharedProgs("SHPF_declManager_GetString");
604 declManager.GetVector = linkToSharedProgs("SHPF_declManager_GetVector");
605 declManager.GetBool = linkToSharedProgs("SHPF_declManager_GetBool");
606 declManager.AddKey = linkToSharedProgs("SHPF_declManager_AddKey");
607 declManager.RemoveKey = linkToSharedProgs("SHPF_declManager_RemoveKey");
608 declManager.Delete = linkToSharedProgs("SHPF_declManager_Delete");
609
610 userinfo.SetString = linkToSharedProgs("SHPF_userinfo_SetString");
611 userinfo.SetBool = linkToSharedProgs("SHPF_userinfo_SetBool");
612 userinfo.SetInteger = linkToSharedProgs("SHPF_userinfo_SetInteger");
613 userinfo.SetFloat = linkToSharedProgs("SHPF_userinfo_SetFloat");
614 userinfo.SetVector = linkToSharedProgs("SHPF_userinfo_SetVector");
615 userinfo.GetString = linkToSharedProgs("SHPF_userinfo_GetString");
616 userinfo.GetInteger = linkToSharedProgs("SHPF_userinfo_GetInteger");
617 userinfo.GetBool = linkToSharedProgs("SHPF_userinfo_GetBool");
618 userinfo.GetFloat = linkToSharedProgs("SHPF_userinfo_GetFloat");
619 userinfo.GetVector = linkToSharedProgs("SHPF_userinfo_GetVector");
620
621 serverinfo.SetString = linkToSharedProgs("SHPF_serverinfo_SetString");
622 serverinfo.SetBool = linkToSharedProgs("SHPF_serverinfo_SetBool");
623 serverinfo.SetInteger = linkToSharedProgs("SHPF_serverinfo_SetInteger");
624 serverinfo.SetFloat = linkToSharedProgs("SHPF_serverinfo_SetFloat");
625 serverinfo.SetVector = linkToSharedProgs("SHPF_serverinfo_SetVector");
626 serverinfo.GetString = linkToSharedProgs("SHPF_serverinfo_GetString");
627 serverinfo.GetInteger = linkToSharedProgs("SHPF_serverinfo_GetInteger");
628 serverinfo.GetBool = linkToSharedProgs("SHPF_serverinfo_GetBool");
629 serverinfo.GetFloat = linkToSharedProgs("SHPF_serverinfo_GetFloat");
630 serverinfo.GetVector = linkToSharedProgs("SHPF_serverinfo_GetVector");
631
632 teams.BestAutoJoinTeam = linkToSharedProgs("SHPF_teams_BestAutoJoinTeam");
633 teams.TeamCount = linkToSharedProgs("SHPF_teams_TeamCount");
634 teams.OpenTeamCount = linkToSharedProgs("SHPF_teams_OpenTeamCount");
635 teams.Color = linkToSharedProgs("SHPF_teams_Color");
636 teams.Name = linkToSharedProgs("SHPF_teams_Name");
637 teams.Score = linkToSharedProgs("SHPF_teams_Score");
638 teams.SpawnPoint = linkToSharedProgs("SHPF_teams_SpawnPoint");
639 teams.NumPlayers = linkToSharedProgs("SHPF_teams_NumPlayers");
640 teams.NumAlivePlayers = linkToSharedProgs("SHPF_teams_NumAlivePlayers");
641 teams.NumDeadPlayers = linkToSharedProgs("SHPF_teams_NumDeadPlayers");
642 teams.TotalDeaths = linkToSharedProgs("SHPF_teams_TotalDeaths");
643 teams.TotalFrags = linkToSharedProgs("SHPF_teams_TotalFrags");
644 teams.Valid = linkToSharedProgs("SHPF_teams_Valid");
645 teams.RandomPlayer = linkToSharedProgs("SHPF_teams_RandomPlayer");
646
647 /* server */
648 teams.AddScore = linkToSharedProgs("SHPF_teams_AddScore");
649 teams.SetScore = linkToSharedProgs("SHPF_teams_SetScore");
650 teams.SetUp = linkToSharedProgs("SHPF_teams_SetUp");
651 teams.AddClass = linkToSharedProgs("SHPF_teams_AddClass");
652 teams.TotalClasses = linkToSharedProgs("SHPF_teams_TotalClasses");
653 teams.ClassForIndex = linkToSharedProgs("SHPF_teams_ClassForIndex");
654 teams.SetSpawnPoint = linkToSharedProgs("SHPF_teams_SetSpawnPoint");
655
656 precache.Model = linkToSharedProgs("SHPF_precache_Model");
657 precache.Sound = linkToSharedProgs("SHPF_precache_Sound");
658 precache.Particle = linkToSharedProgs("SHPF_precache_Particle");
659 precache.Entity = linkToSharedProgs("EntityDef_Precache");
660
661 soundKit.Play = linkToSharedProgs("SHPF_sounds_Play");
662
663 weaponInfo.Type = linkToSharedProgs("SHPF_weaponInfo_Type");
664 weaponInfo.StartAmmo = linkToSharedProgs("SHPF_weaponInfo_StartAmmo");
665 weaponInfo.MaxAmmo = linkToSharedProgs("SHPF_weaponInfo_MaxAmmo");
666 weaponInfo.IsSemiAuto = linkToSharedProgs("SHPF_weaponInfo_IsSemiAuto");
667 weaponInfo.InventoryType = linkToSharedProgs("SHPF_weaponInfo_InventoryType");
668 weaponInfo.FireTime = linkToSharedProgs("SHPF_weaponInfo_FireTime");
669 weaponInfo.ClipSize = linkToSharedProgs("SHPF_weaponInfo_ClipSize");
670 weaponInfo.Class = linkToSharedProgs("SHPF_weaponInfo_Class");
671 weaponInfo.IsClipOnly = linkToSharedProgs("SHPF_weaponInfo_IsClipOnly");
672 weaponInfo.IsDetonationTimed = linkToSharedProgs("SHPF_weaponInfo_IsDetonationTimed");
673
674 entityDef.GetString = linkToSharedProgs("SHPF_entityDef_GetString");
675 entityDef.GetInteger = linkToSharedProgs("SHPF_entityDef_GetInteger");
676 entityDef.GetBool = linkToSharedProgs("SHPF_entityDef_GetBool");
677 entityDef.GetFloat = linkToSharedProgs("SHPF_entityDef_GetFloat");
678 entityDef.GetVector = linkToSharedProgs("SHPF_entityDef_GetVector");
679}
weaponInfo_t weaponInfo
Access weaponInfo_t functions using this variable.
Definition: api.h:293
userinfoAPI_t userinfo
Access userinfoAPI_t functions using this variable.
Definition: api.h:245
precacheAPI_t precache
Access precacheAPI_t functions using this variable.
Definition: api.h:476
soundAPI_t soundKit
Access soundAPI_t functions using this variable.
Definition: api.h:483
declAPI_t declManager
Access declAPI_t functions using this variable.
Definition: api.h:545
cvarAPI_t cvars
Access cvarAPI_t functions using this variable.
Definition: api.h:121
string decl
storage type of a decl reference.
Definition: api.h:485
entityDefAPI_t entityDef
Access entityDefAPI_t functions using this variable.
Definition: api.h:436
teamAPI_t teams
Access teamAPI_t functions using this variable.
Definition: api.h:400
serverinfoAPI_t serverinfo
Access serverinfoAPI_t functions using this variable.
Definition: api.h:178
ammoAPI_t ammo
Access ammoAPI_t functions using this variable.
Definition: api.h:57
Ammo library.
Definition: api.h:38
int MaxForNum(int ammoID)
Find out the maximum ammo of a ammo type given the ID.
int NumForName(string ammoName)
Get the internal ID of an ammo type.
string NameForNum(int ammoID)
Find out the internal name of an ammo ID.
int MaxForName(string ammoName)
Find out the maximum ammo of a named ammo type.
CVar library.
Definition: api.h:68
float GetBool(string cvarName)
Returns the boolean value of a console variable.
float GetFloat(string cvarName)
Returns the floating-point value of a console variable.
void SetVector(string cvarName, vector setValue)
Sets the specified console variable to a set vector.
string GetString(string cvarName)
Returns the string value of a console variable.
void SetString(string cvarName, string setValue)
Sets the specified console variable to a set string value.
void SetFloat(string cvarName, float setValue)
Sets the specified console variable to a set floating-point value.
vector GetVector(string cvarName)
Returns the vector value of a console variable.
void SetInteger(string cvarName, int setValue)
Sets the specified console variable to a set integer value.
void SetBool(string cvarName, float setValue)
Sets the specified console variable to a set boolean value.
int GetInteger(string cvarName)
Returns the integer value of a console variable.
Decl library.
Definition: api.h:489
string GetString(decl declHandle, string keyName)
Returns the string value of a key from a decl.
vector GetVector(decl declHandle, string keyName)
Returns the vector value of a decl key.
int GetInteger(decl declHandle, string keyName)
Returns the integer value of a decl key.
decl New(void)
Returns the name of a new decl in which you can store key/value pairs in.
float GetBool(decl declHandle, string keyName)
Returns the boolean value of a decl key.
void AddKey(decl declHandle, string keyName, string setValue)
Adds/updates a named key within a decl with a new string value.
float GetFloat(decl declHandle, string keyName)
Returns the floating-point value of a decl key.
void Delete(decl declHandle)
Removes a named decl from the game.
void RemoveKey(decl declHandle, string keyName)
Removes a named key from a decl entirely.
EntityDef library.
Definition: api.h:404
string GetString(string defName, string keyName)
Returns the string value of a EntityDef key.
vector GetVector(string defName, string keyName)
Returns the vector value of a EntityDef key.
float GetFloat(string defName, string keyName)
Returns the floating-point value of a EntityDef key.
float GetBool(string defName, string keyName)
Returns the boolean value of a EntityDef key.
int GetInteger(string defName, string keyName)
Returns the integer value of a EntityDef key.
Precaching library.
Definition: api.h:440
float Model(string pathToModel)
Precaches a given model file and additional helper files.
float Particle(string particleEffect)
Precaches a given particle effect.
float Entity(string className)
Precaches a given entity class.
float Sound(string soundDef)
Precaches a given sound def or sample.
ServerInfo library.
Definition: api.h:125
void SetBool(string serverKey, float setValue)
Server only.
void SetVector(string serverKey, vector setValue)
Server only.
float GetBool(string serverKey)
Returns the boolean value of a server info-key.
float GetFloat(string serverKey)
Returns the floating-point value of a server info-key.
void SetString(string serverKey, string setValue)
Server only.
int GetInteger(string serverKey)
Returns the integer value of a server info-key.
vector GetVector(string serverKey)
Returns the vector value of a server info-key.
string GetString(string serverKey)
Returns the string value of a server info-key.
void SetInteger(string serverKey, int setValue)
Server only.
void SetFloat(string serverKey, float setValue)
Server only.
Sound library.
Definition: api.h:480
void Play(string soundDef, float level=75, float pitch=100, float volume=100, float channel=CHAN_AUTO)
Team library.
Definition: api.h:297
string ClassForIndex(int teamID, int classIndex)
Find out the name of a team class given an index.
float Valid(int teamID)
Find out if a given team exists, or valid.
int NumDeadPlayers(int teamID)
Find out how many team players are currently inactive/dead in a match.
int TotalDeaths(int teamID)
Find out how many times all the players in a given team have 'died' in the game.
void SetUp(int teamID, string teamTitle, vector teamColor, float openTeam)
Sets up a team for the current session.
int NumPlayers(int teamID)
Find out how many players are in an active team.
void SetSpawnPoint(int teamID, string spawnPointEntityClassname)
Sets up a team spawn point for the current session.
int TeamCount(void)
Find out how many teams are registered in the current game.
int TotalClasses(int teamID)
Find out how many classes are registered within a team.
int TotalFrags(int teamID)
Find out how many times all the players in a given team have scored 'frags'.
void AddClass(int teamID, string classType)
Sets up a team class for the current session.
void SetScore(int teamID, int scoreValue)
Overridess the score of a specified team.
int NumAlivePlayers(int teamID)
Find out how many team players are active/alive in a match.
string SpawnPoint(int teamID)
Find the entity class name representing individual team spawn points.
int BestAutoJoinTeam(void)
Find out what the best choice of team it is to join.
int Score(int teamID)
Find the current score of a team.
entity RandomPlayer(int teamID)
Find a random player belonging to a given team.
string Name(int teamID)
Find the name of a team, that you can use in prints and written text.
void AddScore(int teamID, int addedScore)
Increases the score of a specified team.
vector Color(int teamID)
Find out which color represents a team.
int OpenTeamCount(void)
Find out how many teams are open to new players.
UserInfo library.
Definition: api.h:182
float GetBool(entity clientEnt, string userKey)
Returns the boolean value of a user info-key.
void SetString(entity clientEnt, string userKey, string setValue)
Server only.
void SetBool(entity clientEnt, string userKey, float setValue)
Sets the specified user info-key to a set boolean value.
float GetFloat(entity clientEnt, string userKey)
Returns the floating-point value of a user info-key.
string GetString(entity clientEnt, string userKey)
Returns the string value of a user info-key.
vector GetVector(entity clientEnt, string userKey)
Returns the vector value of a user info-key.
void SetFloat(entity clientEnt, string userKey, float setValue)
Server only.
int GetInteger(entity clientEnt, string userKey)
Returns the integer value of a user info-key.
void SetInteger(entity clientEnt, string userKey, int setValue)
Server only.
void SetVector(entity clientEnt, string userKey, vector setValue)
Server only.
Weapon library.
Definition: api.h:249
string InventoryType(string weaponDef)
Find out how this weapon is stored.
float FireTime(string weaponDef)
Find out the minimum delay between shots of a weapon, in seconds.
string Type(string weaponDef)
Get the "attack" type of the weapon.
float IsSemiAuto(string weaponDef)
Find out whether the weapon is semi-automatic.
int StartAmmo(string weaponDef)
float IsClipOnly(string weaponDef)
Find out if a weapon takes its ammo only through its clip.
int MaxAmmo(string weaponDef)
Find the amount of ammo a weapon can hold in total when it comes to reserve ammo.
float IsDetonationTimed(string weaponDef)
Find out whether a weapon has anything to do with a timed detonation.
string Class(string weaponDef)
int ClipSize(string weaponDef)
Find out what the clip size of a weapon is.