diff options
author | Bardur Arantsson <bardur@scientician.net> | 2016-06-20 22:49:05 +0200 |
---|---|---|
committer | Bardur Arantsson <bardur@scientician.net> | 2016-06-20 22:49:05 +0200 |
commit | c263b67fbcd7ffdae13bbed8191106b6c1c80609 (patch) | |
tree | 4da280bed1859e1be62b19f0c44003356baadc3d /src | |
parent | c4a8fd220d2742e521f0d96ea3d8cb7e9375bcb4 (diff) |
Change ego_item_type to non-POD type
Diffstat (limited to 'src')
-rw-r--r-- | src/ego_item_type.hpp | 108 | ||||
-rw-r--r-- | src/init2.cc | 2 |
2 files changed, 56 insertions, 54 deletions
diff --git a/src/ego_item_type.hpp b/src/ego_item_type.hpp index f9b6970a..b5cf2781 100644 --- a/src/ego_item_type.hpp +++ b/src/ego_item_type.hpp @@ -12,57 +12,59 @@ constexpr int FLAG_RARITY_MAX = 6; */ struct ego_item_type { - const char *name; /* Name (offset) */ - - bool_ before; /* Before or after the object name ? */ - - byte tval[10]; - byte min_sval[10]; - byte max_sval[10]; - - byte rating; /* Rating boost */ - - byte level; /* Minimum level */ - byte rarity; /* Object rarity */ - byte mrarity; /* Object rarity */ - - s16b max_to_h; /* Maximum to-hit bonus */ - s16b max_to_d; /* Maximum to-dam bonus */ - s16b max_to_a; /* Maximum to-ac bonus */ - - s16b activate; /* Activation Number */ - - s32b max_pval; /* Maximum pval */ - - s32b cost; /* Ego-item "cost" */ - - byte rar[FLAG_RARITY_MAX]; - u32b flags1[FLAG_RARITY_MAX]; /* Ego-Item Flags, set 1 */ - u32b flags2[FLAG_RARITY_MAX]; /* Ego-Item Flags, set 2 */ - u32b flags3[FLAG_RARITY_MAX]; /* Ego-Item Flags, set 3 */ - u32b flags4[FLAG_RARITY_MAX]; /* Ego-Item Flags, set 4 */ - u32b flags5[FLAG_RARITY_MAX]; /* Ego-Item Flags, set 5 */ - u32b esp[FLAG_RARITY_MAX]; /* ESP flags */ - u32b oflags1[FLAG_RARITY_MAX]; /* Ego-Item Obvious Flags, set 1 */ - u32b oflags2[FLAG_RARITY_MAX]; /* Ego-Item Obvious Flags, set 2 */ - u32b oflags3[FLAG_RARITY_MAX]; /* Ego-Item Obvious Flags, set 3 */ - u32b oflags4[FLAG_RARITY_MAX]; /* Ego-Item Obvious Flags, set 4 */ - u32b oflags5[FLAG_RARITY_MAX]; /* Ego-Item Obvious Flags, set 5 */ - u32b oesp[FLAG_RARITY_MAX]; /* Obvious ESP flags */ - u32b fego[FLAG_RARITY_MAX]; /* ego flags */ - - u32b need_flags1; /* Ego-Item Flags, set 1 */ - u32b need_flags2; /* Ego-Item Flags, set 2 */ - u32b need_flags3; /* Ego-Item Flags, set 3 */ - u32b need_flags4; /* Ego-Item Flags, set 4 */ - u32b need_flags5; /* Ego-Item Flags, set 5 */ - u32b need_esp; /* ESP flags */ - u32b forbid_flags1; /* Ego-Item Flags, set 1 */ - u32b forbid_flags2; /* Ego-Item Flags, set 2 */ - u32b forbid_flags3; /* Ego-Item Flags, set 3 */ - u32b forbid_flags4; /* Ego-Item Flags, set 4 */ - u32b forbid_flags5; /* Ego-Item Flags, set 5 */ - u32b forbid_esp; /* ESP flags */ - - s16b power; /* Power granted(if any) */ + const char *name = nullptr; /* Name */ + + bool_ before = FALSE; /* Before or after the object name ? */ + + byte tval[10] = { 0 }; + byte min_sval[10] = { 0 }; + byte max_sval[10] = { 0 }; + + byte rating = 0; /* Rating boost */ + + byte level = 0; /* Minimum level */ + byte rarity = 0; /* Object rarity */ + byte mrarity = 0; /* Object rarity */ + + s16b max_to_h = 0; /* Maximum to-hit bonus */ + s16b max_to_d = 0; /* Maximum to-dam bonus */ + s16b max_to_a = 0; /* Maximum to-ac bonus */ + + s16b activate = 0; /* Activation Number */ + + s32b max_pval = 0; /* Maximum pval */ + + s32b cost = 0; /* Ego-item "cost" */ + + byte rar[FLAG_RARITY_MAX] = { 0 }; + + u32b flags1[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Flags, set 1 */ + u32b flags2[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Flags, set 2 */ + u32b flags3[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Flags, set 3 */ + u32b flags4[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Flags, set 4 */ + u32b flags5[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Flags, set 5 */ + u32b esp[FLAG_RARITY_MAX] = { 0 }; /* ESP flags */ + u32b oflags1[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Obvious Flags, set 1 */ + u32b oflags2[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Obvious Flags, set 2 */ + u32b oflags3[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Obvious Flags, set 3 */ + u32b oflags4[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Obvious Flags, set 4 */ + u32b oflags5[FLAG_RARITY_MAX] = { 0 }; /* Ego-Item Obvious Flags, set 5 */ + u32b oesp[FLAG_RARITY_MAX] = { 0 }; /* Obvious ESP flags */ + + u32b fego[FLAG_RARITY_MAX] = { 0 }; /* ego flags */ + + u32b need_flags1 = 0; /* Ego-Item Flags, set 1 */ + u32b need_flags2 = 0; /* Ego-Item Flags, set 2 */ + u32b need_flags3 = 0; /* Ego-Item Flags, set 3 */ + u32b need_flags4 = 0; /* Ego-Item Flags, set 4 */ + u32b need_flags5 = 0; /* Ego-Item Flags, set 5 */ + u32b need_esp = 0; /* ESP flags */ + u32b forbid_flags1 = 0; /* Ego-Item Flags, set 1 */ + u32b forbid_flags2 = 0; /* Ego-Item Flags, set 2 */ + u32b forbid_flags3 = 0; /* Ego-Item Flags, set 3 */ + u32b forbid_flags4 = 0; /* Ego-Item Flags, set 4 */ + u32b forbid_flags5 = 0; /* Ego-Item Flags, set 5 */ + u32b forbid_esp = 0; /* ESP flags */ + + s16b power = 0; /* Power granted, if any */ }; diff --git a/src/init2.cc b/src/init2.cc index 86a0ab1e..ec6cf9d7 100644 --- a/src/init2.cc +++ b/src/init2.cc @@ -373,7 +373,7 @@ namespace { static void allocate() { - e_info = make_array<ego_item_type>(max_e_idx); + e_info = new ego_item_type[max_e_idx]; } static errr parse(FILE *fp) |