… | |
… | |
197 | |
197 | |
198 | /* This is a one of the many items on the list should be generated. |
198 | /* This is a one of the many items on the list should be generated. |
199 | * Add up the chance total, and check to make sure the yes & no |
199 | * Add up the chance total, and check to make sure the yes & no |
200 | * fields of the treasures are not being used. |
200 | * fields of the treasures are not being used. |
201 | */ |
201 | */ |
202 | tl->total_chance = 0; |
|
|
203 | |
|
|
204 | if (one) |
202 | if (one) |
205 | { |
203 | { |
206 | for (treasure *t = tl->items; t; t = t->next) |
204 | for (treasure *t = tl->items; t; t = t->next) |
207 | { |
205 | { |
208 | if (t->next_yes || t->next_no) |
206 | if (t->next_yes || t->next_no) |
… | |
… | |
397 | |
395 | |
398 | if (tries++ > 100) |
396 | if (tries++ > 100) |
399 | { |
397 | { |
400 | LOG (llevDebug, "createtreasure: tries exceeded 100, returning without making treasure\n"); |
398 | LOG (llevDebug, "createtreasure: tries exceeded 100, returning without making treasure\n"); |
401 | return; |
399 | return; |
|
|
400 | } |
|
|
401 | |
|
|
402 | if (op->flag [FLAG_TREASURE_ENV]) |
|
|
403 | { |
|
|
404 | // do not generate items when there already is something above the object |
|
|
405 | if (op->flag [FLAG_IS_FLOOR] && op->above) |
|
|
406 | return; |
|
|
407 | |
|
|
408 | flag |= GT_ENVIRONMENT; |
402 | } |
409 | } |
403 | |
410 | |
404 | if (tl->total_chance) |
411 | if (tl->total_chance) |
405 | create_one_treasure (tl, op, flag, difficulty, tries); |
412 | create_one_treasure (tl, op, flag, difficulty, tries); |
406 | else |
413 | else |
… | |
… | |
641 | case 2: |
648 | case 2: |
642 | case 3: |
649 | case 3: |
643 | case 4: |
650 | case 4: |
644 | case 5: |
651 | case 5: |
645 | case 6: |
652 | case 6: |
646 | set_attr_value (&op->stats, r, (signed char) (bonus + get_attr_value (&op->stats, r))); |
653 | op->stats.stat (r) += bonus; |
647 | break; |
654 | break; |
648 | |
655 | |
649 | case 7: |
656 | case 7: |
650 | op->stats.dam += bonus; |
657 | op->stats.dam += bonus; |
651 | break; |
658 | break; |
… | |
… | |
1411 | #endif |
1418 | #endif |
1412 | op->face = change->face; |
1419 | op->face = change->face; |
1413 | } |
1420 | } |
1414 | |
1421 | |
1415 | for (i = 0; i < NUM_STATS; i++) |
1422 | for (i = 0; i < NUM_STATS; i++) |
1416 | change_attr_value (&(op->stats), i, get_attr_value (&(change->stats), i)); |
1423 | change_attr_value (&(op->stats), i, change->stats.stat (i)); |
1417 | |
1424 | |
1418 | op->attacktype |= change->attacktype; |
1425 | op->attacktype |= change->attacktype; |
1419 | op->path_attuned |= change->path_attuned; |
1426 | op->path_attuned |= change->path_attuned; |
1420 | op->path_repelled |= change->path_repelled; |
1427 | op->path_repelled |= change->path_repelled; |
1421 | op->path_denied |= change->path_denied; |
1428 | op->path_denied |= change->path_denied; |