3 /* Purpose: support for loading savefiles -BEN- */
9 * This file loads savefiles from Angband 2.7.X and 2.8.X
11 * Ancient savefiles (pre-2.7.0) are loaded by another file.
13 * Note that Angband 2.7.0 through 2.7.3 are now officially obsolete,
14 * and savefiles from those versions may not be successfully converted.
16 * We attempt to prevent corrupt savefiles from inducing memory errors.
18 * Note that this file should not use the random number generator, the
19 * object flavors, the visual attr/char mappings, or anything else which
20 * is initialized *after* or *during* the "load character" function.
22 * This file assumes that the monster/object records are initialized
23 * to zero, and the race/kind tables have been loaded correctly. The
24 * order of object stacks is currently not saved in the savefiles, but
25 * the "next" pointers are saved, so all necessary knowledge is present.
27 * We should implement simple "savefile extenders" using some form of
28 * "sized" chunks of bytes, with a {size,type,data} format, so everyone
29 * can know the size, interested people can know the type, and the actual
30 * data is available to the parsing routines that acknowledge the type.
32 * Consider changing the "globe of invulnerability" code so that it
33 * takes some form of "maximum damage to protect from" in addition to
34 * the existing "number of turns to protect for", and where each hit
35 * by a monster will reduce the shield by that amount.
43 * Maximum number of tries for selection of a proper quest monster
49 * Local "savefile" pointer
54 * Hack -- old "encryption" byte
59 * Hack -- simple "checksum" on the actual values
61 static u32b v_check = 0L;
64 * Hack -- simple "checksum" on the encoded bytes
66 static u32b x_check = 0L;
72 * This function determines if the version of the savefile
73 * currently being read is older than version "x.y.z".
75 static bool older_than(byte x, byte y, byte z)
77 /* Much older, or much more recent */
78 if (sf_major < x) return (TRUE);
79 if (sf_major > x) return (FALSE);
81 /* Distinctly older, or distinctly more recent */
82 if (sf_minor < y) return (TRUE);
83 if (sf_minor > y) return (FALSE);
85 /* Barely older, or barely more recent */
86 if (sf_patch < z) return (TRUE);
87 if (sf_patch > z) return (FALSE);
89 /* Identical versions */
95 * The above function, adapted for Zangband
97 static bool z_older_than(byte x, byte y, byte z)
99 /* Much older, or much more recent */
100 if (z_major < x) return (TRUE);
101 if (z_major > x) return (FALSE);
103 /* Distinctly older, or distinctly more recent */
104 if (z_minor < y) return (TRUE);
105 if (z_minor > y) return (FALSE);
107 /* Barely older, or barely more recent */
108 if (z_patch < z) return (TRUE);
109 if (z_patch > z) return (FALSE);
111 /* Identical versions */
117 * Hack -- Show information on the screen, one line at a time.
119 * Avoid the top two lines, to avoid interference with "msg_print()".
121 static void note(cptr msg)
125 /* Draw the message */
128 /* Advance one line (wrap if needed) */
129 if (++y >= 24) y = 2;
137 * The following functions are used to load the basic building blocks
138 * of savefiles. They also maintain the "checksum" info for 2.7.0+
141 static byte sf_get(void)
145 /* Get a character, decode the value */
146 c = getc(fff) & 0xFF;
150 /* Maintain the checksum info */
154 /* Return the value */
158 static void rd_byte(byte *ip)
163 static void rd_u16b(u16b *ip)
166 (*ip) |= ((u16b)(sf_get()) << 8);
169 static void rd_s16b(s16b *ip)
174 static void rd_u32b(u32b *ip)
177 (*ip) |= ((u32b)(sf_get()) << 8);
178 (*ip) |= ((u32b)(sf_get()) << 16);
179 (*ip) |= ((u32b)(sf_get()) << 24);
182 static void rd_s32b(s32b *ip)
189 * Hack -- read a string
191 static void rd_string(char *str, int max)
195 /* Read the string */
196 for (i = 0; TRUE; i++)
203 /* Collect string while legal */
204 if (i < max) str[i] = tmp8u;
219 * Hack -- strip some bytes
221 static void strip_bytes(int n)
225 /* Strip the bytes */
226 while (n--) rd_byte(&tmp8u);
229 #define OLD_MAX_MANE 22
234 * This function attempts to "repair" old savefiles, and to extract
235 * the most up to date values for various object fields.
237 * Note that Angband 2.7.9 introduced a new method for object "flags"
238 * in which the "flags" on an object are actually extracted when they
239 * are needed from the object kind, artifact index, ego-item index,
240 * and two special "xtra" fields which are used to encode any "extra"
241 * power of certain ego-items. This had the side effect that items
242 * imported from pre-2.7.9 savefiles will lose any "extra" powers they
243 * may have had, and also, all "uncursed" items will become "cursed"
244 * again, including Calris, even if it is being worn at the time. As
245 * a complete hack, items which are inscribed with "uncursed" will be
246 * "uncursed" when imported from pre-2.7.9 savefiles.
248 static void rd_item(object_type *o_ptr)
254 rd_s16b(&o_ptr->k_idx);
261 rd_byte(&o_ptr->tval);
262 rd_byte(&o_ptr->sval);
264 if (z_older_than(10, 4, 4))
266 if (o_ptr->tval == 100) o_ptr->tval = TV_GOLD;
267 if (o_ptr->tval == 98) o_ptr->tval = TV_MUSIC_BOOK;
268 if (o_ptr->tval == 110) o_ptr->tval = TV_HISSATSU_BOOK;
272 rd_s16b(&o_ptr->pval);
274 rd_byte(&o_ptr->discount);
275 rd_byte(&o_ptr->number);
276 rd_s16b(&o_ptr->weight);
278 rd_byte(&o_ptr->name1);
279 rd_byte(&o_ptr->name2);
280 rd_s16b(&o_ptr->timeout);
282 rd_s16b(&o_ptr->to_h);
283 rd_s16b(&o_ptr->to_d);
284 rd_s16b(&o_ptr->to_a);
291 rd_byte(&o_ptr->ident);
293 rd_byte(&o_ptr->marked);
296 rd_u32b(&o_ptr->art_flags1);
297 rd_u32b(&o_ptr->art_flags2);
298 rd_u32b(&o_ptr->art_flags3);
300 if (z_older_than(11, 0, 11))
302 o_ptr->curse_flags = 0L;
303 if (o_ptr->ident & 0x40)
305 o_ptr->curse_flags |= TRC_CURSED;
306 if (o_ptr->art_flags3 & 0x40000000L) o_ptr->curse_flags |= TRC_HEAVY_CURSE;
307 if (o_ptr->art_flags3 & 0x80000000L) o_ptr->curse_flags |= TRC_PERMA_CURSE;
310 artifact_type *a_ptr = &a_info[o_ptr->name1];
311 if (a_ptr->gen_flags & (TRG_HEAVY_CURSE)) o_ptr->curse_flags |= TRC_HEAVY_CURSE;
312 if (a_ptr->gen_flags & (TRG_PERMA_CURSE)) o_ptr->curse_flags |= TRC_PERMA_CURSE;
314 else if (o_ptr->name2)
316 ego_item_type *e_ptr = &e_info[o_ptr->name2];
317 if (e_ptr->gen_flags & (TRG_HEAVY_CURSE)) o_ptr->curse_flags |= TRC_HEAVY_CURSE;
318 if (e_ptr->gen_flags & (TRG_PERMA_CURSE)) o_ptr->curse_flags |= TRC_PERMA_CURSE;
321 o_ptr->art_flags3 &= (0x1FFFFFFFL);
325 rd_u32b(&o_ptr->curse_flags);
328 /* Monster holding object */
329 rd_s16b(&o_ptr->held_m_idx);
332 rd_byte(&o_ptr->xtra1);
333 rd_byte(&o_ptr->xtra2);
335 if (z_older_than(11, 0, 10))
337 if (o_ptr->xtra1 == EGO_XTRA_SUSTAIN)
339 switch (o_ptr->xtra2 % 6)
341 case 0: o_ptr->art_flags2 |= (TR2_SUST_STR); break;
342 case 1: o_ptr->art_flags2 |= (TR2_SUST_INT); break;
343 case 2: o_ptr->art_flags2 |= (TR2_SUST_WIS); break;
344 case 3: o_ptr->art_flags2 |= (TR2_SUST_DEX); break;
345 case 4: o_ptr->art_flags2 |= (TR2_SUST_CON); break;
346 case 5: o_ptr->art_flags2 |= (TR2_SUST_CHR); break;
350 else if (o_ptr->xtra1 == EGO_XTRA_POWER)
352 switch (o_ptr->xtra2 % 11)
354 case 0: o_ptr->art_flags2 |= (TR2_RES_BLIND); break;
355 case 1: o_ptr->art_flags2 |= (TR2_RES_CONF); break;
356 case 2: o_ptr->art_flags2 |= (TR2_RES_SOUND); break;
357 case 3: o_ptr->art_flags2 |= (TR2_RES_SHARDS); break;
358 case 4: o_ptr->art_flags2 |= (TR2_RES_NETHER); break;
359 case 5: o_ptr->art_flags2 |= (TR2_RES_NEXUS); break;
360 case 6: o_ptr->art_flags2 |= (TR2_RES_CHAOS); break;
361 case 7: o_ptr->art_flags2 |= (TR2_RES_DISEN); break;
362 case 8: o_ptr->art_flags2 |= (TR2_RES_POIS); break;
363 case 9: o_ptr->art_flags2 |= (TR2_RES_DARK); break;
364 case 10: o_ptr->art_flags2 |= (TR2_RES_LITE); break;
368 else if (o_ptr->xtra1 == EGO_XTRA_ABILITY)
370 switch (o_ptr->xtra2 % 8)
372 case 0: o_ptr->art_flags3 |= (TR3_FEATHER); break;
373 case 1: o_ptr->art_flags3 |= (TR3_LITE); break;
374 case 2: o_ptr->art_flags3 |= (TR3_SEE_INVIS); break;
375 case 3: o_ptr->art_flags3 |= (TR3_WARNING); break;
376 case 4: o_ptr->art_flags3 |= (TR3_SLOW_DIGEST); break;
377 case 5: o_ptr->art_flags3 |= (TR3_REGEN); break;
378 case 6: o_ptr->art_flags2 |= (TR2_FREE_ACT); break;
379 case 7: o_ptr->art_flags2 |= (TR2_HOLD_LIFE); break;
386 if (z_older_than(10, 2, 3))
391 if ((o_ptr->tval == TV_CHEST) || (o_ptr->tval == TV_CAPTURE))
393 o_ptr->xtra3 = o_ptr->xtra1;
396 if (o_ptr->tval == TV_CAPTURE)
398 if (r_info[o_ptr->pval].flags1 & RF1_FORCE_MAXHP)
399 o_ptr->xtra5 = maxroll(r_info[o_ptr->pval].hdice, r_info[o_ptr->pval].hside);
401 o_ptr->xtra5 = damroll(r_info[o_ptr->pval].hdice, r_info[o_ptr->pval].hside);
402 if (ironman_nightmare)
404 o_ptr->xtra5 = (s16b)MIN(30000, o_ptr->xtra5*2L);
406 o_ptr->xtra4 = o_ptr->xtra5;
411 rd_byte(&o_ptr->xtra3);
412 rd_s16b(&o_ptr->xtra4);
413 rd_s16b(&o_ptr->xtra5);
416 if (z_older_than(11, 0, 5) && (((o_ptr->tval == TV_LITE) && ((o_ptr->sval == SV_LITE_TORCH) || (o_ptr->sval == SV_LITE_LANTERN))) || (o_ptr->tval == TV_FLASK)))
418 o_ptr->xtra4 = o_ptr->pval;
422 /* Feeling - from 2.3.1, "savefile version 1" */
425 rd_byte(&o_ptr->feeling);
431 /* If this savefile is old, maybe we need to translate the feeling */
436 for (i = 0; i <= FEEL_MAX; i++)
438 if (game_inscriptions[i] == NULL)
443 if (streq(buf, game_inscriptions[i]))
452 /* Save the inscription */
453 if (buf[0]) o_ptr->inscription = quark_add(buf);
456 if (buf[0]) o_ptr->art_name = quark_add(buf);
458 /* The Python object */
466 /* Mega-Hack -- handle "dungeon objects" later */
467 if ((o_ptr->k_idx >= 445) && (o_ptr->k_idx <= 479)) return;
469 if (z_older_than(10, 4, 10) && (o_ptr->name2 == EGO_YOIYAMI)) o_ptr->k_idx = lookup_kind(TV_SOFT_ARMOR, SV_YOIYAMI_ROBE);
471 if (z_older_than(10, 4, 9))
473 if (o_ptr->art_flags1 & TR1_MAGIC_MASTERY)
475 o_ptr->art_flags1 &= ~(TR1_MAGIC_MASTERY);
476 o_ptr->art_flags3 |= (TR3_DEC_MANA);
483 artifact_type *a_ptr;
485 /* Obtain the artifact info */
486 a_ptr = &a_info[o_ptr->name1];
488 /* Verify that artifact */
489 if (!a_ptr->name) o_ptr->name1 = 0;
495 ego_item_type *e_ptr;
497 /* Obtain the ego-item info */
498 e_ptr = &e_info[o_ptr->name2];
500 /* Verify that ego-item */
501 if (!e_ptr->name) o_ptr->name2 = 0;
512 static void rd_monster(monster_type *m_ptr)
517 /* Read the monster race */
518 rd_s16b(&m_ptr->r_idx);
520 /* Read the other information */
524 rd_s16b(&m_ptr->maxhp);
525 if (z_older_than(11, 0, 5))
527 m_ptr->max_maxhp = m_ptr->maxhp;
531 rd_s16b(&m_ptr->max_maxhp);
533 rd_s16b(&m_ptr->csleep);
534 rd_byte(&m_ptr->mspeed);
535 if (z_older_than(10, 4, 2))
538 m_ptr->energy = (s16b)tmp8u;
540 else rd_s16b(&m_ptr->energy);
541 if (z_older_than(10,0,7))
548 rd_byte(&m_ptr->fast);
549 rd_byte(&m_ptr->slow);
551 rd_byte(&m_ptr->stunned);
552 rd_byte(&m_ptr->confused);
553 rd_byte(&m_ptr->monfear);
555 if (z_older_than(10,0,10))
559 else if (z_older_than(10,0,11))
567 rd_s16b(&m_ptr->target_y);
568 rd_s16b(&m_ptr->target_x);
571 /* Monster invulnerability introduced from 2.3.2+ */
575 rd_byte(&m_ptr->invulner);
577 if (!(z_major == 2 && z_minor == 0 && z_patch == 6))
578 rd_u32b(&m_ptr->smart);
582 if (z_older_than(10, 4, 5))
585 rd_u32b(&m_ptr->exp);
587 if (z_older_than(10, 2, 2))
589 if (m_ptr->r_idx < 0)
591 m_ptr->r_idx = (0-m_ptr->r_idx);
592 m_ptr->mflag2 |= MFLAG_KAGE;
597 rd_byte(&m_ptr->mflag2);
600 if (z_older_than(10, 1, 3))
607 if (buf[0]) m_ptr->nickname = quark_add(buf);
618 * Read the monster lore
620 static void rd_lore(int r_idx)
624 monster_race *r_ptr = &r_info[r_idx];
626 /* Count sights/deaths/kills */
627 rd_s16b(&r_ptr->r_sights);
628 rd_s16b(&r_ptr->r_deaths);
629 rd_s16b(&r_ptr->r_pkills);
630 rd_s16b(&r_ptr->r_tkills);
632 /* Count wakes and ignores */
633 rd_byte(&r_ptr->r_wake);
634 rd_byte(&r_ptr->r_ignore);
637 rd_byte(&r_ptr->r_xtra1);
638 rd_byte(&r_ptr->r_xtra2);
641 rd_byte(&r_ptr->r_drop_gold);
642 rd_byte(&r_ptr->r_drop_item);
645 rd_byte(&r_ptr->r_cast_inate);
646 rd_byte(&r_ptr->r_cast_spell);
648 /* Count blows of each type */
649 rd_byte(&r_ptr->r_blows[0]);
650 rd_byte(&r_ptr->r_blows[1]);
651 rd_byte(&r_ptr->r_blows[2]);
652 rd_byte(&r_ptr->r_blows[3]);
655 rd_u32b(&r_ptr->r_flags1);
656 rd_u32b(&r_ptr->r_flags2);
657 rd_u32b(&r_ptr->r_flags3);
658 rd_u32b(&r_ptr->r_flags4);
659 rd_u32b(&r_ptr->r_flags5);
660 rd_u32b(&r_ptr->r_flags6);
662 /* Read the "Racial" monster limit per level */
663 rd_byte(&r_ptr->max_num);
670 /* Repair the lore flags */
671 r_ptr->r_flags1 &= r_ptr->flags1;
672 r_ptr->r_flags2 &= r_ptr->flags2;
673 r_ptr->r_flags3 &= r_ptr->flags3;
674 r_ptr->r_flags4 &= r_ptr->flags4;
675 r_ptr->r_flags5 &= r_ptr->flags5;
676 r_ptr->r_flags6 &= r_ptr->flags6;
683 * Add the item "o_ptr" to the inventory of the "Home"
685 * In all cases, return the slot (or -1) where the object was placed
687 * Note that this is a hacked up version of "inven_carry()".
689 * Also note that it may not correctly "adapt" to "knowledge" bacoming
690 * known, the player may have to pick stuff up and drop it again.
692 static void home_carry(store_type *st_ptr, object_type *o_ptr)
700 /* Check each existing item (try to combine) */
701 for (slot = 0; slot < st_ptr->stock_num; slot++)
703 /* Get the existing item */
704 j_ptr = &st_ptr->stock[slot];
706 /* The home acts just like the player */
707 if (object_similar(j_ptr, o_ptr))
709 /* Save the new number of items */
710 object_absorb(j_ptr, o_ptr);
718 if (st_ptr->stock_num >= STORE_INVEN_MAX * 10) {
722 /* Determine the "value" of the item */
723 value = object_value(o_ptr);
725 /* Check existing slots to see if we must "slide" */
726 for (slot = 0; slot < st_ptr->stock_num; slot++)
729 j_ptr = &st_ptr->stock[slot];
731 /* Hack -- readable books always come first */
732 if ((o_ptr->tval == mp_ptr->spell_book) &&
733 (j_ptr->tval != mp_ptr->spell_book)) break;
734 if ((j_ptr->tval == mp_ptr->spell_book) &&
735 (o_ptr->tval != mp_ptr->spell_book)) continue;
737 /* Objects sort by decreasing type */
738 if (o_ptr->tval > j_ptr->tval) break;
739 if (o_ptr->tval < j_ptr->tval) continue;
741 /* Can happen in the home */
742 if (!object_aware_p(o_ptr)) continue;
743 if (!object_aware_p(j_ptr)) break;
745 /* Objects sort by increasing sval */
746 if (o_ptr->sval < j_ptr->sval) break;
747 if (o_ptr->sval > j_ptr->sval) continue;
749 /* Objects in the home can be unknown */
750 if (!object_known_p(o_ptr)) continue;
751 if (!object_known_p(j_ptr)) break;
754 * Hack: otherwise identical rods sort by
755 * increasing recharge time --dsb
757 if (o_ptr->tval == TV_ROD)
759 if (o_ptr->pval < j_ptr->pval) break;
760 if (o_ptr->pval > j_ptr->pval) continue;
763 /* Objects sort by decreasing value */
764 j_value = object_value(j_ptr);
765 if (value > j_value) break;
766 if (value < j_value) continue;
769 /* Slide the others up */
770 for (i = st_ptr->stock_num; i > slot; i--)
772 st_ptr->stock[i] = st_ptr->stock[i-1];
778 /* Insert the new item */
779 st_ptr->stock[slot] = *o_ptr;
781 chg_virtue(V_SACRIFICE, -1);
783 /* Return the location */
791 static errr rd_store(int town_number, int store_number)
803 if (z_older_than(10, 3, 3) && (store_number == STORE_HOME))
805 st_ptr = &town[1].store[store_number];
806 if (st_ptr->stock_num) sort = TRUE;
810 st_ptr = &town[town_number].store[store_number];
813 /* Read the basic info */
814 rd_s32b(&st_ptr->store_open);
815 rd_s16b(&st_ptr->insult_cur);
817 if (z_older_than(11, 0, 4))
826 rd_s16b(&st_ptr->good_buy);
827 rd_s16b(&st_ptr->bad_buy);
829 /* Read last visit */
830 rd_s32b(&st_ptr->last_visit);
832 /* Extract the owner (see above) */
836 for (j = 0; j < num; j++)
841 /* Get local object */
844 /* Wipe the object */
850 /* Acquire valid items */
851 if (st_ptr->stock_num < (store_number == STORE_HOME ? (STORE_INVEN_MAX) * 10 : (store_number == STORE_MUSEUM ? (STORE_INVEN_MAX) * 50 : STORE_INVEN_MAX)))
856 home_carry(st_ptr, q_ptr);
860 k = st_ptr->stock_num++;
862 /* Acquire the item */
863 object_copy(&st_ptr->stock[k], q_ptr);
875 * Read RNG state (added in 2.8.0)
877 static void rd_randomizer(void)
887 rd_u16b(&Rand_place);
890 for (i = 0; i < RAND_DEG; i++)
892 rd_u32b(&Rand_state[i]);
902 * Read options (ignore most pre-2.8.0 options)
904 * Note that the normal options are now stored as a set of 256 bit flags,
905 * plus a set of 256 bit masks to indicate which bit flags were defined
906 * at the time the savefile was created. This will allow new options
907 * to be added, and old options to be removed, at any time, without
908 * hurting old savefiles.
910 * The window options are stored in the same way, but note that each
911 * window gets 32 options, and their order is fixed by certain defines.
913 static void rd_options(void)
927 /* Ignore old options */
933 /* Read "delay_factor" */
937 /* Read "hitpoint_warn" */
942 /*** Cheating options ***/
946 if (c & 0x0002) wizard = TRUE;
948 cheat_peek = (c & 0x0100) ? TRUE : FALSE;
949 cheat_hear = (c & 0x0200) ? TRUE : FALSE;
950 cheat_room = (c & 0x0400) ? TRUE : FALSE;
951 cheat_xtra = (c & 0x0800) ? TRUE : FALSE;
952 cheat_know = (c & 0x1000) ? TRUE : FALSE;
953 cheat_live = (c & 0x2000) ? TRUE : FALSE;
955 rd_byte((byte *)&autosave_l);
956 rd_byte((byte *)&autosave_t);
957 rd_s16b(&autosave_freq);
960 /*** Normal Options ***/
962 /* Read the option flags */
963 for (n = 0; n < 8; n++) rd_u32b(&flag[n]);
965 /* Read the option masks */
966 for (n = 0; n < 8; n++) rd_u32b(&mask[n]);
968 /* Analyze the options */
969 for (n = 0; n < 8; n++)
971 /* Analyze the options */
972 for (i = 0; i < 32; i++)
974 /* Process valid flags */
975 if (mask[n] & (1L << i))
977 /* Process valid flags */
978 if (option_mask[n] & (1L << i))
981 if (flag[n] & (1L << i))
984 option_flag[n] |= (1L << i);
991 option_flag[n] &= ~(1L << i);
998 if (z_older_than(10, 4, 5))
1000 if (option_flag[5] & (0x00000001 << 4)) option_flag[5] &= ~(0x00000001 << 4);
1001 else option_flag[5] |= (0x00000001 << 4);
1002 if (option_flag[2] & (0x00000001 << 5)) option_flag[2] &= ~(0x00000001 << 5);
1003 else option_flag[2] |= (0x00000001 << 5);
1004 if (option_flag[4] & (0x00000001 << 5)) option_flag[4] &= ~(0x00000001 << 5);
1005 else option_flag[4] |= (0x00000001 << 5);
1006 if (option_flag[5] & (0x00000001 << 0)) option_flag[5] &= ~(0x00000001 << 0);
1007 else option_flag[5] |= (0x00000001 << 0);
1008 if (option_flag[5] & (0x00000001 << 12)) option_flag[5] &= ~(0x00000001 << 12);
1009 else option_flag[5] |= (0x00000001 << 12);
1010 if (option_flag[1] & (0x00000001 << 0)) option_flag[1] &= ~(0x00000001 << 0);
1011 else option_flag[1] |= (0x00000001 << 0);
1012 if (option_flag[1] & (0x00000001 << 18)) option_flag[1] &= ~(0x00000001 << 18);
1013 else option_flag[1] |= (0x00000001 << 18);
1014 if (option_flag[1] & (0x00000001 << 19)) option_flag[1] &= ~(0x00000001 << 19);
1015 else option_flag[1] |= (0x00000001 << 19);
1016 if (option_flag[5] & (0x00000001 << 3)) option_flag[1] &= ~(0x00000001 << 3);
1017 else option_flag[5] |= (0x00000001 << 3);
1021 /*** Window Options ***/
1023 /* Read the window flags */
1024 for (n = 0; n < 8; n++) rd_u32b(&flag[n]);
1026 /* Read the window masks */
1027 for (n = 0; n < 8; n++) rd_u32b(&mask[n]);
1029 /* Analyze the options */
1030 for (n = 0; n < 8; n++)
1032 /* Analyze the options */
1033 for (i = 0; i < 32; i++)
1035 /* Process valid flags */
1036 if (mask[n] & (1L << i))
1038 /* Process valid flags */
1039 if (window_mask[n] & (1L << i))
1042 if (flag[n] & (1L << i))
1045 window_flag[n] |= (1L << i);
1052 window_flag[n] &= ~(1L << i);
1065 * Hack -- strip the "ghost" info
1067 * XXX XXX XXX This is such a nasty hack it hurts.
1069 static void rd_ghost(void)
1076 /* Strip old data */
1084 * Read the "extra" information
1086 static void rd_extra(void)
1093 rd_string(player_name, 32);
1095 rd_string(died_from, 80);
1097 for (i = 0; i < 4; i++)
1099 rd_string(history[i], 60);
1102 /* Class/Race/Seikaku/Gender/Spells */
1103 rd_byte(&p_ptr->prace);
1104 rd_byte(&p_ptr->pclass);
1105 rd_byte(&p_ptr->pseikaku);
1106 rd_byte(&p_ptr->psex);
1107 rd_byte(&p_ptr->realm1);
1108 rd_byte(&p_ptr->realm2);
1109 rd_byte(&tmp8u); /* oops */
1111 if (z_older_than(10, 4, 4))
1113 if (p_ptr->realm1 == 9) p_ptr->realm1 = REALM_MUSIC;
1114 if (p_ptr->realm2 == 9) p_ptr->realm2 = REALM_MUSIC;
1115 if (p_ptr->realm1 == 10) p_ptr->realm1 = REALM_HISSATSU;
1116 if (p_ptr->realm2 == 10) p_ptr->realm2 = REALM_HISSATSU;
1119 /* Special Race/Class info */
1120 rd_byte(&p_ptr->hitdie);
1121 rd_u16b(&p_ptr->expfact);
1123 /* Age/Height/Weight */
1124 rd_s16b(&p_ptr->age);
1125 rd_s16b(&p_ptr->ht);
1126 rd_s16b(&p_ptr->wt);
1128 /* Read the stat info */
1129 for (i = 0; i < 6; i++) rd_s16b(&p_ptr->stat_max[i]);
1130 for (i = 0; i < 6; i++) rd_s16b(&p_ptr->stat_max_max[i]);
1131 for (i = 0; i < 6; i++) rd_s16b(&p_ptr->stat_cur[i]);
1133 strip_bytes(24); /* oops */
1135 rd_s32b(&p_ptr->au);
1137 rd_s32b(&p_ptr->max_exp);
1138 rd_s32b(&p_ptr->exp);
1139 rd_u16b(&p_ptr->exp_frac);
1141 rd_s16b(&p_ptr->lev);
1143 for (i = 0; i < 64; i++) rd_s16b(&spell_exp[i]);
1144 if ((p_ptr->pclass == CLASS_SORCERER) && z_older_than(10, 4, 2))
1146 for (i = 0; i < 64; i++) spell_exp[i] = 1600;
1148 if (z_older_than(10, 3, 6))
1149 for (i = 0; i < 5; i++) for (j = 0; j < 60; j++) rd_s16b(&weapon_exp[i][j]);
1151 for (i = 0; i < 5; i++) for (j = 0; j < 64; j++) rd_s16b(&weapon_exp[i][j]);
1152 for (i = 0; i < 10; i++) rd_s16b(&skill_exp[i]);
1153 if (z_older_than(10, 4, 1))
1155 if (p_ptr->pclass != CLASS_BEASTMASTER) skill_exp[GINOU_RIDING] /= 2;
1156 skill_exp[GINOU_RIDING] = MIN(skill_exp[GINOU_RIDING], s_info[p_ptr->pclass].s_max[GINOU_RIDING]);
1158 if (z_older_than(10, 3, 14))
1160 for (i = 0; i < 108; i++) p_ptr->magic_num1[i] = 0;
1161 for (i = 0; i < 108; i++) p_ptr->magic_num2[i] = 0;
1165 for (i = 0; i < 108; i++) rd_s32b(&p_ptr->magic_num1[i]);
1166 for (i = 0; i < 108; i++) rd_byte(&p_ptr->magic_num2[i]);
1168 if ((p_ptr->pclass == CLASS_BARD) && p_ptr->magic_num1[0]) p_ptr->action = ACTION_SING;
1170 if (z_older_than(11, 0, 7))
1172 p_ptr->start_race = p_ptr->prace;
1173 p_ptr->old_race1 = 0L;
1174 p_ptr->old_race2 = 0L;
1175 p_ptr->old_realm = 0;
1179 rd_byte(&p_ptr->start_race);
1180 rd_s32b(&p_ptr->old_race1);
1181 rd_s32b(&p_ptr->old_race2);
1182 rd_s16b(&p_ptr->old_realm);
1185 if (z_older_than(10, 0, 1))
1187 for (i = 0; i < OLD_MAX_MANE; i++)
1194 else if (z_older_than(10, 2, 3))
1196 for (i = 0; i < OLD_MAX_MANE; i++)
1201 for (i = 0; i < MAX_MANE; i++)
1211 for (i = 0; i < MAX_MANE; i++)
1213 rd_s16b(&mane_spell[i]);
1214 rd_s16b(&mane_dam[i]);
1219 if (z_older_than(10, 0, 3))
1221 get_mon_num_prep(NULL, NULL);
1222 for (i = 0; i < MAX_KUBI; i++)
1224 monster_race *r_ptr;
1229 kubi_r_idx[i] = get_mon_num(MAX_DEPTH - 1);
1230 r_ptr = &r_info[kubi_r_idx[i]];
1232 if(!(r_ptr->flags1 & RF1_UNIQUE)) continue;
1234 if(!(r_ptr->flags9 & RF9_DROP_CORPSE)) continue;
1236 if(r_ptr->flags6 & RF6_SPECIAL) continue;
1238 for (j = 0; j < i; j++)
1239 if (kubi_r_idx[i] == kubi_r_idx[j])break;
1244 for (i = 0; i < MAX_KUBI -1; i++)
1247 for (j = i; j < MAX_KUBI; j++)
1249 if (r_info[kubi_r_idx[i]].level > r_info[kubi_r_idx[j]].level)
1251 tmp = kubi_r_idx[i];
1252 kubi_r_idx[i] = kubi_r_idx[j];
1253 kubi_r_idx[j] = tmp;
1257 for (i = 0; i < MAX_KUBI; i++)
1259 if(!r_info[kubi_r_idx[i]].max_num)
1260 kubi_r_idx[i] += 10000;
1265 for (i = 0; i < MAX_KUBI; i++)
1267 rd_s16b(&kubi_r_idx[i]);
1271 if (z_older_than(10, 0, 3))
1277 for (i = 0; i < 4; i++)
1279 rd_s16b(&battle_mon[i]);
1280 if (z_older_than(10, 3, 4))
1283 mon_odds[i] = tmp16s;
1285 else rd_u32b(&mon_odds[i]);
1289 rd_s16b(&p_ptr->town_num);
1291 /* Read arena and rewards information */
1292 rd_s16b(&p_ptr->arena_number);
1294 p_ptr->inside_arena = (bool)tmp16s;
1295 rd_s16b(&p_ptr->inside_quest);
1296 if (z_older_than(10, 3, 5)) p_ptr->inside_battle = FALSE;
1300 p_ptr->inside_battle = (bool)tmp16s;
1302 rd_byte(&p_ptr->exit_bldg);
1303 rd_byte(&p_ptr->leftbldg);
1305 rd_s16b(&p_ptr->oldpx);
1306 rd_s16b(&p_ptr->oldpy);
1307 if (z_older_than(10, 3, 13) && !dun_level && !p_ptr->inside_arena) {p_ptr->oldpy = 33;p_ptr->oldpx = 131;}
1311 if (tmp16s > MAX_BACT)
1314 note(format("¤ÎÃæ", tmp16s));
1316 note(format("Too many (%d) building rewards!", tmp16s));
1321 for (i = 0; i < tmp16s; i++) rd_s16b(&p_ptr->rewards[i]);
1323 rd_s16b(&p_ptr->mhp);
1324 rd_s16b(&p_ptr->chp);
1325 rd_u16b(&p_ptr->chp_frac);
1327 rd_s16b(&p_ptr->msp);
1328 rd_s16b(&p_ptr->csp);
1329 rd_u16b(&p_ptr->csp_frac);
1331 rd_s16b(&p_ptr->max_plv);
1332 if (z_older_than(10, 3, 8))
1334 rd_s16b(&max_dlv[DUNGEON_ANGBAND]);
1338 byte max = (byte)max_d_idx;
1342 for(i = 0; i < max; i++)
1344 rd_s16b(&max_dlv[i]);
1345 if (max_dlv[i] > d_info[i].maxdepth) max_dlv[i] = d_info[i].maxdepth;
1349 /* Repair maximum player level XXX XXX XXX */
1350 if (p_ptr->max_plv < p_ptr->lev) p_ptr->max_plv = p_ptr->lev;
1354 rd_s16b(&p_ptr->sc);
1357 /* Read the flags */
1358 strip_bytes(2); /* Old "rest" */
1359 rd_s16b(&p_ptr->blind);
1360 rd_s16b(&p_ptr->paralyzed);
1361 rd_s16b(&p_ptr->confused);
1362 rd_s16b(&p_ptr->food);
1363 strip_bytes(4); /* Old "food_digested" / "protection" */
1364 rd_s16b(&p_ptr->energy);
1365 rd_s16b(&p_ptr->fast);
1366 rd_s16b(&p_ptr->slow);
1367 rd_s16b(&p_ptr->afraid);
1368 rd_s16b(&p_ptr->cut);
1369 rd_s16b(&p_ptr->stun);
1370 rd_s16b(&p_ptr->poisoned);
1371 rd_s16b(&p_ptr->image);
1372 rd_s16b(&p_ptr->protevil);
1373 rd_s16b(&p_ptr->invuln);
1374 if(z_older_than(10, 0, 0))
1377 rd_s16b(&p_ptr->ult_res);
1378 rd_s16b(&p_ptr->hero);
1379 rd_s16b(&p_ptr->shero);
1380 rd_s16b(&p_ptr->shield);
1381 rd_s16b(&p_ptr->blessed);
1382 rd_s16b(&p_ptr->tim_invis);
1383 rd_s16b(&p_ptr->word_recall);
1384 if (z_older_than(10, 3, 8))
1385 p_ptr->recall_dungeon = DUNGEON_ANGBAND;
1389 p_ptr->recall_dungeon = (byte)tmp16s;
1391 rd_s16b(&p_ptr->see_infra);
1392 rd_s16b(&p_ptr->tim_infra);
1393 rd_s16b(&p_ptr->oppose_fire);
1394 rd_s16b(&p_ptr->oppose_cold);
1395 rd_s16b(&p_ptr->oppose_acid);
1396 rd_s16b(&p_ptr->oppose_elec);
1397 rd_s16b(&p_ptr->oppose_pois);
1398 if (z_older_than(10,0,2)) p_ptr->tsuyoshi = 0;
1399 else rd_s16b(&p_ptr->tsuyoshi);
1401 /* Old savefiles do not have the following fields... */
1402 if ((z_major == 2) && (z_minor == 0) && (z_patch == 6))
1405 p_ptr->wraith_form = 0;
1406 p_ptr->resist_magic = 0;
1407 p_ptr->tim_regen = 0;
1408 p_ptr->kabenuke = 0;
1409 p_ptr->tim_stealth = 0;
1410 p_ptr->tim_ffall = 0;
1411 p_ptr->tim_sh_touki = 0;
1412 p_ptr->lightspeed = 0;
1413 p_ptr->tsubureru = 0;
1414 p_ptr->tim_res_nether = 0;
1415 p_ptr->tim_res_time = 0;
1416 p_ptr->mimic_form = 0;
1417 p_ptr->tim_mimic = 0;
1418 p_ptr->tim_sh_fire = 0;
1421 p_ptr->tim_reflect = 0;
1422 p_ptr->multishadow = 0;
1423 p_ptr->dustrobe = 0;
1425 p_ptr->chaos_patron = get_chaos_patron();
1433 rd_s16b(&p_ptr->tim_esp);
1434 rd_s16b(&p_ptr->wraith_form);
1435 rd_s16b(&p_ptr->resist_magic);
1436 rd_s16b(&p_ptr->tim_regen);
1437 rd_s16b(&p_ptr->kabenuke);
1438 rd_s16b(&p_ptr->tim_stealth);
1439 rd_s16b(&p_ptr->tim_ffall);
1440 rd_s16b(&p_ptr->tim_sh_touki);
1441 rd_s16b(&p_ptr->lightspeed);
1442 rd_s16b(&p_ptr->tsubureru);
1443 if (z_older_than(10, 4, 7))
1444 p_ptr->magicdef = 0;
1446 rd_s16b(&p_ptr->magicdef);
1447 rd_s16b(&p_ptr->tim_res_nether);
1448 if (z_older_than(10, 4, 11))
1450 p_ptr->tim_res_time = 0;
1451 p_ptr->mimic_form = 0;
1452 p_ptr->tim_mimic = 0;
1453 p_ptr->tim_sh_fire = 0;
1457 rd_s16b(&p_ptr->tim_res_time);
1458 rd_byte(&p_ptr->mimic_form);
1459 rd_s16b(&p_ptr->tim_mimic);
1460 rd_s16b(&p_ptr->tim_sh_fire);
1464 if ( z_older_than(11,0,3) ){
1465 p_ptr->tim_reflect=0;
1466 p_ptr->multishadow=0;
1470 rd_s16b(&p_ptr->tim_reflect);
1471 rd_s16b(&p_ptr->multishadow);
1472 rd_s16b(&p_ptr->dustrobe);
1475 rd_s16b(&p_ptr->chaos_patron);
1476 rd_u32b(&p_ptr->muta1);
1477 rd_u32b(&p_ptr->muta2);
1478 rd_u32b(&p_ptr->muta3);
1480 for (i = 0; i < 8; i++)
1481 rd_s16b(&p_ptr->virtues[i]);
1482 for (i = 0; i < 8; i++)
1483 rd_s16b(&p_ptr->vir_types[i]);
1486 /* Calc the regeneration modifier for mutations */
1487 mutant_regenerate_mod = calc_mutant_regenerate_mod();
1489 if (z_older_than(10,0,9))
1492 if (tmp8u) p_ptr->special_attack = ATTACK_CONFUSE;
1493 p_ptr->ele_attack = 0;
1497 rd_s16b(&p_ptr->ele_attack);
1498 rd_u32b(&p_ptr->special_attack);
1500 if (p_ptr->special_attack & KAMAE_MASK) p_ptr->action = ACTION_KAMAE;
1501 else if (p_ptr->special_attack & KATA_MASK) p_ptr->action = ACTION_KATA;
1502 if (z_older_than(10,0,12))
1504 p_ptr->ele_immune = 0;
1505 p_ptr->special_defense = 0;
1509 rd_s16b(&p_ptr->ele_immune);
1510 rd_u32b(&p_ptr->special_defense);
1512 rd_byte(&p_ptr->knowledge);
1513 rd_byte(&tmp8u); /* oops */
1514 rd_byte(&tmp8u); /* oops */
1515 rd_byte(&p_ptr->action);
1516 if (!z_older_than(10, 4, 3))
1519 if (tmp8u) p_ptr->action = ACTION_LEARN;
1521 rd_byte((byte *)&preserve_mode);
1522 rd_byte((byte *)&wait_report_score);
1525 for (i = 0; i < 48; i++) rd_byte(&tmp8u);
1527 /* Skip the flags */
1531 /* Hack -- the two "special seeds" */
1532 rd_u32b(&seed_flavor);
1533 rd_u32b(&seed_town);
1537 rd_u16b(&panic_save);
1538 rd_u16b(&total_winner);
1546 /* Read "feeling" */
1550 /* Turn of last "feeling" */
1556 if (z_older_than(10, 3, 12))
1558 dungeon_turn = turn;
1560 else rd_s32b(&dungeon_turn);
1562 if (z_older_than(10, 3, 13))
1566 else rd_s32b(&old_battle);
1568 if (z_older_than(10,0,3))
1570 monster_race *r_ptr;
1574 today_mon = get_mon_num(MAX(max_dlv[DUNGEON_ANGBAND], 3));
1575 r_ptr = &r_info[today_mon];
1577 if (r_ptr->flags1 & RF1_UNIQUE) continue;
1578 if (r_ptr->flags2 & (RF2_MULTIPLY)) continue;
1579 if (!(r_ptr->flags9 & RF9_DROP_CORPSE) || !(r_ptr->flags9 & RF9_DROP_SKELETON)) continue;
1580 if (r_ptr->level < MIN(max_dlv[DUNGEON_ANGBAND], 40)) continue;
1581 if (r_ptr->rarity > 10) continue;
1582 if (r_ptr->level == 0) continue;
1586 p_ptr->today_mon = 0;
1590 rd_s16b(&today_mon);
1591 rd_s16b(&p_ptr->today_mon);
1594 if (z_older_than(10,0,7))
1600 rd_s16b(&p_ptr->riding);
1603 if (z_older_than(10,1,2))
1612 if (z_older_than(10,3,9))
1616 else if (z_older_than(10, 3, 10))
1624 rd_s32b(&p_ptr->visit);
1626 if (!z_older_than(11, 0, 5))
1628 rd_u32b(&p_ptr->count);
1636 * Read the player inventory
1638 * Note that the inventory changed in Angband 2.7.4. Two extra
1639 * pack slots were added and the equipment was rearranged. Note
1640 * that these two features combine when parsing old save-files, in
1641 * which items from the old "aux" slot are "carried", perhaps into
1642 * one of the two new "inventory" slots.
1644 * Note that the inventory is "re-sorted" later by "dungeon()".
1646 static errr rd_inventory(void)
1654 p_ptr->total_weight = 0;
1660 /* Read until done */
1665 /* Get the next item index */
1668 /* Nope, we reached the end */
1669 if (n == 0xFFFF) break;
1671 /* Get local object */
1674 /* Wipe the object */
1680 /* Hack -- verify item */
1681 if (!q_ptr->k_idx) return (53);
1683 /* Wield equipment */
1684 if (n >= INVEN_RARM)
1687 object_copy(&inventory[n], q_ptr);
1689 /* Add the weight */
1690 p_ptr->total_weight += (q_ptr->number * q_ptr->weight);
1696 /* Warning -- backpack is full */
1697 else if (inven_cnt == INVEN_PACK)
1701 note("»ý¤Áʪ¤ÎÃæ¤Î¥¢¥¤¥Æ¥à¤¬Â¿¤¹¤®¤ë¡ª");
1703 note("Too many items in the inventory!");
1711 /* Carry inventory */
1718 object_copy(&inventory[n], q_ptr);
1720 /* Add the weight */
1721 p_ptr->total_weight += (q_ptr->number * q_ptr->weight);
1735 * Read the saved messages
1737 static void rd_messages(void)
1747 /* Read the messages */
1748 for (i = 0; i < num; i++)
1750 /* Read the message */
1751 rd_string(buf, 128);
1753 /* Save the message */
1763 * The monsters/objects must be loaded in the same order
1764 * that they were stored, since the actual indexes matter.
1766 static errr rd_dungeon(void)
1777 /*** Basic info ***/
1780 rd_s16b(&dun_level);
1781 if (z_older_than(10, 3, 8)) dungeon_type = DUNGEON_ANGBAND;
1782 else rd_byte(&dungeon_type);
1784 /* Set the base level for old versions */
1785 base_level = dun_level;
1787 rd_s16b(&base_level);
1789 rd_s16b(&num_repro);
1794 if (z_older_than(10, 3, 13) && !dun_level && !p_ptr->inside_arena) {py = 33;px = 131;}
1797 rd_s16b(&tmp16s); /* max_panel_rows */
1798 rd_s16b(&tmp16s); /* max_panel_cols */
1801 if (!py || !px) {py = 10;px = 10;}/* ¥À¥ó¥¸¥ç¥óÀ¸À®¤Ë¼ºÇÔ¤·¤Æ¥»¥°¥á¥ó¥Æ¤Ã¤¿¤È¤¤ÎÉüµìÍÑ */
1809 /*** Run length decoding ***/
1811 /* Load the dungeon data */
1812 for (x = y = 0; y < ymax; )
1816 if (z_older_than(10,3,6))
1821 /* Apply the RLE info */
1822 for (i = count; i > 0; i--)
1824 /* Access the cave */
1825 c_ptr = &cave[y][x];
1827 /* Extract "info" */
1828 if (z_older_than(10,3,6))
1829 c_ptr->info = tmp8u;
1830 else c_ptr->info = tmp16s;
1839 if (++y >= ymax) break;
1845 /*** Run length decoding ***/
1847 /* Load the dungeon data */
1848 for (x = y = 0; y < ymax; )
1854 /* Apply the RLE info */
1855 for (i = count; i > 0; i--)
1857 /* Access the cave */
1858 c_ptr = &cave[y][x];
1860 if (c_ptr->feat == FEAT_INVIS)
1862 c_ptr->feat = FEAT_FLOOR;
1863 c_ptr->info |= CAVE_TRAP;
1866 /* Extract "feat" */
1867 c_ptr->feat = tmp8u;
1876 if (++y >= ymax) break;
1881 /*** Run length decoding ***/
1883 /* Load the dungeon data */
1884 for (x = y = 0; y < ymax; )
1890 /* Apply the RLE info */
1891 for (i = count; i > 0; i--)
1893 /* Access the cave */
1894 c_ptr = &cave[y][x];
1896 /* Extract "feat" */
1897 c_ptr->mimic = tmp8u;
1906 if (++y >= ymax) break;
1911 /*** Run length decoding ***/
1913 /* Load the dungeon data */
1914 for (x = y = 0; y < ymax; )
1920 /* Apply the RLE info */
1921 for (i = count; i > 0; i--)
1923 /* Access the cave */
1924 c_ptr = &cave[y][x];
1926 /* Extract "feat" */
1927 c_ptr->special = tmp16s;
1936 if (++y >= ymax) break;
1943 /* Read the item count */
1946 /* Verify maximum */
1947 if (limit >= max_o_idx)
1950 note(format("¥¢¥¤¥Æ¥à¤ÎÇÛÎó¤¬Â礤¹¤®¤ë(%d)¡ª", limit));
1952 note(format("Too many (%d) object entries!", limit));
1958 /* Read the dungeon items */
1959 for (i = 1; i < limit; i++)
1966 /* Get a new record */
1973 note(format("¥¢¥¤¥Æ¥àÇÛÃÖ¥¨¥é¡¼ (%d <> %d)", i, o_idx));
1975 note(format("Object allocation error (%d <> %d)", i, o_idx));
1983 o_ptr = &o_list[o_idx];
1989 /* XXX XXX XXX XXX XXX */
1992 if (o_ptr->held_m_idx)
1994 monster_type *m_ptr;
1997 m_ptr = &m_list[o_ptr->held_m_idx];
2000 o_ptr->next_o_idx = m_ptr->hold_o_idx;
2002 /* Place the object */
2003 m_ptr->hold_o_idx = o_idx;
2009 /* Access the item location */
2010 c_ptr = &cave[o_ptr->iy][o_ptr->ix];
2013 o_ptr->next_o_idx = c_ptr->o_idx;
2015 /* Place the object */
2016 c_ptr->o_idx = o_idx;
2023 /* Read the monster count */
2026 /* Hack -- verify */
2027 if (limit >= max_m_idx)
2030 note(format("¥â¥ó¥¹¥¿¡¼¤ÎÇÛÎó¤¬Â礤¹¤®¤ë(%d)¡ª", limit));
2032 note(format("Too many (%d) monster entries!", limit));
2038 /* Read the monsters */
2039 for (i = 1; i < limit; i++)
2043 monster_type *m_ptr;
2045 monster_race *r_ptr;
2048 /* Get a new record */
2055 note(format("¥â¥ó¥¹¥¿¡¼ÇÛÃÖ¥¨¥é¡¼ (%d <> %d)", i, m_idx));
2057 note(format("Monster allocation error (%d <> %d)", i, m_idx));
2064 /* Acquire monster */
2065 m_ptr = &m_list[m_idx];
2067 /* Read the monster */
2072 c_ptr = &cave[m_ptr->fy][m_ptr->fx];
2074 /* Mark the location */
2075 c_ptr->m_idx = m_idx;
2079 r_ptr = &r_info[m_ptr->r_idx];
2081 /* Count XXX XXX XXX */
2087 /* The dungeon is ready */
2088 if (z_older_than(10, 3, 13) && !dun_level && !p_ptr->inside_arena)
2089 character_dungeon = FALSE;
2091 character_dungeon = TRUE;
2100 * Actually read the savefile
2102 static errr rd_savefile_new_aux(void)
2114 #ifdef VERIFY_CHECKSUMS
2115 u32b n_x_check, n_v_check;
2116 u32b o_x_check, o_v_check;
2120 /* Mention the savefile version */
2122 note(format("¥Ð¡¼¥¸¥ç¥ó %d.%d.%d ¤Î¥»¡¼¥Ö¡¦¥Õ¥¡¥¤¥ë¤ò¥í¡¼¥ÉÃæ...",
2124 note(format("Loading a %d.%d.%d savefile...",
2127 (z_major > 9) ? z_major - 10 : z_major, z_minor, z_patch));
2130 /* Strip the version bytes */
2133 /* Hack -- decrypt */
2134 xor_byte = sf_extra;
2137 /* Clear the checksums */
2141 #if SAVEFILE_VERSION
2142 /* Read the version number of the savefile */
2143 rd_u32b(&sf_version);
2144 #endif /* SAVEFILE_VERSION */
2146 /* Operating system info */
2149 /* Time of savefile creation */
2152 /* Number of resurrections */
2155 /* Number of times played */
2159 /* Later use (always zero) */
2162 /* Later use (always zero) */
2166 /* Read RNG state */
2169 if (arg_fiddle) note("Íð¿ô¾ðÊó¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2171 if (arg_fiddle) note("Loaded Randomizer Info");
2176 /* Then the options */
2179 if (arg_fiddle) note("¥ª¥×¥·¥ç¥ó¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2181 if (arg_fiddle) note("Loaded Option Flags");
2185 * Munchkin players are marked
2187 * XXX - should be replaced with a better method,
2188 * after the new scorefile-handling is implemented.
2196 /* Then the "messages" */
2199 if (arg_fiddle) note("¥á¥Ã¥»¡¼¥¸¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2201 if (arg_fiddle) note("Loaded Messages");
2206 for (i = 0; i < max_r_idx; i++)
2208 monster_race *r_ptr;
2209 /* Access that monster */
2212 /* Hack -- Reset the death counter */
2213 r_ptr->max_num = 100;
2214 if (r_ptr->flags1 & RF1_UNIQUE) r_ptr->max_num = 1;
2215 if (r_ptr->flags7 & RF7_UNIQUE_7) r_ptr->max_num = 7;
2218 /* Monster Memory */
2221 /* Incompatible save files */
2222 if (tmp16u > max_r_idx)
2225 note(format("¥â¥ó¥¹¥¿¡¼¤Î¼ï²¤¬Â¿¤¹¤®¤ë(%u)¡ª", tmp16u));
2227 note(format("Too many (%u) monster races!", tmp16u));
2233 /* Read the available records */
2234 for (i = 0; i < tmp16u; i++)
2236 monster_race *r_ptr;
2241 /* Access that monster */
2246 if (arg_fiddle) note("¥â¥ó¥¹¥¿¡¼¤Î»×¤¤½Ð¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2248 if (arg_fiddle) note("Loaded Monster Memory");
2256 /* Incompatible save files */
2257 if (tmp16u > max_k_idx)
2260 note(format("¥¢¥¤¥Æ¥à¤Î¼ïÎब¿¤¹¤®¤ë(%u)¡ª", tmp16u));
2262 note(format("Too many (%u) object kinds!", tmp16u));
2268 /* Read the object memory */
2269 for (i = 0; i < tmp16u; i++)
2272 object_kind *k_ptr = &k_info[i];
2276 k_ptr->aware = (tmp8u & 0x01) ? TRUE: FALSE;
2277 k_ptr->tried = (tmp8u & 0x02) ? TRUE: FALSE;
2280 if (arg_fiddle) note("¥¢¥¤¥Æ¥à¤ÎµÏ¿¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2282 if (arg_fiddle) note("Loaded Object Memory");
2288 * Initialize arena and rewards information
2290 p_ptr->arena_number = 0;
2291 p_ptr->inside_arena = 0;
2292 p_ptr->inside_quest = 0;
2293 p_ptr->leftbldg = FALSE;
2294 p_ptr->exit_bldg = TRUE;
2296 /* Start in town 1 */
2297 p_ptr->town_num = 1;
2299 p_ptr->wilderness_x = 4;
2300 p_ptr->wilderness_y = 4;
2304 /* Init the wilderness seeds */
2305 for (i = 0; i < max_wild_x; i++)
2307 for (j = 0; j < max_wild_y; j++)
2309 wilderness[j][i].seed = randint0(0x10000000);
2313 /* 2.1.3 or newer version */
2315 u16b max_towns_load;
2316 u16b max_quests_load;
2317 byte max_rquests_load;
2318 s16b old_inside_quest = p_ptr->inside_quest;
2320 /* Number of towns */
2321 rd_u16b(&max_towns_load);
2323 /* Incompatible save files */
2324 if (max_towns_load > max_towns)
2327 note(format("Ä®¤¬Â¿¤¹¤®¤ë(%u)¡ª", max_towns_load));
2329 note(format("Too many (%u) towns!", max_towns_load));
2335 /* Number of quests */
2336 rd_u16b(&max_quests_load);
2338 if (z_older_than(11, 0, 7))
2340 max_rquests_load = 10;
2344 rd_byte(&max_rquests_load);
2347 /* Incompatible save files */
2348 if (max_quests_load > max_quests)
2351 note(format("¥¯¥¨¥¹¥È¤¬Â¿¤¹¤®¤ë(%u)¡ª", max_quests_load));
2353 note(format("Too many (%u) quests!", max_quests_load));
2359 for (i = 0; i < max_quests_load; i++)
2363 rd_s16b(&quest[i].status);
2364 rd_s16b(&quest[i].level);
2366 if (z_older_than(11, 0, 6))
2368 quest[i].complev = 0;
2372 rd_byte(&quest[i].complev);
2375 /* Load quest status if quest is running */
2376 if (quest[i].status == QUEST_STATUS_TAKEN || (!z_older_than(10, 3, 14) && (quest[i].status == QUEST_STATUS_COMPLETED)) || (!z_older_than(11, 0, 7) && (i >= MIN_RANDOM_QUEST) && (i <= (MIN_RANDOM_QUEST+max_rquests_load))))
2378 rd_s16b(&quest[i].cur_num);
2379 rd_s16b(&quest[i].max_num);
2380 rd_s16b(&quest[i].type);
2382 /* Load quest monster index */
2383 rd_s16b(&quest[i].r_idx);
2385 if ((quest[i].type == QUEST_TYPE_RANDOM) && (!quest[i].r_idx))
2390 monster_race *r_ptr;
2393 * Random monster 5 - 10 levels out of depth
2394 * (depending on level)
2396 r_idx = get_mon_num(quest[i].level + 5 + randint1(quest[i].level / 10));
2397 r_ptr = &r_info[r_idx];
2399 if(!(r_ptr->flags1 & RF1_UNIQUE)) continue;
2401 if(r_ptr->flags6 & RF6_SPECIAL) continue;
2403 if(r_ptr->flags7 & RF7_FRIENDLY) continue;
2405 if(r_ptr->flags7 & RF7_AQUATIC) continue;
2407 if(r_ptr->flags8 & RF8_WILD_ONLY) continue;
2410 * Accept monsters that are 2 - 6 levels
2411 * out of depth depending on the quest level
2413 if (r_ptr->level > (quest[i].level + (quest[i].level / 20))) break;
2416 quest[i].r_idx = r_idx;
2419 /* Load quest item index */
2420 rd_s16b(&quest[i].k_idx);
2423 a_info[quest[i].k_idx].gen_flags |= TRG_QUESTITEM;
2425 rd_byte(&quest[i].flags);
2427 if (z_older_than(10, 3, 11))
2429 if (quest[i].flags & QUEST_FLAG_PRESET)
2431 quest[i].dungeon = 0;
2435 init_flags = INIT_ASSIGN;
2436 p_ptr->inside_quest = i;
2438 process_dungeon_file("q_info_j.txt", 0, 0, 0, 0);
2439 p_ptr->inside_quest = old_inside_quest;
2444 rd_byte(&quest[i].dungeon);
2447 if (quest[i].status == QUEST_STATUS_TAKEN || quest[i].status == QUEST_STATUS_UNTAKEN)
2448 if (r_info[quest[i].r_idx].flags1 & RF1_UNIQUE)
2449 r_info[quest[i].r_idx].flags1 |= RF1_QUESTOR;
2452 /* Ignore the empty quests from old versions */
2455 /* Ignore quest status */
2458 /* Ignore quest level */
2462 * We don't have to care about the other info,
2463 * since status should be 0 for these quests anyway
2468 /* Position in the wilderness */
2469 rd_s32b(&p_ptr->wilderness_x);
2470 rd_s32b(&p_ptr->wilderness_y);
2471 if (z_older_than(10, 3, 13))
2473 p_ptr->wilderness_x = 5;
2474 p_ptr->wilderness_y = 48;
2477 if (z_older_than(10, 3, 7)) p_ptr->wild_mode = FALSE;
2478 else rd_byte((byte *)&p_ptr->wild_mode);
2479 if (z_older_than(10, 3, 7)) ambush_flag = FALSE;
2480 else rd_byte((byte *)&ambush_flag);
2482 /* Size of the wilderness */
2483 rd_s32b(&wild_x_size);
2484 rd_s32b(&wild_y_size);
2486 /* Incompatible save files */
2487 if ((wild_x_size > max_wild_x) || (wild_y_size > max_wild_y))
2490 note(format("¹ÓÌÂ礤¹¤®¤ë(%u/%u)¡ª", wild_x_size, wild_y_size));
2492 note(format("Wilderness is too big (%u/%u)!", wild_x_size, wild_y_size));
2498 /* Load the wilderness seeds */
2499 for (i = 0; i < wild_x_size; i++)
2501 for (j = 0; j < wild_y_size; j++)
2503 rd_u32b(&wilderness[j][i].seed);
2509 if (arg_fiddle) note("¥¯¥¨¥¹¥È¾ðÊó¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2511 if (arg_fiddle) note("Loaded Quests");
2514 /* Load the Artifacts */
2517 /* Incompatible save files */
2518 if (tmp16u > max_a_idx)
2521 note(format("ÅÁÀâ¤Î¥¢¥¤¥Æ¥à¤¬Â¿¤¹¤®¤ë(%u)¡ª", tmp16u));
2523 note(format("Too many (%u) artifacts!", tmp16u));
2529 /* Read the artifact flags */
2530 for (i = 0; i < tmp16u; i++)
2533 a_info[i].cur_num = tmp8u;
2539 if (arg_fiddle) note("ÅÁÀâ¤Î¥¢¥¤¥Æ¥à¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2541 if (arg_fiddle) note("Loaded Artifacts");
2546 /* Read the extra stuff */
2548 if (p_ptr->energy > 999) world_player = TRUE;
2550 if (arg_fiddle) note("ÆÃÊ̾ðÊó¤ò¥í¡¼¥É¤·¤Þ¤·¤¿");
2552 if (arg_fiddle) note("Loaded extra information");
2556 /* Read the player_hp array */
2559 /* Incompatible save files */
2560 if (tmp16u > PY_MAX_LEVEL)
2563 note(format("¥Ò¥Ã¥È¥Ý¥¤¥ó¥ÈÇÛÎó¤¬Â礤¹¤®¤ë(%u)¡ª", tmp16u));
2565 note(format("Too many (%u) hitpoint entries!", tmp16u));
2571 /* Read the player_hp array */
2572 for (i = 0; i < tmp16u; i++)
2574 rd_s16b(&player_hp[i]);
2577 /* Important -- Initialize the sex */
2578 sp_ptr = &sex_info[p_ptr->psex];
2580 /* Important -- Initialize the race/class */
2581 rp_ptr = &race_info[p_ptr->prace];
2582 cp_ptr = &class_info[p_ptr->pclass];
2583 ap_ptr = &seikaku_info[p_ptr->pseikaku];
2585 if(z_older_than(10, 2, 2) && (p_ptr->pclass == CLASS_BEASTMASTER) && !death)
2587 p_ptr->hitdie = rp_ptr->r_mhp + cp_ptr->c_mhp + ap_ptr->a_mhp;
2588 do_cmd_rerate(FALSE);
2590 if(z_older_than(10, 3, 2) && (p_ptr->pclass == CLASS_ARCHER) && !death)
2592 p_ptr->hitdie = rp_ptr->r_mhp + cp_ptr->c_mhp + ap_ptr->a_mhp;
2593 do_cmd_rerate(FALSE);
2595 if(z_older_than(10, 2, 6) && (p_ptr->pclass == CLASS_SORCERER) && !death)
2597 p_ptr->hitdie = rp_ptr->r_mhp/2 + cp_ptr->c_mhp + ap_ptr->a_mhp;
2598 do_cmd_rerate(FALSE);
2600 if(z_older_than(10, 4, 7) && (p_ptr->pclass == CLASS_BLUE_MAGE) && !death)
2602 p_ptr->hitdie = rp_ptr->r_mhp + cp_ptr->c_mhp + ap_ptr->a_mhp;
2603 do_cmd_rerate(FALSE);
2606 /* Important -- Initialize the magic */
2607 mp_ptr = &m_info[p_ptr->pclass];
2610 /* Read spell info */
2611 rd_u32b(&spell_learned1);
2612 rd_u32b(&spell_learned2);
2613 rd_u32b(&spell_worked1);
2614 rd_u32b(&spell_worked2);
2615 rd_u32b(&spell_forgotten1);
2616 rd_u32b(&spell_forgotten2);
2618 if (z_older_than(10,0,5))
2620 p_ptr->learned_spells = 0;
2621 for (i = 0; i < 64; i++)
2623 /* Count known spells */
2625 (spell_learned1 & (1L << i)) :
2626 (spell_learned2 & (1L << (i - 32))))
2628 p_ptr->learned_spells++;
2632 else rd_s16b(&p_ptr->learned_spells);
2634 if (z_older_than(10,0,6))
2636 p_ptr->add_spells = 0;
2638 else rd_s16b(&p_ptr->add_spells);
2639 if (p_ptr->pclass == CLASS_MINDCRAFTER) p_ptr->add_spells = 0;
2641 for (i = 0; i < 64; i++)
2643 rd_byte(&spell_order[i]);
2647 /* Read the inventory */
2651 note("»ý¤Áʪ¾ðÊó¤òÆɤ߹þ¤à¤³¤È¤¬¤Ç¤¤Þ¤»¤ó");
2653 note("Unable to read inventory");
2659 /* Read number of towns */
2661 town_count = tmp16u;
2663 /* Read the stores */
2665 for (i = 1; i < town_count; i++)
2667 for (j = 0; j < tmp16u; j++)
2669 if (rd_store(i, j)) return (22);
2673 rd_s16b(&p_ptr->pet_follow_distance);
2674 if (z_older_than(10, 4, 10))
2676 p_ptr->pet_extra_flags = 0;
2678 if (tmp8u) p_ptr->pet_extra_flags |= PF_OPEN_DOORS;
2680 if (tmp8u) p_ptr->pet_extra_flags |= PF_PICKUP_ITEMS;
2682 if (z_older_than(10,0,4)) p_ptr->pet_extra_flags |= PF_TELEPORT;
2686 if (tmp8u) p_ptr->pet_extra_flags |= PF_TELEPORT;
2689 if (z_older_than(10,0,7)) p_ptr->pet_extra_flags |= PF_ATTACK_SPELL;
2693 if (tmp8u) p_ptr->pet_extra_flags |= PF_ATTACK_SPELL;
2696 if (z_older_than(10,0,8)) p_ptr->pet_extra_flags |= PF_SUMMON_SPELL;
2700 if (tmp8u) p_ptr->pet_extra_flags |= PF_SUMMON_SPELL;
2703 if (!z_older_than(10,0,8))
2706 if (tmp8u) p_ptr->pet_extra_flags |= PF_BALL_SPELL;
2711 rd_s16b(&p_ptr->pet_extra_flags);
2714 if (!z_older_than(11, 0, 9))
2716 char buf[SCREEN_BUF_SIZE];
2717 rd_string(buf, SCREEN_BUF_SIZE);
2718 if (buf[0]) screen_dump = string_make(buf);
2723 for (i = MIN_RANDOM_QUEST; i < MAX_RANDOM_QUEST + 1; i++)
2725 r_info[quest[i].r_idx].flags1 &= ~(RF1_QUESTOR);
2730 /* I'm not dead yet... */
2733 /* Dead players have no dungeon */
2735 note("¥À¥ó¥¸¥ç¥óÉü¸µÃæ...");
2737 note("Restoring Dungeon...");
2743 note("¥À¥ó¥¸¥ç¥ó¥Ç¡¼¥¿Æɤ߹þ¤ß¼ºÇÔ");
2745 note("Error reading dungeon data");
2751 /* Read the ghost info */
2758 strip_bytes(tmp32s);
2763 #ifdef VERIFY_CHECKSUMS
2765 /* Save the checksum */
2766 n_v_check = v_check;
2768 /* Read the old checksum */
2769 rd_u32b(&o_v_check);
2772 if (o_v_check != n_v_check)
2775 note("¥Á¥§¥Ã¥¯¥µ¥à¤¬¤ª¤«¤·¤¤");
2777 note("Invalid checksum");
2784 /* Save the encoded checksum */
2785 n_x_check = x_check;
2787 /* Read the checksum */
2788 rd_u32b(&o_x_check);
2792 if (o_x_check != n_x_check)
2795 note("¥¨¥ó¥³¡¼¥É¤µ¤ì¤¿¥Á¥§¥Ã¥¯¥µ¥à¤¬¤ª¤«¤·¤¤");
2797 note("Invalid encoded checksum");
2811 * Actually read the savefile
2813 errr rd_savefile_new(void)
2817 /* The savefile is a binary file */
2818 fff = my_fopen(savefile, "rb");
2821 if (!fff) return (-1);
2823 /* Call the sub-function */
2824 err = rd_savefile_new_aux();
2826 /* Check for errors */
2827 if (ferror(fff)) err = -1;
2829 /* Close the file */