mirror of
https://github.com/yquake2/rogue.git
synced 2025-05-12 02:41:06 +00:00
Merge pull request #89 from protocultor/prefweap
Added prefweap command to select weapon by priority
This commit is contained in:
commit
72a6f98730
1 changed files with 110 additions and 0 deletions
110
src/g_cmds.c
110
src/g_cmds.c
|
@ -1598,6 +1598,112 @@ Cmd_CycleWeap_f(edict_t *ent)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gitem_t *
|
||||||
|
preferred_weapon(edict_t *ent)
|
||||||
|
{
|
||||||
|
gclient_t *cl;
|
||||||
|
gitem_t *noammo_fallback;
|
||||||
|
gitem_t *noweap_fallback;
|
||||||
|
gitem_t *weap;
|
||||||
|
gitem_t *ammo;
|
||||||
|
int i;
|
||||||
|
int num_weaps;
|
||||||
|
|
||||||
|
if (!ent)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
cl = ent->client;
|
||||||
|
|
||||||
|
if (!cl)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
num_weaps = gi.argc();
|
||||||
|
noammo_fallback = NULL;
|
||||||
|
noweap_fallback = NULL;
|
||||||
|
|
||||||
|
/* find the first eligible weapon in the list we can switch to */
|
||||||
|
for (i = 1; i < num_weaps; i++)
|
||||||
|
{
|
||||||
|
weap = FindItemByClassname(gi.argv(i));
|
||||||
|
|
||||||
|
if (weap && (weap->flags & IT_WEAPON) && weap->use)
|
||||||
|
{
|
||||||
|
if (cl->pers.inventory[ITEM_INDEX(weap)] > 0)
|
||||||
|
{
|
||||||
|
if (weap->ammo)
|
||||||
|
{
|
||||||
|
ammo = FindItem(weap->ammo);
|
||||||
|
if (ammo)
|
||||||
|
{
|
||||||
|
if (cl->pers.inventory[ITEM_INDEX(ammo)] >= get_ammo_usage(weap))
|
||||||
|
{
|
||||||
|
return weap;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!noammo_fallback)
|
||||||
|
{
|
||||||
|
noammo_fallback = weap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return weap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (!noweap_fallback)
|
||||||
|
{
|
||||||
|
noweap_fallback = weap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* if no weapon was found, the fallbacks will be used for
|
||||||
|
printing the appropriate error message to the console
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (noammo_fallback)
|
||||||
|
{
|
||||||
|
return noammo_fallback;
|
||||||
|
}
|
||||||
|
|
||||||
|
return noweap_fallback;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
Cmd_PrefWeap_f(edict_t *ent)
|
||||||
|
{
|
||||||
|
gitem_t *weap;
|
||||||
|
|
||||||
|
if (!ent)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gi.argc() <= 1)
|
||||||
|
{
|
||||||
|
gi.cprintf(ent, PRINT_HIGH, "Usage: prefweap classname1 classname2 .. classnameN\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
weap = preferred_weapon(ent);
|
||||||
|
if (weap)
|
||||||
|
{
|
||||||
|
if (ent->client->pers.inventory[ITEM_INDEX(weap)] <= 0)
|
||||||
|
{
|
||||||
|
gi.cprintf(ent, PRINT_HIGH, "Out of item: %s\n", weap->pickup_name);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
weap->use(ent, weap);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
ClientCommand(edict_t *ent)
|
ClientCommand(edict_t *ent)
|
||||||
{
|
{
|
||||||
|
@ -1758,6 +1864,10 @@ ClientCommand(edict_t *ent)
|
||||||
{
|
{
|
||||||
Cmd_CycleWeap_f(ent);
|
Cmd_CycleWeap_f(ent);
|
||||||
}
|
}
|
||||||
|
else if (Q_stricmp(cmd, "prefweap") == 0)
|
||||||
|
{
|
||||||
|
Cmd_PrefWeap_f(ent);
|
||||||
|
}
|
||||||
else /* anything that doesn't match a command will be a chat */
|
else /* anything that doesn't match a command will be a chat */
|
||||||
{
|
{
|
||||||
Cmd_Say_f(ent, false, true);
|
Cmd_Say_f(ent, false, true);
|
||||||
|
|
Loading…
Reference in a new issue