summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBardur Arantsson <bardur@scientician.net>2016-06-20 22:49:05 +0200
committerBardur Arantsson <bardur@scientician.net>2016-06-20 22:49:05 +0200
commitc263b67fbcd7ffdae13bbed8191106b6c1c80609 (patch)
tree4da280bed1859e1be62b19f0c44003356baadc3d /src
parentc4a8fd220d2742e521f0d96ea3d8cb7e9375bcb4 (diff)
Change ego_item_type to non-POD type
Diffstat (limited to 'src')
-rw-r--r--src/ego_item_type.hpp108
-rw-r--r--src/init2.cc2
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)