mirror of
https://github.com/ReactionQuake3/reaction.git
synced 2025-01-22 01:21:12 +00:00
Itembanning added
This commit is contained in:
parent
0dcbd89981
commit
6ccad3d92a
6 changed files with 123 additions and 56 deletions
Binary file not shown.
|
@ -5,6 +5,9 @@
|
|||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// $Log$
|
||||
// Revision 1.52 2002/11/17 20:14:15 jbravo
|
||||
// Itembanning added
|
||||
//
|
||||
// Revision 1.51 2002/09/29 16:06:44 jbravo
|
||||
// Work done at the HPWorld expo
|
||||
//
|
||||
|
@ -2710,21 +2713,12 @@ int BotSameTeam(bot_state_t * bs, int entnum)
|
|||
}
|
||||
if (gametype >= GT_TEAM) {
|
||||
//Makro - added teamplay code; changed some stuff
|
||||
if (gametype != GT_TEAMPLAY) {
|
||||
trap_GetConfigstring(CS_PLAYERS + bs->client, info1, sizeof(info1));
|
||||
trap_GetConfigstring(CS_PLAYERS + entnum, info2, sizeof(info2));
|
||||
//
|
||||
team1 = atoi(Info_ValueForKey(info1, "t"));
|
||||
team2 = atoi(Info_ValueForKey(info2, "t"));
|
||||
} else {
|
||||
team1 = g_entities[bs->client].client->sess.savedTeam;
|
||||
team2 = g_entities[entnum].client->sess.savedTeam;
|
||||
}
|
||||
team1 = g_entities[bs->client].client->sess.savedTeam;
|
||||
team2 = g_entities[entnum].client->sess.savedTeam;
|
||||
if (team1 == TEAM_SPECTATOR || team2 == TEAM_SPECTATOR)
|
||||
return qfalse;
|
||||
if (team1 == team2)
|
||||
return qtrue;
|
||||
|
||||
}
|
||||
return qfalse;
|
||||
}
|
||||
|
|
|
@ -5,6 +5,9 @@
|
|||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// $Log$
|
||||
// Revision 1.123 2002/11/17 20:14:15 jbravo
|
||||
// Itembanning added
|
||||
//
|
||||
// Revision 1.122 2002/11/13 00:50:38 jbravo
|
||||
// Fixed item dropping, specmode selection on death and helmet probs.
|
||||
//
|
||||
|
@ -1486,14 +1489,32 @@ void ClientBegin(int clientNum)
|
|||
// NiceAss: Only set it if there is no value. Fix for going into spectator resetting values.
|
||||
if (ent->r.svFlags & SVF_BOT) {
|
||||
//Makro - changed to m4/laser from pistol/kevlar
|
||||
if (!client->teamplayWeapon)
|
||||
client->teamplayWeapon = WP_M4;
|
||||
if (!client->teamplayItem)
|
||||
if (!client->teamplayWeapon) {
|
||||
if ((int) g_RQ3_weaponban.integer & WPF_M4) {
|
||||
client->teamplayWeapon = WP_M4;
|
||||
} else if ((int) g_RQ3_weaponban.integer & WPF_MK23) {
|
||||
client->teamplayWeapon = WP_PISTOL;
|
||||
} else if ((int) g_RQ3_weaponban.integer & WPF_KNIFE) {
|
||||
client->teamplayWeapon = WP_KNIFE;
|
||||
} else {
|
||||
client->teamplayWeapon = WP_PISTOL;
|
||||
}
|
||||
}
|
||||
if (!client->teamplayItem && ((int) g_RQ3_weaponban.integer & ITF_LASER))
|
||||
client->teamplayItem = HI_LASER;
|
||||
} else {
|
||||
if (!client->teamplayWeapon)
|
||||
client->teamplayWeapon = WP_MP5;
|
||||
if (!client->teamplayItem)
|
||||
if (!client->teamplayWeapon) {
|
||||
if ((int) g_RQ3_weaponban.integer & WPF_MP5) {
|
||||
client->teamplayWeapon = WP_MP5;
|
||||
} else if ((int) g_RQ3_weaponban.integer & WPF_MK23) {
|
||||
client->teamplayWeapon = WP_PISTOL;
|
||||
} else if ((int) g_RQ3_weaponban.integer & WPF_KNIFE) {
|
||||
client->teamplayWeapon = WP_KNIFE;
|
||||
} else {
|
||||
client->teamplayWeapon = WP_PISTOL;
|
||||
}
|
||||
}
|
||||
if (!client->teamplayItem && ((int) g_RQ3_weaponban.integer & ITF_KEVLAR))
|
||||
client->teamplayItem = HI_KEVLAR;
|
||||
}
|
||||
i = RQ3TeamCount(-1, client->sess.sessionTeam);
|
||||
|
|
|
@ -5,6 +5,9 @@
|
|||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// $Log$
|
||||
// Revision 1.131 2002/11/17 20:14:15 jbravo
|
||||
// Itembanning added
|
||||
//
|
||||
// Revision 1.130 2002/10/30 20:04:34 jbravo
|
||||
// Adding helmet
|
||||
//
|
||||
|
@ -398,6 +401,14 @@ typedef enum {
|
|||
#define WPF_KNIFE 0x00000080 // 128
|
||||
#define WPF_GRENADE 0x00000100 // 256
|
||||
|
||||
// JBravo: adding itembanning
|
||||
#define ITF_SILENCER 0x00000001 // 1
|
||||
#define ITF_SLIPPERS 0x00000002 // 2
|
||||
#define ITF_BANDOLIER 0x00000004 // 4
|
||||
#define ITF_KEVLAR 0x00000008 // 8
|
||||
#define ITF_LASER 0x00000010 // 16
|
||||
#define ITF_HELMET 0x00000020 // 32
|
||||
|
||||
//============================================================================
|
||||
|
||||
typedef struct gentity_s gentity_t;
|
||||
|
@ -1390,6 +1401,7 @@ extern vmCvar_t g_RQ3_tkbanrounds; // JBravo: no. of games team killers are bann
|
|||
extern vmCvar_t g_RQ3_ppl_idletime; // JBravo: Seconds Idle before playing an insane sound
|
||||
extern vmCvar_t g_RQ3_idleaction; // JBravo: what to do with Idlers. 0 = sound, 1 = team none, 2 = kick
|
||||
extern vmCvar_t g_RQ3_weaponban; // JBravo: Bitmapped cvar for weaponbanning
|
||||
extern vmCvar_t g_RQ3_itemban; // JBravo: Bitmapped cvar for itembanning
|
||||
extern vmCvar_t g_RQ3_ctb_respawndelay; // JBravo: delay in seconds for ctb respawns
|
||||
extern vmCvar_t g_RQ3_allWeapons; // JBravo: if set, TP/DM players get all the weapons
|
||||
extern vmCvar_t g_RQ3_allItems; // JBravo: if set, TP/DM players get all the items
|
||||
|
|
|
@ -5,6 +5,9 @@
|
|||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// $Log$
|
||||
// Revision 1.128 2002/11/17 20:14:15 jbravo
|
||||
// Itembanning added
|
||||
//
|
||||
// Revision 1.127 2002/10/31 01:10:07 jbravo
|
||||
// Bumped the version to 2.3
|
||||
//
|
||||
|
@ -463,6 +466,7 @@ vmCvar_t g_RQ3_tkbanrounds;
|
|||
vmCvar_t g_RQ3_ppl_idletime;
|
||||
vmCvar_t g_RQ3_idleaction;
|
||||
vmCvar_t g_RQ3_weaponban;
|
||||
vmCvar_t g_RQ3_itemban;
|
||||
vmCvar_t g_RQ3_ctb_respawndelay;
|
||||
vmCvar_t g_RQ3_allWeapons;
|
||||
vmCvar_t g_RQ3_allItems;
|
||||
|
@ -615,6 +619,7 @@ static cvarTable_t gameCvarTable[] = {
|
|||
{&g_RQ3_haveHelmet, "g_RQ3_haveHelmet", "0", CVAR_ARCHIVE, 0, qtrue},
|
||||
{&g_RQ3_idleaction, "g_RQ3_idleaction", "0", CVAR_ARCHIVE, 0, qtrue},
|
||||
{&g_RQ3_weaponban, "g_RQ3_weaponban", "511", CVAR_ARCHIVE, 0, qtrue},
|
||||
{&g_RQ3_itemban, "g_RQ3_itemban", "63", CVAR_ARCHIVE, 0, qtrue},
|
||||
//Blaze: let cvar.cfg be set by the server admins
|
||||
{&g_RQ3_cvarfile, "g_RQ3_cvarfile", "cvar.cfg", CVAR_ARCHIVE, 0, qtrue},
|
||||
//Slicer: Team Status Cvars for MM
|
||||
|
@ -2591,37 +2596,45 @@ void RQ3_StartUniqueItems(void)
|
|||
|
||||
G_Printf("RQ3_StartUniqueItems: Starting unique item spawn code...\n");
|
||||
|
||||
rq3_item = BG_FindItemForHoldable(HI_SLIPPERS);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
|
||||
rq3_item = BG_FindItemForHoldable(HI_KEVLAR);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
|
||||
rq3_item = BG_FindItemForHoldable(HI_SILENCER);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
|
||||
rq3_item = BG_FindItemForHoldable(HI_BANDOLIER);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
|
||||
rq3_item = BG_FindItemForHoldable(HI_LASER);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
|
||||
if (g_RQ3_haveHelmet.integer) {
|
||||
rq3_item = BG_FindItemForHoldable(HI_HELMET);
|
||||
// JBravo: adding itembanning
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_SLIPPERS) {
|
||||
rq3_item = BG_FindItemForHoldable(HI_SLIPPERS);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
}
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_KEVLAR) {
|
||||
rq3_item = BG_FindItemForHoldable(HI_KEVLAR);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
}
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_SILENCER) {
|
||||
rq3_item = BG_FindItemForHoldable(HI_SILENCER);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
}
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_BANDOLIER) {
|
||||
rq3_item = BG_FindItemForHoldable(HI_BANDOLIER);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
}
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_LASER) {
|
||||
rq3_item = BG_FindItemForHoldable(HI_LASER);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
}
|
||||
if (g_RQ3_haveHelmet.integer) {
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_HELMET) {
|
||||
rq3_item = BG_FindItemForHoldable(HI_HELMET);
|
||||
rq3_temp = (gentity_t *) SelectRandomDeathmatchSpawnPoint();
|
||||
Drop_Item(rq3_temp, rq3_item, angle);
|
||||
angle += 30;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
|
@ -5,6 +5,9 @@
|
|||
//-----------------------------------------------------------------------------
|
||||
//
|
||||
// $Log$
|
||||
// Revision 1.146 2002/11/17 20:14:15 jbravo
|
||||
// Itembanning added
|
||||
//
|
||||
// Revision 1.145 2002/11/13 00:50:38 jbravo
|
||||
// Fixed item dropping, specmode selection on death and helmet probs.
|
||||
//
|
||||
|
@ -1096,24 +1099,48 @@ void RQ3_Cmd_Choose_f(gentity_t * ent)
|
|||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_AKIMBO_NAME));
|
||||
}
|
||||
} else if (Q_stricmp(cmd, RQ3_KEVLAR_NAME) == 0 || Q_stricmp(cmd, "kevlar") == 0) {
|
||||
ent->client->teamplayItem = HI_KEVLAR;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_KEVLAR_NAME));
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_KEVLAR) {
|
||||
ent->client->teamplayItem = HI_KEVLAR;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_KEVLAR_NAME));
|
||||
} else {
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_KEVLAR_NAME));
|
||||
}
|
||||
} else if (Q_stricmp(cmd, RQ3_LASER_NAME) == 0 || Q_stricmp(cmd, "laser") == 0) {
|
||||
ent->client->teamplayItem = HI_LASER;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_LASER_NAME));
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_LASER) {
|
||||
ent->client->teamplayItem = HI_LASER;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_LASER_NAME));
|
||||
} else {
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_LASER_NAME));
|
||||
}
|
||||
} else if (Q_stricmp(cmd, RQ3_SLIPPERS_NAME) == 0 || Q_stricmp(cmd, "slippers") == 0) {
|
||||
ent->client->teamplayItem = HI_SLIPPERS;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_SLIPPERS_NAME));
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_SLIPPERS) {
|
||||
ent->client->teamplayItem = HI_SLIPPERS;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_SLIPPERS_NAME));
|
||||
} else {
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_SLIPPERS_NAME));
|
||||
}
|
||||
} else if (Q_stricmp(cmd, RQ3_SILENCER_NAME) == 0 || Q_stricmp(cmd, "silencer") == 0) {
|
||||
ent->client->teamplayItem = HI_SILENCER;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_SILENCER_NAME));
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_SILENCER) {
|
||||
ent->client->teamplayItem = HI_SILENCER;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_SILENCER_NAME));
|
||||
} else {
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_SILENCER_NAME));
|
||||
}
|
||||
} else if (Q_stricmp(cmd, RQ3_BANDOLIER_NAME) == 0 || Q_stricmp(cmd, "bandolier") == 0) {
|
||||
ent->client->teamplayItem = HI_BANDOLIER;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_BANDOLIER_NAME));
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_BANDOLIER) {
|
||||
ent->client->teamplayItem = HI_BANDOLIER;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_BANDOLIER_NAME));
|
||||
} else {
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_BANDOLIER_NAME));
|
||||
}
|
||||
} else if (Q_stricmp(cmd, RQ3_HELMET_NAME) == 0 || Q_stricmp(cmd, "helmet") == 0) {
|
||||
if (g_RQ3_haveHelmet.integer) {
|
||||
ent->client->teamplayItem = HI_HELMET;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_HELMET_NAME));
|
||||
if ((int) g_RQ3_weaponban.integer & ITF_HELMET) {
|
||||
ent->client->teamplayItem = HI_HELMET;
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"Item selected: %s\n\"", RQ3_HELMET_NAME));
|
||||
} else {
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_HELMET_NAME));
|
||||
}
|
||||
} else {
|
||||
trap_SendServerCommand(ent - g_entities, va("print \"%s is disabled on this server.\n\"", RQ3_HELMET_NAME));
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue