Added bury, dig and drain commands.
Signed-off-by: Polonkai Gergely <polesz@w00d5t0ck.info>
This commit is contained in:
parent
e5f990fe3c
commit
3509974c90
190
src/act.other.c
190
src/act.other.c
@ -24,6 +24,19 @@
|
|||||||
#include "house.h"
|
#include "house.h"
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
|
|
||||||
|
const char *digbury_msgs[][2] = {
|
||||||
|
{ "You start to break some floor boards when you dig.", "$n starts to break some floor boards as $e starts digging." },
|
||||||
|
{ "You wonder if this is a good place after all, with all the gravel.", "$n breaks a sweat digging up all the gravel here." },
|
||||||
|
{ "You make a nice hold while digging up a lot of dirt.", "$n digs a hole and goes about $s business." },
|
||||||
|
{ "You seem to be hitting a lot of roots when you dig.", "$n looks like $e is trying to dig up a tree." },
|
||||||
|
{ "You dig up more clay than dirt here.", "$n seems to be digging up a lot of clay." },
|
||||||
|
{ "You start to chip away the rock here.", "$n bangs away at the side of the mountain." },
|
||||||
|
{ "You can't dig in the water!", NULL },
|
||||||
|
{ "You can't dig in the water!", NULL },
|
||||||
|
{ "You can't dig up air!", NULL },
|
||||||
|
{ "If you see this, please tell a Prophet!", NULL }
|
||||||
|
};
|
||||||
|
|
||||||
/* extern variables */
|
/* extern variables */
|
||||||
extern struct spell_info_type spell_info[];
|
extern struct spell_info_type spell_info[];
|
||||||
extern const char *class_abbrevs[];
|
extern const char *class_abbrevs[];
|
||||||
@ -65,6 +78,9 @@ ACMD(do_wimpy);
|
|||||||
ACMD(do_display);
|
ACMD(do_display);
|
||||||
ACMD(do_gen_write);
|
ACMD(do_gen_write);
|
||||||
ACMD(do_gen_tog);
|
ACMD(do_gen_tog);
|
||||||
|
ACMD(do_bury);
|
||||||
|
ACMD(do_dig);
|
||||||
|
ACMD(do_drain);
|
||||||
|
|
||||||
|
|
||||||
ACMD(do_quit)
|
ACMD(do_quit)
|
||||||
@ -972,3 +988,177 @@ ACMD(do_gen_tog)
|
|||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ACMD(do_bury)
|
||||||
|
{
|
||||||
|
struct obj_data *obj;
|
||||||
|
char buf[MAX_INPUT_LENGTH], arg[MAX_INPUT_LENGTH];
|
||||||
|
|
||||||
|
half_chop(argument, arg, buf);
|
||||||
|
if (!*arg)
|
||||||
|
{
|
||||||
|
send_to_char(ch, "What do you want to %s?\r\n", CMD_NAME);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(obj = get_obj_in_list_vis(ch, arg, NULL, ch->carrying)))
|
||||||
|
{
|
||||||
|
send_to_char(ch, "You don't have %s %s\r\n", AN(arg), arg);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** find the sector types that you don't want people
|
||||||
|
** to be able to dig or bury in.
|
||||||
|
*/
|
||||||
|
if (
|
||||||
|
(world[IN_ROOM(ch)].sector_type == SECT_WATER_SWIM)
|
||||||
|
|| (world[IN_ROOM(ch)].sector_type == SECT_WATER_NOSWIM)
|
||||||
|
|| (world[IN_ROOM(ch)].sector_type == SECT_UNDERWATER)
|
||||||
|
|| (world[IN_ROOM(ch)].sector_type == SECT_FLYING)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
/* display the messages if available */
|
||||||
|
if (digbury_msgs[world[IN_ROOM(ch)].sector_type][0] != NULL)
|
||||||
|
send_to_char(ch, "%s\r\n", digbury_msgs[world[IN_ROOM(ch)].sector_type][0]);
|
||||||
|
|
||||||
|
if (digbury_msgs[world[IN_ROOM(ch)].sector_type][1] != NULL)
|
||||||
|
act(digbury_msgs[world[IN_ROOM(ch)].sector_type][1], TRUE, ch, NULL, NULL, TO_ROOM);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set a wait state */
|
||||||
|
WAIT_STATE(ch, 10 RL_SEC);
|
||||||
|
|
||||||
|
if(digbury_msgs[world[IN_ROOM(ch)].sector_type][0] != NULL)
|
||||||
|
send_to_char(ch, "%s\r\n", digbury_msgs[world[IN_ROOM(ch)].sector_type][0]);
|
||||||
|
|
||||||
|
if(digbury_msgs[world[IN_ROOM(ch)].sector_type][1] != NULL)
|
||||||
|
act(digbury_msgs[world[IN_ROOM(ch)].sector_type][1], TRUE, ch, NULL, NULL, TO_ROOM);
|
||||||
|
|
||||||
|
act("You bury $a $o here.\r\n", TRUE, ch, obj, NULL, TO_CHAR);
|
||||||
|
act("$n buries $a $o here.\r\n", TRUE, ch, obj, NULL, TO_ROOM);
|
||||||
|
|
||||||
|
obj_from_char(obj);
|
||||||
|
|
||||||
|
SET_BIT(GET_OBJ_EXTRA(obj), ITEM_BURIED);
|
||||||
|
|
||||||
|
obj_to_room(obj, IN_ROOM(ch));
|
||||||
|
}
|
||||||
|
|
||||||
|
ACMD(do_dig)
|
||||||
|
{
|
||||||
|
struct obj_data *obj;
|
||||||
|
int found_item = 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
** find the sector types that you don't want people
|
||||||
|
** to be able to dig or bury in.
|
||||||
|
*/
|
||||||
|
if (
|
||||||
|
(world[IN_ROOM(ch)].sector_type == SECT_WATER_SWIM)
|
||||||
|
|| (world[IN_ROOM(ch)].sector_type == SECT_WATER_NOSWIM)
|
||||||
|
|| (world[IN_ROOM(ch)].sector_type == SECT_UNDERWATER)
|
||||||
|
|| (world[IN_ROOM(ch)].sector_type == SECT_FLYING)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
/* display the messages if available */
|
||||||
|
if (digbury_msgs[world[IN_ROOM(ch)].sector_type][0] != NULL)
|
||||||
|
send_to_char(ch, "%s\r\n", digbury_msgs[world[IN_ROOM(ch)].sector_type][0]);
|
||||||
|
|
||||||
|
if (digbury_msgs[world[IN_ROOM(ch)].sector_type][1] != NULL)
|
||||||
|
act(digbury_msgs[world[IN_ROOM(ch)].sector_type][1], TRUE, ch, NULL, NULL, TO_ROOM);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set a wait state */
|
||||||
|
WAIT_STATE(ch, 10 RL_SEC);
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Now that we have established that we can dig lets go
|
||||||
|
** ahead and do it!
|
||||||
|
*/
|
||||||
|
if (digbury_msgs[world[IN_ROOM(ch)].sector_type][0] != NULL)
|
||||||
|
send_to_char(ch, "%s\r\n", digbury_msgs[world[IN_ROOM(ch)].sector_type][0]);
|
||||||
|
|
||||||
|
if (digbury_msgs[world[IN_ROOM(ch)].sector_type][1] != NULL)
|
||||||
|
act(digbury_msgs[world[IN_ROOM(ch)].sector_type][1], TRUE, ch, NULL, NULL,TO_ROOM);
|
||||||
|
|
||||||
|
/*
|
||||||
|
** search for an object in the room that has a ITEM_BURIED flag
|
||||||
|
*/
|
||||||
|
obj = world[IN_ROOM(ch)].contents;
|
||||||
|
|
||||||
|
while (obj != NULL)
|
||||||
|
{
|
||||||
|
if (IS_BURIED(obj))
|
||||||
|
{
|
||||||
|
/* Remove the buried bit so the player can see it. */
|
||||||
|
REMOVE_BIT(GET_OBJ_EXTRA(obj), ITEM_BURIED);
|
||||||
|
|
||||||
|
if(CAN_SEE_OBJ(ch, obj))
|
||||||
|
{
|
||||||
|
found_item = 1; /* player found something */
|
||||||
|
|
||||||
|
act("You found $a $o buried here.\r\n", TRUE, ch, obj, NULL, TO_CHAR);
|
||||||
|
act("$n has found $a $o buried here.\r\n", TRUE, ch, obj, NULL,TO_ROOM);
|
||||||
|
|
||||||
|
obj_from_room(obj);
|
||||||
|
obj_to_char(obj, ch);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* add the bit back becuase the player can't unbury what
|
||||||
|
** what he can't find... */
|
||||||
|
SET_BIT(GET_OBJ_EXTRA(obj), ITEM_BURIED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* go to the next obj */
|
||||||
|
obj = obj->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* if the player didn't find anything */
|
||||||
|
if (!found_item)
|
||||||
|
send_to_char(ch, "Sorry! You didn't find anything.\r\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
ACMD(do_drain)
|
||||||
|
{
|
||||||
|
char arg[MAX_INPUT_LENGTH];
|
||||||
|
struct obj_data *obj;
|
||||||
|
int HIT = 0,
|
||||||
|
MANA = 0,
|
||||||
|
MOVE = 0;
|
||||||
|
|
||||||
|
one_argument(argument, arg);
|
||||||
|
|
||||||
|
if (!*arg)
|
||||||
|
{
|
||||||
|
send_to_char(ch, "Drain what?\r\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(obj = get_obj_in_list_vis(ch, arg, NULL, world[ch->in_room].contents)))
|
||||||
|
{
|
||||||
|
send_to_char(ch, "That object is not here.\r\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
act("$n bends down and touches $p which slowly disappears.\r\n", FALSE, ch, obj, NULL, TO_ROOM);
|
||||||
|
act("You bend down and drain $p.\r\n", FALSE, ch, obj, NULL, TO_ROOM);
|
||||||
|
|
||||||
|
HIT = rand() % GET_LEVEL(ch) * 2 + 1;
|
||||||
|
MANA = rand() % GET_LEVEL(ch) + 1;
|
||||||
|
MOVE = rand() % 15 + 1;
|
||||||
|
GET_HIT(ch) = GET_HIT(ch) + HIT;
|
||||||
|
GET_MANA(ch) = GET_MANA(ch) + MANA;
|
||||||
|
GET_MOVE(ch) = GET_MOVE(ch) + MOVE;
|
||||||
|
|
||||||
|
extract_obj(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -70,6 +70,7 @@ ACMD(do_at);
|
|||||||
ACMD(do_backstab);
|
ACMD(do_backstab);
|
||||||
ACMD(do_ban);
|
ACMD(do_ban);
|
||||||
ACMD(do_bash);
|
ACMD(do_bash);
|
||||||
|
ACMD(do_bury);
|
||||||
ACMD(do_cast);
|
ACMD(do_cast);
|
||||||
ACMD(do_color);
|
ACMD(do_color);
|
||||||
ACMD(do_commands);
|
ACMD(do_commands);
|
||||||
@ -78,7 +79,9 @@ ACMD(do_credits);
|
|||||||
ACMD(do_date);
|
ACMD(do_date);
|
||||||
ACMD(do_dc);
|
ACMD(do_dc);
|
||||||
ACMD(do_diagnose);
|
ACMD(do_diagnose);
|
||||||
|
ACMD(do_dig);
|
||||||
ACMD(do_display);
|
ACMD(do_display);
|
||||||
|
ACMD(do_drain);
|
||||||
ACMD(do_drink);
|
ACMD(do_drink);
|
||||||
ACMD(do_drop);
|
ACMD(do_drop);
|
||||||
ACMD(do_eat);
|
ACMD(do_eat);
|
||||||
@ -233,6 +236,7 @@ cpp_extern const struct command_info cmd_info[] = {
|
|||||||
{ "brb" , POS_RESTING , do_action , 0, 0 },
|
{ "brb" , POS_RESTING , do_action , 0, 0 },
|
||||||
{ "brief" , POS_DEAD , do_gen_tog , 0, SCMD_BRIEF },
|
{ "brief" , POS_DEAD , do_gen_tog , 0, SCMD_BRIEF },
|
||||||
{ "burp" , POS_RESTING , do_action , 0, 0 },
|
{ "burp" , POS_RESTING , do_action , 0, 0 },
|
||||||
|
{ "bury" , POS_STANDING, do_bury , 0, 0 },
|
||||||
{ "buy" , POS_STANDING, do_not_here , 0, 0 },
|
{ "buy" , POS_STANDING, do_not_here , 0, 0 },
|
||||||
{ "bug" , POS_DEAD , do_gen_write, 0, SCMD_BUG },
|
{ "bug" , POS_DEAD , do_gen_write, 0, SCMD_BUG },
|
||||||
|
|
||||||
@ -264,8 +268,10 @@ cpp_extern const struct command_info cmd_info[] = {
|
|||||||
{ "dc" , POS_DEAD , do_dc , LVL_GOD, 0 },
|
{ "dc" , POS_DEAD , do_dc , LVL_GOD, 0 },
|
||||||
{ "deposit" , POS_STANDING, do_not_here , 1, 0 },
|
{ "deposit" , POS_STANDING, do_not_here , 1, 0 },
|
||||||
{ "diagnose" , POS_RESTING , do_diagnose , 0, 0 },
|
{ "diagnose" , POS_RESTING , do_diagnose , 0, 0 },
|
||||||
|
{ "dig" , POS_STANDING, do_dig , 0, 0 },
|
||||||
{ "display" , POS_DEAD , do_display , 0, 0 },
|
{ "display" , POS_DEAD , do_display , 0, 0 },
|
||||||
{ "donate" , POS_RESTING , do_drop , 0, SCMD_DONATE },
|
{ "donate" , POS_RESTING , do_drop , 0, SCMD_DONATE },
|
||||||
|
{ "drain" , POS_STANDING, do_drain , 0, 0 },
|
||||||
{ "drink" , POS_RESTING , do_drink , 0, SCMD_DRINK },
|
{ "drink" , POS_RESTING , do_drink , 0, SCMD_DRINK },
|
||||||
{ "drop" , POS_RESTING , do_drop , 0, SCMD_DROP },
|
{ "drop" , POS_RESTING , do_drop , 0, SCMD_DROP },
|
||||||
{ "drool" , POS_RESTING , do_action , 0, 0 },
|
{ "drool" , POS_RESTING , do_action , 0, 0 },
|
||||||
|
@ -314,6 +314,7 @@
|
|||||||
#define ITEM_PEN 21 /* Item is a pen */
|
#define ITEM_PEN 21 /* Item is a pen */
|
||||||
#define ITEM_BOAT 22 /* Item is a boat */
|
#define ITEM_BOAT 22 /* Item is a boat */
|
||||||
#define ITEM_FOUNTAIN 23 /* Item is a fountain */
|
#define ITEM_FOUNTAIN 23 /* Item is a fountain */
|
||||||
|
#define ITEM_BURIED 24 /* Item is buried */
|
||||||
|
|
||||||
|
|
||||||
/* Take/Wear flags: used by obj_data.obj_flags.wear_flags */
|
/* Take/Wear flags: used by obj_data.obj_flags.wear_flags */
|
||||||
|
@ -400,6 +400,7 @@ void update_pos(struct char_data *victim);
|
|||||||
GET_OBJ_VAL((obj), 3) == 1)
|
GET_OBJ_VAL((obj), 3) == 1)
|
||||||
|
|
||||||
#define CAN_WEAR(obj, part) OBJWEAR_FLAGGED((obj), (part))
|
#define CAN_WEAR(obj, part) OBJWEAR_FLAGGED((obj), (part))
|
||||||
|
#define IS_BURIED(obj) (IS_SET(GET_OBJ_EXTRA((obj)), ITEM_BURIED))
|
||||||
|
|
||||||
|
|
||||||
/* compound utilities and other macros **********************************/
|
/* compound utilities and other macros **********************************/
|
||||||
@ -452,10 +453,10 @@ void update_pos(struct char_data *victim);
|
|||||||
(!obj->worn_by || CAN_SEE(sub, obj->worn_by)))
|
(!obj->worn_by || CAN_SEE(sub, obj->worn_by)))
|
||||||
|
|
||||||
#define MORT_CAN_SEE_OBJ(sub, obj) \
|
#define MORT_CAN_SEE_OBJ(sub, obj) \
|
||||||
(LIGHT_OK(sub) && INVIS_OK_OBJ(sub, obj) && CAN_SEE_OBJ_CARRIER(sub, obj))
|
(LIGHT_OK(sub) && INVIS_OK_OBJ(sub, obj) && CAN_SEE_OBJ_CARRIER(sub, obj) )
|
||||||
|
|
||||||
#define CAN_SEE_OBJ(sub, obj) \
|
#define CAN_SEE_OBJ(sub, obj) \
|
||||||
(MORT_CAN_SEE_OBJ(sub, obj) || (!IS_NPC(sub) && PRF_FLAGGED((sub), PRF_HOLYLIGHT)))
|
((MORT_CAN_SEE_OBJ(sub, obj) && !IS_BURIED(obj)) || (!IS_NPC(sub) && PRF_FLAGGED((sub), PRF_HOLYLIGHT)))
|
||||||
|
|
||||||
#define CAN_CARRY_OBJ(ch,obj) \
|
#define CAN_CARRY_OBJ(ch,obj) \
|
||||||
(((IS_CARRYING_W(ch) + GET_OBJ_WEIGHT(obj)) <= CAN_CARRY_W(ch)) && \
|
(((IS_CARRYING_W(ch) + GET_OBJ_WEIGHT(obj)) <= CAN_CARRY_W(ch)) && \
|
||||||
|
Loading…
Reference in New Issue
Block a user