]> git.pond.sub.org Git - empserver/commitdiff
nat: Move putnat() into nat_reset() and simplify
authorMarkus Armbruster <armbru@pond.sub.org>
Mon, 31 Oct 2016 16:20:05 +0000 (17:20 +0100)
committerMarkus Armbruster <armbru@pond.sub.org>
Sun, 6 Aug 2017 18:09:21 +0000 (20:09 +0200)
Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
include/nat.h
src/lib/commands/add.c
src/lib/common/nat.c
src/util/files.c

index a1700cedf344f2d52de1efea13b2a93a3b94c0e5..fe5aeec5390c0f955682994db56c54720c5eb54f 100644 (file)
@@ -206,8 +206,7 @@ extern int nat_accepts(natid, natid, enum rej_comm);
 extern int in_contact(natid, natid);
 extern void agecontact(struct natstr *np);
 extern int influx(struct natstr *np);
-extern struct natstr *nat_reset(struct natstr *, natid, char *, char *,
-                               enum nat_status);
+extern void nat_reset(natid, char *, char *, enum nat_status);
 
 /* src/lib/subs/natsub.c */
 extern int check_nat_name(char *, natid);
index 1998e5ca12e5aba27ce9a2bf29804dabbef98cb2..891da1316c5d2fb69aa59abfffd377dc11bcae8b 100644 (file)
@@ -28,7 +28,7 @@
  *
  *  Known contributors to this file:
  *     Steve McClure, 2000
- *     Markus Armbruster, 2004-2013
+ *     Markus Armbruster, 2004-2016
  */
 
 #include <config.h>
@@ -117,7 +117,7 @@ add(void)
        pr("%s is logged in!\n", prnat(natp));
        return RET_FAIL;
     }
-    nat_reset(natp, natp->nat_cnum, cntryname, pname, stat);
-    putnat(natp);
-    return 0;
+
+    nat_reset(natp->nat_cnum, cntryname, pname, stat);
+    return RET_OK;
 }
index b51eb66f3298d884143d5b6ff83db82139ae09f1..3d6579968e09b3cbbdc3269c25308949feb04680 100644 (file)
@@ -125,37 +125,37 @@ influx(struct natstr *np)
 }
 
 /*
- * Initialize @natp for country #@cnum in status @stat.
+ * Initialize country #@cnum in status @stat.
  * @stat must be STAT_UNUSED, STAT_NEW, STAT_VIS or STAT_GOD.
  * Also wipe realms and telegrams.
  */
-struct natstr *
-nat_reset(struct natstr *natp, natid cnum, char *name, char *rep,
-         enum nat_status stat)
+void
+nat_reset(natid cnum, char *name, char *rep, enum nat_status stat)
 {
+    struct natstr nat;
     struct realmstr newrealm;
     char buf[1024];
     int i;
 
-    ef_blank(EF_NATION, cnum, natp);
-    natp->nat_stat = stat;
-    strncpy(natp->nat_cnam, name, sizeof(natp->nat_cnam) - 1);
-    strncpy(natp->nat_pnam, rep, sizeof(natp->nat_pnam) - 1);
+    ef_blank(EF_NATION, cnum, &nat);
+    nat.nat_stat = stat;
+    strncpy(nat.nat_cnam, name, sizeof(nat.nat_cnam) - 1);
+    strncpy(nat.nat_pnam, rep, sizeof(nat.nat_pnam) - 1);
     if (stat == STAT_GOD)
-       natp->nat_money = 123456789;
+       nat.nat_money = 123456789;
     for (i = 0; i < MAXNOR; i++) {
        ef_blank(EF_REALM, i + cnum * MAXNOR, &newrealm);
        putrealm(&newrealm);
     }
     mailbox_create(mailbox(buf, cnum));
-    /* FIXME natp->nat_ann = #annos */
-    natp->nat_level[NAT_HLEV] = start_happiness;
-    natp->nat_level[NAT_RLEV] = start_research;
-    natp->nat_level[NAT_TLEV] = start_technology;
-    natp->nat_level[NAT_ELEV] = start_education;
+    /* FIXME nat.nat_ann = #annos */
+    nat.nat_level[NAT_HLEV] = start_happiness;
+    nat.nat_level[NAT_RLEV] = start_research;
+    nat.nat_level[NAT_TLEV] = start_technology;
+    nat.nat_level[NAT_ELEV] = start_education;
     for (i = 0; i < MAXNOC; i++)
-       natp->nat_relate[i] = NEUTRAL;
-    natp->nat_flags =
+       nat.nat_relate[i] = NEUTRAL;
+    nat.nat_flags =
        NF_FLASH | NF_BEEP | NF_COASTWATCH | NF_SONAR | NF_TECHLISTS;
-    return natp;
+    putnat(&nat);
 }
index 722b489440db8e42a4949c515fadc0e238bfccc0..af8541cb312ef59850152ad2e1d090d831cd8c95 100644 (file)
@@ -30,7 +30,7 @@
  *     Thomas Ruschak
  *     Ken Stevens, 1995
  *     Steve McClure, 1998
- *     Markus Armbruster, 2004-2011
+ *     Markus Armbruster, 2004-2016
  */
 
 #include <config.h>
@@ -60,7 +60,6 @@ int
 main(int argc, char *argv[])
 {
     char buf[255];
-    struct natstr nat;
     int i;
     int opt;
     char *config_file = NULL;
@@ -135,9 +134,8 @@ main(int argc, char *argv[])
     if (mailbox_create(annfil) < 0)
        exit(1);
 
-    nat_reset(&nat, 0, "POGO", "peter", STAT_GOD);
-    putnat(&nat);
-    printf("All praise to %s!\n", nat.nat_cnam);
+    nat_reset(0, "POGO", "peter", STAT_GOD);
+    printf("All praise to POGO!\n");
 
     for (i = 0; i < EF_MAX; i++) {
        if (!EF_IS_GAME_STATE(i))