]> git.pond.sub.org Git - empserver/blob - src/util/files.c
(dflt_econfig): New.
[empserver] / src / util / files.c
1 /*
2  *  Empire - A multi-player, client/server Internet based war game.
3  *  Copyright (C) 1986-2004, Dave Pare, Jeff Bailey, Thomas Ruschak,
4  *                           Ken Stevens, Steve McClure
5  *
6  *  This program is free software; you can redistribute it and/or modify
7  *  it under the terms of the GNU General Public License as published by
8  *  the Free Software Foundation; either version 2 of the License, or
9  *  (at your option) any later version.
10  *
11  *  This program is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  *  GNU General Public License for more details.
15  *
16  *  You should have received a copy of the GNU General Public License
17  *  along with this program; if not, write to the Free Software
18  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  *  ---
21  *
22  *  See the "LEGAL", "LICENSE", "CREDITS" and "README" files for all the
23  *  related information and legal notices. It is expected that any future
24  *  projects/authors will amend these files as needed.
25  *
26  *  ---
27  *
28  *  files.c: Create all the misc files
29  * 
30  *  Known contributors to this file:
31  *     Thomas Ruschak
32  *     Ken Stevens, 1995
33  *     Steve McClure, 1998
34  */
35
36 #if defined(aix) || defined(linux) || defined(solaris)
37 #include <unistd.h>
38 #endif /* aix or linux */
39
40 #include <sys/types.h>
41 #include <fcntl.h>
42 #if !defined(_WIN32)
43 #include <sys/uio.h>
44 #include <sys/file.h>
45 #else
46 #include <direct.h>
47 #include "../lib/gen/getopt.h"
48 #endif
49 #include <stdarg.h>
50 #include <stdio.h>
51
52 #include "options.h"
53 #include "misc.h"
54 #include "sect.h"
55 #include "nat.h"
56 #include "ship.h"
57 #include "land.h"
58 #include "plane.h"
59 #include "nuke.h"
60 #include "power.h"
61 #include "trade.h"
62 #include "file.h"
63 #include "tel.h"
64 #include "prototypes.h"
65 #include "optlist.h"
66
67 static void file_sct_init(coord x, coord y, s_char *ptr);
68
69 static void
70 print_usage(char *program_name)
71 {
72     printf("Usage: %s -f -e econfig_file\n", program_name);
73     printf("-f force mode\n");
74 }
75
76 int
77 main(int argc, char *argv[])
78 {
79     s_char buf[255];
80     s_char *filename;
81     int x, y;
82     struct natstr nat;
83     struct sctstr sct;
84     int i;
85     s_char *map;
86     int opt;
87     char *config_file = NULL;
88     int force = 0;
89
90     while ((opt = getopt(argc, argv, "e:f")) != EOF) {
91         switch (opt) {
92         case 'e':
93             config_file = optarg;
94             break;
95         case 'f':
96             force = 1;
97             break;
98         default:
99             print_usage(argv[0]);
100             exit(-1);
101         }
102     }
103
104     if (emp_config(config_file) < 0)
105         exit(1);
106
107     empfile[EF_MAP].size = (WORLD_X * WORLD_Y) / 2;
108     empfile[EF_BMAP].size = (WORLD_X * WORLD_Y) / 2;
109
110     if (access(datadir, F_OK) < 0 && mkdir(datadir, 0750) < 0) {
111         perror(datadir);
112         printf("Can't make game directory\n");
113         exit(1);
114     }
115     if (!force) {
116         printf("WARNING: this blasts the existing game in %s (if any)\n",
117            datadir);
118         printf("continue? ");
119         fgets(buf, sizeof(buf) - 1, stdin);
120         if (*buf != 'y' && *buf != 'Y')
121             exit(1);
122     }
123     for (i = 0; i < EF_MAX; i++) {
124         if (ef_open(i, O_RDWR | O_CREAT | O_TRUNC, 0) < 0) {
125             perror("ef_open");
126             exit(1);
127         }
128     }
129     memset(&nat, 0, sizeof(nat));
130     nat.ef_type = EF_NATION;
131     if (nat.nat_cnam[0] == 0)
132         strcpy(nat.nat_cnam, "POGO");
133     if (nat.nat_pnam[0] == 0)
134         strcpy(nat.nat_pnam, "peter");
135     nat.nat_stat = STAT_INUSE | STAT_NORM | STAT_GOD | STAT_ABS;
136     nat.nat_btu = 255;
137     nat.nat_money = 123456789;
138     nat.nat_cnum = 0;
139     nat.nat_flags |= NF_FLASH;
140     for (i = 0; i <= PRI_MAX; i++)
141         nat.nat_priorities[i] = -1;
142     putnat((&nat));
143     printf("All praise to %s!\n", nat.nat_cnam);
144     memset(&nat, 0, sizeof(nat));
145     for (i = 1; i < MAXNOC; i++) {
146         nat.ef_type = EF_NATION;
147         nat.nat_cnum = i;
148         putnat((&nat));
149     }
150     ef_close(EF_NATION);
151     if (access(teldir, F_OK) < 0 && mkdir(teldir, 0750) < 0) {
152         perror(teldir);
153         printf("Can't make telegram directory\n");
154         exit(1);
155     }
156     for (x = MAXNOC - 1; x >= 0; x--) {
157         filename = mailbox(buf, x);
158         close(creat(filename, 0600));
159         chmod(filename, 0600);
160     }
161     close(creat(timestampfil, 0600));
162     close(creat(annfil, 0600));
163     chmod(infodir, 0750);
164     chmod(datadir, 0770);
165     chmod(teldir, 0770);
166
167     /* create a zero-filled sector file */
168     memset(&sct, 0, sizeof(sct));
169     for (y = 0; y < WORLD_Y; y++) {
170         for (x = 0; x < WORLD_X / 2; x++) {
171             file_sct_init(x * 2 + (y & 01), y, (s_char *)&sct);
172             putsect(&sct);
173         }
174     }
175     map = (s_char *)calloc(WORLD_X * WORLD_Y / 2, sizeof(*map));
176     for (i = 0; i < MAXNOC; i++) {
177         ef_write(EF_MAP, i, map);
178     }
179     map = (s_char *)calloc(WORLD_X * WORLD_Y / 2, sizeof(*map));
180     for (i = 0; i < MAXNOC; i++) {
181         ef_write(EF_BMAP, i, map);
182     }
183     for (i = 0; i < EF_MAX; i++) {
184         ef_close(i);
185     }
186
187     exit(0);
188 }
189
190 static void
191 file_sct_init(coord x, coord y, s_char *ptr)
192 {
193     struct sctstr *sp = (struct sctstr *)ptr;
194
195     sp->ef_type = EF_SECTOR;
196     sp->sct_x = x;
197     sp->sct_y = y;
198     sp->sct_dist_x = x;
199     sp->sct_dist_y = y;
200 }
201
202 void
203 logerror(s_char *format, ...)
204 {
205     va_list ap;
206
207     va_start(ap, format);
208     vfprintf(stderr, format, ap);
209     va_end(ap);
210 }
211
212 void
213 log_last_commands(void)
214 {
215 }