]> git.pond.sub.org Git - empserver/blobdiff - src/lib/commands/flash.c
Change flash not to print "Flash sent" for deities
[empserver] / src / lib / commands / flash.c
index 6cf9b6c11eb246275e61e339f2d959c4fc3debe7..e07ea128b8fdf3c1296707486d729082be9bfe96 100644 (file)
@@ -1,6 +1,6 @@
 /*
  *  Empire - A multi-player, client/server Internet based war game.
- *  Copyright (C) 1986-2006, Dave Pare, Jeff Bailey, Thomas Ruschak,
+ *  Copyright (C) 1986-2010, Dave Pare, Jeff Bailey, Thomas Ruschak,
  *                           Ken Stevens, Steve McClure
  *
  *  This program is free software; you can redistribute it and/or modify
  *
  *  ---
  *
- *  See the "LEGAL", "LICENSE", "CREDITS" and "README" files for all the
- *  related information and legal notices. It is expected that any future
- *  projects/authors will amend these files as needed.
+ *  See files README, COPYING and CREDITS in the root of the source
+ *  tree for related information and legal notices.  It is expected
+ *  that future projects/authors will amend these files as needed.
  *
  *  ---
  *
  *  flash.c: Flash a message to another player
- * 
+ *
  *  Known contributors to this file:
  *     Ken Stevens, 1995
  *     Steve McClure, 1998
+ *     Ron Koenderink, 2005
+ *     Markus Armbruster, 2004-2009
  */
 
 #include <config.h>
 
-#include <time.h>
-#include "misc.h"
-#include "player.h"
-#include "nat.h"
-#include "file.h"
 #include "commands.h"
 
+static int chat(struct natstr *, struct natstr *, char *);
+static int sendmessage(struct natstr *, struct natstr *, char *, int);
+
 int
 flash(void)
 {
     struct natstr *us;
     struct natstr *to;
-    char buf[1024];            /* UTF-8 */
     int tocn;
-    char *sp;                  /* points into player->combuf[], UTF-8 */
 
     us = getnatp(player->cnum);
     if ((tocn = natarg(player->argp[1], "to which country? ")) < 0)
@@ -71,80 +69,62 @@ flash(void)
        }
     }
 
-    if (player->argp[2]) {
-       for (sp = player->combuf; *sp && *sp != ' '; ++sp) ;
-       for (++sp; *sp && *sp != ' '; ++sp) ;
-       buf[0] = ':';
-       if (player->flags & PF_UTF8)
-           strcpy(buf+1, sp);
-       else
-           copy_utf8_to_ascii_no_funny(buf+1, sp);
-       sendmessage(us, to, buf, 1);
-    } else {
-       sendmessage(us, to, "...", 1);
-       while (ugetstring("> ", buf)) {
-           if (*buf == '.')
-               break;
-           sendmessage(us, to, buf, 0);
-       }
-       sendmessage(us, to, "<EOT>", 0);
-    }
-    return RET_OK;
+    return chat(us, to, player->comtail[2]);
 }
 
 int
 wall(void)
 {
-    struct natstr *us;
+    return chat(getnatp(player->cnum), NULL, player->comtail[1]);
+}
+
+/*
+ * Send flash message(s) from US to TO.
+ * Null TO broadcasts to all.
+ * MESSAGE is UTF-8.  If it is null, prompt for messages interactively.
+ * Return RET_OK.
+ */
+static int
+chat(struct natstr *us, struct natstr *to, char *message)
+{
     char buf[1024];            /* UTF-8 */
-    char *sp;                  /* points into player->combuf[], UTF-8 */
 
-    us = getnatp(player->cnum);
-    if (player->argp[1]) {
-       for (sp = player->combuf; *sp && *sp != ' '; ++sp) ;
+    if (message) {
        buf[0] = ':';
-       if (player->flags & PF_UTF8)
-           strcpy(buf+1, sp);
-       else
-           copy_utf8_to_ascii_no_funny(buf+1, sp);
-       sendmessage(us, 0, buf, 1);
+       buf[1] = ' ';
+       strcpy(buf+2, message);
+       sendmessage(us, to, buf, 1);
     } else {
-       sendmessage(us, 0, "...", 1);
+       sendmessage(us, to, "...", 1);
        while (ugetstring("> ", buf)) {
            if (*buf == '.')
                break;
-           sendmessage(us, 0, buf, 0);
+           sendmessage(us, to, buf, 0);
        }
-       sendmessage(us, 0, "<EOT>", 0);
+       sendmessage(us, to, "<EOT>", 0);
     }
     return RET_OK;
 }
 
 /*
  * Send flash message MESSAGE from US to TO.
- * MESSAGE is UTF-8.  Long messages are broken into several parts.
- * A header identifying US is prepended to each part.  The first
- * header is more verbose if ONESHOT.
+ * MESSAGE is UTF-8.
+ * Null TO broadcasts to all.
+ * A header identifying US is prepended to the message.  It is more
+ * verbose if VERBOSE.
  */
-int
-sendmessage(struct natstr *us, struct natstr *to, char *message, int oneshot)
+static int
+sendmessage(struct natstr *us, struct natstr *to, char *message, int verbose)
 {
     struct player *other;
     struct tm *tm;
     time_t now;
     int sent = 0;
     struct natstr *wto;
-    char c;
-    int pos;
-
-    pos = ufindpfx(message, 60);
-    c = message[pos];
-    if (c)
-        message[pos] = '\0';
 
     time(&now);
     tm = localtime(&now);
-    for (other = player_next(0); other != 0; other = player_next(other)) {
+    for (other = player_next(NULL); other; other = player_next(other)) {
        if (other->state != PS_PLAYING)
            continue;
        if (to && other->cnum != to->nat_cnum)
@@ -157,7 +137,7 @@ sendmessage(struct natstr *us, struct natstr *to, char *message, int oneshot)
            continue;
        if (player == other)
            continue;
-       if (oneshot)
+       if (verbose)
            if (to)
                pr_flash(other, "FLASH from %s (#%d) @ %02d:%02d%s\n",
                         us->nat_cnam, us->nat_cnum, tm->tm_hour,
@@ -170,16 +150,14 @@ sendmessage(struct natstr *us, struct natstr *to, char *message, int oneshot)
        else
            pr_flash(other, "%s (#%d): %s\n",
                     us->nat_cnam, us->nat_cnum, message);
-       player_wakeup(other);
        sent++;
     }
+    
     if (player->god) {
-       if (to)
-           if (sent)
-               pr("Flash sent to %s\n", to->nat_cnam);
-           else
+       if (to) {
+           if (!sent)
                pr("%s is not logged on\n", to->nat_cnam);
-       else if (sent)
+       else if (sent)
            pr("Broadcast sent to %d players\n", sent);
        else
            pr("No-one is logged in\n");
@@ -194,9 +172,5 @@ sendmessage(struct natstr *us, struct natstr *to, char *message, int oneshot)
                pr("%s is not accepting flashes\n", to->nat_cnam);
        }
     }
-    if (c) {
-       message[pos] = c;
-       sendmessage(us, to, &message[pos], 0);
-    }
     return 0;
 }