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.11 by root, Wed Sep 13 02:05:18 2006 UTC vs.
Revision 1.16 by root, Thu Dec 14 22:45:40 2006 UTC

16 16
17 You should have received a copy of the GNU General Public License 17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software 18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 20
21 The authors can be reached via e-mail at crossfire-devel@real-time.com 21 The authors can be reached via e-mail at <crossfire@schmorp.de>
22*/ 22*/
23 23
24#define EXTERN // horrible hack 24#define EXTERN // horrible hack
25 25
26#include <global.h> 26#include <global.h>
27#include <object.h> 27#include <object.h>
28 28
29extern const char *const attacktype_desc[NROFATTACKS] = { 29extern const char *const attacktype_desc[NROFATTACKS] = {
30# define def(uc, lc, name, plus, change) # name, 30# define def(uc, lc, name, plus, change) # name,
31# include "attackinc.h"
32# undef def
33};
34
35extern const keyword resist_save[NROFATTACKS] = {
36# define def(uc, lc, name, plus, change) KW_resist_ ## lc,
37# include "attackinc.h" 31# include "attackinc.h"
38# undef def 32# undef def
39}; 33};
40 34
41extern const char *const resist_plus[NROFATTACKS] = { 35extern const char *const resist_plus[NROFATTACKS] = {
97 REAL_WIZ, 91 REAL_WIZ,
98 RECYCLE_TMP_MAPS, 92 RECYCLE_TMP_MAPS,
99 EXPLORE_MODE, 93 EXPLORE_MODE,
100 SPELLPOINT_LEVEL_DEPEND, 94 SPELLPOINT_LEVEL_DEPEND,
101 SET_FRIENDLY_FIRE, 95 SET_FRIENDLY_FIRE,
102 "", /* Who format specifier */
103 "", /* who wiz format specifier */
104 MOTD, 96 MOTD,
105 "rules", 97 "rules",
106 "news", 98 "news",
107 "", /* DM_MAIL */ 99 "", /* DM_MAIL */
108 0, /* This and the next 3 values are metaserver values */
109 "",
110 "",
111 0,
112 "",
113 0, 0, 0, 0, 0, 0, 0, 0, /* worldmap settings */ 100 0, 0, 0, 0, 0, 0, 0, 0, /* worldmap settings */
114 EMERGENCY_MAPPATH, EMERGENCY_X, EMERGENCY_Y, 101 EMERGENCY_MAPPATH, EMERGENCY_X, EMERGENCY_Y,
115 0, 102 0,
116 1.0, 103 1.0,
117 104
177 continue; /* ignore comments */ 164 continue; /* ignore comments */
178 165
179 if (online == 0) 166 if (online == 0)
180 { 167 {
181 tmpbuf[strlen (tmpbuf) - 1] = 0; /* kill newline */ 168 tmpbuf[strlen (tmpbuf) - 1] = 0; /* kill newline */
182 settings.emergency_mapname = strdup_local (tmpbuf); 169 settings.emergency_mapname = strdup (tmpbuf);
183 } 170 }
184 else if (online == 1) 171 else if (online == 1)
185 { 172 {
186 settings.emergency_x = atoi (tmpbuf); 173 settings.emergency_x = atoi (tmpbuf);
187 } 174 }
214void 201void
215init_library (void) 202init_library (void)
216{ 203{
217 init_environ (); 204 init_environ ();
218 init_globals (); 205 init_globals ();
219 init_objects ();
220 init_vars (); 206 init_vars ();
221 init_block (); 207 init_block ();
222 ReadBmapNames (); 208 ReadBmapNames ();
223 ReadSmooth (); 209 ReadSmooth ();
224 init_anim (); /* Must be after we read in the bitmaps */ 210 init_anim (); /* Must be after we read in the bitmaps */
277 263
278void 264void
279init_globals (void) 265init_globals (void)
280{ 266{
281 if (settings.logfilename[0] == 0) 267 if (settings.logfilename[0] == 0)
282 {
283 logfile = stderr; 268 logfile = stderr;
284 }
285 else if ((logfile = fopen (settings.logfilename, "a")) == NULL) 269 else if ((logfile = fopen (settings.logfilename, "a")) == NULL)
286 { 270 {
287 fprintf (stderr, "Unable to open %s as the logfile - will use stderr instead\n", settings.logfilename); 271 fprintf (stderr, "Unable to open %s as the logfile - will use stderr instead\n", settings.logfilename);
288 logfile = stderr; 272 logfile = stderr;
289 } 273 }
290 else 274 else
291 {
292 setvbuf (logfile, NULL, _IOLBF, 0); 275 setvbuf (logfile, NULL, _IOLBF, 0);
293 }
294 exiting = 0;
295 first_player = NULL;
296 first_friendly_object = NULL;
297 first_map = NULL;
298 first_treasurelist = NULL;
299 first_artifactlist = NULL;
300 first_archetype = NULL;
301 *first_map_ext_path = 0;
302 warn_archetypes = 0;
303 nroftreasures = 0;
304 nrofartifacts = 0;
305 nrofallowedstr = 0;
306 ring_arch = NULL;
307 amulet_arch = NULL;
308 staff_arch = NULL;
309 trying_emergency_save = 0;
310 num_animations = 0;
311 animations_allocated = 0;
312 init_defaults ();
313} 276}
314
315/*
316 * Sets up and initialises the linked list of free and used objects.
317 * Allocates a certain chunk of objects and puts them on the free list.
318 * Called by init_library();
319 */
320
321void
322init_objects (void)
323{
324 /* Initialize all objects: */
325 objects = NULL;
326 active_objects = NULL;
327}
328
329/*
330 * Initialises global variables which can be changed by options.
331 * Called by init_library().
332 */
333
334void
335init_defaults (void)
336{
337 editor = 0;
338 nroferrors = 0;
339}
340
341 277
342void 278void
343init_dynamic (void) 279init_dynamic (void)
344{ 280{
345 archetype *at = first_archetype; 281 archetype *at = first_archetype;
347 while (at) 283 while (at)
348 { 284 {
349 if (at->clone.type == MAP) 285 if (at->clone.type == MAP)
350 { 286 {
351 if (at->clone.race) 287 if (at->clone.race)
352 {
353 strcpy (first_map_ext_path, at->clone.race); 288 strcpy (first_map_ext_path, at->clone.race);
354 } 289
355 if (EXIT_PATH (&at->clone)) 290 if (EXIT_PATH (&at->clone))
356 { 291 {
357 strcpy (first_map_path, EXIT_PATH (&at->clone)); 292 strcpy (first_map_path, EXIT_PATH (&at->clone));
358 return; 293 return;
359 } 294 }
360 } 295 }
296
361 at = at->next; 297 at = at->next;
362 } 298 }
299
363 LOG (llevDebug, "You Need a archetype called 'map' and it have to contain start map\n"); 300 LOG (llevDebug, "You Need a archetype called 'map' and it have to contain start map\n");
364 exit (-1); 301 exit (-1);
365} 302}
366 303
367unsigned long todtick; 304unsigned long todtick;
480 { 417 {
481 p = strtok (buf, "="); 418 p = strtok (buf, "=");
482 attack_mess[mess][level].level = atoi (buf); 419 attack_mess[mess][level].level = atoi (buf);
483 p = strtok (NULL, "="); 420 p = strtok (NULL, "=");
484 if (p != NULL) 421 if (p != NULL)
485 attack_mess[mess][level].buf1 = strdup_local (p); 422 attack_mess[mess][level].buf1 = strdup (p);
486 else 423 else
487 attack_mess[mess][level].buf1 = strdup_local (""); 424 attack_mess[mess][level].buf1 = strdup ("");
488 mode = 2; 425 mode = 2;
489 continue; 426 continue;
490 } 427 }
491 else if (mode == 2) 428 else if (mode == 2)
492 { 429 {
493 p = strtok (buf, "="); 430 p = strtok (buf, "=");
494 attack_mess[mess][level].level = atoi (buf); 431 attack_mess[mess][level].level = atoi (buf);
495 p = strtok (NULL, "="); 432 p = strtok (NULL, "=");
496 if (p != NULL) 433 if (p != NULL)
497 attack_mess[mess][level].buf2 = strdup_local (p); 434 attack_mess[mess][level].buf2 = strdup (p);
498 else 435 else
499 attack_mess[mess][level].buf2 = strdup_local (""); 436 attack_mess[mess][level].buf2 = strdup ("");
500 mode = 3; 437 mode = 3;
501 continue; 438 continue;
502 } 439 }
503 else if (mode == 3) 440 else if (mode == 3)
504 { 441 {
505 p = strtok (buf, "="); 442 p = strtok (buf, "=");
506 attack_mess[mess][level].level = atoi (buf); 443 attack_mess[mess][level].level = atoi (buf);
507 p = strtok (NULL, "="); 444 p = strtok (NULL, "=");
508 if (p != NULL) 445 if (p != NULL)
509 attack_mess[mess][level].buf3 = strdup_local (p); 446 attack_mess[mess][level].buf3 = strdup (p);
510 else 447 else
511 attack_mess[mess][level].buf3 = strdup_local (""); 448 attack_mess[mess][level].buf3 = strdup ("");
512 mode = 1; 449 mode = 1;
513 level++; 450 level++;
514 total++; 451 total++;
515 continue; 452 continue;
516 } 453 }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines