ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/common/init.C
(Generate patch)

Comparing deliantra/server/common/init.C (file contents):
Revision 1.18 by root, Sat Dec 30 10:16:10 2006 UTC vs.
Revision 1.26 by root, Tue Mar 6 14:01:10 2007 UTC

1/* 1/*
2 CrossFire, A Multiplayer game for X-windows 2 * CrossFire, A Multiplayer game for X-windows
3 3 *
4 * Copyright (C) 2005, 2006, 2007 Marc Lehmann & Crossfire+ Development Team
4 Copyright (C) 2002 Mark Wedel & Crossfire Development Team 5 * Copyright (C) 2002 Mark Wedel & Crossfire Development Team
5 Copyright (C) 1992 Frank Tore Johansen 6 * Copyright (C) 1992 Frank Tore Johansen
6 7 *
7 This program is free software; you can redistribute it and/or modify 8 * This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by 9 * it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or 10 * the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version. 11 * (at your option) any later version.
11 12 *
12 This program is distributed in the hope that it will be useful, 13 * This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details. 16 * GNU General Public License for more details.
16 17 *
17 You should have received a copy of the GNU General Public License 18 * You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software 19 * along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 21 *
21 The authors can be reached via e-mail at <crossfire@schmorp.de> 22 * The authors can be reached via e-mail at <crossfire@schmorp.de>
22*/ 23 */
23 24
24#define EXTERN // horrible hack 25#define EXTERN // horrible hack
25 26
26#include <global.h> 27#include <global.h>
27#include <object.h> 28#include <object.h>
146 * init_hash_table if you are doing any object loading. 147 * init_hash_table if you are doing any object loading.
147 */ 148 */
148void 149void
149init_library (void) 150init_library (void)
150{ 151{
151 init_environ ();
152 init_globals (); 152 init_globals ();
153 init_vars ();
154 init_block (); 153 init_block ();
155 ReadBmapNames (); 154 ReadBmapNames ();
156 ReadSmooth (); 155 ReadSmooth ();
157 init_anim (); /* Must be after we read in the bitmaps */ 156 init_anim (); /* Must be after we read in the bitmaps */
158 init_archetypes (); /* Reads all archetypes from file */ 157 init_archetypes (); /* Reads all archetypes from file */
161 init_clocks (); 160 init_clocks ();
162 init_experience (); 161 init_experience ();
163} 162}
164 163
165 164
166/* init_environ initializes values from the environmental variables. 165/* init_environ initialises values from the environmental variables.
167 * it needs to be called very early, since command line options should 166 * it needs to be called very early, since command line options should
168 * overwrite these if specified. 167 * overwrite these if specified.
169 */ 168 */
170void 169void
171init_environ (void) 170init_environ (void)
199 cp = getenv ("CROSSFIRE_TMPDIR"); 198 cp = getenv ("CROSSFIRE_TMPDIR");
200 if (cp) 199 if (cp)
201 settings.tmpdir = cp; 200 settings.tmpdir = cp;
202} 201}
203 202
204
205/* 203/*
206 * Initialises all global variables. 204 * Initialises all global variables.
207 * Might use environment-variables as default for some of them. 205 * Might use environment-variables as default for some of them.
208 */ 206 */
209
210void 207void
211init_globals (void) 208init_globals (void)
212{ 209{
213 if (settings.logfilename[0] == 0) 210 if (settings.logfilename[0] == 0)
214 logfile = stderr; 211 logfile = stderr;
229 while (at) 226 while (at)
230 { 227 {
231 if (at->clone.type == MAP) 228 if (at->clone.type == MAP)
232 { 229 {
233 if (at->clone.race) 230 if (at->clone.race)
234 strcpy (first_map_ext_path, at->clone.race); 231 first_map_ext_path = at->clone.race;
235 232
236 if (EXIT_PATH (&at->clone)) 233 if (EXIT_PATH (&at->clone))
237 { 234 {
238 strcpy (first_map_path, EXIT_PATH (&at->clone)); 235 first_map_path = EXIT_PATH (&at->clone);
239 return; 236 return;
240 } 237 }
241 } 238 }
242 239
243 at = at->next; 240 at = at->next;
251 248
252/* 249/*
253 * Write out the current time to the file so time does not 250 * Write out the current time to the file so time does not
254 * reset every time the server reboots. 251 * reset every time the server reboots.
255 */ 252 */
256
257void 253void
258write_todclock (void) 254write_todclock (void)
259{ 255{
260 char filename[MAX_BUF]; 256 char filename[MAX_BUF];
261 FILE *fp; 257 FILE *fp;
269 fprintf (fp, "%lu", todtick); 265 fprintf (fp, "%lu", todtick);
270 fclose (fp); 266 fclose (fp);
271} 267}
272 268
273/* 269/*
274 * Initializes the gametime and TOD counters 270 * initialises the gametime and TOD counters
275 * Called by init_library(). 271 * Called by init_library().
276 */ 272 */
277
278void 273void
279init_clocks (void) 274init_clocks (void)
280{ 275{
281 char filename[MAX_BUF]; 276 char filename[MAX_BUF];
282 FILE *fp; 277 FILE *fp;
286 return; 281 return;
287 else 282 else
288 has_been_done = 1; 283 has_been_done = 1;
289 284
290 sprintf (filename, "%s/clockdata", settings.localdir); 285 sprintf (filename, "%s/clockdata", settings.localdir);
291 LOG (llevDebug, "Reading clockdata from %s...", filename); 286 LOG (llevDebug, "Reading clockdata from %s...\n", filename);
292 if ((fp = fopen (filename, "r")) == NULL) 287 if ((fp = fopen (filename, "r")) == NULL)
293 { 288 {
294 LOG (llevError, "Can't open %s.\n", filename); 289 LOG (llevError, "Can't open %s.\n", filename);
295 todtick = 0; 290 todtick = 0;
296 write_todclock (); 291 write_todclock ();
297 return; 292 return;
298 } 293 }
294
299 fscanf (fp, "%lu", &todtick); 295 fscanf (fp, "%lu", &todtick);
300 LOG (llevDebug, "todtick=%lu\n", todtick); 296 LOG (llevDebug, "todtick=%lu\n", todtick);
301 fclose (fp); 297 fclose (fp);
302} 298}
303 299
304/* 300/*
305 * Initializes the attack messages. 301 * initialises the attack messages.
306 * Called by init_library(). 302 * Called by init_library().
307 */ 303 */
308 304
309//attackmess_t attack_mess[NROFATTACKMESS][MAXATTACKMESS]; 305//attackmess_t attack_mess[NROFATTACKMESS][MAXATTACKMESS];
310 306
323 return; 319 return;
324 else 320 else
325 has_been_done = 1; 321 has_been_done = 1;
326 322
327 sprintf (filename, "%s/attackmess", settings.datadir); 323 sprintf (filename, "%s/attackmess", settings.datadir);
328 LOG (llevDebug, "Reading attack messages from %s...", filename); 324 LOG (llevDebug, "Reading attack messages from %s...\n", filename);
329 if ((fp = open_and_uncompress (filename, 0, &comp)) == NULL) 325 if ((fp = open_and_uncompress (filename, 0, &comp)) == NULL)
330 { 326 {
331 LOG (llevError, "Can't open %s.\n", filename); 327 LOG (llevError, "Can't open %s.\n", filename);
332 return; 328 return;
333 } 329 }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines