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.25 by root, Tue Mar 6 03:06:00 2007 UTC vs.
Revision 1.32 by root, Mon Apr 16 06:23:39 2007 UTC

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,
84 SIMPLE_EXP, 84 SIMPLE_EXP,
85 RESET_LOCATION_TIME,
86 SET_TITLE, 85 SET_TITLE,
87 RESURRECTION, 86 RESURRECTION,
88 SEARCH_ITEMS, 87 SEARCH_ITEMS,
89 SPELL_ENCUMBRANCE, 88 SPELL_ENCUMBRANCE,
90 SPELL_FAILURE_EFFECTS, 89 SPELL_FAILURE_EFFECTS,
149void 148void
150init_library (void) 149init_library (void)
151{ 150{
152 init_globals (); 151 init_globals ();
153 init_block (); 152 init_block ();
154 ReadBmapNames ();
155 ReadSmooth ();
156 init_anim (); /* Must be after we read in the bitmaps */
157 init_archetypes (); /* Reads all archetypes from file */ 153 init_archetypes (); /* Reads all archetypes from file */
158 init_dynamic (); 154 init_dynamic ();
159 init_attackmess (); 155 init_attackmess ();
160 init_clocks ();
161 init_experience (); 156 init_experience ();
162} 157}
163 158
164 159
165/* init_environ initialises values from the environmental variables. 160/* init_environ initialises values from the environmental variables.
198 cp = getenv ("CROSSFIRE_TMPDIR"); 193 cp = getenv ("CROSSFIRE_TMPDIR");
199 if (cp) 194 if (cp)
200 settings.tmpdir = cp; 195 settings.tmpdir = cp;
201} 196}
202 197
203
204/* 198/*
205 * Initialises all global variables. 199 * Initialises all global variables.
206 * Might use environment-variables as default for some of them. 200 * Might use environment-variables as default for some of them.
207 */ 201 */
208
209void 202void
210init_globals (void) 203init_globals (void)
211{ 204{
212 if (settings.logfilename[0] == 0) 205 if (settings.logfilename[0] == 0)
213 logfile = stderr; 206 logfile = stderr;
240 } 233 }
241 234
242 at = at->next; 235 at = at->next;
243 } 236 }
244 237
245 LOG (llevDebug, "You Need a archetype called 'map' and it have to contain start map\n"); 238 LOG (llevDebug, "You need an archetype of type 'map' and it has to contain the player start map\n");
246 exit (-1); 239 exit (-1);
247}
248
249unsigned long todtick;
250
251/*
252 * Write out the current time to the file so time does not
253 * reset every time the server reboots.
254 */
255
256void
257write_todclock (void)
258{
259 char filename[MAX_BUF];
260 FILE *fp;
261
262 sprintf (filename, "%s/clockdata", settings.localdir);
263 if ((fp = fopen (filename, "w")) == NULL)
264 {
265 LOG (llevError, "Cannot open %s for writing\n", filename);
266 return;
267 }
268 fprintf (fp, "%lu", todtick);
269 fclose (fp);
270}
271
272/*
273 * initialises the gametime and TOD counters
274 * Called by init_library().
275 */
276
277void
278init_clocks (void)
279{
280 char filename[MAX_BUF];
281 FILE *fp;
282 static int has_been_done = 0;
283
284 if (has_been_done)
285 return;
286 else
287 has_been_done = 1;
288
289 sprintf (filename, "%s/clockdata", settings.localdir);
290 LOG (llevDebug, "Reading clockdata from %s...\n", filename);
291 if ((fp = fopen (filename, "r")) == NULL)
292 {
293 LOG (llevError, "Can't open %s.\n", filename);
294 todtick = 0;
295 write_todclock ();
296 return;
297 }
298 fscanf (fp, "%lu", &todtick);
299 LOG (llevDebug, "todtick=%lu\n", todtick);
300 fclose (fp);
301} 240}
302 241
303/* 242/*
304 * initialises the attack messages. 243 * initialises the attack messages.
305 * Called by init_library(). 244 * Called by init_library().

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines