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.27 by root, Tue Mar 6 19:02:35 2007 UTC vs.
Revision 1.35 by root, Thu May 17 14:14:54 2007 UTC

1/* 1/*
2 * CrossFire, A Multiplayer game for X-windows 2 * CrossFire, A Multiplayer game
3 * 3 *
4 * Copyright (C) 2005, 2006, 2007 Marc Lehmann & Crossfire+ Development Team 4 * Copyright (C) 2005, 2006, 2007 Marc Lehmann & Crossfire+ Development Team
5 * Copyright (C) 2002 Mark Wedel & Crossfire Development Team 5 * Copyright (C) 2002 Mark Wedel & Crossfire Development Team
6 * Copyright (C) 1992 Frank Tore Johansen 6 * Copyright (C) 1992 Frank Tore Johansen
7 * 7 *
72 DATADIR, 72 DATADIR,
73 LOCALDIR, 73 LOCALDIR,
74 PLAYERDIR, MAPDIR, ARCHETYPES, REGIONS, TREASURES, 74 PLAYERDIR, MAPDIR, ARCHETYPES, REGIONS, TREASURES,
75 UNIQUE_DIR, TEMPLATE_DIR, 75 UNIQUE_DIR, TEMPLATE_DIR,
76 TMPDIR, 76 TMPDIR,
77 PK_LUCK_PENALTY,
77 STAT_LOSS_ON_DEATH, 78 STAT_LOSS_ON_DEATH,
78 PK_LUCK_PENALTY,
79 PERMANENT_EXPERIENCE_RATIO, 79 PERMANENT_EXPERIENCE_RATIO,
80 DEATH_PENALTY_RATIO, 80 DEATH_PENALTY_RATIO,
81 DEATH_PENALTY_LEVEL, 81 DEATH_PENALTY_LEVEL,
82 BALANCED_STAT_LOSS, 82 BALANCED_STAT_LOSS,
83 NOT_PERMADETH, 83 NOT_PERMADETH,
85 SET_TITLE, 85 SET_TITLE,
86 RESURRECTION, 86 RESURRECTION,
87 SEARCH_ITEMS, 87 SEARCH_ITEMS,
88 SPELL_ENCUMBRANCE, 88 SPELL_ENCUMBRANCE,
89 SPELL_FAILURE_EFFECTS, 89 SPELL_FAILURE_EFFECTS,
90 CASTING_TIME, 90 SET_FRIENDLY_FIRE,
91 REAL_WIZ, 91 0,
92 0,
92 EXPLORE_MODE, 93 EXPLORE_MODE,
93 SPELLPOINT_LEVEL_DEPEND, 94 SPELLPOINT_LEVEL_DEPEND,
94 SET_FRIENDLY_FIRE,
95 MOTD, 95 MOTD,
96 "rules", 96 "rules",
97 "news", 97 "news",
98 "", /* DM_MAIL */ 98 "", /* DM_MAIL */
99 0, 0, 0, 0, 0, 0, 0, 0, /* worldmap settings */ 99 0, 0, 0, 0, 0, 0, 0, 0, /* worldmap settings */
104 ARMOR_MAX_ENCHANT, 104 ARMOR_MAX_ENCHANT,
105 ARMOR_WEIGHT_REDUCTION, 105 ARMOR_WEIGHT_REDUCTION,
106 ARMOR_WEIGHT_LINEAR, 106 ARMOR_WEIGHT_LINEAR,
107 ARMOR_SPEED_IMPROVEMENT, 107 ARMOR_SPEED_IMPROVEMENT,
108 ARMOR_SPEED_LINEAR, 108 ARMOR_SPEED_LINEAR,
109 1, /* no_player_stealing */
110 1, /* create_home_portals */
111}; 109};
112 110
113/* perhaps not the best place for this, but needs to be 111/* perhaps not the best place for this, but needs to be
114 * in some file in the common area so that standalone 112 * in some file in the common area so that standalone
115 * programs, like the random map generator, can be built. 113 * programs, like the random map generator, can be built.
148void 146void
149init_library (void) 147init_library (void)
150{ 148{
151 init_globals (); 149 init_globals ();
152 init_block (); 150 init_block ();
153 ReadBmapNames ();
154 ReadSmooth ();
155 init_anim (); /* Must be after we read in the bitmaps */
156 init_archetypes (); /* Reads all archetypes from file */
157 init_dynamic (); 151 init_dynamic ();
158 init_attackmess (); 152 init_attackmess ();
159 init_clocks ();
160 init_experience (); 153 init_experience ();
161} 154}
162
163 155
164/* init_environ initialises values from the environmental variables. 156/* init_environ initialises values from the environmental variables.
165 * it needs to be called very early, since command line options should 157 * it needs to be called very early, since command line options should
166 * overwrite these if specified. 158 * overwrite these if specified.
167 */ 159 */
171 char *cp; 163 char *cp;
172 164
173 cp = getenv ("CROSSFIRE_LIBDIR"); 165 cp = getenv ("CROSSFIRE_LIBDIR");
174 if (cp) 166 if (cp)
175 settings.datadir = cp; 167 settings.datadir = cp;
168
176 cp = getenv ("CROSSFIRE_LOCALDIR"); 169 cp = getenv ("CROSSFIRE_LOCALDIR");
177 if (cp) 170 if (cp)
178 settings.localdir = cp; 171 settings.localdir = cp;
172
179 cp = getenv ("CROSSFIRE_PLAYERDIR"); 173 cp = getenv ("CROSSFIRE_PLAYERDIR");
180 if (cp) 174 if (cp)
181 settings.playerdir = cp; 175 settings.playerdir = cp;
176
182 cp = getenv ("CROSSFIRE_MAPDIR"); 177 cp = getenv ("CROSSFIRE_MAPDIR");
183 if (cp) 178 if (cp)
184 settings.mapdir = cp; 179 settings.mapdir = cp;
180
185 cp = getenv ("CROSSFIRE_ARCHETYPES"); 181 cp = getenv ("CROSSFIRE_ARCHETYPES");
186 if (cp) 182 if (cp)
187 settings.archetypes = cp; 183 settings.archetypes = cp;
184
188 cp = getenv ("CROSSFIRE_TREASURES"); 185 cp = getenv ("CROSSFIRE_TREASURES");
189 if (cp) 186 if (cp)
190 settings.treasures = cp; 187 settings.treasures = cp;
188
191 cp = getenv ("CROSSFIRE_UNIQUEDIR"); 189 cp = getenv ("CROSSFIRE_UNIQUEDIR");
192 if (cp) 190 if (cp)
193 settings.uniquedir = cp; 191 settings.uniquedir = cp;
192
194 cp = getenv ("CROSSFIRE_TEMPLATEDIR"); 193 cp = getenv ("CROSSFIRE_TEMPLATEDIR");
195 if (cp) 194 if (cp)
196 settings.templatedir = cp; 195 settings.templatedir = cp;
196
197 cp = getenv ("CROSSFIRE_TMPDIR"); 197 cp = getenv ("CROSSFIRE_TMPDIR");
198 if (cp) 198 if (cp)
199 settings.tmpdir = cp; 199 settings.tmpdir = cp;
200} 200}
201 201
237 } 237 }
238 238
239 at = at->next; 239 at = at->next;
240 } 240 }
241 241
242 LOG (llevDebug, "You Need a archetype called 'map' and it have to contain start map\n"); 242 LOG (llevDebug, "You need an archetype of type 'map' and it has to contain the player start map\n");
243 exit (-1); 243 exit (-1);
244}
245
246unsigned long todtick;
247
248/*
249 * Write out the current time to the file so time does not
250 * reset every time the server reboots.
251 */
252void
253write_todclock (void)
254{
255 char filename[MAX_BUF];
256 FILE *fp;
257
258 sprintf (filename, "%s/clockdata", settings.localdir);
259 if ((fp = fopen (filename, "w")) == NULL)
260 {
261 LOG (llevError, "Cannot open %s for writing\n", filename);
262 return;
263 }
264 fprintf (fp, "%lu", todtick);
265 fclose (fp);
266}
267
268/*
269 * initialises the gametime and TOD counters
270 * Called by init_library().
271 */
272void
273init_clocks (void)
274{
275 char filename[MAX_BUF];
276 FILE *fp;
277 static int has_been_done = 0;
278
279 if (has_been_done)
280 return;
281 else
282 has_been_done = 1;
283
284 sprintf (filename, "%s/clockdata", settings.localdir);
285 LOG (llevDebug, "Reading clockdata from %s...\n", filename);
286 if ((fp = fopen (filename, "r")) == NULL)
287 {
288 LOG (llevError, "Can't open %s.\n", filename);
289 todtick = 0;
290 write_todclock ();
291 return;
292 }
293
294 fscanf (fp, "%lu", &todtick);
295 LOG (llevDebug, "todtick=%lu\n", todtick);
296 fclose (fp);
297} 244}
298 245
299/* 246/*
300 * initialises the attack messages. 247 * initialises the attack messages.
301 * Called by init_library(). 248 * Called by init_library().

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines