diff options
Diffstat (limited to 'src/map/atcommand.c')
-rw-r--r-- | src/map/atcommand.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/map/atcommand.c b/src/map/atcommand.c index 6debf2256..bb2ce41c7 100644 --- a/src/map/atcommand.c +++ b/src/map/atcommand.c @@ -213,6 +213,7 @@ ATCOMMAND_FUNC(setbattleflag); // by MouseJstr ATCOMMAND_FUNC(unmute); // [Valaris] ATCOMMAND_FUNC(uptime); // by MC Cameri ATCOMMAND_FUNC(changesex); // by MC Cameri +ATCOMMAND_FUNC(mute); // celest #ifndef TXT_ONLY ATCOMMAND_FUNC(checkmail); // [Valaris] @@ -463,6 +464,8 @@ static AtCommandInfo atcommand_info[] = { { AtCommand_UnMute, "@unmute", 60, atcommand_unmute }, // [Valaris] { AtCommand_UpTime, "@uptime", 0, atcommand_uptime }, // by MC Cameri { AtCommand_ChangeSex, "@changesex", 1, atcommand_changesex }, // by MC Cameri + { AtCommand_Mute, "@mute", 99, atcommand_mute }, // [celest] + { AtCommand_Mute, "@red", 99, atcommand_mute }, // [celest] #ifndef TXT_ONLY // sql-only commands { AtCommand_CheckMail, "@checkmail", 1, atcommand_listmail }, // [Valaris] @@ -7696,6 +7699,7 @@ int atcommand_unmute( if((pl_sd=map_nick2sd((char *) message)) != NULL) { if(pl_sd->sc_data[SC_NOCHAT].timer!=-1) { + pl_sd->status.manner = 0; // have to set to 0 first [celest] skill_status_change_end(&pl_sd->bl,SC_NOCHAT,-1); clif_displaymessage(sd->fd,"Player unmuted"); } @@ -7771,6 +7775,36 @@ atcommand_changesex( return 0; } +/*================================================ + * @mute - Mutes a player for a set amount of time + *------------------------------------------------ + */ +int atcommand_mute( + const int fd, struct map_session_data* sd, + const char* command, const char* message) +{ + struct map_session_data *pl_sd = NULL; + char character[100]; + int manner; + + if (!message || !*message || sscanf(message, "%d %99[^\n]", &manner, character) < 1) { + clif_displaymessage(fd, "usage: @mute <time> <character name>."); + return -1; + } + + if ((pl_sd = map_nick2sd(character)) != NULL) { + pl_sd->status.manner -= manner; + if(pl_sd->status.manner < 0) + skill_status_change_start(&pl_sd->bl,SC_NOCHAT,0,0,0,0,0,0); + } + else { + clif_displaymessage(fd, msg_table[3]); // Character not found. + return -1; + } + + return 0; +} + #ifndef TXT_ONLY /* Begin SQL-Only commands */ /*========================================== |