X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=src%2Fload.c;h=e24e9d9db470b40ad0536e5a5e5093af2f550793;hb=97c7a62d7abe963c7a9abcb22a35273101a09081;hp=bd0615898e0d9c23e4625ffdf7dafd809da1cbef;hpb=deac8120d23c7d04d095035a6815a72977639d83;p=hengband%2Fhengband.git diff --git a/src/load.c b/src/load.c index bd0615898..e24e9d9db 100644 --- a/src/load.c +++ b/src/load.c @@ -338,18 +338,24 @@ static void strip_bytes(int n) static void rd_item_old(object_type *o_ptr) { char buf[128]; + byte_hack tmp8u; + s16b tmp16s; /* Kind */ rd_s16b(&o_ptr->k_idx); /* Location */ - rd_byte(&o_ptr->iy); - rd_byte(&o_ptr->ix); + rd_byte(&tmp8u); + o_ptr->iy = (POSITION)tmp8u; + rd_byte(&tmp8u); + o_ptr->ix = (POSITION)tmp8u; /* Type/Subtype */ - rd_byte(&o_ptr->tval); - rd_byte(&o_ptr->sval); + rd_byte(&tmp8u); + o_ptr->tval = tmp8u; + rd_byte(&tmp8u); + o_ptr->sval = tmp8u; if (z_older_than(10, 4, 4)) { @@ -362,21 +368,32 @@ static void rd_item_old(object_type *o_ptr) rd_s16b(&o_ptr->pval); rd_byte(&o_ptr->discount); - rd_byte(&o_ptr->number); - rd_s16b(&o_ptr->weight); + rd_byte(&tmp8u); + o_ptr->number = (ITEM_NUMBER)tmp8u; + + rd_s16b(&tmp16s); + o_ptr->weight = tmp16s; + + rd_byte(&tmp8u); + o_ptr->name1 = tmp8u; + + rd_byte(&tmp8u); + o_ptr->name2 = tmp8u; - rd_byte(&o_ptr->name1); - rd_byte(&o_ptr->name2); rd_s16b(&o_ptr->timeout); rd_s16b(&o_ptr->to_h); - rd_s16b(&o_ptr->to_d); + + rd_s16b(&tmp16s); + o_ptr->to_d = tmp16s; rd_s16b(&o_ptr->to_a); rd_s16b(&o_ptr->ac); - rd_byte(&o_ptr->dd); - rd_byte(&o_ptr->ds); + rd_byte(&tmp8u); + o_ptr->dd = tmp8u; + rd_byte(&tmp8u); + o_ptr->ds = tmp8u; rd_byte(&o_ptr->ident); @@ -593,6 +610,8 @@ static void rd_item(object_type *o_ptr) object_kind *k_ptr; u32b flags; char buf[128]; + byte_hack tmp8u; + s16b tmp16s; if (h_older_than(1, 5, 0, 0)) { @@ -608,8 +627,10 @@ static void rd_item(object_type *o_ptr) rd_s16b(&o_ptr->k_idx); /* Location */ - rd_byte(&o_ptr->iy); - rd_byte(&o_ptr->ix); + rd_byte(&tmp8u); + o_ptr->iy = (POSITION)tmp8u; + rd_byte(&tmp8u); + o_ptr->ix = (POSITION)tmp8u; /* Type/Subtype */ k_ptr = &k_info[o_ptr->k_idx]; @@ -622,21 +643,37 @@ static void rd_item(object_type *o_ptr) if (flags & SAVE_ITEM_DISCOUNT) rd_byte(&o_ptr->discount); else o_ptr->discount = 0; - if (flags & SAVE_ITEM_NUMBER) rd_byte(&o_ptr->number); + if (flags & SAVE_ITEM_NUMBER) { + rd_byte(&tmp8u); + o_ptr->number = tmp8u; + } else o_ptr->number = 1; - rd_s16b(&o_ptr->weight); + rd_s16b(&tmp16s); + o_ptr->weight = tmp16s; - if (flags & SAVE_ITEM_NAME1) rd_byte(&o_ptr->name1); + if (flags & SAVE_ITEM_NAME1) + { + rd_byte(&tmp8u); + o_ptr->name1 = tmp8u; + } else o_ptr->name1 = 0; - if (flags & SAVE_ITEM_NAME2) rd_byte(&o_ptr->name2); + if (flags & SAVE_ITEM_NAME2) + { + rd_byte(&tmp8u); + o_ptr->name2 = tmp8u; + } else o_ptr->name2 = 0; if (flags & SAVE_ITEM_TIMEOUT) rd_s16b(&o_ptr->timeout); else o_ptr->timeout = 0; if (flags & SAVE_ITEM_TO_H) rd_s16b(&o_ptr->to_h); else o_ptr->to_h = 0; - if (flags & SAVE_ITEM_TO_D) rd_s16b(&o_ptr->to_d); + if (flags & SAVE_ITEM_TO_D) + { + rd_s16b(&tmp16s); + o_ptr->to_d = tmp16s; + } else o_ptr->to_d = 0; if (flags & SAVE_ITEM_TO_A) rd_s16b(&o_ptr->to_a); else o_ptr->to_a = 0; @@ -644,9 +681,17 @@ static void rd_item(object_type *o_ptr) if (flags & SAVE_ITEM_AC) rd_s16b(&o_ptr->ac); else o_ptr->ac = 0; - if (flags & SAVE_ITEM_DD) rd_byte(&o_ptr->dd); + if (flags & SAVE_ITEM_DD) + { + rd_byte(&tmp8u); + o_ptr->dd = tmp8u; + } else o_ptr->dd = 0; - if (flags & SAVE_ITEM_DS) rd_byte(&o_ptr->ds); + if (flags & SAVE_ITEM_DS) + { + rd_byte(&tmp8u); + o_ptr->ds = tmp8u; + } else o_ptr->ds = 0; if (flags & SAVE_ITEM_IDENT) rd_byte(&o_ptr->ident); @@ -773,6 +818,8 @@ static void rd_item(object_type *o_ptr) static void rd_monster_old(monster_type *m_ptr) { byte tmp8u; + s16b tmp16s; + u32b tmp32u; char buf[128]; /* Read the monster race */ @@ -795,17 +842,24 @@ static void rd_monster_old(monster_type *m_ptr) rd_byte(&m_ptr->sub_align); /* Read the other information */ - rd_byte(&m_ptr->fy); - rd_byte(&m_ptr->fx); - rd_s16b(&m_ptr->hp); - rd_s16b(&m_ptr->maxhp); + rd_byte(&tmp8u); + m_ptr->fy = (POSITION)tmp8u; + rd_byte(&tmp8u); + m_ptr->fx = (POSITION)tmp8u; + + rd_s16b(&tmp16s); + m_ptr->hp = tmp16s; + rd_s16b(&tmp16s); + m_ptr->maxhp = tmp16s; + if (z_older_than(11, 0, 5)) { m_ptr->max_maxhp = m_ptr->maxhp; } else { - rd_s16b(&m_ptr->max_maxhp); + rd_s16b(&tmp16s); + m_ptr->max_maxhp = (HIT_POINT)tmp16s; } if(h_older_than(2, 1, 2, 1)) { @@ -853,14 +907,15 @@ static void rd_monster_old(monster_type *m_ptr) } else if (z_older_than(10,0,11)) { - s16b tmp16s; rd_s16b(&tmp16s); reset_target(m_ptr); } else { - rd_s16b(&m_ptr->target_y); - rd_s16b(&m_ptr->target_x); + rd_s16b(&tmp16s); + m_ptr->target_y = (POSITION)tmp16s; + rd_s16b(&tmp16s); + m_ptr->target_x = (POSITION)tmp16s; } rd_byte(&tmp8u); @@ -874,7 +929,9 @@ static void rd_monster_old(monster_type *m_ptr) if (z_older_than(10, 4, 5)) m_ptr->exp = 0; else - rd_u32b(&m_ptr->exp); + tmp32u = 0; + rd_u32b(&tmp32u); + m_ptr->exp = tmp32u; if (z_older_than(10, 2, 2)) { @@ -919,6 +976,8 @@ static void rd_monster(monster_type *m_ptr) u32b flags; char buf[128]; byte tmp8u; + s16b tmp16s; + u32b tmp32u; if (h_older_than(1, 5, 0, 0)) { @@ -935,11 +994,18 @@ static void rd_monster(monster_type *m_ptr) rd_s16b(&m_ptr->r_idx); /* Read the other information */ - rd_byte(&m_ptr->fy); - rd_byte(&m_ptr->fx); - rd_s16b(&m_ptr->hp); - rd_s16b(&m_ptr->maxhp); - rd_s16b(&m_ptr->max_maxhp); + rd_byte(&tmp8u); + m_ptr->fy = (POSITION)tmp8u; + rd_byte(&tmp8u); + m_ptr->fx = (POSITION)tmp8u; + + rd_s16b(&tmp16s); + m_ptr->hp = (HIT_POINT)tmp16s; + rd_s16b(&tmp16s); + m_ptr->maxhp = (HIT_POINT)tmp16s; + rd_s16b(&tmp16s); + m_ptr->max_maxhp = (HIT_POINT)tmp16s; + if(h_older_than(2, 1, 2, 1)) { m_ptr->dealt_damage = 0; @@ -994,9 +1060,17 @@ static void rd_monster(monster_type *m_ptr) } else m_ptr->mtimed[MTIMED_MONFEAR] = 0; - if (flags & SAVE_MON_TARGET_Y) rd_s16b(&m_ptr->target_y); + if (flags & SAVE_MON_TARGET_Y) + { + rd_s16b(&tmp16s); + m_ptr->target_y = (POSITION)tmp16s; + } else m_ptr->target_y = 0; - if (flags & SAVE_MON_TARGET_X) rd_s16b(&m_ptr->target_x); + if (flags & SAVE_MON_TARGET_X) + { + rd_s16b(&tmp16s); + m_ptr->target_x = (POSITION)tmp16s; + } else m_ptr->target_x = 0; if (flags & SAVE_MON_INVULNER) @@ -1009,7 +1083,11 @@ static void rd_monster(monster_type *m_ptr) if (flags & SAVE_MON_SMART) rd_u32b(&m_ptr->smart); else m_ptr->smart = 0; - if (flags & SAVE_MON_EXP) rd_u32b(&m_ptr->exp); + if (flags & SAVE_MON_EXP) + { + rd_u32b(&tmp32u); + m_ptr->exp = (EXP)tmp32u; + } else m_ptr->exp = 0; m_ptr->mflag = 0; /* Not saved */ @@ -1078,25 +1156,31 @@ static void rd_monster(monster_type *m_ptr) * @param r_idx èªã¿è¾¼ã¿å ã¢ã³ã¹ã¿ã¼ID * @return ãªã */ -static void rd_lore(int r_idx) +static void rd_lore(MONRACE_IDX r_idx) { byte tmp8u; + s16b tmp16s; monster_race *r_ptr = &r_info[r_idx]; /* Count sights/deaths/kills */ - rd_s16b(&r_ptr->r_sights); - rd_s16b(&r_ptr->r_deaths); - rd_s16b(&r_ptr->r_pkills); + rd_s16b(&tmp16s); + r_ptr->r_sights = (MONSTER_NUMBER)tmp16s; + rd_s16b(&tmp16s); + r_ptr->r_deaths = (MONSTER_NUMBER)tmp16s; + rd_s16b(&tmp16s); + r_ptr->r_pkills = (MONSTER_NUMBER)tmp16s; if (h_older_than(1, 7, 0, 5)) { r_ptr->r_akills = r_ptr->r_pkills; } else { - rd_s16b(&r_ptr->r_akills); + rd_s16b(&tmp16s); + r_ptr->r_akills = (MONSTER_NUMBER)tmp16s; } - rd_s16b(&r_ptr->r_tkills); + rd_s16b(&tmp16s); + r_ptr->r_tkills = (MONSTER_NUMBER)tmp16s; /* Count wakes and ignores */ rd_byte(&r_ptr->r_wake); @@ -1107,8 +1191,10 @@ static void rd_lore(int r_idx) rd_byte(&r_ptr->r_xtra2); /* Count drops */ - rd_byte(&r_ptr->r_drop_gold); - rd_byte(&r_ptr->r_drop_item); + rd_byte(&tmp8u); + r_ptr->r_drop_gold = (ITEM_NUMBER)tmp8u; + rd_byte(&tmp8u); + r_ptr->r_drop_item = (ITEM_NUMBER)tmp8u; /* Count spells */ rd_byte(&tmp8u); @@ -1169,7 +1255,8 @@ static void rd_lore(int r_idx) } /* Read the "Racial" monster limit per level */ - rd_byte(&r_ptr->max_num); + rd_byte(&tmp8u); + r_ptr->max_num = (MONSTER_NUMBER)tmp8u; /* Location in saved floor */ rd_s16b(&r_ptr->floor_id); @@ -1574,6 +1661,7 @@ static void rd_ghost(void) static void load_quick_start(void) { byte tmp8u; + s16b tmp16s; int i; if (z_older_than(11, 0, 13)) @@ -1586,8 +1674,10 @@ static void load_quick_start(void) rd_byte(&previous_char.prace); rd_byte(&previous_char.pclass); rd_byte(&previous_char.pseikaku); - rd_byte(&previous_char.realm1); - rd_byte(&previous_char.realm2); + rd_byte(&tmp8u); + previous_char.realm1 = (REALM_IDX)tmp8u; + rd_byte(&tmp8u); + previous_char.realm2 = (REALM_IDX)tmp8u; rd_s16b(&previous_char.age); rd_s16b(&previous_char.ht); @@ -1598,7 +1688,11 @@ static void load_quick_start(void) for (i = 0; i < 6; i++) rd_s16b(&previous_char.stat_max[i]); for (i = 0; i < 6; i++) rd_s16b(&previous_char.stat_max_max[i]); - for (i = 0; i < PY_MAX_LEVEL; i++) rd_s16b(&previous_char.player_hp[i]); + for (i = 0; i < PY_MAX_LEVEL; i++) + { + rd_s16b(&tmp16s); + previous_char.player_hp[i] = (HIT_POINT)tmp16s; + } rd_s16b(&previous_char.chaos_patron); @@ -1623,6 +1717,7 @@ static void rd_extra(void) byte tmp8u; s16b tmp16s; + s32b tmp32s; u16b tmp16u; rd_string(p_ptr->name, sizeof(p_ptr->name)); @@ -1650,8 +1745,10 @@ static void rd_extra(void) rd_byte(&p_ptr->pclass); rd_byte(&p_ptr->pseikaku); rd_byte(&p_ptr->psex); - rd_byte(&p_ptr->realm1); - rd_byte(&p_ptr->realm2); + rd_byte(&tmp8u); + p_ptr->realm1 = (REALM_IDX)tmp8u; + rd_byte(&tmp8u); + p_ptr->realm2 = (REALM_IDX)tmp8u; rd_byte(&tmp8u); /* oops */ if (z_older_than(10, 4, 4)) @@ -1663,7 +1760,8 @@ static void rd_extra(void) } /* Special Race/Class info */ - rd_byte(&p_ptr->hitdie); + rd_byte(&tmp8u); + p_ptr->hitdie = tmp8u; rd_u16b(&p_ptr->expfact); /* Age/Height/Weight */ @@ -1744,8 +1842,10 @@ static void rd_extra(void) else { rd_byte(&p_ptr->start_race); - rd_s32b(&p_ptr->old_race1); - rd_s32b(&p_ptr->old_race2); + rd_s32b(&tmp32s); + p_ptr->old_race1 = (BIT_FLAGS)tmp32s; + rd_s32b(&tmp32s); + p_ptr->old_race2 = (BIT_FLAGS)tmp32s; rd_s16b(&p_ptr->old_realm); } @@ -1777,8 +1877,10 @@ static void rd_extra(void) { for (i = 0; i < MAX_MANE; i++) { - rd_s16b(&p_ptr->mane_spell[i]); - rd_s16b(&p_ptr->mane_dam[i]); + rd_s16b(&tmp16s); + p_ptr->mane_spell[i] = (SPELL_IDX)tmp16s; + rd_s16b(&tmp16s); + p_ptr->mane_dam[i] = (SPELL_IDX)tmp16s; } rd_s16b(&p_ptr->mane_num); } @@ -1840,8 +1942,11 @@ static void rd_extra(void) rd_byte(&p_ptr->exit_bldg); rd_byte(&tmp8u); - rd_s16b(&p_ptr->oldpx); - rd_s16b(&p_ptr->oldpy); + rd_s16b(&tmp16s); + p_ptr->oldpx = (POSITION)tmp16s; + rd_s16b(&tmp16s); + p_ptr->oldpy = (POSITION)tmp16s; + if (z_older_than(10, 3, 13) && !dun_level && !p_ptr->inside_arena) {p_ptr->oldpy = 33;p_ptr->oldpx = 131;} /* Was p_ptr->rewards[MAX_BACT] */ @@ -1891,7 +1996,8 @@ static void rd_extra(void) rd_s16b(&p_ptr->max_plv); if (z_older_than(10, 3, 8)) { - rd_s16b(&max_dlv[DUNGEON_ANGBAND]); + rd_s16b(&tmp16s); + max_dlv[DUNGEON_ANGBAND] = tmp16s; } else { @@ -1901,7 +2007,8 @@ static void rd_extra(void) for(i = 0; i < max; i++) { - rd_s16b(&max_dlv[i]); + rd_s16b(&tmp16s); + max_dlv[i] = tmp16s; if (max_dlv[i] > d_info[i].maxdepth) max_dlv[i] = d_info[i].maxdepth; } } @@ -2029,7 +2136,8 @@ static void rd_extra(void) else { rd_s16b(&p_ptr->tim_res_time); - rd_byte(&p_ptr->mimic_form); + rd_byte(&tmp8u); + p_ptr->mimic_form = (IDX)tmp8u; rd_s16b(&p_ptr->tim_mimic); rd_s16b(&p_ptr->tim_sh_fire); } @@ -2100,7 +2208,8 @@ static void rd_extra(void) p_ptr->autopick_autoregister = tmp8u ? TRUE : FALSE; rd_byte(&tmp8u); /* oops */ - rd_byte(&p_ptr->action); + rd_byte(&tmp8u); + p_ptr->action = (ACTION_IDX)tmp8u; if (!z_older_than(10, 4, 3)) { rd_byte(&tmp8u); @@ -2246,13 +2355,13 @@ static void rd_extra(void) } else if (z_older_than(10, 3, 10)) { - s32b tmp32s; rd_s32b(&tmp32s); p_ptr->visit = 1L; } else { - rd_s32b(&p_ptr->visit); + rd_s32b(&tmp32s); + p_ptr->visit = (BIT_FLAGS)tmp32s; } if (!z_older_than(11, 0, 5)) { @@ -2369,6 +2478,7 @@ static void rd_messages(void) { int i; char buf[128]; + int message_max; if (h_older_than(2, 2, 0, 75)) @@ -2376,9 +2486,10 @@ static void rd_messages(void) u16b num; /* Total */ rd_u16b(&num); + message_max = (int)num; /* Read the messages */ - for (i = 0; i < num; i++) + for (i = 0; i < message_max; i++) { /* Read the message */ rd_string(buf, sizeof(buf)); @@ -2392,9 +2503,10 @@ static void rd_messages(void) u32b num; /* Total */ rd_u32b(&num); + message_max = (int)num; /* Read the messages */ - for (i = 0; i < num; i++) + for (i = 0; i < message_max; i++) { /* Read the message */ rd_string(buf, sizeof(buf)); @@ -2448,23 +2560,31 @@ static errr rd_dungeon_old(void) /*** Basic info ***/ /* Header info */ - rd_s16b(&dun_level); + rd_s16b(&tmp16s); + dun_level = (DEPTH)tmp16s; if (z_older_than(10, 3, 8)) dungeon_type = DUNGEON_ANGBAND; - else rd_byte(&dungeon_type); + else + { + rd_byte(&tmp8u); + dungeon_type = (IDX)tmp8u; + } /* Set the base level for old versions */ base_level = dun_level; - rd_s16b(&base_level); + rd_s16b(&tmp16s); + base_level = (DEPTH)tmp16s; rd_s16b(&num_repro); rd_s16b(&tmp16s); - p_ptr->y = (int)tmp16s; + p_ptr->y = (POSITION)tmp16s; rd_s16b(&tmp16s); - p_ptr->x = (int)tmp16s; + p_ptr->x = (POSITION)tmp16s; if (z_older_than(10, 3, 13) && !dun_level && !p_ptr->inside_arena) {p_ptr->y = 33;p_ptr->x = 131;} - rd_s16b(&cur_hgt); - rd_s16b(&cur_wid); + rd_s16b(&tmp16s); + cur_hgt = (POSITION)tmp16s; + rd_s16b(&tmp16s); + cur_wid = (POSITION)tmp16s; rd_s16b(&tmp16s); /* max_panel_rows */ rd_s16b(&tmp16s); /* max_panel_cols */ @@ -2797,7 +2917,7 @@ static errr rd_dungeon_old(void) /* Read the monsters */ for (i = 1; i < limit; i++) { - int m_idx; + MONSTER_IDX m_idx; monster_type *m_ptr; /* Get a new record */ @@ -2843,15 +2963,22 @@ static errr rd_dungeon_old(void) /*! * @brief ä¿åãããããã¢ãèªã¿è¾¼ã / Read the saved floor - * @return ãªã + * @return infoèªã¿è¾¼ã¿ã¨ã©ã¼ã³ã¼ã * @details + * ãã®é¢æ°ã¯ãã»ã¼ããã¼ã¿ã®äºææ§ãä¿ã¤ããã«å¤ãã®ãã¼ã¿æ¹å¤å¦çãåãã¦ããã + * ç¾å¨ç¢ºèªãã¦ããå¦çã¯ä»¥ä¸ã®éãã + *