… | |
… | |
309 | // dire hack, need to rationalise |
309 | // dire hack, need to rationalise |
310 | void |
310 | void |
311 | overwrite (archetype *at, object *op) |
311 | overwrite (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 | |