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

Comparing deliantra/server/common/arch.C (file contents):
Revision 1.53 by root, Tue Apr 17 18:40:31 2007 UTC vs.
Revision 1.55 by root, Tue Apr 17 19:12:32 2007 UTC

309// dire hack, need to rationalise 309// dire hack, need to rationalise
310void 310void
311overwrite (archetype *at, object *op) 311overwrite (archetype *at, object *op)
312{ 312{
313 at->clone = *op; 313 at->clone = *op;
314
315 at->clone.arch = at; 314 at->clone.arch = at;
315
316 at->clone.inv = op->inv; op->inv = 0; 316 at->clone.inv = op->inv; op->inv = 0;
317 317
318 op->destroy (); 318 op->destroy ();
319} 319}
320 320
330 330
331 coroapi::cede_to_tick_every (100); 331 coroapi::cede_to_tick_every (100);
332 332
333 for (;;) 333 for (;;)
334 { 334 {
335 object *op = object::create ();
335 archetype *at = get (f.get_str ()); 336 archetype *at = get (f.get_str ());
336 object *op = object::create (); 337 f.get (op->name);
338 f.next ();
339
340 if (f.kw == KW_inherit)
341 {
342 if (archetype *at = find (f.get_str ()))
343 *op = at->clone;
344 else
345 LOG (llevError, "archetype '%s' tries to inherit from non-existent archetype '%s'.\n",
346 &at->name, f.get_str ());
347
348 f.next ();
349 }
337 350
338 if (!op->parse_kv (f)) 351 if (!op->parse_kv (f))
339 goto fail; 352 goto fail;
340 353
341 parts.push_back (std::make_pair (at, op)); 354 parts.push_back (std::make_pair (at, op));
342 355
343 if (f.kw != KW_more) 356 if (f.kw != KW_more)
344 break; 357 break;
345 358
346 f.next (); 359 f.next ();
360
347 assert (f.kw == KW_object); 361 if (f.kw != KW_object)
362 {
363 f.parse_error ("more object");
364 goto fail;
365 }
348 } 366 }
349 367
350 { 368 {
351 archetype *head = parts.front ().first; 369 archetype *head = parts.front ().first;
352 370

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines