OSDN Git Service

[Refactor] #38995 player_base を player_type の base_name へ改名して移動.
[hengband/hengband.git] / src / birth.c
1 /*!
2  * @file birth.c
3  * @brief プレイヤーの作成を行う / Create a player character
4  * @date 2013/12/28
5  * @author
6  * Copyright (c) 1997 Ben Harrison, James E. Wilson, Robert A. Koeneke\n
7  *\n
8  * This software may be copied and distributed for educational, research,\n
9  * and not for profit purposes provided that this copyright and statement\n
10  * are included in all such copies.  Other copyrights may also apply.\n
11  * 2013 Deskull Doxygen向けのコメント整理\n
12  */
13
14 #include "angband.h"
15 #include "util.h"
16 #include "bldg.h"
17 #include "core.h"
18
19 #include "artifact.h"
20 #include "avatar.h"
21 #include "cmd-dump.h"
22 #include "dungeon.h"
23 #include "history.h"
24 #include "monsterrace-hook.h"
25 #include "store.h"
26 #include "patron.h"
27 #include "quest.h"
28 #include "player-class.h"
29 #include "player-status.h"
30 #include "player-personality.h"
31 #include "player-sex.h"
32 #include "spells.h"
33 #include "spells-status.h"
34 #include "wild.h"
35 #include "floor.h"
36 #include "cmd-pet.h"
37 #include "dungeon-file.h"
38 #include "floor-town.h"
39 #include "files.h"
40 #include "birth.h"
41 #include "player-race.h"
42 #include "player-skill.h"
43 #include "world.h"
44 #include "objectkind.h"
45 #include "monsterrace.h"
46 #include "autopick.h"
47 #include "save.h"
48 #include "realm.h"
49 #include "japanese.h"
50
51  /*
52   * The last character rolled,
53   * holded for quick start
54   */
55 birther previous_char;
56
57 /*!
58  * オートローラーの内容を描画する間隔 / 
59  * How often the autoroller will update the display and pause
60  * to check for user interuptions.
61  * Bigger values will make the autoroller faster, but slower
62  * system may have problems because the user can't stop the
63  * autoroller for this number of rolls.
64  */
65 #define AUTOROLLER_STEP 5431L
66
67 #if 0
68 /*!
69  * オートローラを1回まわすごとに1/10秒のウェイトをかけるマクロ定義 / Define this to cut down processor use while autorolling
70  */
71 #define AUTOROLLER_DELAY
72 #endif
73
74 /*!
75  * ランダムクエストのモンスターを確定するために試行する回数 / Maximum number of tries for selection of a proper quest monster
76  */
77 #define MAX_TRIES 100
78
79 /* 選択可能な職業の最大数 */
80 #define MAX_CLASS_CHOICE     MAX_CLASS
81
82
83
84 /*! 種族の解説メッセージテーブル */
85 static concptr race_jouhou[MAX_RACES] =
86 {
87 #ifdef JP
88 "人間は基本となるキャラクタです。他の全ての種族は人間と比較されます。人間はどんな職業に就くこともでき、どの職業でも平均的にこなせます。人間は寿命が短いため、レベル上昇が他のどんな種族よりも早くなる傾向があります。また、特別な修正や特性は持っていません。",
89   
90 "ハーフエルフは人間より賢いですが、強くはありません。彼らは探索, 解除, 魔法防御, 隠密行動, 射撃, そして魔法道具使用でわずかに優れています。しかし武器の取り扱いはそう得意ではありません。ハーフエルフはどの職業に就くこともでき、生まれつきの特性はありません。",
91   
92 "エルフは人間より良い魔法使いになれますが、戦闘は苦手です。彼らは人間やハーフエルフよりも頭が良く、高い賢さを持っています。エルフは探索, 解除, 知覚, 隠密行動, 射撃, そして魔法道具使用で優れていますが、武器の扱いは得意ではありません。彼らは生まれつき光に対する耐性を持っています。",
93   
94 "ホビット、またはハーフリングは弓や投擲に長け、魔法防御も優れています。また、探索, 解除, 知覚, そして隠密行動でもとても良い能力を示します。そのため、彼らは優れた盗賊となることができます(しかし、「忍びの者」と呼ばれることを好みます)。ホビットは人間より遥かに貧弱で、戦士としてはてんでダメです。彼らはかなり良い赤外線視力を持っており、温血動物を離れた場所から見つけることができます。彼らは経験値を保持する力が強く、経験値吸収攻撃に対して耐性を持っています。",
95   
96 "ノームはドワーフより小さいですが、ホビットよりは大きい種族です。彼らはホビット同様地表の洞穴のような家に住んでいます。ノームはとても良い魔法防御を持ち、探索, 解除, 知覚, 隠密行動でも優れています。彼らは人間より低い腕力を持ち、武器を持っての戦闘は苦手です。ノームはかなり良い赤外線視力を持っており、温血動物を離れた場所から見つけることができます。ノームは生まれつき麻痺に対する耐性を持っています。",
97   
98 "ドワーフは頑固な坑夫であり、伝説の戦士です。彼らは人間にくらべ強くタフですが、知能は劣ります。しかし、長命ゆえに彼らは非常に賢いです。彼らは良い魔法防御を持ち、探索, 知覚, 戦闘, 射撃では優れています。彼らは一つ大きな欠点を持っています。ドワーフの隠密行動は絶望的に悪いです。彼らは決して盲目にはなりません。",
99   
100 "ハーフオークはよい戦士になれますが、魔法は期待できません。彼らはドワーフと同じくらい隠密行動が悪く、また探索や解除, 知覚もひどいです。ハーフオークは醜く、店での買い物ではより高い金額を要求されがちです。彼らは地下に住むことを好むため、ハーフオークは暗闇に対する耐性を備えています。",
101   
102 "ハーフトロルは信じられないほど強く、他の大部分の種族より大きなHPを持ちます。彼らは不運にもとても愚かです。彼らの探索, 解除, 知覚, 隠密行動は悪く、その外見はハーフオークがしかめっ面をするほど醜悪です。ハーフトロルは腕力が下がることがありません。レベルが上がると、彼らは再生能力を手にいれ、戦士ならばさらに遅消化能力も獲得します。",
103   
104 "アンバライトは多くのアドバンテージを授けられた、うわさによれば不死の種族です。彼らは知覚, 戦闘, 射撃に優れており、他の面でもかなり熟練しています。事実上あらゆるものを見てきており、新鮮なものはほとんどないため、彼らの成長は他のどの種族より遅いものです。彼らはとてもタフで頑強であり、彼らの耐久力が下がることはありません。また、怪我をすぐに治す再生能力があります。",
105   
106 "ハイエルフは世界の始まりから存在する不死の種族です。彼らは全てのスキルに熟達しており、強く、知的で非常に人気があります - 誰もが彼らのことを好いています。ハイエルフは見えないものを見ることができ、普通のエルフ同様光に対する耐性を持っています。しかし、彼らにとって未知のものはほとんどなく、経験を得ることは大変に困難です。",
107   
108 "野蛮人は北方から来た頑強な種族です。彼らは激しく戦い、彼らの激怒は世界中で恐れられています。戦闘が彼らの人生です。彼らは恐れを知らず、ハーフトロルよりもすぐに狂暴に戦闘に入ってしまうことを学びます。しかし、野蛮人は魔法を疑っており、そのため魔法の道具を使うことはかなり大変なこととなっています。",
109   
110 "ハーフオーガはハーフオークに似ていますが、それだけではありません。彼らは大きく、邪悪で愚かです。戦士としては彼らは必要な資質を全て持っており、また魔法使いになることさえできます。結局、彼らはオーガ・メイジに関係があり、レベルが十分に上がったら彼らから罠のルーンをセットするスキルを学ぶのです。ハーフオークのように、彼らは暗闇に対する耐性を持ち、ハーフトロル同様に腕力が下がることはありません。",
111   
112 "半巨人は大変力強いのですが、呪文を唱えられるほど利口ではありません。彼らはよい戦闘能力を持ちますが、それ以外のことは苦手です。彼らの厚い皮膚は破片に対する耐性を持ちます。また、ハーフオーガやハーフトロル同様腕力を下げられることがありません。",
113   
114 "巨大なタイタンと人間の子孫であり、この強大な生物は他のほぼ全ての種族よりはるかに勝っています。彼らは多種族にみられるような魅力的な特殊能力は持っていませんが、その大変大きなHPはそれを補ってあまりあります。半タイタンはそこそこのスキルを持っていますが、その巨大さゆえに罠の解除やこっそり歩くことは困難です。法と秩序を愛する彼らは、カオスに対する耐性を持っています。",
115   
116 "一つ目ではありますが、サイクロプスは多くの二つの目を持つ生物以上に見ることができます。サイクロプスは非常に力強いのですが、知的であるとはちょっと言えません。彼らに比べれば、ハーフトロルの方がハンサムに見えるということは言うまでもありません。サイクロプスは戦闘, 射撃に優れていますが、その他の大部分のスキルは苦手です。サイクロプスは音に対する耐性を持っています。",
117   
118 "イークは最も哀れな生物の一つであり、並のモンスターであっても不注意なイークならば徹底的に打ちのめせるほど肉体的には強くありませんが、彼らはかなり知的でいくらか賢い生物です。イークは戦闘スキルは苦手ですが、他の分野では優れています。彼らの皮膚は、時間とともに酸への耐性を増していき、レベルが十分に上がれば完全に免疫を持つようになります。",
119   
120 "クラッコンは奇怪な半知的の昆虫型生物です。彼らはすばらしい戦士になれますが、精神的な能力はひどく制限されています。彼らは探索を除けば大部分のスキルをそこそこにこなします。クラッコンは決して混乱させられることがなく、レベルが上がるごとに速くなります。",
121   
122 "コボルドは弱いゴブリンの種族です。彼らは毒を持った武器を好み、毒矢(無制限に供給されます)を投げる能力を身につけることができます。コボルドはそこそこの戦士になれますが、その他のスキルは軒並み悪いです。彼らは生まれつき毒に対する耐性を持っています。",
123   
124 "嫌われ、迫害されてきた小人族です。彼らは大抵のスキルをそつなくこなします。洞穴居住者である彼らは、暗闇に悩まされることはありませんし、生まれつき持っている魔法のアイテムに対する嗜好のため、彼らは装備による魔法のボーナスを奪う効果に耐性を持っています。",
125   
126 "闇の、洞穴に住む種族であるダークエルフは魔法の知識に対する長い伝統を持っています。ダークエルフは魔法の道具をうまく使うことができ、他の多くの種族より簡単に呪文を唱えられるだけの知能を持っています。その鋭い視覚によって、彼らはハイエルフ同様見えないものをみる能力を学びますが、それはある程度レベルが上がったときです。ダークエルフは暗闇に対する耐性を持っています。",
127   
128 "ドラゴンのような特性を持った人間型種族です。彼らはレベルが上がるにつれ、新しい元素への耐性を手にいれます。ドラコニアンは優れた能力値を持ってゲームを開始でき、大抵のスキルをうまくこなせます。その翼で、彼らは簡単に落とし穴や溶岩、水を無傷で飛び越えることができます。",
129   
130 "秘密主義の神秘的な古代種族です。彼らの文明はこの惑星上の何よりも古いかもしれません。その肉体的資質は決して誉められたものではありませんが、彼らの知能と賢さはマインドフレアを他のどんな種族よりも強力な魔法使いにします。マインドフレアの知能と賢さは下がることがなく、レベルが上がれば見えないものをみる能力、テレパシー能力を獲得します。",
131   
132 "地獄からやってきた悪魔的な生物です。彼らは他の種族から毛嫌いされていますが、大抵の職業をかなりうまくこなすことができます。インプは生まれつき火に耐性を持っており、レベルが上がれば見えないものを見る能力を獲得します。",
133   
134 "ゴーレムは泥のような生命のない材料からつくられ、生命を吹き込まれた人工的な生物です。彼らには思考というものがほとんどなく、そのため魔法に依存する職業では役立たずです。しかし戦士としては大変にタフです。彼らは毒に耐性を持ち、見えないものを見ることができ、さらに麻痺知らずです。レベルが上がれば、彼らは生命力吸収攻撃に耐性を持つようになります。ゴーレムは通常の食物からはほとんど栄養を摂取できませんが、代わりに魔法棒や杖から魔力を吸収して動力源にする事ができます。また、その頑丈な身体のため、ACにボーナスを得ることができ、さらに決して気絶させられることがありません。",
135   
136 "スケルトンには2つのタイプが存在します。普通の戦士タイプと、リッチと呼ばれる呪文を使うスケルトンです。アンデッドである彼らは、毒や生命力吸収攻撃を心配する必要はありません。彼らは物体を知覚するのに眼を利用していないため、見えない物に騙されません。彼らの骨はとがった破片のようなものに耐性を持ち、レベルが上がれば冷気に対する耐性を獲得します。薬や食物の持つ効果はスケルトンの胃(存在しませんが)を通過することなくその力を発揮しますが、薬や食物自体は彼の顎を通り抜けて落ちてしまい、栄養を吸収することはできません。その代わりに魔法棒や杖から魔力を吸収してエネルギー源にする事ができます。",
137   
138 "ゾンビはアンデッドであり、生命力吸収攻撃に耐性を持ち、スケルトンのようにレベルが上がれば冷気の耐性を獲得します。また、毒に耐性を持ち見えないものを見ることができます。(スケルトンとは違い)切る攻撃には弱いですが、地獄に対する耐性を持っています。ゴーレムのように、彼らは食物からほとんど栄養を摂取できませんが、代わりに魔法棒や杖から魔力を吸収してエネルギー源にする事ができます。",
139   
140 "強力なアンデッドの一種である吸血鬼は、畏敬の念を呼び起こす外見をしています。アンデッドの例にもれず、彼らも生命力を吸収されることがなく、地獄に対する耐性を持っています。また、冷気と毒に対する耐性も備えています。しかし、新鮮な血液に常に飢えており、それは近くにいる生物から血液を吸うことによってのみ満たされます。この強力な生物は深刻な弱点を持っています。太陽光線(や光源)は彼らの破滅を意味します。幸運にも、吸血鬼はその身体から「暗黒の光」のオーラを放出しています。一方、暗闇は彼らをより強力にするものです。",
141   
142 "幽霊は強力なアンデッドの一種です。彼らは不気味な緑色の光に包まれています。半物質的な存在である彼らは、壁を通り抜けることができますが、そのときには壁の密度によって傷つけられてしまいます。他のアンデッド同様、彼らも生命力を吸収されることがなく、見えないものを見ることができ、毒と冷気に対して耐性を備え、さらに地獄に対する耐性も持っています。レベルが十分に上がると彼らはテレパシーを獲得します。幽霊は卓越した魔法使いになることができますが、その身体的特性は非常に貧弱です。彼らは食物からほとんど栄養を摂取できませんが、代わりに魔法棒や杖から魔力を吸収してエネルギー源にする事ができます。",
143   
144 "妖精は非常に小さいです。彼らは小さな翼を持ち、罠や危険な地形を飛び越えることができます。彼らは日光を大変好み、光に対する耐性を持っています。身体的にはもっとも貧弱な種族の一つですが、妖精は魔法の面で大変な才能を持っており、非常に熟練した魔法使いになることができます。高レベルではより速く飛ぶことができるようになります。",
145   
146 "この種族はカオスによってつくられた冒涜的で嫌悪される存在です。彼らは独立した種族ではなく、人間型種族、大抵は人間がカオスによって歪められた存在、もしくは人間と獣の悪夢のような交配種です。全ての獣人はカオスに盲従しており、そのため混乱と音に対して耐性を備えていますが、純粋なログルスはまだ彼らに対し効果を持っています。獣人は混沌を好み、それは彼らをさらに歪めます。獣人は突然変異を起こしやすい性質を持っています。彼らがつくられたとき、ランダムな変異を受けます。その後、レベルが上がるごとに違う変異を受ける可能性があります。",
147   
148 "エントは非常に強く、賢いですが、その巨大さゆえに罠の解除やこっそりと歩くことは苦手です。成長するにつれて腕力や耐久力が上がりますが、器用さは下がっていきます。彼らには大きな欠点があり、炎によって通常よりも大きなダメージを受けてしまいます。彼らは食物からほとんど栄養を摂取できませんが、代わりに薬等から水分を摂取する事で活動できます。",
149   
150 "天使の上位種であるアルコンは、全てのスキルに熟達しており、強くて賢く、非常に人気があります。彼らは目に見えないものを見ることができ、その翼で罠や危険な地形を飛び越えることができます。しかし、非常に成長が遅いという欠点もあります。",
151   
152 "悪魔の上位種であるバルログは、強く、知的で、またタフでもあります。しかし、彼らは神を信じようとはせず、プリーストには全く向いていません。炎と地獄、経験値吸収への耐性を持っており、レベルが上がれば見えないものを見る能力を獲得します。また、地獄や火炎のブレスを吐くこともできます。彼等はほとんどの技能で優れていますが、静かに歩くことは苦手です。彼らは食物からほとんど栄養を摂取できませんが、人間タイプを生贄にする事で精力を回復する事ができます。",
153   
154 "ドゥナダンは西方から来た屈強な種族です。このいにしえの種族は全ての領域において人間の能力を凌駕し、特に耐久力に関してはそれが顕著です。しかしながらこの種族は全てに卓越していることが災いして、この世界には新しい経験といったものがほとんどなく、レベルを上げることが非常に困難です。彼らはとてもタフで頑強であり、彼らの耐久力が下がることはありません。",
155   
156 "影フェアリーは人間よりやや大きい妖精族で、翼を持ち、罠や危険な地形を飛び越えることができます。しかし、彼らは日光を嫌い、閃光によって通常よりも大きなダメージを受けてしまいます。肉体的には非常に貧弱ですが、魔法の面では優れた能力を持っています。彼らにはすばらしい長所が一つあり、モンスターの反感をかうような強力なアイテムを装備してもモンスターを怒らせることがありません。ただしその場合でも隠密行動能力が下がり、また、自分自身の性格によって反感をかっている場合には効果がありません。",
157   
158 "クターとしている無表情の謎の生物です。彼らは外見がかわいらしいため、魅力が高いです。彼らは混乱しません。なぜなら、混乱してもクターとしているため変わりないからです。しかも、そのクターとしている外見から敵に見つかりにくいです。しかし、彼らは注意力が少ないため探索や知覚能力は悪いです。彼らはレベルが上がると横に伸びてACを上げる技を覚えますが、伸びている間は魔法防御能力は低くなってしまいます。",
159   
160 "アンドロイドは機械の身体を持つ人工的な存在です。魔法をうまく使うことはできませんが、戦士としては非常に優れています。彼らは他の種族のように経験値を得て成長するということはありません。身体に身につける装備によって成長します。ただし、指輪、アミュレット、光源は成長に影響しません。彼らは毒の耐性を持ち、麻痺知らずで、生命力を吸収されることがありません。また、身体が頑丈なのでACにボーナスを得ます。しかし身体のいたるところに電子回路が組み込まれているため、電撃によって通常よりも大きなダメージを受けてしまいます。彼らは食物からほとんど動力を得られませんが、油を補給する事で動力源を得る事ができます。",
161
162 "マーフォーク実装中",
163
164 #else
165
166 "The human is the base character.  All other races are compared to them.  Humans can choose any class and are average at everything.  Humans tend to go up levels faster than most other races because of their shorter life spans.  No racial adjustments or intrinsics occur to characters choosing human.",
167
168 "Half-elves tend to be smarter and faster than humans, but not as strong.  Half-elves are slightly better at searching, disarming, saving throws, stealth, bows, and magic, but they are not as good at hand weapons.  Half-elves may choose any class and do not receive any intrinsic abilities.",
169
170 "Elves are better magicians then humans, but not as good at fighting.  They tend to be smarter and faster than either humans or half-elves and also have better wisdom.  Elves are better at searching, disarming, perception, stealth, bows, and magic, but they are not as good at hand weapons.  They resist light effects intrinsically.",
171
172 "Hobbits, or Halflings, are very good at bows, throwing, and have good saving throws.  They also are very good at searching, disarming, perception, and stealth; so they make excellent rogues, but prefer to be called burglars.  They are much weaker than humans, and no good at melee fighting.  Halflings have fair infravision, so they can detect warm creatures at a distance.  They have a strong hold on their life force, and are thus intrinsically resistant to life draining.",
173
174 "Gnomes are smaller than dwarves but larger than Halflings.  They, like the hobbits, live in the earth in burrow-like homes.  Gnomes make excellent mages, and have very good saving throws.  They are good at searching, disarming, perception, and stealth.  They have lower strength than humans so they are not very good at fighting with hand weapons.  Gnomes have fair infra-vision, so they can detect warm-blooded creatures at a distance.  Gnomes are intrinsically protected against paralysis.",
175
176 "Dwarves are the headstrong miners and fighters of legend.  Dwarves tend to be stronger and tougher but slower and less intelligent than humans.  Because they are so headstrong and are somewhat wise, they resist spells which are cast on them.  They are very good at searching, perception, fighting, and bows.  Dwarves  have a miserable stealth.  They can never be blinded.",
177
178 "Half-orcs make excellent warriors, but are terrible at magic.  They are as bad as dwarves at stealth, and horrible at searching, disarming, and perception.  Half-orcs are quite ugly, and tend to pay more for goods in town.  Because of their preference to living underground to on the surface, half-orcs resist darkness attacks.",
179
180 "Half-Trolls are incredibly strong, and have more hit points than most other races.  They are also very stupid and slow.  They are bad at searching, disarming, perception, and stealth.  They are so ugly that a Half-Orc grimaces in their presence.  They also happen to be fun to run...  Half-trolls always have their strength sustained.  At higher levels, Half-Trolls regenerate wounds automatically, and if he or her is warrior slowly.",
181
182 "The Amberites are a reputedly immortal race, who are endowed with numerous advantages in addition to their longevity.  They are very tough and their constitution cannot be reduced, and their ability to heal wounds far surpasses that of any other race.  Having seen virtually everything, very little is new to them, and they gain levels much slower than the other races.",
183
184 "High-elves are a race of immortal beings dating from the beginning of time.  They are masters of all skills, and are strong and intelligent, although their wisdom is sometimes suspect.  High-elves begin their lives able to see the unseen, and resist light effects just like regular elves.  However, there are few things that they have not seen already, and experience is very hard for them to gain.",
185
186 "Barbarians are hardy men of the north.  They are fierce in combat, and their wrath is feared throughout the world.  Combat is their life: they feel no fear, and they learn to enter battle frenzy at will even sooner than half-trolls.  Barbarians are, however, suspicious of magic, which makes magic devices fairly hard for them to use. ",
187
188 "Half-Ogres are like Half-Orcs, only more so.  They are big, bad, and stupid.  For warriors, they have all the necessary attributes, and they can even become wizards: after all, they are related to Ogre Magi, from whom they have learned the skill of setting trapped runes once their level is high enough.  Like Half-Orcs, they resist darkness, and like Half-Trolls, they have their strength sustained.",
189
190 "Half-Giants limited intelligence makes it difficult for them to become full spellcasters, but with their huge strength they make excellent warriors.  Their thick skin makes them resistant to shards, and like Half-Ogres and Half-Trolls, they have their strength sustained.",
191
192 "Half-mortal descendants of the mighty titans, these immensely powerful creatures put almost any other race to shame.  They may lack the fascinating special powers of certain other races, but their enhanced attributes more than make up for that.  They learn to estimate the strengths of their foes, and their love for law and order makes them resistant to the effects of Chaos.",
193
194 "With but one eye, a Cyclops can see more than many with two eyes.  They are headstrong, and loud noises bother them very little.  They are not quite qualified for the magic using professions, but as a certain Mr.  Ulysses can testify, their accuracy with thrown rocks can be deadly...",
195
196 "Yeeks are among the most pathetic creatures.  Fortunately, their horrible screams can scare away less confident foes, and their skin becomes more and more resistant to acid, as they gain experience.  But having said that, even a mediocre monster can wipe the proverbial floor with an unwary Yeek.",
197
198 "Klackons are bizarre semi-intelligent ant-like insectoid creatures.  They make great fighters, but their mental abilities are severely limited.  Obedient and well-ordered, they can never be confused.  They are also very nimble, and become faster as they advance levels.  They are also very acidic, inherently resisting acid, and capable of spitting acid at higher levels. ",
199
200 "Kobolds are a weak goblin race.  They love poisoned weapons, and can learn to throw poisoned darts (of which they carry an unlimited supply).  They are also inherently resistant to poison, although they are not one of the more powerful races.",
201
202 "The hated and persecuted race of nocturnal dwarves, these cavedwellers are not much bothered by darkness.  Their natural inclination to magical items has made them immune to effects which could drain away magical energy.",
203
204 "Another dark, cavedwelling race, likewise unhampered by darkness attacks, the Dark Elves have a long tradition and knowledge of magic.  They have an inherent magic missile attack available to them at a low level.  With their keen sight, they also learn to see invisible things as their relatives High-Elves do, but at a higher level.",
205
206 "A humanoid race with dragon-like attributes.  As they advance levels, they gain new elemental resistances (up to Poison Resistance), and they also have a breath weapon, which becomes more powerful with experience.  The exact type of the breath weapon depends on the Draconian's class and level.  With their wings, they can easily escape any pit trap unharmed.",
207
208 "A secretive and mysterious ancient race.  Their civilization may well be older than any other on our planet, and their intelligence and wisdom are naturally sustained, and are so great that they enable Mind Flayers to become more powerful spellcasters than any other race, even if their physical attributes are a good deal less admirable.  As they advance levels, they gain the powers of See Invisible and Telepathy.",
209
210 "A demon-creature from the nether-world, naturally resistant to fire attacks, and capable of learning fire bolt and fire ball attacks.  They are little loved by other races, but can perform fairly well in most professions.  As they advance levels, they gain the powers of See Invisible.",
211
212 "A Golem is an artificial creature, built from a lifeless raw material like clay, and awakened to life.  They are nearly mindless, making them useless for professions which rely on magic, but as warriors they are very tough.  They are resistant to poison, they can see invisible things, and move freely.  At higher levels, they also become resistant to attacks which threaten to drain away their experience.  Golems gain very little nutrition from ordinary food, but can absorb mana from staves and wands as their power source.  Golems also gain a natural armor class bonus from their tough body.",
213
214 "There are two types of skeletons: the ordinary, warrior-like skeletons, and the spell-using skeletons, which are also called liches.  As undead beings, skeletons need to worry very little about poison or attacks that can drain life.  They do not really use eyes for perceiving things, and are thus not fooled by invisibility.  Their bones are resistant to sharp shrapnel, and they will quickly become resistant to cold.  Although the magical effects of these will affect the skeleton even without entering the skeleton's (non-existent) belly, the potion or food itself will fall through the skeleton's jaws, giving no nutritional benefit.  They can absorb mana from staves and wands as their energy source.",
215
216 "Much like Skeletons, Zombies too are undead horrors: they are resistant to exp-draining attacks, and can learn to restore their experience.  Like skeletons, they become resistant to cold-based attacks (actually earlier than skeletons), resist poison and can see invisible.  While still vulnerable to cuts (unlike skeletons), Zombies are resistant to Nether.  Like Golems, they gain very little nutrition from the food of mortals, but can absorb mana from staves and wands as their energy source.",
217
218 "One of the mightier undead creatures, the Vampire is an awe-inspiring sight.  Yet this dread creature has a serious weakness: the bright rays of sun are its bane, and it will need to flee the surface to the deep recesses of earth until the sun finally sets.  Darkness, on the other hand, only makes the Vampire stronger.  As undead, the Vampire has a firm hold on its experience, and resists nether attacks.  The Vampire also resists cold and poison based attacks.  It is, however, susceptible to its perpetual hunger for fresh blood, which can only be satiated by sucking the blood from a nearby monster.",
219
220 "Another powerful undead creature: the Spectre is a ghastly apparition, surrounded by an unearthly green glow.  They exist only partially on our plane of existence: half-corporeal, they can pass through walls, although the density of the wall will hurt them in the process of doing this.  As undead, they have a firm hold on their experience, see invisible, and resist poison and cold.  They also resist nether.  At higher levels they develop telepathic abilities.  Spectres make superb spellcasters, but their physical form is very weak.  They gain very little nutrition from the food of mortals, but can absorb mana from staves and wands as their energy source.",
221
222 "One of the several fairy races, Sprites are very small.  They have tiny wings and can fly over traps that may open up beneath them.  They enjoy sunlight intensely, and need worry little about light based attacks.  Although physically among the weakest races, Sprites are very talented in magic, and can become highly skilled wizards.  Sprites have the special power of spraying Sleeping Dust, and at higher levels they learn to fly faster.",
223
224 "This race is a blasphemous abomination produced by Chaos.  It is not an independent race but rather a humanoid creature, most often a human, twisted by the Chaos, or a nightmarish crossbreed of a human and a beast.  All Beastmen are accustomed to Chaos so much that they are untroubled by confusion and sound, although raw logrus can still have effects on them.  Beastmen revel in chaos, as it twists them more and more.  Beastmen are subject to mutations: when they have been created, they receive a random mutation.  After that, every time they advance a level they have a small chance of gaining yet another mutation.",
225
226 "The Ents are a powerful race dating from the beginning of the world, oldest of all animals or plants who inhabit Arda.  Spirits of the land, they were summoned to guard the forests of Middle-earth.  Being much like trees they are very clumsy but strong, and very susceptible to fire.  They gain very little nutrition from the food of mortals, but they can absorb water from potions as their nutrition.",
227
228 "Archons are a higher class of angels.  They are good at all skills, and are strong, wise, and are a favorite with any people.  They are able to see the unseen, and their wings allow them to safely fly over traps and other dangerous places.  However, belonging to a higher plane as they do, the experiences of this world do not leave a strong impression on them and they gain levels slowly.",
229
230 "Balrogs are a higher class of demons.  They are strong, intelligent and tough.  They do not believe in gods, and are not suitable for priest at all.  Balrog are resistant to fire and nether, and have a firm hold on their experience.  They also eventually learn to see invisible things.  They are good at almost all skills except stealth.  They gain very little nutrition from the food of mortals, and need human corpses as sacrifices to regain their vitality.",
231
232 "Dunedain are a race of hardy men from the West.  This elder race surpasses human abilities in every field, especially constitution.  However, being men of the world, very little is new to them, and levels are very hard for them to gain.  Their constitution cannot be reduced. ",
233
234 "Shadow Fairies are one of the several fairy races.  They have wings, and can fly over traps that may open up beneath them.  Shadow Fairies must beware of sunlight, as they are vulnerable to bright light.  They are physically weak, but have advantages in using magic and are amazingly stealthy.  Shadow Fairies have a wonderful advantage in that they never aggravate monsters (If their equipment normally aggravates monsters, they only suffer a penalty to stealth, but if they aggravate by their personality itself, the advantage will be lost).",
235
236 "A Kutar is an expressionless animal-like living creature.  The word 'kuta' means 'absentmindedly' or 'vacantly'.  Their absentmindedness hurts their searching and perception skills, but renders them incapable of being confused.  Their unearthly calmness and serenity make them among the most stealthy of any race.  Kutars, although expressionless, are beautiful and so have a high charisma.  Members of this race can learn to expand their body horizontally.  This increases armour class, but renders them vulnerable to magical attacks.",
237
238 "An android is a artificial creation with a body of machinery.  They are poor at spell casting, but they make excellent warriors.  They don't acquire experience like other races, but rather gain in power as they attach new equipment to their frame.  Rings, amulets, and lights do not influence growth.  Androids are resistant to poison, can move freely, and are immune to exp-draining attacks.  Moreover, because of their hard metallic bodies, they get a bonus to AC.  Androids have electronic circuits throughout their body and must beware of electric shocks.  They gain very little nutrition from the food of mortals, but they can use flasks of oil as their energy source."
239
240 "Merfolk implementing.",
241
242 #endif
243 };
244
245 /*! 職業の解説メッセージテーブル */
246 static concptr class_jouhou[MAX_CLASS] =
247 {
248 #ifdef JP
249 "戦士は、直面する問題のほとんどを細切れに叩き切ることで解決するキャラクタです。が、時折退却して魔法の道具の世話になることもあります。不運にも、高レベルなアイテムの多くは彼らが扱える範囲を越えています。",
250   
251 "メイジは魔法使いであり、その機知によって生き延びなければなりません。戦士のように、単純に切りまくることで道を開くことは望めません。呪文書に加えて、メイジは助けになる魔法の道具を持ち運ぶべきです。これは他の何よりも遥かに簡単にマスターできます。魔法に必要な能力値は知能です。",
252   
253 "プリーストは高貴な力を使うことに専念したキャラクタです。彼らは自身の神のためにダンジョンを探索し、もし宝を手にいれたなら、それは彼が信仰する宗教の栄光となります。プリーストは新しい祈りを神からの贈り物という形で受け取るため、どれを学ぶのか自分で選ぶことはできません。プリーストは魔法の道具の使い方をよく知っていますが、メイジほどうまくは使えません。刃のついた武器より鈍器を好み、祝福されていない刃のついた武器を装備すると不愉快な感覚に襲われ、戦闘能力が落ちてしまいます。魔法に必要な能力値は賢さです。",
254   
255 "盗賊はその狡猾さで生き抜くことを好むキャラクタですが、肝心なときには戦闘で道を切り開くことができます、盗賊は罠やドアを見つける能力に優れ、罠の解除や鍵開けに熟達しています。盗賊は高い隠密行動を持ち、たくさんのモンスターの群れのそばを起こすことなく通り抜けたり、忍び寄って先制攻撃することができます。魔法に必要な能力値は知能です。",
256   
257 "レンジャーは戦士とメイジを合わせたような職業で、身の回りの自然と特別な関係を作り上げています。彼はより戦士であり、弓のような遠距離武器を巧く使える職業です。レンジャーはよい隠密行動、よい知覚、よい探索、よい魔法防御を持ち、魔法の道具の使用にも長けています。魔法に必要な能力値は知能です。",
258   
259 "パラディンは戦士とプリーストを合わせた職業です。パラディンはとてもよい戦士ですが、遠距離武器を扱うのは得意ではありません。パラディンには多くの能力が欠けています。隠密行動, 知覚, 探索, そして魔法道具使用が苦手ですが、その神との提携によって魔法防御はそこそこです。魔法に必要な能力値は賢さです。",
260   
261 "魔法戦士はその名称が意味する通りの職業であり、戦士とメイジの資質をあわせ持ちます。彼らの同業者であるレンジャーが自然の魔法と生き抜くためのスキルに特化している一方、本当の魔法剣士はどちらの世界でも一番になろうとしています。戦士としては普通のメイジとは比べ物にならないほど優れています。しかし、実際には魔法でも戦闘でも専門の職業には及ばず、戦士とメイジの中間に位置するような職業です。魔法に必要な能力値は知能です。",
262   
263 "混沌の戦士は恐るべきカオスの魔王の使いとして恐れられる存在です。混沌の戦士はパトロンとなる悪魔を持ち、レベルが上がる度に報酬を得ることがあります。彼は治療してくれたり、こちらを変化させたり、能力値を上げてくれるかもしれませんし、回りに怪物達を出現させたり、能力値や装備を奪うかも知れません。もしくは単にこちらを無視するだけかもしれません。カオスの魔王は無秩序で予測のつかない存在です。報酬の種類はパトロンとなる悪魔と偶然に依存します(違う悪魔は異なる報酬を与えます)。魔法に必要な能力値は知能です。",
264   
265 "修行僧は他の職業とは著しく異なる職業です。彼らは他の職業同様武器と防具を使えますが、マーシャルアーツの訓練を積んでいるため、武器、防具なしでより強力な存在となります。高レベルでは、必要な耐性を身につけるためある種の防具を装備する必要がありますが、もしあまりに重すぎる防具を装備してしまうと、その体術に深刻な妨げとなります。レベルが上がると、彼らは新しい強力な攻撃法を学び、防御能力も上昇します。魔法に必要な能力値は賢さです。",
266   
267 "超能力者は魔法のかわりにその精神の力を使う唯一の職業です。この力は超能力者独特のもので、単に超感覚的なものから他人の精神を支配するものまで様々です。彼らの力はある種の訓練によって開発されるものなので、超能力者は力を使うのに呪文書を必要としません。使える力は単純にキャラクタのレベルによって決まります。超能力に必要な能力値は賢さです。",
268   
269 "ハイメイジは一つの領域に特化し、その領域を通常のメイジよりはるかに深く学んだメイジです。1つの領域に特化したおかげで、彼らは自らが選択した領域の呪文を唱える際の消費MP、最低レベル、失敗率で相当な恩恵を受けます。しかし、生命の領域ではプリーストほどうまくはなれないことには注意すべきです。魔法に必要な能力値は知能です。",
270   
271 "観光客は観光のためにこの世界にやってきました。戦闘力が低く、強力な呪文を使うこともできないため、最も生きぬいていくのが厳しい職業と言えます。魔法に必要な能力値は知能です。",
272   
273 "ものまね師は戦闘力はそこそこありますが、自分から特殊な能力を使うことは全くできません。しかし、自分の目の前にいる相手が特殊能力を使った場合、その能力と全く同じ能力をそっくりそのまま使うことができます。ものまねに必要な能力は基本的に器用さですが、まねる特殊能力に関係ある他の能力も必要です。",
274   
275 "魔獣使いは変愚蛮怒世界のダンジョンに住む生物と心を通い合わせられます。彼らは最もうまくモンスターを乗りこなすことができ、召喚したり手なづけたりしたモンスターを自分の手足のように使います。魔法に必要な能力は魅力です。",
276   
277 "スペルマスターは全ての魔法を極める者です。彼らは全分野において非常に優れた魔法使いであり、あらゆる魔法書のすべての呪文を学習の手間なく使いこなすことができます。その反面、彼らは戦士としては最低で、どんな武器も満足に扱えません。魔術師の杖だけは例外ですが、武器としては使い物にならないでしょう。すべての魔法をうまく生かさなければならないため、非常に上級者向けな職業と言えます。魔法に必要な能力は知能です。",
278   
279 "アーチャーは魔法を使うことはできませんが、どんな職業よりも巧みに弓やスリングを使いこなします。大量の矢や弾を必要とするのは確かですが、岩石からスリング用の弾を作ったり、レベルが上がるとモンスターの骨やがらくたから矢を作ったりする技術を身につけます。また、戦士と比べて隠密行動、知覚、探索、魔法道具の使用などにも優れており、いざというときには魔法の道具に頼ることもできます。",
280   
281 "魔道具術師は杖、魔法棒、ロッドといった魔法のアイテムから魔力を取り込むことによって魔法を使います。魔法のアイテムを発見することが他の職業よりもはるかに重要になります。戦闘力は高くはないですが、そこそこの強さがあります。魔法に必要な能力は知能です。",
282   
283 "吟遊詩人は魔力を帯びた歌を歌うことができます。多くの歌は普通の魔法と異なり、歌を歌っている間継続して効果を発揮します。しかし、同時に2つの歌を歌うことができない、という欠点もあります。視界内全体に影響を及ぼす歌が多い、という特徴もあります。肉体的な能力は貧弱で、単純に切りまくることで道を開くことはできません。魔法に必要な能力は魅力です。",
284   
285 "赤魔道師は下級魔法のほとんどを使うことができ、戦闘力も十分にあります。レベルが上がると強力な能力「連続魔」を身につけることができます。しかし、魔法を覚えるスピードは遅く、上級魔法を使えないので、メイジほどには魔法を頼りにすることができません。魔法道具使用と魔法防御はそこそこですが、それ以外の技能は苦手です。魔法に必要な能力は知能です。",
286   
287 "剣術家は戦士に次ぐ戦闘力があり、様々な技を使うことができます。彼らのMPはレベルに依存せず、賢さだけで決まり、気合いをためることにより、最大値を越えてMPを増やすことができます。しかし、戦士と同様、高レベルの魔法のアイテムは彼らの扱える範囲を越えており、罠の解除や探索の能力も高いとはいえません。必殺技の使用に必要な能力は賢さです。",
288   
289 "練気術師は「気」を使う達人です。修行僧と同様、武器や防具を持たずに戦うことを好み、武器・防具なしでより強力な存在となります。修行僧ほどの戦闘能力はありませんが、修行僧と同様の魔法が使え、さらに「気」の力を操ります。武器を持つことや、重すぎる防具を装備することは、「気」の力の使用を妨げます。魔法と練気術に必要な能力は賢さです。",
290   
291 "青魔道師は優れた魔法使いであり、その機知によって生き延びなければなりません。メイジ等の他の魔法使いとの違いは魔法の覚え方で、青魔道師はモンスターの魔法の効果を受けることでその魔法を覚えます。覚えるためには「ラーニング」の状態になっていないといけません。魔法に必要な能力は知能です。",
292   
293 "騎兵は馬に乗り戦場を駆け抜けるエリート戦士です。魔法は使えませんが、馬上からの圧倒的な攻撃力を誇る上に、高い機動力を生かした射撃をも得意としています。レベルが上がれば、野生のモンスターにまたがり無理矢理手なずけることができます。彼らは己の肉体と精神に誇りを持ち、魔法道具にはあまり頼ろうとはしません。",
294   
295 "狂戦士は怒り狂って武器を振るう恐るべき戦士です。全職業中最高の肉体能力を誇り、恐怖と麻痺に対する耐性を持ち、レベルが上がればその強靭な肉体で矢の呪文を跳ね返すことができます。さらに武器なしで戦うことや、呪いのかけられた装備を力づくで剥がすことができ、いくつかの技を(反魔法状態でも)使うことができます。しかし、巻物や魔法道具は全く使うことができず、罠の解除や隠密行動、探索、魔法防御、飛び道具の技能に関しては絶望的です。ひたすら殴って道を開くしかありません。幽霊は非常に勝利しやすいですがスコアがかなり低く修正されます。",
296
297 "鍛冶師は武器や防具を自分で強化することができます。特殊効果を持つ武器や防具から特殊効果の元となるエッセンスを取り出し、別の武器や防具にエッセンスを付加することによってその特殊効果を付加できます。ある程度の戦闘能力も持ちますが、魔法は一切使用できず、隠密や魔法防御の技能も低くなります。",
298
299 "鏡使いは、魔力の込められた鏡を作り出して、それを触媒として攻撃を行なうことができる鏡魔法を使います。鏡使いは鏡の上で実力を発揮し、鏡の上では素早いテレポートが可能となります。魔法の鏡は、レベルによって一度に制御できる数が制限されます。鏡魔法に必要な能力は知能です。",
300
301 "忍者は暗闇に潜む恐るべき暗殺者であり、光源を持たずに行動し、相手の不意をつき一撃で息の根を止めます。また、相手を惑わすための忍術も身につけます。罠やドアを見つける能力に優れ、罠の解除や鍵開けに熟達しています。軽装を好み、重い鎧や武器を装備すると著しく動きが制限され、また、盾を装備しようとはしません。軽装ならば、レベルが上がるにつれより速くより静かに行動できます。さらに忍者は恐怖せず、成長すれば毒がほとんど効かなくなり、透明なものを見ることができるようになります。忍術に必要な能力は器用さです。",
302
303 "スナイパーは一撃必殺を狙う恐るべき射手です。精神を高めることにより、射撃の威力と精度を高めます。また、魔法を使うことはできませんが、研ぎ澄まされた精神から繰り出される射撃術はさらなる威力をもたらすことでしょう。テクニックが必要とされる職業です。"
304
305 #else
306
307 "A Warrior is a hack-and-slash character, who solves most of his problems by cutting them to pieces, but will occasionally fall back on the help of a magical device.  Unfortunately, many high-level devices may be forever beyond their use.",
308
309 "A Mage is a spell caster that must live by his wits as he cannot hope to simply hack his way through the dungeon like a warrior.  In addition to his spellbooks, a mage should carry a range of magical devices to help him in his endeavors which he can master far more easily than anyone else.  A mage's prime statistic is Intelligence as this determines his spell casting ability. ",
310
311 "A Priest is a character devoted to serving a higher power.  They explore the dungeon in the service of their God.  Since Priests receive new prayers as gifts from their patron deity, they cannot choose which ones they will learn.  Priests are familiar with magical devices which they believe act as foci for divine intervention in the natural order of things.  A priest wielding an edged weapon will be so uncomfortable with it that his fighting ability.  A Priest's primary stat is Wisdom since this determine his success at praying to his deity. ",
312
313 "A Rogue is a character that prefers to live by his cunning, but is capable of fighting his way out of a tight spot.  Rogues are good at locating hidden traps and doors and are the masters of disarming traps and picking locks.  A rogue has a high stealth allowing him to sneak around many creatures without having to fight, or to get in a telling first blow.  A rogue may also backstab a fleeing monster.  Intelligence determines a Rogue's spell casting ability.",
314
315 "A Ranger is a combination of a warrior and a mage who has developed a special affinity for the natural world around him.  He is a good fighter and also good about a missile weapon such as a bow.  A ranger has a good stealth, good perception, good searching, a good saving throw and is good with magical devices.  Intelligence determines a Ranger's spell casting ability.",
316
317 "A Paladin is a combination of a warrior and a priest.  Paladins are very good fighters, but not very good at missile weapons.  A paladin lacks much in the way of abilities.  He is poor at stealth, perception, searching, and magical devices but has a decent saving throw due to his divine alliance.  Wisdom determines a Paladin's success at praying to his deity.",
318
319 "A Warrior-Mage is precisely what the name suggests: a cross between the warrior and mage classes.  While their brothers, the rangers, specialize in Nature magic and survival skills, true Warrior-Mages attempt to reach the best of both worlds.  As warriors they are much superior to the usual Mage class.  Intelligence determines a Warrior-Mage's spell casting ability.",
320
321 "Chaos Warriors are the feared servants of the terrible Demon Lords of Chaos.  Every Chaos Warrior has a Patron Demon and, when gaining a level, may receive a reward from his Patron.  He might be healed or polymorphed, his stats could be increased, or he might be rewarded with an awesome weapon.  On the other hand, the Patrons might surround him with monsters, drain his stats or wreck his equipment or they might simply ignore him.  The Demon Lords of Chaos are chaotic and unpredictable indeed.  The exact type of reward depends on both the Patron Demon (different Demons give different rewards) and chance.",
322
323 "The Monk character class is very different from all other classes.  Their training in martial arts makes them much more powerful with no armor or weapons.  To gain the resistances necessary for survival a monk may need to wear some kind of armor, but if the armor he wears is too heavy, it will severely disturb his martial arts maneuvers.  As the monk advances levels, new, powerful forms of attack become available.  Their defensive capabilities increase likewise, but if armour is being worn, this effect decreases.  Wisdom determines a Monk's spell casting ability.",
324
325 "The Mindcrafter is a unique class that uses the powers of the mind instead of magic.  These powers are unique to Mindcrafters, and vary from simple extrasensory powers to mental domination of others.  Since these powers are developed by the practice of certain disciplines, a Mindcrafter requires no spellbooks to use them.  The available powers are simply determined by the character's level.  Wisdom determines a Mindcrafter's ability to use mind powers.",
326
327 "High-mages are mages who specialize in one particular field of magic and learn it very well - much better than the ordinary mage.  For the price of giving up a second realm of magic, they gain substantial benefits in the mana costs, minimum levels, and failure rates in the spells of the realm of their specialty.  A high mage's prime statistic is intelligence as this determines his spell casting ability. ",
328
329 "Tourists have visited this world for the purpose of sightseeing.  Their fighting skills is bad, and they cannot cast powerful spells.  They are the most difficult class to win the game with.  Intelligence determines a tourist's spell casting ability.",
330
331 "Imitators have enough fighting skills to survive, but rely on their ability to imitate monster spells.  When monsters in line of sight use spells, they are added to a temporary spell list which the imitator can choose among.  Spells should be imitated quickly, because timing and situation are everything.  An imitator can only repeat a spell once each time he observes it.  Dexterity determines general imitation ability, but a stat related to the specific action is often also taken into account.",
332
333 "Beastmasters are in tune with the minds of the creatures of the world of Hengband.  They are very good at riding, and have enough fighting ability.  They use monsters which summoned or dominated by him as his hands and feet.  Beastmasters can cast trump magic, and very good at summoning spell, but they can not summon non-living creatures.  Charisma determines a Beastmaster's spell casting ability.",
334
335 "Sorcerers are the all-around best magicians, being able to cast any spell from most magic realms without having to learn it.  On the downside, they are the worst fighters in the dungeon, being unable to use any weapon but a Wizardstaff.",
336
337 "Archers are to bows what warriors are to melee.  They are the best class around with any bow, crossbow, or sling.  They need a lot of ammunition, but will learn how to make it from junk found in the dungeon.  An archer is better than a warrior at stealth, perception, searching and magical devices.",
338
339 "Magic-Eaters can absorb the energy of wands, staffs, and rods, and can then use these magics as if they were carrying all of these absorbed devices.  They are middling-poor at fighting.  A Magic-Eater's prime statistic is intelligence.",
340
341 "Bards are something like traditional musicians.  Their magical attacks are sound-based, and last as long as the Bard has mana.  Although a bard cannot sing two or more songs at the same time, he or she does have the advantage that many songs affect all areas in sight.  A bard's prime statistic is charisma.",
342
343 "Red-Mages can use almost all spells from lower rank spellbooks of most realms without having to learn it.  At higher level, they develop the powerful ability \"Double Magic\".  However, they have large penalties in the mana costs, minimum levels, and failure rates of spells, and they cannot use any spells from higher rank spellbooks.  They are not bad at using magical devices and magic resistance, and are decent fighter, but are bad at other skills.  A red-mage's prime statistic is intelligence.",
344
345 "Samurai, masters of the art of the blade, are the next strongest fighters after Warriors.  Their spellpoints do not depend on level, but depend solely on wisdom, and they can use the technique Concentration to temporarily increase SP beyond its usual maximum value.  Samurai are not good at most other skills, and many magical devices may be too difficult for them to use.  Wisdom determines a Samurai's ability to use the special combat techniques available to him.",
346
347 "A ForceTrainer is a master of the spiritual Force.  They prefer fighting with neither weapon nor armor.  They are not as good fighters as are Monks, but they can use both magic and the spiritual Force.  Wielding weapons or wearing heavy armor disturbs use of the Force.  Wisdom is a ForceTrainer's primary stat.",
348
349 "A Blue-Mage is a spell caster that must live by his wits, as he cannot hope to simply hack his way through the dungeon like a warrior.  A major difference between the Mage and the Blue-Mage is the method of learning spells: Blue-Mages may learn spells from monsters by activating his Learning ability.  A Blue-Mage's prime statistic is Intelligence as this determines his spell casting ability. ",
350
351 "Cavalry ride on horses into battle.  Although they cannot cast spells, they are proud of their overwhelming offensive strength on horseback.  They are good at shooting.  At high levels, they learn to forcibly saddle and tame wild monsters.  Since they take pride in the body and the soul, they don't use magical devices well.",
352
353 "A Berserker is a fearful fighter indeed, immune to fear and paralysis.  At high levels, Berserkers can reflect bolt spells with their tough flesh.  Furthermore, they can fight without weapons, can remove cursed equipment by force, and can even use their special combat techniques when surrounded by an anti-magic barrier.  Berserkers, however, cannot use any magical devices or read any scrolls, and are hopeless at all non-combat skills.  Since Berserker Spectres are quite easy to *win* with, their scores are lowered.",
354
355 "A Weaponsmith can improve weapons and armors for him or herself.  They can extract the essences of special effects from weapons or armors which have various special abilities, and can add these essences to another weapon or armor.  They are good at fighting, but cannot cast spells, and are poor at skills such as stealth or magic defense.",
356
357 "Mirror-Masters are spell casters; like other mages, they must live by their wits.  They can create magical mirrors, and employ them in the casting of Mirror-Magic spells.  A Mirror-Master standing on a mirror has greater ability and, for example, can perform quick teleports.  The maximum number of Magical Mirrors which can be controlled simultaneously depends on the level.  Intelligence determines a Mirror-Master's spell casting ability.",
358
359 "A Ninja is a fearful assassin lurking in darkness.  He or she can navigate effectively with no light source, catch enemies unawares, and kill with a single blow.  Ninjas can use Ninjutsu, and are good at locating hidden traps and doors, disarming traps and picking locks.  Since heavy armors, heavy weapons, or shields will restrict their motion greatly, they prefer light clothes, and become faster and more stealthy as they gain levels.  A Ninja knows no fear and, at high level, becomes almost immune to poison and able to see invisible things.  Dexterity determines a Ninja's ability to use Ninjutsu.",
360
361 "Snipers are good at shooting, and they can kill targets by a few shots. After they concentrate deeply, they can demonstrate their shooting talents. You can see incredibly firepower of their shots."
362 #endif
363 };
364
365 /*! 性格の解説メッセージテーブル */
366 static concptr seikaku_jouhou[MAX_SEIKAKU] =
367 {
368 #ifdef JP
369 "ふつうは、特に特筆するべき部分がない性格です。あらゆる技能を平均的にこなします。",
370
371 "ちからじまんは、肉体的な能力や技能が上昇します。しかし、魔法に関係する能力や技能は劣り、戦士よりのステータスを持ちます。",
372
373 "きれものは、肉体的な能力は下がりますが、知能や魔法に関係する技能は上昇し、メイジよりのステータスを持ちます。",
374
375 "しあわせものは、神を信仰する能力が高くなります。肉体的には平均的な能力を持ち、プリーストに近いステータスとなります。",
376
377 "すばしっこいは、どのスキルも比較的うまくこなしますが、肉体的な能力は低くなります。",
378
379 "いのちしらずは、戦闘力、魔法能力の両方が上昇しますが、魔法防御、HPといった能力は悪くなります。",
380
381 "好きな食べ物は焼きビーフン。抑えてはいるが、冒険心旺盛な一匹狼。正義感、勇気とも平均以上だがカッとしやすい所もある。計画的人生より行き当たりばったりの人生を選んでしまうタイプで、異性の扱いは苦手。",
382
383 "なまけものは、あらゆるスキルが低く、何をやってもうまくいきません。",
384
385 "セクシーギャルは、あらゆるスキルをうまくこなすことができます。しかし、その人をなめた性格は全てのモンスターを怒らせることになるでしょう。この性格は女性しか選ぶことができません。",
386
387 "ラッキーマンは、能力値はなまけものに匹敵するくらい低いにもかかわらず、どんなことをしてもなぜかうまくいってしまいます。この性格は男性しか選ぶことができません。",
388
389 "がまんづよいは、じっくりと物事にとりくむ慎重な性格で、他の性格に比べて高い耐久力を得ることができます。しかし、自分から行動するのは苦手で、多くの技能は低くなってしまいます。",
390
391 "いかさまは、初心者の練習用の性格です。あらゆる能力が高くなっています。この性格を使えば勝利者になることは容易ですが、勝利しても全く自慢になりません。",
392
393 "チャージマンは「こんなところ」に連れて行かれても仕方のない可愛そうなお友達なんDA。腕っ節やタフさはマンモス並みに強いのだけれど知能面はまるで駄目なのが分かるだろう?この性格は最初から気が狂っているので、混乱したり幻覚を見る心配がないのです。",
394
395 #else
396
397 "\"Ordinary\" is a personality with no special skills or talents, with unmodified stats and skills.",
398
399 "\"Mighty\" raises your physical stats and skills, but reduces stats and skills which influence magic.  It makes your stats suitable for a warrior.  Also it directly influences your hit-points and spell fail rate.",
400
401 "\"Shrewd\" reduces your physical stats, and raises your intelligence and magical skills.  It makes your stats suitable for a mage.  Also it directly influences your hit-points and spell fail rate.",
402
403 "\"Pious\" deepens your faith in your God.  It makes your physical ability average, and your stats suitable for priest. ",
404
405 "\"Nimble\" renders you highly skilled comparatively well, but reduces your physical ability. ",
406
407 "\"Fearless\" raises both your melee and magical ability.  Stats such as magic defense and constitution are reduced.  Also it has a direct bad influence on your hit-points.",
408
409 "\"Combat\" gives you comparatively high melee and shooting abilities, and average constitution.  Other skills such as stealth, magic defence, and magical devices are weakened.  All \"Combat\" people have great respect for the legendary \"Combat Echizen\".\n\
410 (See \"Death Crimson\" / Ecole Software Corp.)",
411
412 "A \"Lazy\" person has no good stats and can do no action well.  Also it has a direct bad influence on your spell fail rate.",
413
414 "\"Sexy\" rises all of your abilities, but your haughty attitude will aggravate all monsters.  Only females can choose this personality.",
415
416 "A \"Lucky\" man has poor stats, equivalent to a \"Lazy\" person.  Mysteriously, however, he can do all things well.  Only males can choose this personality.",
417
418 "A \"Patient\" person does things carefully.  Patient people have high constitution, and high resilience, but poor abilities in most other skills.  Also it directly influences your hit-points.",
419
420 "\"munchkin\" is a personality for beginners.  It raises all your stats and skills.  With this personality, you can win the game easily, but gain little honor in doing so.",
421
422 "\ChargeMan\" is crazy killer. It render you powerfull strength and constitution, but poor intelligence.you are not confused and seen the illusion because this you go mad from the beginning.",
423
424 #endif
425 };
426
427 /*! 魔法領域の詳細解説メッセージテーブル */
428 static concptr realm_jouhou[VALID_REALM] =
429 {
430 #ifdef JP
431 "生命は回復能力に優れた魔法です。治療や防御、感知魔法が多く含まれていますが、攻撃呪文もわずかに持っています。特に高レベルの呪文にはアンデッドを塵に帰す力をあると言われています。",
432
433 "仙術は「meta」領域であり、感知や鑑定、さらに退却用の呪文や自身の能力を高める呪文などの便利な呪文が含まれています。しかし、直接攻撃用の呪文は持っていません。",
434
435 "自然の魔法は使用者を元素のマスターにします。これには防御、探知、治療と攻撃呪文が含まれています。また、生命以外の領域で最高の治療呪文もこの領域にあります。",
436
437 "カオスの魔法は制御が困難で、予測のできない魔法もあります。カオスは非常に非元素的であり、カオスの呪文は想像できる最も恐るべき破壊兵器です。この呪文を唱えるものはカオスの尖兵に対し、敵や自分自身さえも変異させるよう要求します。",
438
439 "黒魔術である暗黒の魔法ほど邪悪なカテゴリーはありません。これらの呪文は比較的学ぶのが困難ですが、高レベルになると術者に生物とアンデッドを自由に操る能力を与えます。残念なことに、もっとも強力な呪文はその触媒として術者自身の血を必要とし、詠唱中にしばしば術者を傷つけます。",
440
441 "トランプの魔法はテレポート系の呪文で精選されたものを持っており、その出入り口は他の生物を召喚するためにも使えるため、召喚呪文から選りすぐられたものも同様に持っています。しかし、この魔法によって全ての怪物が別の場所へ呼ばれるのを理解するわけではなく、もし召喚呪文に失敗するとその生物は敵となります。",
442
443 "秘術の魔法は、全ての領域から有用な呪文だけを取り入れようとした多用途領域です。必要な「道具」的呪文を持っていても高レベルの強力な呪文は持っていません。結果として、全ての呪文書は街で買い求めることができます。また、他の領域に存在する同様な呪文の方がより低レベル、低コストで唱えることができます。",
444
445 "匠の魔法は、自分や道具を強化するための魔法が含まれています。魔法によって自分自身の戦闘力を非常に高めることができますが、相手を直接攻撃するような呪文は含まれていません。",
446
447 "悪魔の魔法は暗黒と同様非常に邪悪なカテゴリーです。様々な攻撃魔法に優れ、また悪魔のごとき知覚能力を得ることができます。高レベルの呪文は悪魔を自在に操り、自分自身の肉体をも悪魔化させることができます。",
448
449 "破邪は「正義」の魔法です。直接敵を傷つける魔法が多く含まれ、特に邪悪な敵に対する力は恐るべきものがあります。しかし、善良な敵にはあまり効果がありません。",
450
451 "歌集は、歌によって効果を発揮する魔法です。魔法と同様、使った時に効果のあるものと、歌い続けることによって持続して効果を発揮するものがあります。後者の場合は、MPの続く限り効果を発揮することができますが、同時に歌える歌は1つだけという制限もあります。",
452
453 "武芸の書は、様々な戦闘の技について書かれています。この本は技を覚えるときに読む必要がありますが、一度覚えた技は使うのに本を持つ必要はありません。技を使うときには必ず武器を装備していなければいけません。",
454
455 "呪術は忌むべき領域です。複数の呪いの言葉を歌のように紡ぎながら詠唱します。多くの呪文は詠唱し続けることによって効果が持続されます。呪文には相手の行動を束縛するもの、ダメージを与えるもの、攻撃に対して反撃するものが多くあります。"
456 #else
457
458 "Life magic is very good for healing; it relies mostly on healing, protection and detection spells.  Also life magic have a few attack spells as well.  It said that some high level spell of life magic can disintegrate Undead monsters into ash.",
459
460 "Sorcery is a `meta` realm, including enchantment and general spells.  It provides superb protection spells, spells to enhance your odds in combat and, most importantly, a vast selection of spells for gathering information.  However, Sorcery has one weakness: it has no spells to deal direct damage to your enemies.",
461
462 "Nature magic makes you master of elements; it provides protection, detection, curing and attack spells.  Nature also has a spell of Herbal Healing, which is the only powerful healing spell outside the realm of Life magic.",
463
464 "There are few types of magic more unpredictable and difficult to control than Chaos magic.  Chaos is the very element of unmaking, and the Chaos spells are the most terrible weapons of destruction imaginable.  The caster can also call on the primal forces of Chaos to induce mutations in his/her opponents and even him/herself.",
465
466 "There is no fouler nor more evil category of spells than the necromantic spells of Death Magic.  These spells are relatively hard to learn, but at higher levels the spells give the caster power over living and the (un)dead, but the most powerful spells need his / her own blood as the focus, often hurting the caster in the process of casting.",
467
468 "Trump magic has, indeed, an admirable selection of teleportation spells.  Since the Trump gateways can also be used to summon other creatures, Trump magic has an equally impressive selection of summoning spells.  However, not all monsters appreciate being drawn to another place by Trump user.",
469
470 "Arcane magic is a general purpose realm of magic.  It attempts to encompass all 'useful' spells from all realms.  This is the downside of Arcane magic: while Arcane does have all the necessary 'tool' spells for a dungeon delver, it has no ultra-powerful high level spells.  As a consequence, all Arcane spellbooks can be bought in town.  It should also be noted that the 'specialized' realms usually offer the same spell at a lower level and cost. ",
471
472 "Craft magic can strengthen the caster or the equipments.  These spells can greatly improve the caster's fighting ability.  Using them against opponents directly is not possible.",
473
474 "Demon is a very evil realm, same as Death.  It provides various attack spells and devilish detection spells.  at higher levels, Demon magic provides ability to dominate demons, and to polymorph yourself into a demon.",
475
476 "Crusade is a magic of 'Justice'.  It includes damage spells, which are greatly effective against foul and evil monsters, but have poor effects against good monsters.",
477
478 "Music magic shows various effects as sing song.  There is two type of song; the one which shows effects instantly and the other one shows effect continuously until SP runs out.  But the latter type has a limit; only one song can be sing at the same time.",
479
480 "The books of Kendo describe about various combat techniques.  When learning new techniques, you are required to carry the books, but once you memorizes them, you don't have to carry them.  When using a technique, wielding a weapon is required.",
481
482 "Hex is a very terrible realm. Spells gives continual effects when they are spelled continually like songs. Spells may obstract monsters' actions, may deal damages in sight, may revenge against enemies."
483 #endif
484 };
485
486 /*! 魔法領域の簡易解説メッセージテーブル */
487 static concptr realm_subinfo[VALID_REALM] =
488 {
489 #ifdef JP
490 "感知と防御と回復に優れています",
491 "攻撃はできませんが非常に便利です",
492 "感知と防御に優れています",
493 "破壊的な攻撃に優れています",
494 "生命のある敵への攻撃に優れています",
495 "召喚とテレポートに優れています",
496 "やや弱いながらも非常に便利です",
497 "直接戦闘の補助に優れています",
498 "攻撃と防御の両面に優れています",
499 "邪悪な怪物に対する攻撃に優れています",
500 "様々な魔法効果を持った歌を歌います",
501 "打撃攻撃に特殊能力を付加します",
502 "敵を邪魔しつつ復讐を狙います"
503 #else
504 "Good at detection and healing.",
505 "Utility and protective spells.",
506 "Good at detection and defence.",
507 "Offensive and destructive.",
508 "Ruins living creatures.",
509 "Good at summoning, teleportation.",
510 "Very useful but poor a bit.",
511 "Support for melee fighting.",
512 "Good at both offence and defence.",
513 "Destroys evil creatures.",
514 "Song with magical effects.",
515 "Special attacks on melee.",
516 "Good at obstacle and revenge."
517 #endif
518 };
519
520
521 /*! オートローラの能力値的要求水準 / Autoroll limit */
522 static s16b stat_limit[6];
523
524 /*! オートローラの年齢、身長、体重、社会的地位の要求水準 */
525 static struct {
526         s16b agemin, agemax;
527         s16b htmin, htmax;
528         s16b wtmin, wtmax;
529         s16b scmin, scmax;
530 } chara_limit;
531
532 /*! オートローラ中、各能力値が水準を超えた回数 / Autoroll matches */
533 static s32b stat_match[6];
534
535 /*! オートローラの試行回数 / Autoroll round */
536 static s32b auto_round;
537
538 /*! 
539  * @brief プレイヤー作成を中断して変愚蛮怒を終了する
540  * @return なし
541  */
542 static void birth_quit(void)
543 {
544         remove_loc();
545         quit(NULL);
546 }
547
548 /*!
549  * @brief 指定されたヘルプファイルを表示する / Show specific help file
550  * @param helpfile ファイル名
551  * @return なし
552  */
553 static void show_help(concptr helpfile)
554 {
555         screen_save();
556         (void)show_file(TRUE, helpfile, NULL, 0, 0);
557         screen_load();
558 }
559
560
561 /*!
562  * @brief プレイヤーの魔法領域を選択する / Choose from one of the available magical realms
563  * @param choices 選択可能な魔法領域のビット配列
564  * @param count 選択可能な魔法領域を返すポインタ群。
565  * @return 選択した魔法領域のID
566  */
567 static byte choose_realm(s32b choices, int *count)
568 {
569         int picks[VALID_REALM] = {0};
570         int k, i, cs, os;
571         byte auto_select = REALM_NONE;
572         int n = 0;
573         char c;
574         char sym[VALID_REALM];
575         char p2 = ')';
576         char buf[80], cur[80];
577
578         /* Count the choices */
579         if (choices & CH_LIFE)
580         {
581                 (*count)++;
582                 auto_select = REALM_LIFE;
583         }
584         if (choices & CH_SORCERY)
585         {
586                 (*count)++;
587                 auto_select = REALM_SORCERY;
588         }
589         if (choices & CH_NATURE)
590         {
591                 (*count)++;
592                 auto_select = REALM_NATURE;
593         }
594         if (choices & CH_CHAOS)
595         {
596                 (*count)++;
597                 auto_select = REALM_CHAOS;
598         }
599         if (choices & CH_DEATH)
600         {
601                 (*count)++;
602                 auto_select = REALM_DEATH;
603         }
604         if (choices & CH_TRUMP)
605         {
606                 (*count)++;
607                 auto_select = REALM_TRUMP;
608         }
609         if (choices & CH_ARCANE)
610         {
611                 (*count)++;
612                 auto_select = REALM_ARCANE;
613         }
614         if (choices & CH_ENCHANT)
615         {
616                 (*count)++;
617                 auto_select = REALM_CRAFT;
618         }
619         if (choices & CH_DAEMON)
620         {
621                 (*count)++;
622                 auto_select = REALM_DAEMON;
623         }
624         if (choices & CH_CRUSADE)
625         {
626                 (*count)++;
627                 auto_select = REALM_CRUSADE;
628         }
629         if (choices & CH_MUSIC)
630         {
631                 (*count)++;
632                 auto_select = REALM_MUSIC;
633         }
634         if (choices & CH_HISSATSU)
635         {
636                 (*count)++;
637                 auto_select = REALM_HISSATSU;
638         }
639         if (choices & CH_HEX)
640         {
641                 (*count)++;
642                 auto_select = REALM_HEX;
643         }
644
645         clear_from(10);
646
647         /* Auto-select the realm */
648         if ((*count) < 2) return auto_select;
649
650         /* Constraint to the 1st realm */
651         if (p_ptr->realm2 != 255)
652         {
653                 if (p_ptr->pclass == CLASS_PRIEST)
654                 {
655                         if (is_good_realm(p_ptr->realm1))
656                         {
657                                 choices &= ~(CH_DEATH | CH_DAEMON);
658                         }
659                         else
660                         {
661                                 choices &= ~(CH_LIFE | CH_CRUSADE);
662                         }
663                 }
664         }
665
666         /* Extra info */
667         put_str (_("注意:魔法の領域の選択によりあなたが習得する呪文のタイプが決まります。", "Note: The realm of magic will determine which spells you can learn."), 23, 5);
668
669         cs = 0;
670         for (i = 0; i < 32; i++)
671         {
672                 /* Analize realms */
673                 if (choices & (1L << i))
674                 {
675                         if (p_ptr->realm1 == i+1)
676                         {
677                                 if (p_ptr->realm2 == 255)
678                                         cs = n;
679                                 else
680                                         continue;
681                         }
682                         if (p_ptr->realm2 == i+1)
683                                 cs = n;
684
685                         sym[n] = I2A(n);
686
687                         sprintf(buf, "%c%c %s", sym[n], p2, realm_names[i+1]);
688                         put_str(buf, 12 + (n/5), 2 + 15 * (n%5));
689                         picks[n++] = i+1;
690                 }
691         }
692         sprintf(cur, "%c%c %s", '*', p2, _("ランダム", "Random"));
693
694         /* Get a realm */
695         k = -1;
696         os = n;
697         while (1)       {
698                 /* Move Cursol */
699                 if (cs != os)
700                 {
701                         c_put_str(TERM_WHITE, cur, 12 + (os/5), 2 + 15 * (os%5));
702                         put_str("                                   ", 3, 40);
703                         put_str("                                   ", 4, 40);
704
705                         if(cs == n)
706                         {
707                                 sprintf(cur, "%c%c %s", '*', p2, _("ランダム", "Random"));
708                         }
709                         else
710                         {
711                                 sprintf(cur, "%c%c %s", sym[cs], p2, realm_names[picks[cs]]);
712                                 sprintf(buf, "%s", realm_names[picks[cs]]);
713 #ifdef JP
714                                 c_put_str(TERM_L_BLUE, buf, 3, 40);
715                                 put_str("の特徴", 3, 40+strlen(buf));
716 #else
717                                 c_put_str(TERM_L_BLUE, realm_names[picks[cs]], 3, 40);
718                                 put_str(": Characteristic", 3, 40+strlen(realm_names[picks[cs]]));
719 #endif
720                                 put_str(realm_subinfo[technic2magic(picks[cs])-1], 4, 40);
721                         }
722                         c_put_str(TERM_YELLOW, cur, 12 + (cs/5), 2 + 15 * (cs%5));
723                         os = cs;
724                 }
725
726                 if (k >= 0) break;
727
728                 sprintf(buf, _("領域を選んで下さい(%c-%c) ('='初期オプション設定): ", "Choose a realm (%c-%c) ('=' for options): "), sym[0], sym[n-1]);
729
730                 put_str(buf, 10, 10);
731                 c = inkey();
732                 if (c == 'Q') birth_quit();
733                 if (c == 'S') return 255;
734                 if (c == ' ' || c == '\r' || c == '\n')
735                 {
736                         if(cs == n)
737                         {
738                                 k = randint0(n);
739                                 break;
740                         }
741                         else
742                         {
743                                 k = cs;
744                                 break;
745                         }
746                 }
747                 if (c == '*')
748                 {
749                         k = randint0(n);
750                         break;
751                 }
752                 if (c == '8')
753                 {
754                         if (cs >= 5) cs -= 5;
755                 }
756                 if (c == '4')
757                 {
758                         if (cs > 0) cs--;
759                 }
760                 if (c == '6')
761                 {
762                         if (cs < n) cs++;
763                 }
764                 if (c == '2')
765                 {
766                         if ((cs + 5) <= n) cs += 5;
767                 }
768                 k = (islower(c) ? A2I(c) : -1);
769                 if ((k >= 0) && (k < n))
770                 {
771                         cs = k;
772                         continue;
773                 }
774                 k = (isupper(c) ? (26 + c - 'A') : -1);
775                 if ((k >= 26) && (k < n))
776                 {
777                         cs = k;
778                         continue;
779                 }
780                 else k = -1;
781                 if (c == '?')
782                 {
783                         show_help(_("jmagic.txt#MagicRealms", "magic.txt#MagicRealms"));
784                 }
785                 else if (c == '=')
786                 {
787                         screen_save();
788                         do_cmd_options_aux(OPT_PAGE_BIRTH, _("初期オプション((*)はスコアに影響)", "Birth option((*)s effect score)"));
789
790                         screen_load();
791                 }
792                 else if (c !='2' && c !='4' && c !='6' && c !='8') bell();
793         }
794
795         /* Clean up */
796         clear_from(10);
797
798         return (byte_hack)(picks[k]);
799 }
800
801
802 /*!
803  * @brief 選択した魔法領域の解説を表示する / Choose the magical realms
804  * @return ユーザが魔法領域の確定を選んだらTRUEを返す。
805  */
806 static bool get_player_realms(void)
807 {
808         int i, count;
809
810         /* Clean up infomation of modifications */
811         put_str("                                   ", 3, 40);
812         put_str("                                   ", 4, 40);
813         put_str("                                   ", 5, 40);
814
815         /* Select the first realm */
816         p_ptr->realm1 = REALM_NONE;
817         p_ptr->realm2 = 255;
818         while (1)
819         {
820                 char temp[80*10];
821                 concptr t;
822                 count = 0;
823                 p_ptr->realm1 = choose_realm(realm_choices1[p_ptr->pclass], &count);
824
825                 if (255 == p_ptr->realm1) return FALSE;
826                 if (!p_ptr->realm1) break;
827
828                 /* Clean up*/
829                 clear_from(10);
830                 put_str("                                   ", 3, 40);
831                 put_str("                                   ", 4, 40);
832                 put_str("                                   ", 5, 40);
833
834                 roff_to_buf(realm_jouhou[technic2magic(p_ptr->realm1)-1], 74, temp, sizeof(temp));
835                 t = temp;
836                 for (i = 0; i < 10; i++)
837                 {
838                         if(t[0] == 0)
839                                 break; 
840                         else
841                         {
842                                 prt(t, 12+i, 3);
843                                 t += strlen(t) + 1;
844                         }
845                 }
846
847                 if (count < 2)
848                 {
849                         prt(_("何かキーを押してください", "Hit any key."), 0, 0);
850                         (void)inkey();
851                         prt("", 0, 0);
852                         break;
853                 }
854                 else if (get_check_strict(_("よろしいですか?", "Are you sure? "), CHECK_DEFAULT_Y)) break;
855         }
856
857         /* Select the second realm */
858         p_ptr->realm2 = REALM_NONE;
859         if (p_ptr->realm1)
860         {
861                 /* Print the realm */
862                 put_str(_("魔法        :", "Magic       :"), 6, 1);
863                 c_put_str(TERM_L_BLUE, realm_names[p_ptr->realm1], 6, 15);
864
865                 /* Select the second realm */
866                 while (1)
867                 {
868                         char temp[80*8];
869                         concptr t;
870
871                         count = 0;
872                         p_ptr->realm2 = choose_realm(realm_choices2[p_ptr->pclass], &count);
873
874                         if (255 == p_ptr->realm2) return FALSE;
875                         if (!p_ptr->realm2) break;
876
877                         /* Clean up*/
878                         clear_from(10);
879                         put_str("                                   ", 3, 40);
880                         put_str("                                   ", 4, 40);
881                         put_str("                                   ", 5, 40);
882
883                         roff_to_buf(realm_jouhou[technic2magic(p_ptr->realm2)-1], 74, temp, sizeof(temp));
884                         t = temp;
885                         for (i = 0; i < A_MAX; i++)
886                         {
887                                 if(t[0] == 0)
888                                         break; 
889                                 else
890                                 {
891                                         prt(t, 12+i, 3);
892                                         t += strlen(t) + 1;
893                                 }
894                         }
895
896                         if (count < 2)
897                         {
898                                 prt(_("何かキーを押してください", "Hit any key."), 0, 0);
899                                 (void)inkey();
900                                 prt("", 0, 0);
901                                 break;
902                         }
903                         else if (get_check_strict(_("よろしいですか?", "Are you sure? "), CHECK_DEFAULT_Y)) break;
904                 }
905                 if (p_ptr->realm2)
906                 {
907                         /* Print the realm */
908                         c_put_str(TERM_L_BLUE, format("%s, %s", realm_names[p_ptr->realm1], realm_names[p_ptr->realm2]), 6, 15);
909                 }
910         }
911
912         return (TRUE);
913 }
914
915
916 /*!
917  * @brief プレイヤーのクイックスタート情報をプレイヤー構造体から保存する / Save the current data for later
918  * @param birther_ptr クイックスタート構造体の参照ポインタ
919  * @return なし。
920  */
921 static void save_prev_data(birther *birther_ptr)
922 {
923         int i;
924
925         /* Save the data */
926         birther_ptr->psex = p_ptr->psex;
927         birther_ptr->prace = p_ptr->prace;
928         birther_ptr->pclass = p_ptr->pclass;
929         birther_ptr->pseikaku = p_ptr->pseikaku;
930         birther_ptr->realm1 = p_ptr->realm1;
931         birther_ptr->realm2 = p_ptr->realm2;
932         birther_ptr->age = p_ptr->age;
933         birther_ptr->ht = p_ptr->ht;
934         birther_ptr->wt = p_ptr->wt;
935         birther_ptr->sc = p_ptr->sc;
936         birther_ptr->au = p_ptr->au;
937
938         /* Save the stats */
939         for (i = 0; i < A_MAX; i++)
940         {
941                 birther_ptr->stat_max[i] = p_ptr->stat_max[i];
942                 birther_ptr->stat_max_max[i] = p_ptr->stat_max_max[i];
943         }
944
945         /* Save the hp */
946         for (i = 0; i < PY_MAX_LEVEL; i++)
947         {
948                 birther_ptr->player_hp[i] = p_ptr->player_hp[i];
949         }
950
951         birther_ptr->chaos_patron = p_ptr->chaos_patron;
952
953         /* Save the virtues */
954         for (i = 0; i < 8; i++)
955         {
956                 birther_ptr->vir_types[i] = p_ptr->vir_types[i];
957         }
958
959         /* Save the history */
960         for (i = 0; i < 4; i++)
961         {
962                 strcpy(birther_ptr->history[i], p_ptr->history[i]);
963         }
964 }
965
966
967 /*!
968  * @brief プレイヤーのクイックスタート情報をプレイヤー構造体へ読み込む / Load the previous data
969  * @param swap TRUEならば現在のプレイヤー構造体上との内容をスワップする形で読み込む。
970  * @return なし。
971  */
972 static void load_prev_data(bool swap)
973 {
974         int i;
975
976         birther temp;
977
978         /*** Save the current data ***/
979         if (swap) save_prev_data(&temp);
980
981
982         /*** Load the previous data ***/
983
984         /* Load the data */
985         p_ptr->psex = previous_char.psex;
986         p_ptr->prace = previous_char.prace;
987         p_ptr->pclass = previous_char.pclass;
988         p_ptr->pseikaku = previous_char.pseikaku;
989         p_ptr->realm1 = previous_char.realm1;
990         p_ptr->realm2 = previous_char.realm2;
991         p_ptr->age = previous_char.age;
992         p_ptr->ht = previous_char.ht;
993         p_ptr->wt = previous_char.wt;
994         p_ptr->sc = previous_char.sc;
995         p_ptr->au = previous_char.au;
996
997         /* Load the stats */
998         for (i = 0; i < A_MAX; i++)
999         {
1000                 p_ptr->stat_cur[i] = p_ptr->stat_max[i] = previous_char.stat_max[i];
1001                 p_ptr->stat_max_max[i] = previous_char.stat_max_max[i];
1002         }
1003
1004         /* Load the hp */
1005         for (i = 0; i < PY_MAX_LEVEL; i++)
1006         {
1007                 p_ptr->player_hp[i] = previous_char.player_hp[i];
1008         }
1009         p_ptr->mhp = p_ptr->player_hp[0];
1010         p_ptr->chp = p_ptr->player_hp[0];
1011
1012         p_ptr->chaos_patron = previous_char.chaos_patron;
1013
1014         for (i = 0; i < 8; i++)
1015         {
1016                 p_ptr->vir_types[i] = previous_char.vir_types[i];
1017         }
1018
1019         /* Load the history */
1020         for (i = 0; i < 4; i++)
1021         {
1022                 strcpy(p_ptr->history[i], previous_char.history[i]);
1023         }
1024
1025         /*** Save the previous data ***/
1026         if (swap)
1027         {
1028                 (void)COPY(&previous_char, &temp, birther);
1029         }
1030 }
1031
1032
1033
1034
1035 /*!
1036  * @brief プレイヤーの能力値表現に基づいて加減算を行う。
1037  * @param value 現在の能力値
1038  * @param amount 加減算する値
1039  * @return 加減算の結果
1040  */
1041 static int adjust_stat(int value, int amount)
1042 {
1043         int i;
1044
1045         /* Negative amounts */
1046         if (amount < 0)
1047         {
1048                 /* Apply penalty */
1049                 for (i = 0; i < (0 - amount); i++)
1050                 {
1051                         if (value >= 18+10)
1052                         {
1053                                 value -= 10;
1054                         }
1055                         else if (value > 18)
1056                         {
1057                                 value = 18;
1058                         }
1059                         else if (value > 3)
1060                         {
1061                                 value--;
1062                         }
1063                 }
1064         }
1065
1066         /* Positive amounts */
1067         else if (amount > 0)
1068         {
1069                 /* Apply reward */
1070                 for (i = 0; i < amount; i++)
1071                 {
1072                         if (value < 18)
1073                         {
1074                                 value++;
1075                         }
1076                         else
1077                         {
1078                                 value += 10;
1079                         }
1080                 }
1081         }
1082
1083         /* Return the result */
1084         return (value);
1085 }
1086
1087
1088
1089
1090 /*!
1091  * @brief プレイヤーの能力値を一通りロールする。 / Roll for a characters stats
1092  * @details
1093  * calc_bonuses()による、独立ステータスからの副次ステータス算出も行っている。
1094  * For efficiency, we include a chunk of "calc_bonuses()".\n
1095  * @return なし
1096  */
1097 static void get_stats(void)
1098 {
1099         /* Roll and verify some stats */
1100         while (TRUE)
1101         {
1102                 int i;
1103                 int sum = 0;
1104
1105                 /* Roll some dice */
1106                 for (i = 0; i < 2; i++)
1107                 {
1108                         s32b tmp = randint0(60*60*60);
1109                         BASE_STATUS val;
1110
1111                         /* Extract 5 + 1d3 + 1d4 + 1d5 */
1112                         val = 5 + 3;
1113                         val += tmp % 3; tmp /= 3;
1114                         val += tmp % 4; tmp /= 4;
1115                         val += tmp % 5; tmp /= 5;
1116
1117                         /* Save that value */
1118                         sum += val;
1119                         p_ptr->stat_cur[3*i] = p_ptr->stat_max[3*i] = val;
1120
1121                         /* Extract 5 + 1d3 + 1d4 + 1d5 */
1122                         val = 5 + 3;
1123                         val += tmp % 3; tmp /= 3;
1124                         val += tmp % 4; tmp /= 4;
1125                         val += tmp % 5; tmp /= 5;
1126
1127                         /* Save that value */
1128                         sum += val;
1129                         p_ptr->stat_cur[3*i+1] = p_ptr->stat_max[3*i+1] = val;
1130
1131                         /* Extract 5 + 1d3 + 1d4 + 1d5 */
1132                         val = 5 + 3;
1133                         val += tmp % 3; tmp /= 3;
1134                         val += tmp % 4; tmp /= 4;
1135                         val += (BASE_STATUS)tmp;
1136
1137                         /* Save that value */
1138                         sum += val;
1139                         p_ptr->stat_cur[3*i+2] = p_ptr->stat_max[3*i+2] = val;
1140                 }
1141
1142                 /* Verify totals */
1143                 if ((sum > 42+5*6) && (sum < 57+5*6)) break;
1144                 /* 57 was 54... I hate 'magic numbers' :< TY */
1145         }
1146 }
1147
1148 /*!
1149  * @brief プレイヤーの限界ステータスを決める。
1150  * @return なし
1151  */
1152 void get_max_stats(void)
1153 {
1154         int i, j;
1155         int dice[6];
1156
1157         /* Roll and verify some stats */
1158         while (TRUE)
1159         {
1160                 /* Roll some dice */
1161                 for (j = i = 0; i < A_MAX; i++)
1162                 {
1163                         /* Roll the dice */
1164                         dice[i] = randint1(7);
1165
1166                         /* Collect the maximum */
1167                         j += dice[i];
1168                 }
1169
1170                 /* Verify totals */
1171                 if (j == 24) break;
1172         }
1173
1174         /* Acquire the stats */
1175         for (i = 0; i < A_MAX; i++)
1176         {
1177                 BASE_STATUS max_max = 18 + 60 + dice[i]*10;
1178
1179                 /* Save that value */
1180                 p_ptr->stat_max_max[i] = max_max;
1181                 if (p_ptr->stat_max[i] > max_max)
1182                         p_ptr->stat_max[i] = max_max;
1183                 if (p_ptr->stat_cur[i] > max_max)
1184                         p_ptr->stat_cur[i] = max_max;
1185         }
1186         p_ptr->knowledge &= ~(KNOW_STAT);
1187         p_ptr->redraw |= (PR_STATS);
1188 }
1189
1190
1191 /*!
1192  * @brief その他「オートローラ中は算出の対象にしない」副次ステータスを処理する / Roll for some info that the auto-roller ignores
1193  * @return なし
1194  */
1195 static void get_extra(bool roll_hitdie)
1196 {
1197         int i, j;
1198
1199         /* Experience factor */
1200         if (p_ptr->prace == RACE_ANDROID) p_ptr->expfact = rp_ptr->r_exp;
1201         else p_ptr->expfact = rp_ptr->r_exp + cp_ptr->c_exp;
1202
1203         if (((p_ptr->pclass == CLASS_MONK) || (p_ptr->pclass == CLASS_FORCETRAINER) || (p_ptr->pclass == CLASS_NINJA)) && ((p_ptr->prace == RACE_KLACKON) || (p_ptr->prace == RACE_SPRITE)))
1204                 p_ptr->expfact -= 15;
1205
1206         /* Reset record of race/realm changes */
1207         p_ptr->start_race = p_ptr->prace;
1208         p_ptr->old_race1 = 0L;
1209         p_ptr->old_race2 = 0L;
1210         p_ptr->old_realm = 0;
1211
1212         for (i = 0; i < 64; i++)
1213         {
1214                 if (p_ptr->pclass == CLASS_SORCERER) p_ptr->spell_exp[i] = SPELL_EXP_MASTER;
1215                 else if (p_ptr->pclass == CLASS_RED_MAGE) p_ptr->spell_exp[i] = SPELL_EXP_SKILLED;
1216                 else p_ptr->spell_exp[i] = SPELL_EXP_UNSKILLED;
1217         }
1218
1219         for (i = 0; i < 5; i++)
1220                 for (j = 0; j < 64; j++)
1221                         p_ptr->weapon_exp[i][j] = s_info[p_ptr->pclass].w_start[i][j];
1222         if ((p_ptr->pseikaku == SEIKAKU_SEXY) && (p_ptr->weapon_exp[TV_HAFTED-TV_WEAPON_BEGIN][SV_WHIP] < WEAPON_EXP_BEGINNER))
1223         {
1224                 p_ptr->weapon_exp[TV_HAFTED-TV_WEAPON_BEGIN][SV_WHIP] = WEAPON_EXP_BEGINNER;
1225         }
1226
1227         for (i = 0; i < GINOU_MAX; i++)
1228                 p_ptr->skill_exp[i] = s_info[p_ptr->pclass].s_start[i];
1229
1230         /* Hitdice */
1231         if (p_ptr->pclass == CLASS_SORCERER)
1232                 p_ptr->hitdie = rp_ptr->r_mhp/2 + cp_ptr->c_mhp + ap_ptr->a_mhp;
1233         else
1234                 p_ptr->hitdie = rp_ptr->r_mhp + cp_ptr->c_mhp + ap_ptr->a_mhp;
1235
1236         /* Roll for hit point unless quick-start */
1237         if (roll_hitdie) roll_hitdice(p_ptr, SPOP_NO_UPDATE);
1238
1239         /* Initial hitpoints */
1240         p_ptr->mhp = p_ptr->player_hp[0];
1241 }
1242
1243
1244 /*!
1245  * @brief プレイヤーの生い立ちの自動生成を行う。 / Get the racial history, and social class, using the "history charts".
1246  * @return なし
1247  */
1248 static void get_history(void)
1249 {
1250         int i, n, chart, roll, social_class;
1251
1252         char *s, *t;
1253
1254         char buf[240];
1255
1256         /* Clear the previous history strings */
1257         for (i = 0; i < 4; i++) p_ptr->history[i][0] = '\0';
1258
1259         /* Clear the history text */
1260         buf[0] = '\0';
1261
1262         /* Initial social class */
1263         social_class = randint1(4);
1264
1265         /* Starting place */
1266         switch (p_ptr->prace)
1267         {
1268                 case RACE_AMBERITE:
1269                 {
1270                         chart = 67;
1271                         break;
1272                 }
1273                 case RACE_HUMAN:
1274                 case RACE_BARBARIAN:
1275                 case RACE_DUNADAN:
1276                 case RACE_MERFOLK:
1277                 {
1278                         chart = 1;
1279                         break;
1280                 }
1281                 case RACE_HALF_ELF:
1282                 {
1283                         chart = 4;
1284                         break;
1285                 }
1286                 case RACE_ELF:
1287                 case RACE_HIGH_ELF:
1288                 {
1289                         chart = 7;
1290                         break;
1291                 }
1292                 case RACE_HOBBIT:
1293                 {
1294                         chart = 10;
1295                         break;
1296                 }
1297                 case RACE_GNOME:
1298                 {
1299                         chart = 13;
1300                         break;
1301                 }
1302                 case RACE_DWARF:
1303                 {
1304                         chart = 16;
1305                         break;
1306                 }
1307                 case RACE_HALF_ORC:
1308                 {
1309                         chart = 19;
1310                         break;
1311                 }
1312                 case RACE_HALF_TROLL:
1313                 {
1314                         chart = 22;
1315                         break;
1316                 }
1317                 case RACE_DARK_ELF:
1318                 {
1319                         chart = 69;
1320                         break;
1321                 }
1322                 case RACE_HALF_OGRE:
1323                 {
1324                         chart = 74;
1325                         break;
1326                 }
1327                 case RACE_HALF_GIANT:
1328                 {
1329                         chart = 75;
1330                         break;
1331                 }
1332                 case RACE_HALF_TITAN:
1333                 {
1334                         chart = 76;
1335                         break;
1336                 }
1337                 case RACE_CYCLOPS:
1338                 {
1339                         chart = 77;
1340                         break;
1341                 }
1342                 case RACE_YEEK:
1343                 {
1344                         chart = 78;
1345                         break;
1346                 }
1347                 case RACE_KOBOLD:
1348                 {
1349                         chart = 82;
1350                         break;
1351                 }
1352                 case RACE_KLACKON:
1353                 {
1354                         chart = 84;
1355                         break;
1356                 }
1357                 case RACE_NIBELUNG:
1358                 {
1359                         chart = 87;
1360                         break;
1361                 }
1362                 case RACE_DRACONIAN:
1363                 {
1364                         chart = 89;
1365                         break;
1366                 }
1367                 case RACE_MIND_FLAYER:
1368                 {
1369                         chart = 92;
1370                         break;
1371                 }
1372                 case RACE_IMP:
1373                 {
1374                         chart = 94;
1375                         break;
1376                 }
1377                 case RACE_GOLEM:
1378                 {
1379                         chart = 98;
1380                         break;
1381                 }
1382                 case RACE_SKELETON:
1383                 {
1384                         chart = 102;
1385                         break;
1386                 }
1387                 case RACE_ZOMBIE:
1388                 {
1389                         chart = 107;
1390                         break;
1391                 }
1392                 case RACE_VAMPIRE:
1393                 {
1394                         chart = 113;
1395                         break;
1396                 }
1397                 case RACE_SPECTRE:
1398                 {
1399                         chart = 118;
1400                         break;
1401                 }
1402                 case RACE_SPRITE:
1403                 {
1404                         chart = 124;
1405                         break;
1406                 }
1407                 case RACE_BEASTMAN:
1408                 {
1409                         chart = 129;
1410                         break;
1411                 }
1412                 case RACE_ENT:
1413                 {
1414                         chart = 137;
1415                         break;
1416                 }
1417                 case RACE_ANGEL:
1418                 {
1419                         chart = 142;
1420                         break;
1421                 }
1422                 case RACE_DEMON:
1423                 {
1424                         chart = 145;
1425                         break;
1426                 }
1427                 case RACE_S_FAIRY:
1428                 {
1429                         chart = 148;
1430                         break;
1431                 }
1432                 case RACE_KUTAR:
1433                 {
1434                         chart = 154;
1435                         break;
1436                 }
1437                 case RACE_ANDROID:
1438                 {
1439                         chart = 155;
1440                         break;
1441                 }
1442                 default:
1443                 {
1444                         chart = 0;
1445                         break;
1446                 }
1447         }
1448
1449
1450         /* Process the history */
1451         while (chart)
1452         {
1453                 /* Start over */
1454                 i = 0;
1455
1456                 /* Roll for nobility */
1457                 roll = randint1(100);
1458
1459
1460                 /* Access the proper entry in the table */
1461                 while ((chart != bg[i].chart) || (roll > bg[i].roll)) i++;
1462
1463                 /* Acquire the textual history */
1464                 (void)strcat(buf, bg[i].info);
1465
1466                 /* Add in the social class */
1467                 social_class += (int)(bg[i].bonus) - 50;
1468
1469                 /* Enter the next chart */
1470                 chart = bg[i].next;
1471         }
1472
1473
1474         /* Verify social class */
1475         if (social_class > 100) social_class = 100;
1476         else if (social_class < 1) social_class = 1;
1477
1478         /* Save the social class */
1479         p_ptr->sc = (s16b)social_class;
1480
1481
1482         /* Skip leading spaces */
1483         for (s = buf; *s == ' '; s++) /* loop */;
1484
1485         /* Get apparent length */
1486         n = strlen(s);
1487
1488         /* Kill trailing spaces */
1489
1490         while ((n > 0) && (s[n-1] == ' ')) s[--n] = '\0';
1491
1492        {
1493         char temp[64*4];
1494         roff_to_buf(s, 60, temp, sizeof(temp));
1495         t = temp;
1496         for(i=0 ; i<4 ; i++){
1497              if(t[0]==0)break; 
1498              else {strcpy(p_ptr->history[i], t);t += strlen(t)+1;}
1499              }
1500        }
1501 }
1502
1503 /*!
1504  * @brief プレイヤーの身長体重を決める / Get character's height and weight
1505  * @return なし
1506  */
1507 void get_height_weight(void)
1508 {
1509         int h_percent; /* 身長が平均にくらべてどのくらい違うか. */
1510
1511         /* Calculate the height/weight for males */
1512         if (p_ptr->psex == SEX_MALE)
1513         {
1514                 p_ptr->ht = randnor(rp_ptr->m_b_ht, rp_ptr->m_m_ht);
1515                 h_percent = (int)(p_ptr->ht) * 100 / (int)(rp_ptr->m_b_ht);
1516                 p_ptr->wt = randnor((int)(rp_ptr->m_b_wt) * h_percent /100
1517                                     , (int)(rp_ptr->m_m_wt) * h_percent / 300 );
1518         }
1519   
1520         /* Calculate the height/weight for females */
1521         else if (p_ptr->psex == SEX_FEMALE)
1522         {
1523                 p_ptr->ht = randnor(rp_ptr->f_b_ht, rp_ptr->f_m_ht);
1524                 h_percent = (int)(p_ptr->ht) * 100 / (int)(rp_ptr->f_b_ht);
1525                 p_ptr->wt = randnor((int)(rp_ptr->f_b_wt) * h_percent /100
1526                                     , (int)(rp_ptr->f_m_wt) * h_percent / 300 );
1527         }
1528 }
1529
1530
1531 /*!
1532  * @brief プレイヤーの年齢を決める。 / Computes character's age, height, and weight by henkma
1533  * @details 内部でget_height_weight()も呼び出している。
1534  * @return なし
1535  */
1536 static void get_ahw(void)
1537 {
1538         /* Get character's age */
1539         p_ptr->age = rp_ptr->b_age + randint1(rp_ptr->m_age);
1540
1541         /* Get character's height and weight */
1542         get_height_weight();
1543 }
1544
1545 /*!
1546  * @brief プレイヤーの初期所持金を決める。 / Get the player's starting money
1547  * @return なし
1548  */
1549 static void get_money(void)
1550 {
1551         int i, gold;
1552
1553         /* Social Class determines starting gold */
1554         gold = (p_ptr->sc * 6) + randint1(100) + 300;
1555         if (p_ptr->pclass == CLASS_TOURIST)
1556           gold += 2000;
1557
1558         /* Process the stats */
1559         for (i = 0; i < A_MAX; i++)
1560         {
1561                 /* Mega-Hack -- reduce gold for high stats */
1562                 if (p_ptr->stat_max[i] >= 18 + 50) gold -= 300;
1563                 else if (p_ptr->stat_max[i] >= 18 + 20) gold -= 200;
1564                 else if (p_ptr->stat_max[i] > 18) gold -= 150;
1565                 else gold -= (p_ptr->stat_max[i] - 8) * 10;
1566         }
1567
1568         /* Minimum 100 gold */
1569         if (gold < 100) gold = 100;
1570
1571         if (p_ptr->pseikaku == SEIKAKU_NAMAKE)
1572                 gold /= 2;
1573         else if (p_ptr->pseikaku == SEIKAKU_MUNCHKIN)
1574                 gold = 10000000;
1575         if (p_ptr->prace == RACE_ANDROID) gold /= 5;
1576
1577         /* Save the gold */
1578         p_ptr->au = gold;
1579 }
1580
1581
1582
1583 /*!
1584  * @brief put_stats()のサブルーチンとして、オートロール中のステータスを表示する / Display stat values, subset of "put_stats()"
1585  * @details See 'display_player()' for screen layout constraints.
1586  * @return なし
1587  */
1588 static void birth_put_stats(void)
1589 {
1590         int i, j, m, p;
1591         int col;
1592         TERM_COLOR attr;
1593         char buf[80];
1594
1595
1596         if (autoroller)
1597         {
1598                 col = 42;
1599                 /* Put the stats (and percents) */
1600                 for (i = 0; i < A_MAX; i++)
1601                 {
1602                         /* Race/Class bonus */
1603                         j = rp_ptr->r_adj[i] + cp_ptr->c_adj[i] + ap_ptr->a_adj[i];
1604
1605                         /* Obtain the current stat */
1606                         m = adjust_stat(p_ptr->stat_max[i], j);
1607
1608                         /* Put the stat */
1609                         cnv_stat(m, buf);
1610                         c_put_str(TERM_L_GREEN, buf, 3+i, col+24);
1611
1612                         /* Put the percent */
1613                         if (stat_match[i])
1614                         {
1615                                 if (stat_match[i] > 1000000L)
1616                                 {
1617                                         /* Prevent overflow */
1618                                         p = stat_match[i] / (auto_round / 1000L);
1619                                 }
1620                                 else
1621                                 {
1622                                         p = 1000L * stat_match[i] / auto_round;
1623                                 }
1624                         
1625                                 attr = (p < 100) ? TERM_YELLOW : TERM_L_GREEN;
1626                                 sprintf(buf, "%3d.%d%%", p/10, p%10);
1627                                 c_put_str(attr, buf, 3+i, col+13);
1628                         }
1629
1630                         /* Never happened */
1631                         else
1632                         {
1633                                 c_put_str(TERM_RED, _("(なし)", "(NONE)"), 3+i, col+13);
1634                         }
1635                 }
1636         }
1637 }
1638
1639
1640 /*!
1641  * @brief ベースアイテム構造体の鑑定済みフラグをリセットする。
1642  * @return なし
1643  */
1644 static void k_info_reset(void)
1645 {
1646         int i;
1647
1648         /* Reset the "objects" */
1649         for (i = 1; i < max_k_idx; i++)
1650         {
1651                 object_kind *k_ptr = &k_info[i];
1652
1653                 /* Reset "tried" */
1654                 k_ptr->tried = FALSE;
1655
1656                 /* Reset "aware" */
1657                 k_ptr->aware = FALSE;
1658         }
1659 }
1660
1661
1662 /*!
1663  * @brief プレイヤー構造体の内容を初期値で消去する(名前を除く) / Clear all the global "character" data (without name)
1664  * @return なし
1665  */
1666 static void player_wipe_without_name(void)
1667 {
1668         int i;
1669         player_type tmp;
1670
1671         /* Temporary copy for migration - written back later */
1672         COPY(&tmp, p_ptr, player_type);
1673
1674         /* Hack -- free the "last message" string */
1675         if (p_ptr->last_message) string_free(p_ptr->last_message);
1676
1677         if (p_ptr->inventory_list != NULL) C_WIPE(p_ptr->inventory_list, INVEN_TOTAL, object_type);
1678
1679         /* Hack -- zero the struct */
1680         (void)WIPE(p_ptr, player_type);
1681
1682         C_MAKE(p_ptr->inventory_list, INVEN_TOTAL, object_type);
1683
1684         /* Wipe the history */
1685         for (i = 0; i < 4; i++)
1686         {
1687                 strcpy(p_ptr->history[i], "");
1688         }
1689
1690         /* Wipe the quests */
1691         for (i = 0; i < max_q_idx; i++)
1692         {
1693                 quest_type* const q_ptr = &quest[i];
1694                 
1695                 q_ptr->status = QUEST_STATUS_UNTAKEN;
1696
1697                 q_ptr->cur_num = 0;
1698                 q_ptr->max_num = 0;
1699                 q_ptr->type = 0;
1700                 q_ptr->level = 0;
1701                 q_ptr->r_idx = 0;
1702                 q_ptr->complev = 0;
1703                 q_ptr->comptime = 0;
1704         }
1705
1706         /* No weight */
1707         p_ptr->total_weight = 0;
1708
1709         /* No items */
1710         p_ptr->inven_cnt = 0;
1711         p_ptr->equip_cnt = 0;
1712
1713         /* Clear the inventory */
1714         for (i = 0; i < INVEN_TOTAL; i++)
1715         {
1716                 object_wipe(&p_ptr->inventory_list[i]);
1717         }
1718
1719         /* Start with no artifacts made yet */
1720         for (i = 0; i < max_a_idx; i++)
1721         {
1722                 artifact_type *a_ptr = &a_info[i];
1723                 a_ptr->cur_num = 0;
1724         }
1725
1726         /* Reset the objects */
1727         k_info_reset();
1728
1729         /* Reset the "monsters" */
1730         for (i = 1; i < max_r_idx; i++)
1731         {
1732                 monster_race *r_ptr = &r_info[i];
1733
1734                 /* Hack -- Reset the counter */
1735                 r_ptr->cur_num = 0;
1736
1737                 /* Hack -- Reset the max counter */
1738                 r_ptr->max_num = 100;
1739
1740                 /* Hack -- Reset the max counter */
1741                 if (r_ptr->flags1 & RF1_UNIQUE) r_ptr->max_num = 1;
1742
1743                 /* Hack -- Non-unique Nazguls are semi-unique */
1744                 else if (r_ptr->flags7 & RF7_NAZGUL) r_ptr->max_num = MAX_NAZGUL_NUM;
1745
1746                 /* Clear visible kills in this life */
1747                 r_ptr->r_pkills = 0;
1748
1749                 /* Clear all kills in this life */
1750                 r_ptr->r_akills = 0;
1751         }
1752
1753
1754         /* Hack -- Well fed player */
1755         p_ptr->food = PY_FOOD_FULL - 1;
1756
1757
1758         /* Wipe the spells */
1759         if (p_ptr->pclass == CLASS_SORCERER)
1760         {
1761                 p_ptr->spell_learned1 = p_ptr->spell_learned2 = 0xffffffffL;
1762                 p_ptr->spell_worked1 = p_ptr->spell_worked2 = 0xffffffffL;
1763         }
1764         else
1765         {
1766                 p_ptr->spell_learned1 = p_ptr->spell_learned2 = 0L;
1767                 p_ptr->spell_worked1 = p_ptr->spell_worked2 = 0L;
1768         }
1769         p_ptr->spell_forgotten1 = p_ptr->spell_forgotten2 = 0L;
1770         for (i = 0; i < 64; i++) p_ptr->spell_order[i] = 99;
1771         p_ptr->learned_spells = 0;
1772         p_ptr->add_spells = 0;
1773         p_ptr->knowledge = 0;
1774
1775         /* Clean the mutation count */
1776         p_ptr->mutant_regenerate_mod = 100;
1777
1778         /* Clear "cheat" options */
1779         cheat_peek = FALSE;
1780         cheat_hear = FALSE;
1781         cheat_room = FALSE;
1782         cheat_xtra = FALSE;
1783         cheat_know = FALSE;
1784         cheat_live = FALSE;
1785         cheat_save = FALSE;
1786         cheat_diary_output = FALSE;
1787         cheat_turn = FALSE;
1788
1789         /* Assume no winning game */
1790         p_ptr->total_winner = FALSE;
1791
1792         p_ptr->timewalk = FALSE;
1793
1794         /* Assume no panic save */
1795         p_ptr->panic_save = 0;
1796
1797         /* Assume no cheating */
1798         p_ptr->noscore = 0;
1799         p_ptr->wizard = FALSE;
1800
1801         /* Not waiting to report score */
1802         p_ptr->wait_report_score = FALSE;
1803
1804         /* Default pet command settings */
1805         p_ptr->pet_follow_distance = PET_FOLLOW_DIST;
1806         p_ptr->pet_extra_flags = (PF_TELEPORT | PF_ATTACK_SPELL | PF_SUMMON_SPELL);
1807
1808         /* Wipe the recall depths */
1809         for (i = 0; i < max_d_idx; i++)
1810         {
1811                 max_dlv[i] = 0;
1812         }
1813
1814         p_ptr->visit = 1;
1815
1816         /* Reset wild_mode to FALSE */
1817         p_ptr->wild_mode = FALSE;
1818
1819         for (i = 0; i < 108; i++)
1820         {
1821                 p_ptr->magic_num1[i] = 0;
1822                 p_ptr->magic_num2[i] = 0;
1823         }
1824
1825         /* Level one */
1826         p_ptr->max_plv = p_ptr->lev = 1;
1827
1828         /* Initialize arena and rewards information -KMW- */
1829         p_ptr->arena_number = 0;
1830         p_ptr->inside_arena = FALSE;
1831         p_ptr->inside_quest = 0;
1832         for (i = 0; i < MAX_MANE; i++)
1833         {
1834                 p_ptr->mane_spell[i] = -1;
1835                 p_ptr->mane_dam[i] = 0;
1836         }
1837         p_ptr->mane_num = 0;
1838         p_ptr->exit_bldg = TRUE; /* only used for arena now -KMW- */
1839
1840         /* Bounty */
1841         p_ptr->today_mon = 0;
1842
1843         /* Reset monster arena */
1844         update_gambling_monsters();
1845
1846         /* Reset mutations */
1847         p_ptr->muta1 = 0;
1848         p_ptr->muta2 = 0;
1849         p_ptr->muta3 = 0;
1850
1851         /* Reset virtues */
1852         for (i = 0; i < 8; i++) p_ptr->virtues[i]=0;
1853
1854         p_ptr->dungeon_idx = 0;
1855
1856         /* Set the recall dungeon accordingly */
1857         if (vanilla_town || ironman_downward)
1858         {
1859                 p_ptr->recall_dungeon = DUNGEON_ANGBAND;
1860         }
1861         else
1862         {
1863                 p_ptr->recall_dungeon = DUNGEON_GALGALS;
1864         }
1865
1866         /* Data migration */
1867         memcpy(p_ptr->name, tmp.name, sizeof(tmp.name));
1868 }
1869
1870
1871
1872 /*!
1873  * @brief ダンジョン内部のクエストを初期化する / Initialize random quests and final quests
1874  * @return なし
1875  */
1876 static void init_dungeon_quests(void)
1877 {
1878         int number_of_quests = MAX_RANDOM_QUEST - MIN_RANDOM_QUEST + 1;
1879         int i;
1880
1881         /* Init the random quests */
1882         init_flags = INIT_ASSIGN;
1883         p_ptr->inside_quest = MIN_RANDOM_QUEST;
1884
1885         process_dungeon_file("q_info.txt", 0, 0, 0, 0);
1886
1887         p_ptr->inside_quest = 0;
1888
1889         /* Generate quests */
1890         for (i = MIN_RANDOM_QUEST + number_of_quests - 1; i >= MIN_RANDOM_QUEST; i--)
1891         {
1892                 quest_type *q_ptr = &quest[i];
1893                 monster_race *quest_r_ptr;
1894
1895                 q_ptr->status = QUEST_STATUS_TAKEN;
1896                 determine_random_questor(q_ptr);
1897
1898                 /* Mark uniques */
1899                 quest_r_ptr = &r_info[q_ptr->r_idx];
1900                 quest_r_ptr->flags1 |= RF1_QUESTOR;
1901
1902                 q_ptr->max_num = 1;
1903         }
1904
1905         /* Init the two main quests (Oberon + Serpent) */
1906         init_flags = INIT_ASSIGN;
1907         p_ptr->inside_quest = QUEST_OBERON;
1908
1909         process_dungeon_file("q_info.txt", 0, 0, 0, 0);
1910
1911         quest[QUEST_OBERON].status = QUEST_STATUS_TAKEN;
1912
1913         p_ptr->inside_quest = QUEST_SERPENT;
1914
1915         process_dungeon_file("q_info.txt", 0, 0, 0, 0);
1916
1917         quest[QUEST_SERPENT].status = QUEST_STATUS_TAKEN;
1918         p_ptr->inside_quest = 0;
1919 }
1920
1921 /*!
1922  * @brief ゲームターンを初期化する / Reset current_world_ptr->game_turn
1923  * @details アンデッド系種族は開始時刻を夜からにする。
1924  * @return なし
1925  */
1926 static void init_turn(void)
1927 {
1928         if ((p_ptr->prace == RACE_VAMPIRE) ||
1929                 (p_ptr->prace == RACE_SKELETON) ||
1930                 (p_ptr->prace == RACE_ZOMBIE) ||
1931                 (p_ptr->prace == RACE_SPECTRE))
1932         {
1933                 /* Undead start just after midnight */
1934                 current_world_ptr->game_turn = (TURNS_PER_TICK*3 * TOWN_DAWN) / 4 + 1;
1935                 current_world_ptr->game_turn_limit = TURNS_PER_TICK * TOWN_DAWN * MAX_DAYS + TURNS_PER_TICK * TOWN_DAWN * 3 / 4;
1936         }
1937         else
1938         {
1939                 current_world_ptr->game_turn = 1;
1940                 current_world_ptr->game_turn_limit = TURNS_PER_TICK * TOWN_DAWN * (MAX_DAYS - 1) + TURNS_PER_TICK * TOWN_DAWN * 3 / 4;
1941         }
1942
1943         current_world_ptr->dungeon_turn = 1;
1944         current_world_ptr->dungeon_turn_limit = TURNS_PER_TICK * TOWN_DAWN * (MAX_DAYS - 1) + TURNS_PER_TICK * TOWN_DAWN * 3 / 4;
1945 }
1946
1947
1948 /*!
1949  * @brief 所持状態にあるアイテムの中から一部枠の装備可能なものを装備させる。
1950  * @details アンデッド系種族は開始時刻を夜からにする。
1951  * @return なし
1952  */
1953 static void wield_all(void) 
1954
1955         object_type *o_ptr; 
1956         object_type *i_ptr; 
1957         object_type object_type_body; 
1958  
1959         int slot; 
1960         INVENTORY_IDX item; 
1961  
1962         /* Scan through the slots backwards */ 
1963         for (item = INVEN_PACK - 1; item >= 0; item--) 
1964         { 
1965                 o_ptr = &p_ptr->inventory_list[item]; 
1966  
1967                 /* Skip non-objects */ 
1968                 if (!o_ptr->k_idx) continue; 
1969  
1970                 /* Make sure we can wield it and that there's nothing else in that slot */ 
1971                 slot = wield_slot(o_ptr); 
1972                 if (slot < INVEN_RARM) continue; 
1973                 if (slot == INVEN_LITE) continue; /* Does not wield toaches because buys a lantern soon */
1974                 if (p_ptr->inventory_list[slot].k_idx) continue; 
1975  
1976                 i_ptr = &object_type_body; 
1977                 object_copy(i_ptr, o_ptr); 
1978                 i_ptr->number = 1; 
1979  
1980                 /* Decrease the item (from the pack) */ 
1981                 if (item >= 0) 
1982                 { 
1983                         inven_item_increase(item, -1); 
1984                         inven_item_optimize(item); 
1985                 } 
1986  
1987                 /* Decrease the item (from the floor) */ 
1988                 else 
1989                 { 
1990                         floor_item_increase(0 - item, -1); 
1991                         floor_item_optimize(0 - item); 
1992                 } 
1993  
1994                 o_ptr = &p_ptr->inventory_list[slot]; 
1995                 object_copy(o_ptr, i_ptr); 
1996                 p_ptr->total_weight += i_ptr->weight; 
1997  
1998                 /* Increment the equip counter by hand */ 
1999                 p_ptr->equip_cnt++;
2000
2001         } 
2002         return; 
2003
2004
2005
2006 /*!
2007  * プレイヤーの職業毎の初期装備テーブル。/\n
2008  * Each player starts out with a few items, given as tval/sval pairs.\n
2009  * In addition, he always has some food and a few torches.\n
2010  */
2011 static byte player_init[MAX_CLASS][3][2] =
2012 {
2013         {
2014                 /* Warrior */
2015                 { TV_RING, SV_RING_RES_FEAR }, /* Warriors need it! */
2016                 { TV_HARD_ARMOR, SV_CHAIN_MAIL },
2017                 { TV_SWORD, SV_BROAD_SWORD }
2018         },
2019
2020         {
2021                 /* Mage */
2022                 { TV_SORCERY_BOOK, 0 }, /* Hack: for realm1 book */
2023                 { TV_DEATH_BOOK, 0 }, /* Hack: for realm2 book */
2024                 { TV_SWORD, SV_DAGGER }
2025         },
2026
2027         {
2028                 /* Priest */
2029                 { TV_SORCERY_BOOK, 0 }, /* Hack: for Life / Death book */
2030                 { TV_DEATH_BOOK, 0 }, /* Hack: for realm2 book */
2031                 { TV_HAFTED, SV_MACE }
2032         },
2033
2034         {
2035                 /* Rogue */
2036                 { TV_SORCERY_BOOK, 0 }, /* Hack: for realm1 book */
2037                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR },
2038                 { TV_SWORD, SV_DAGGER }
2039         },
2040
2041         {
2042                 /* Ranger */
2043                 { TV_NATURE_BOOK, 0 },
2044                 { TV_DEATH_BOOK, 0 },           /* Hack: for realm2 book */
2045                 { TV_SWORD, SV_DAGGER }
2046         },
2047
2048         {
2049                 /* Paladin */
2050                 { TV_SORCERY_BOOK, 0 },
2051                 { TV_SCROLL, SV_SCROLL_PROTECTION_FROM_EVIL },
2052                 { TV_SWORD, SV_BROAD_SWORD }
2053         },
2054
2055         {
2056                 /* Warrior-Mage */
2057                 { TV_SORCERY_BOOK, 0 }, /* Hack: for realm1 book */
2058                 { TV_DEATH_BOOK, 0 }, /* Hack: for realm2 book */
2059                 { TV_SWORD, SV_SHORT_SWORD }
2060         },
2061
2062         {
2063                 /* Chaos Warrior */
2064                 { TV_SORCERY_BOOK, 0 }, /* Hack: For realm1 book */
2065                 { TV_HARD_ARMOR, SV_METAL_SCALE_MAIL },
2066                 { TV_SWORD, SV_BROAD_SWORD }
2067         },
2068
2069         {
2070                 /* Monk */
2071                 { TV_SORCERY_BOOK, 0 },
2072                 { TV_POTION, SV_POTION_SPEED },
2073                 { TV_POTION, SV_POTION_HEROISM }
2074         },
2075
2076         {
2077                 /* Mindcrafter */
2078                 { TV_POTION, SV_POTION_SPEED },
2079                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR },
2080                 { TV_SWORD, SV_SMALL_SWORD }
2081         },
2082
2083         {
2084                 /* High Mage */
2085                 { TV_SORCERY_BOOK, 0 }, /* Hack: for realm1 book */
2086                 { TV_RING, SV_RING_SUSTAIN_INT},
2087                 { TV_SWORD, SV_DAGGER }
2088         },
2089
2090         {
2091                 /* Tourist */
2092                 { TV_FOOD, SV_FOOD_JERKY},
2093                 { TV_SCROLL, SV_SCROLL_MAPPING },
2094                 { TV_BOW, SV_SLING}
2095         },
2096
2097         {
2098                 /* Imitator */
2099                 { TV_POTION, SV_POTION_SPEED },
2100                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR },
2101                 { TV_SWORD, SV_SHORT_SWORD}
2102         },
2103
2104         {
2105                 /* Beastmaster */
2106                 { TV_TRUMP_BOOK, 0 },
2107                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR },
2108                 { TV_POLEARM, SV_SPEAR}
2109         },
2110
2111         {
2112                 /* Sorcerer */
2113                 { TV_HAFTED, SV_WIZSTAFF }, /* Hack: for realm1 book */
2114                 { TV_RING, SV_RING_SUSTAIN_INT},
2115                 { TV_WAND, SV_WAND_MAGIC_MISSILE }
2116         },
2117
2118         {
2119                 /* Archer */
2120                 { TV_BOW, SV_SHORT_BOW },
2121                 { TV_SOFT_ARMOR, SV_LEATHER_SCALE_MAIL},
2122                 { TV_SWORD, SV_SHORT_SWORD },
2123         },
2124
2125         {
2126                 /* Magic eater */
2127                 { TV_WAND, SV_WAND_MAGIC_MISSILE },
2128                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR},
2129                 { TV_SWORD, SV_SHORT_SWORD },
2130         },
2131
2132         {
2133                 /* Bard */
2134                 { TV_MUSIC_BOOK, 0 },
2135                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR},
2136                 { TV_SWORD, SV_SHORT_SWORD },
2137         },
2138
2139         {
2140                 /* Red Mage */
2141                 { TV_ARCANE_BOOK, 0 },
2142                 { TV_SOFT_ARMOR, SV_HARD_LEATHER_ARMOR},
2143                 { TV_SWORD, SV_SHORT_SWORD },
2144         },
2145
2146         {
2147                 /* Samurai */
2148                 { TV_HISSATSU_BOOK, 0 },
2149                 { TV_HARD_ARMOR, SV_CHAIN_MAIL },
2150                 { TV_SWORD, SV_BROAD_SWORD }
2151         },
2152
2153         {
2154                 /* ForceTrainer */
2155                 { TV_SORCERY_BOOK, 0 },
2156                 { TV_POTION, SV_POTION_SPEED },
2157                 { TV_POTION, SV_POTION_RESTORE_MANA }
2158         },
2159
2160         {
2161                 /* Blue Mage */
2162                 { TV_SOFT_ARMOR, SV_ROBE },
2163                 { TV_WAND, SV_WAND_MAGIC_MISSILE },
2164                 { TV_SWORD, SV_DAGGER }
2165         },
2166
2167         {
2168                 /* Cavalry */
2169                 { TV_BOW, SV_SHORT_BOW },
2170                 { TV_SOFT_ARMOR, SV_LEATHER_SCALE_MAIL},
2171                 { TV_POLEARM, SV_BROAD_SPEAR}
2172         },
2173
2174         {
2175                 /* Berserker */
2176                 { TV_POTION, SV_POTION_HEALING },
2177                 { TV_HARD_ARMOR, SV_AUGMENTED_CHAIN_MAIL },
2178                 { TV_POLEARM, SV_BROAD_AXE }
2179         },
2180
2181         {
2182                 /* Weaponsmith */
2183                 { TV_RING, SV_RING_RES_FEAR }, /* Warriors need it! */
2184                 { TV_HARD_ARMOR, SV_CHAIN_MAIL },
2185                 { TV_POLEARM, SV_BROAD_AXE }
2186         },
2187         {
2188                 /* Mirror-Master */
2189                 { TV_POTION, SV_POTION_SPEED },
2190                 { TV_RING, SV_RING_SUSTAIN_INT},
2191                 { TV_SWORD, SV_DAGGER }
2192         },
2193         {
2194                 /* Ninja */
2195                 { TV_POTION, SV_POTION_SPEED },
2196                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR },
2197                 { TV_SWORD, SV_DAGGER }
2198         },
2199         {
2200                 /* Sniper */
2201                 { TV_BOW, SV_LIGHT_XBOW },
2202                 { TV_SOFT_ARMOR, SV_SOFT_LEATHER_ARMOR },
2203                 { TV_SWORD, SV_DAGGER }
2204         },
2205 };
2206
2207 /*!
2208  * @brief 初期所持アイテムの処理 / Add an outfit object
2209  * @details アイテムを既知のものとした上でwield_all()関数により装備させる。
2210  * @param o_ptr 処理したいオブジェクト構造体の参照ポインタ
2211  * @return なし
2212  */
2213 static void add_outfit(object_type *o_ptr)
2214 {
2215         s16b slot;
2216
2217         object_aware(o_ptr);
2218         object_known(o_ptr);
2219         slot = inven_carry(o_ptr);
2220
2221         /* Auto-inscription */
2222         autopick_alter_item(slot, FALSE);
2223
2224         /* Now try wielding everything */ 
2225         wield_all(); 
2226 }
2227
2228
2229 /*!
2230  * @brief 種族/職業/性格などに基づき初期所持アイテムを設定するメインセット関数。 / Init players with some belongings
2231  * @details Having an item makes the player "aware" of its purpose.
2232  * @return なし
2233  */
2234 void player_outfit(void)
2235 {
2236         int i;
2237         OBJECT_TYPE_VALUE tv;
2238         OBJECT_SUBTYPE_VALUE sv;
2239
2240         object_type     forge;
2241         object_type     *q_ptr;
2242
2243         q_ptr = &forge;
2244
2245         /* Give the player some food */
2246         switch (p_ptr->prace)
2247         {
2248         case RACE_VAMPIRE:
2249                 /* Nothing! */
2250                 /* Vampires can drain blood of creatures */
2251                 break;
2252
2253         case RACE_DEMON:
2254                 /* Demon can drain vitality from humanoid corpse */
2255                 get_mon_num_prep(monster_hook_human, NULL);
2256
2257                 for (i = rand_range(3,4); i > 0; i--)
2258                 {
2259                         object_prep(q_ptr, lookup_kind(TV_CORPSE, SV_CORPSE));
2260                         q_ptr->pval = get_mon_num(2);
2261                         if(q_ptr->pval)
2262                         {
2263                                 q_ptr->number = 1;
2264                                 add_outfit(q_ptr);
2265                         }
2266                 }
2267                 break;
2268
2269         case RACE_SKELETON:
2270         case RACE_GOLEM:
2271         case RACE_ZOMBIE:
2272         case RACE_SPECTRE:
2273                 /* Staff (of Nothing) */
2274                 object_prep(q_ptr, lookup_kind(TV_STAFF, SV_STAFF_NOTHING));
2275                 q_ptr->number = 1;
2276
2277                 add_outfit(q_ptr);
2278                 break;
2279
2280         case RACE_ENT:
2281                 /* Potions of Water */
2282                 object_prep(q_ptr, lookup_kind(TV_POTION, SV_POTION_WATER));
2283                 q_ptr->number = (ITEM_NUMBER)rand_range(15, 23);
2284                 add_outfit(q_ptr);
2285
2286                 break;
2287
2288         case RACE_ANDROID:
2289                 /* Flasks of oil */
2290                 object_prep(q_ptr, lookup_kind(TV_FLASK, SV_ANY));
2291
2292                 /* Fuel with oil (move pval to xtra4) */
2293                 apply_magic(q_ptr, 1, AM_NO_FIXED_ART);
2294
2295                 q_ptr->number = (ITEM_NUMBER)rand_range(7, 12);
2296                 add_outfit(q_ptr);
2297
2298                 break;
2299
2300         default:
2301                 /* Food rations */
2302                 object_prep(q_ptr, lookup_kind(TV_FOOD, SV_FOOD_RATION));
2303                 q_ptr->number = (ITEM_NUMBER)rand_range(3, 7);
2304
2305                 add_outfit(q_ptr);
2306         }
2307         q_ptr = &forge;
2308
2309         if ((p_ptr->prace == RACE_VAMPIRE) && (p_ptr->pclass != CLASS_NINJA))
2310         {
2311                 /* Hack -- Give the player scrolls of DARKNESS! */
2312                 object_prep(q_ptr, lookup_kind(TV_SCROLL, SV_SCROLL_DARKNESS));
2313
2314                 q_ptr->number = (ITEM_NUMBER)rand_range(2, 5);
2315
2316                 add_outfit(q_ptr);
2317         }
2318         else if (p_ptr->pclass != CLASS_NINJA)
2319         {
2320                 /* Hack -- Give the player some torches */
2321                 object_prep(q_ptr, lookup_kind(TV_LITE, SV_LITE_TORCH));
2322                 q_ptr->number = (ITEM_NUMBER)rand_range(3, 7);
2323                 q_ptr->xtra4 = rand_range(3, 7) * 500;
2324
2325                 add_outfit(q_ptr);
2326         }
2327         q_ptr = &forge;
2328
2329         if (p_ptr->prace == RACE_MERFOLK)
2330         {
2331                 object_prep(q_ptr, lookup_kind(TV_RING, SV_RING_LEVITATION_FALL));
2332                 q_ptr->number = 1;
2333                 add_outfit(q_ptr);
2334         }
2335
2336         if ((p_ptr->pclass == CLASS_RANGER) || (p_ptr->pclass == CLASS_CAVALRY))
2337         {
2338                 /* Hack -- Give the player some arrows */
2339                 object_prep(q_ptr, lookup_kind(TV_ARROW, SV_AMMO_NORMAL));
2340                 q_ptr->number = (byte)rand_range(15, 20);
2341
2342                 add_outfit(q_ptr);
2343         }
2344         if (p_ptr->pclass == CLASS_RANGER)
2345         {
2346                 /* Hack -- Give the player some arrows */
2347                 object_prep(q_ptr, lookup_kind(TV_BOW, SV_SHORT_BOW));
2348
2349                 add_outfit(q_ptr);
2350         }
2351         else if (p_ptr->pclass == CLASS_ARCHER)
2352         {
2353                 /* Hack -- Give the player some arrows */
2354                 object_prep(q_ptr, lookup_kind(TV_ARROW, SV_AMMO_NORMAL));
2355                 q_ptr->number = (ITEM_NUMBER)rand_range(15, 20);
2356
2357                 add_outfit(q_ptr);
2358         }
2359         else if (p_ptr->pclass == CLASS_HIGH_MAGE)
2360         {
2361                 /* Hack -- Give the player some arrows */
2362                 object_prep(q_ptr, lookup_kind(TV_WAND, SV_WAND_MAGIC_MISSILE));
2363                 q_ptr->number = 1;
2364                 q_ptr->pval = (PARAMETER_VALUE)rand_range(25, 30);
2365
2366                 add_outfit(q_ptr);
2367         }
2368         else if (p_ptr->pclass == CLASS_SORCERER)
2369         {
2370                 OBJECT_TYPE_VALUE book_tval;
2371                 for (book_tval = TV_LIFE_BOOK; book_tval <= TV_LIFE_BOOK+MAX_MAGIC-1; book_tval++)
2372                 {
2373                         /* Hack -- Give the player some arrows */
2374                         object_prep(q_ptr, lookup_kind(book_tval, 0));
2375                         q_ptr->number = 1;
2376
2377                         add_outfit(q_ptr);
2378                 }
2379         }
2380         else if (p_ptr->pclass == CLASS_TOURIST)
2381         {
2382                 if (p_ptr->pseikaku != SEIKAKU_SEXY)
2383                 {
2384                         /* Hack -- Give the player some arrows */
2385                         object_prep(q_ptr, lookup_kind(TV_SHOT, SV_AMMO_LIGHT));
2386                         q_ptr->number = rand_range(15, 20);
2387
2388                         add_outfit(q_ptr);
2389                 }
2390
2391                 object_prep(q_ptr, lookup_kind(TV_FOOD, SV_FOOD_BISCUIT));
2392                 q_ptr->number = rand_range(2, 4);
2393
2394                 add_outfit(q_ptr);
2395
2396                 object_prep(q_ptr, lookup_kind(TV_FOOD, SV_FOOD_WAYBREAD));
2397                 q_ptr->number = rand_range(2, 4);
2398
2399                 add_outfit(q_ptr);
2400
2401                 object_prep(q_ptr, lookup_kind(TV_FOOD, SV_FOOD_JERKY));
2402                 q_ptr->number = rand_range(1, 3);
2403
2404                 add_outfit(q_ptr);
2405
2406                 object_prep(q_ptr, lookup_kind(TV_FOOD, SV_FOOD_PINT_OF_ALE));
2407                 q_ptr->number = rand_range(2, 4);
2408
2409                 add_outfit(q_ptr);
2410
2411                 object_prep(q_ptr, lookup_kind(TV_FOOD, SV_FOOD_PINT_OF_WINE));
2412                 q_ptr->number = rand_range(2, 4);
2413
2414                 add_outfit(q_ptr);
2415         }
2416         else if (p_ptr->pclass == CLASS_NINJA)
2417         {
2418                 /* Hack -- Give the player some arrows */
2419                 object_prep(q_ptr, lookup_kind(TV_SPIKE, 0));
2420                 q_ptr->number = rand_range(15, 20);
2421
2422                 add_outfit(q_ptr);
2423         }
2424         else if (p_ptr->pclass == CLASS_SNIPER)
2425         {
2426                 /* Hack -- Give the player some bolts */
2427                 object_prep(q_ptr, lookup_kind(TV_BOLT, SV_AMMO_NORMAL));
2428                 q_ptr->number = rand_range(15, 20);
2429
2430                 add_outfit(q_ptr);
2431         }
2432
2433         if(p_ptr->pseikaku == SEIKAKU_SEXY)
2434         {
2435                 player_init[p_ptr->pclass][2][0] = TV_HAFTED;
2436                 player_init[p_ptr->pclass][2][1] = SV_WHIP;
2437         }
2438
2439         /* Hack -- Give the player three useful objects */
2440         for (i = 0; i < 3; i++)
2441         {
2442                 /* Look up standard equipment */
2443                 tv = player_init[p_ptr->pclass][i][0];
2444                 sv = player_init[p_ptr->pclass][i][1];
2445
2446                 if ((p_ptr->prace == RACE_ANDROID) && ((tv == TV_SOFT_ARMOR) || (tv == TV_HARD_ARMOR))) continue;
2447                 /* Hack to initialize spellbooks */
2448                 if (tv == TV_SORCERY_BOOK) tv = TV_LIFE_BOOK + p_ptr->realm1 - 1;
2449                 else if (tv == TV_DEATH_BOOK) tv = TV_LIFE_BOOK + p_ptr->realm2 - 1;
2450
2451                 else if (tv == TV_RING && sv == SV_RING_RES_FEAR &&
2452                     p_ptr->prace == RACE_BARBARIAN)
2453                         /* Barbarians do not need a ring of resist fear */
2454                         sv = SV_RING_SUSTAIN_STR;
2455
2456                 else if (tv == TV_RING && sv == SV_RING_SUSTAIN_INT && p_ptr->prace == RACE_MIND_FLAYER)
2457                 {
2458                         tv = TV_POTION;
2459                         sv = SV_POTION_RESTORE_MANA;
2460                 }
2461                 q_ptr = &forge;
2462
2463                 /* Hack -- Give the player an object */
2464                 object_prep(q_ptr, lookup_kind(tv, sv));
2465
2466                 /* Assassins begin the game with a poisoned dagger */
2467                 if ((tv == TV_SWORD || tv == TV_HAFTED) && (p_ptr->pclass == CLASS_ROGUE &&
2468                         p_ptr->realm1 == REALM_DEATH)) /* Only assassins get a poisoned weapon */
2469                 {
2470                         q_ptr->name2 = EGO_BRAND_POIS;
2471                 }
2472
2473                 add_outfit(q_ptr);
2474         }
2475
2476         /* Hack -- make aware of the water */
2477         k_info[lookup_kind(TV_POTION, SV_POTION_WATER)].aware = TRUE;
2478 }
2479
2480 /*!
2481  * @brief プレイヤーの種族選択を行う / Player race
2482  * @return なし
2483  */
2484 static bool get_player_race(void)
2485 {
2486         int     k, n, cs, os;
2487         concptr    str;
2488         char    c;
2489         char    sym[MAX_RACES];
2490         char    p2 = ')';
2491         char    buf[80], cur[80];
2492
2493         /* Extra info */
2494         clear_from(10);
2495         put_str(_("注意:《種族》によってキャラクターの先天的な資質やボーナスが変化します。",
2496                 "Note: Your 'race' determines various intrinsic factors and bonuses."), 23, 5);
2497
2498         /* Dump races */
2499         for (n = 0; n < MAX_RACES; n++)
2500         {
2501                 /* Analyze */
2502                 rp_ptr = &race_info[n];
2503                 str = rp_ptr->title;
2504
2505                 /* Display */
2506                 if (n < 26)
2507                         sym[n] = I2A(n);
2508                 else
2509                         sym[n] = ('A' + n - 26);
2510                 sprintf(buf, "%c%c%s", sym[n], p2, str);
2511                 put_str(buf, 12 + (n / 5), 1 + 16 * (n % 5));
2512
2513         }
2514
2515         sprintf(cur, "%c%c%s", '*', p2, _("ランダム", "Random"));
2516
2517         /* Choose */
2518         k = -1;
2519         cs = p_ptr->prace;
2520         os = MAX_RACES;
2521         while (1)
2522         {
2523                 /* Move Cursol */
2524                 if (cs != os)
2525                 {
2526                         c_put_str(TERM_WHITE, cur, 12 + (os/5), 1 + 16 * (os%5));
2527                         put_str("                                   ", 3, 40);
2528                         if(cs == MAX_RACES)
2529                         {
2530                                 sprintf(cur, "%c%c%s", '*', p2, _("ランダム", "Random"));
2531                                 put_str("                                   ", 4, 40);
2532                                 put_str("                                   ", 5, 40);
2533                         }
2534                         else
2535                         {
2536                                 rp_ptr = &race_info[cs];
2537                                 str = rp_ptr->title;
2538                                 sprintf(cur, "%c%c%s", sym[cs], p2, str);
2539                                 c_put_str(TERM_L_BLUE, rp_ptr->title, 3, 40);
2540                                 put_str(_("腕力 知能 賢さ 器用 耐久 魅力 経験 ", "Str  Int  Wis  Dex  Con  Chr   EXP "), 4, 40);
2541                                 put_str(_("の種族修正", ": Race modification"), 3, 40 + strlen(rp_ptr->title));
2542
2543                                 sprintf(buf, "%+3d  %+3d  %+3d  %+3d  %+3d  %+3d %+4d%% ",
2544                                         rp_ptr->r_adj[0], rp_ptr->r_adj[1], rp_ptr->r_adj[2], rp_ptr->r_adj[3],
2545                                         rp_ptr->r_adj[4], rp_ptr->r_adj[5], (rp_ptr->r_exp - 100));
2546                                 c_put_str(TERM_L_BLUE, buf, 5, 40);
2547                         }
2548                         c_put_str(TERM_YELLOW, cur, 12 + (cs/5), 1 + 16 * (cs%5));
2549                         os = cs;
2550                 }
2551
2552                 if (k >= 0) break;
2553
2554                 sprintf(buf, _("種族を選んで下さい (%c-%c) ('='初期オプション設定): ", "Choose a race (%c-%c) ('=' for options): "), sym[0], sym[MAX_RACES-1]);
2555
2556                 put_str(buf, 10, 10);
2557                 c = inkey();
2558                 if (c == 'Q') birth_quit();
2559                 if (c == 'S') return (FALSE);
2560                 if (c == ' ' || c == '\r' || c == '\n')
2561                 {
2562                         if(cs == MAX_RACES)
2563                         {
2564                                 k = randint0(MAX_RACES);
2565                                 cs = k;
2566                                 continue;
2567                         }
2568                         else
2569                         {
2570                                 k = cs;
2571                                 break;
2572                         }
2573                 }
2574                 if (c == '*')
2575                 {
2576                         k = randint0(MAX_RACES);
2577                         cs = k;
2578                         continue;
2579                 }
2580                 if (c == '8')
2581                 {
2582                         if (cs >= 5) cs -= 5;
2583                 }
2584                 if (c == '4')
2585                 {
2586                         if (cs > 0) cs--;
2587                 }
2588                 if (c == '6')
2589                 {
2590                         if (cs < MAX_RACES) cs++;
2591                 }
2592                 if (c == '2')
2593                 {
2594                         if ((cs + 5) <= MAX_RACES) cs += 5;
2595                 }
2596                 k = (islower(c) ? A2I(c) : -1);
2597                 if ((k >= 0) && (k < MAX_RACES))
2598                 {
2599                         cs = k;
2600                         continue;
2601                 }
2602                 k = (isupper(c) ? (26 + c - 'A') : -1);
2603                 if ((k >= 26) && (k < MAX_RACES))
2604                 {
2605                         cs = k;
2606                         continue;
2607                 }
2608                 else k = -1;
2609                 if (c == '?')
2610                 {
2611 #ifdef JP
2612                         show_help("jraceclas.txt#TheRaces");
2613 #else
2614                         show_help("raceclas.txt#TheRaces");
2615 #endif
2616                 }
2617                 else if (c == '=')
2618                 {
2619                         screen_save();
2620                         do_cmd_options_aux(OPT_PAGE_BIRTH, _("初期オプション((*)はスコアに影響)", "Birth Option((*)s effect score)"));
2621                         screen_load();
2622                 }
2623                 else if (c !='2' && c !='4' && c !='6' && c !='8') bell();
2624         }
2625
2626         /* Set race */
2627         p_ptr->prace = (byte_hack)k;
2628
2629         rp_ptr = &race_info[p_ptr->prace];
2630
2631         /* Display */
2632         c_put_str(TERM_L_BLUE, rp_ptr->title, 4, 15);
2633
2634         /* Success */
2635         return TRUE;
2636 }
2637
2638
2639 /*!
2640  * @brief プレイヤーの職業選択を行う / Player class
2641  * @return なし
2642  */
2643 static bool get_player_class(void)
2644 {
2645         int     k, n, cs, os;
2646         char    c;
2647         char    sym[MAX_CLASS_CHOICE];
2648         char    p2 = ')';
2649         char    buf[80], cur[80];
2650         concptr    str;
2651
2652
2653         /* Extra info */
2654         clear_from(10);
2655         put_str(_("注意:《職業》によってキャラクターの先天的な能力やボーナスが変化します。",
2656                 "Note: Your 'class' determines various intrinsic abilities and bonuses."), 23, 5);
2657
2658         put_str(_("()で囲まれた選択肢はこの種族には似合わない職業です。", 
2659                 "Any entries in parentheses should only be used by advanced players."), 11, 5);
2660
2661
2662         /* Dump classes */
2663         for (n = 0; n < MAX_CLASS_CHOICE; n++)
2664         {
2665                 /* Analyze */
2666                 cp_ptr = &class_info[n];
2667                 mp_ptr = &m_info[n];
2668                 str = cp_ptr->title;
2669                 if (n < 26)
2670                         sym[n] = I2A(n);
2671                 else
2672                         sym[n] = ('A' + n - 26);
2673
2674                 /* Display */
2675                 if (!(rp_ptr->choice & (1L << n)))
2676                         sprintf(buf, "%c%c(%s)", sym[n], p2, str);
2677                 else
2678                         sprintf(buf, "%c%c%s", sym[n], p2, str);
2679
2680                 put_str(buf, 13+ (n/4), 2 + 19 * (n%4));
2681         }
2682
2683         sprintf(cur, "%c%c%s", '*', p2, _("ランダム", "Random"));
2684
2685         /* Get a class */
2686         k = -1;
2687         cs = p_ptr->pclass;
2688         os = MAX_CLASS_CHOICE;
2689         while (1)
2690         {
2691                 /* Move Cursol */
2692                 if (cs != os)
2693                 {
2694                         c_put_str(TERM_WHITE, cur, 13 + (os/4), 2 + 19 * (os%4));
2695                         put_str("                                   ", 3, 40);
2696                         if(cs == MAX_CLASS_CHOICE)
2697                         {
2698                                 sprintf(cur, "%c%c%s", '*', p2, _("ランダム", "Random"));
2699                                 put_str("                                   ", 4, 40);
2700                                 put_str("                                   ", 5, 40);
2701                         }
2702                         else
2703                         {
2704                                 cp_ptr = &class_info[cs];
2705                                 mp_ptr = &m_info[cs];
2706                                 str = cp_ptr->title;
2707                                 if (!(rp_ptr->choice & (1L << cs)))
2708                                         sprintf(cur, "%c%c(%s)", sym[cs], p2, str);
2709                                 else
2710                                         sprintf(cur, "%c%c%s", sym[cs], p2, str);
2711
2712                                 c_put_str(TERM_L_BLUE, cp_ptr->title, 3, 40);
2713                                 put_str(_("の職業修正", ": Class modification"), 3, 40 + strlen(cp_ptr->title));
2714                                 put_str(_("腕力 知能 賢さ 器用 耐久 魅力 経験 ", "Str  Int  Wis  Dex  Con  Chr   EXP "), 4, 40);
2715                                 sprintf(buf, "%+3d  %+3d  %+3d  %+3d  %+3d  %+3d %+4d%% ",
2716                                         cp_ptr->c_adj[0], cp_ptr->c_adj[1], cp_ptr->c_adj[2], cp_ptr->c_adj[3],
2717                                         cp_ptr->c_adj[4], cp_ptr->c_adj[5], cp_ptr->c_exp);
2718                                 c_put_str(TERM_L_BLUE, buf, 5, 40);
2719                         }
2720                         c_put_str(TERM_YELLOW, cur, 13 + (cs / 4), 2 + 19 * (cs % 4));
2721                         os = cs;
2722                 }
2723
2724                 if (k >= 0) break;
2725
2726                 sprintf(buf, _("職業を選んで下さい (%c-%c) ('='初期オプション設定): ", "Choose a class (%c-%c) ('=' for options): "), sym[0], sym[MAX_CLASS_CHOICE-1]);
2727
2728                 put_str(buf, 10, 10);
2729                 c = inkey();
2730                 if (c == 'Q') birth_quit();
2731                 if (c == 'S') return (FALSE);
2732                 if (c == ' ' || c == '\r' || c == '\n')
2733                 {
2734                         if(cs == MAX_CLASS_CHOICE)
2735                         {
2736                                 k = randint0(MAX_CLASS_CHOICE);
2737                                 cs = k;
2738                                 continue;
2739                         }
2740                         else
2741                         {
2742                                 k = cs;
2743                                 break;
2744                         }
2745                 }
2746                 if (c == '*')
2747                 {
2748                         k = randint0(MAX_CLASS_CHOICE);
2749                         cs = k;
2750                         continue;
2751                 }
2752                 if (c == '8')
2753                 {
2754                         if (cs >= 4) cs -= 4;
2755                 }
2756                 if (c == '4')
2757                 {
2758                         if (cs > 0) cs--;
2759                 }
2760                 if (c == '6')
2761                 {
2762                         if (cs < MAX_CLASS_CHOICE) cs++;
2763                 }
2764                 if (c == '2')
2765                 {
2766                         if ((cs + 4) <= MAX_CLASS_CHOICE) cs += 4;
2767                 }
2768                 k = (islower(c) ? A2I(c) : -1);
2769                 if ((k >= 0) && (k < MAX_CLASS_CHOICE))
2770                 {
2771                         cs = k;
2772                         continue;
2773                 }
2774                 k = (isupper(c) ? (26 + c - 'A') : -1);
2775                 if ((k >= 26) && (k < MAX_CLASS_CHOICE))
2776                 {
2777                         cs = k;
2778                         continue;
2779                 }
2780                 else k = -1;
2781                 if (c == '?')
2782                 {
2783 #ifdef JP
2784                         show_help("jraceclas.txt#TheClasses");
2785 #else
2786                         show_help("raceclas.txt#TheClasses");
2787 #endif
2788                 }
2789                 else if (c == '=')
2790                 {
2791                         screen_save();
2792                         do_cmd_options_aux(OPT_PAGE_BIRTH, _("初期オプション((*)はスコアに影響)", "Birth Option((*)s effect score)"));
2793                         screen_load();
2794                 }
2795                 else if (c !='2' && c !='4' && c !='6' && c !='8') bell();
2796         }
2797
2798         /* Set class */
2799         p_ptr->pclass = (byte_hack)k;
2800         cp_ptr = &class_info[p_ptr->pclass];
2801         mp_ptr = &m_info[p_ptr->pclass];
2802
2803         /* Display */
2804         c_put_str(TERM_L_BLUE, cp_ptr->title, 5, 15);
2805
2806         return TRUE;
2807 }
2808
2809
2810 /*!
2811  * @brief プレイヤーの性格選択を行う / Player Player seikaku
2812  * @return なし
2813  */
2814 static bool get_player_seikaku(void)
2815 {
2816         int k;
2817         int n, os, cs;
2818         char c;
2819         char sym[MAX_SEIKAKU];
2820         char p2 = ')';
2821         char buf[80], cur[80];
2822         char tmp[64];
2823         concptr str;
2824
2825         /* Extra info */
2826         clear_from(10);
2827         put_str(_("注意:《性格》によってキャラクターの能力やボーナスが変化します。", "Note: Your personality determines various intrinsic abilities and bonuses."), 23, 5);
2828
2829         /* Dump seikakus */
2830         for (n = 0; n < MAX_SEIKAKU; n++)
2831         {
2832                 if(seikaku_info[n].sex && (seikaku_info[n].sex != (p_ptr->psex+1))) continue;
2833
2834                 /* Analyze */
2835                 ap_ptr = &seikaku_info[n];
2836                 str = ap_ptr->title;
2837                 if (n < 26)
2838                         sym[n] = I2A(n);
2839                 else
2840                         sym[n] = ('A' + n - 26);
2841
2842                 /* Display */
2843                 sprintf(buf, "%c%c%s", I2A(n), p2, str);
2844                 put_str(buf, 12 + (n/4), 2 + 18 * (n%4));
2845         }
2846
2847         sprintf(cur, "%c%c%s", '*', p2, _("ランダム", "Random"));
2848
2849         /* Get a seikaku */
2850         k = -1;
2851         cs = p_ptr->pseikaku;
2852         os = MAX_SEIKAKU;
2853         while (1)
2854         {
2855                 /* Move Cursol */
2856                 if (cs != os)
2857                 {
2858                         c_put_str(TERM_WHITE, cur, 12 + (os/4), 2 + 18 * (os%4));
2859                         put_str("                                   ", 3, 40);
2860                         if(cs == MAX_SEIKAKU)
2861                         {
2862                                 sprintf(cur, "%c%c%s", '*', p2, _("ランダム", "Random"));
2863                                 put_str("                                   ", 4, 40);
2864                                 put_str("                                   ", 5, 40);
2865                         }
2866                         else
2867                         {
2868                                 ap_ptr = &seikaku_info[cs];
2869                                 str = ap_ptr->title;
2870                                 sprintf(cur, "%c%c%s", sym[cs], p2, str);
2871                                 c_put_str(TERM_L_BLUE, ap_ptr->title, 3, 40);
2872                                 put_str(_("の性格修正", ": Personality modification"), 3, 40+strlen(ap_ptr->title));
2873                                 put_str(_("腕力 知能 賢さ 器用 耐久 魅力      ", "Str  Int  Wis  Dex  Con  Chr       "), 4, 40);
2874                                 sprintf(buf, "%+3d  %+3d  %+3d  %+3d  %+3d  %+3d       ",
2875                                         ap_ptr->a_adj[0], ap_ptr->a_adj[1], ap_ptr->a_adj[2], ap_ptr->a_adj[3],
2876                                         ap_ptr->a_adj[4], ap_ptr->a_adj[5]);
2877                                 c_put_str(TERM_L_BLUE, buf, 5, 40);
2878                         }
2879                         c_put_str(TERM_YELLOW, cur, 12 + (cs/4), 2 + 18 * (cs%4));
2880                         os = cs;
2881                 }
2882
2883                 if (k >= 0) break;
2884
2885                 sprintf(buf, _("性格を選んで下さい (%c-%c) ('='初期オプション設定): ", "Choose a personality (%c-%c) ('=' for options): "), sym[0], sym[MAX_SEIKAKU-1]);
2886
2887                 put_str(buf, 10, 10);
2888                 c = inkey();
2889                 if (c == 'Q') birth_quit();
2890                 if (c == 'S') return (FALSE);
2891                 if (c == ' ' || c == '\r' || c == '\n')
2892                 {
2893                         if(cs == MAX_SEIKAKU)
2894                         {
2895                                 do
2896                                 {
2897                                         k = randint0(MAX_SEIKAKU);
2898                                 }
2899                                 while(seikaku_info[k].sex && (seikaku_info[k].sex != (p_ptr->psex+1)));
2900                                 cs = k;
2901                                 continue;
2902                         }
2903                         else
2904                         {
2905                                 k = cs;
2906                                 break;
2907                         }
2908                 }
2909                 if (c == '*')
2910                 {
2911                         do
2912                         {
2913                                 k = randint0(n);
2914                         }
2915                         while(seikaku_info[k].sex && (seikaku_info[k].sex != (p_ptr->psex+1)));
2916                         cs = k;
2917                         continue;
2918                 }
2919                 if (c == '8')
2920                 {
2921                         if (cs >= 4) cs -= 4;
2922                         if (cs != MAX_SEIKAKU && seikaku_info[cs].sex && (seikaku_info[cs].sex != (p_ptr->psex+1)))
2923                         {
2924                                 if((cs - 4) > 0)
2925                                         cs -= 4;
2926                                 else
2927                                         cs += 4;
2928                         }
2929                 }
2930                 if (c == '4')
2931                 {
2932                         if (cs > 0) cs--;
2933                         if (cs != MAX_SEIKAKU && seikaku_info[cs].sex && (seikaku_info[cs].sex != (p_ptr->psex+1)))
2934                         {
2935                                 if((cs - 1) > 0)
2936                                         cs--;
2937                                 else
2938                                         cs++;
2939                         }
2940                 }
2941                 if (c == '6')
2942                 {
2943                         if (cs < MAX_SEIKAKU) cs++;
2944                         if (cs != MAX_SEIKAKU && seikaku_info[cs].sex && (seikaku_info[cs].sex != (p_ptr->psex+1)))
2945                         {
2946                                 if((cs + 1) <= MAX_SEIKAKU)
2947                                         cs++;
2948                                 else
2949                                         cs--;
2950                         }
2951                 }
2952                 if (c == '2')
2953                 {
2954                         if ((cs + 4) <= MAX_SEIKAKU) cs += 4;
2955                         if (cs != MAX_SEIKAKU && seikaku_info[cs].sex && (seikaku_info[cs].sex != (p_ptr->psex+1)))
2956                         {
2957                                 if((cs + 4) <= MAX_SEIKAKU)
2958                                         cs += 4;
2959                                 else
2960                                         cs -= 4;
2961                         }
2962                 }
2963                 k = (islower(c) ? A2I(c) : -1);
2964                 if ((k >= 0) && (k < MAX_SEIKAKU))
2965                 {
2966                         if((seikaku_info[k].sex == 0) || (seikaku_info[k].sex == (p_ptr->psex+1)))
2967                         {
2968                                 cs = k;
2969                                 continue;
2970                         }
2971                 }
2972                 k = (isupper(c) ? (26 + c - 'A') : -1);
2973                 if ((k >= 26) && (k < MAX_SEIKAKU))
2974                 {
2975                         if((seikaku_info[k].sex == 0) || (seikaku_info[k].sex == (p_ptr->psex+1)))
2976                         {
2977                                 cs = k;
2978                                 continue;
2979                         }
2980                 }
2981                 else k = -1;
2982                 if (c == '?')
2983                 {
2984 #ifdef JP
2985                         show_help("jraceclas.txt#ThePersonalities");
2986 #else
2987                         show_help("raceclas.txt#ThePersonalities");
2988 #endif
2989                 }
2990                 else if (c == '=')
2991                 {
2992                         screen_save();
2993                         do_cmd_options_aux(OPT_PAGE_BIRTH, _("初期オプション((*)はスコアに影響)", "Birth Option((*)s effect score)"));
2994                         screen_load();
2995                 }
2996                 else if (c !='2' && c !='4' && c !='6' && c !='8') bell();
2997         }
2998
2999         /* Set seikaku */
3000         p_ptr->pseikaku = (CHARACTER_IDX)k;
3001         ap_ptr = &seikaku_info[p_ptr->pseikaku];
3002 #ifdef JP
3003         strcpy(tmp, ap_ptr->title);
3004         if(ap_ptr->no == 1)
3005         strcat(tmp,"の");
3006 #else
3007         strcpy(tmp, ap_ptr->title);
3008         strcat(tmp," ");
3009 #endif
3010         strcat(tmp,p_ptr->name);
3011
3012         c_put_str(TERM_L_BLUE, tmp, 1, 34);
3013
3014         return TRUE;
3015 }
3016
3017 #ifdef ALLOW_AUTOROLLER
3018 /*!
3019  * @brief オートローラで得たい能力値の基準を決める。
3020  * @return なし
3021  */
3022 static bool get_stat_limits(void)
3023 {
3024         int i, j, m, cs, os;
3025         int cval[6];
3026         char c;
3027         char buf[80], cur[80];
3028         char inp[80];
3029
3030         /* Clean up */
3031         clear_from(10);
3032
3033         /* Extra infomation */
3034         put_str(_("最低限得たい能力値を設定して下さい。", "Set minimum stats."), 10, 10);
3035         put_str(_("2/8で項目選択、4/6で値の増減、Enterで次へ", "2/8 for Select, 4/6 for Change value, Enter for Goto next"), 11, 10);
3036         
3037         put_str(_("         基本値  種族 職業 性格     合計値  最大値", "           Base   Rac  Cla  Per      Total  Maximum"), 13, 10);
3038
3039         /* Output the maximum stats */
3040         for (i = 0; i < A_MAX; i++)
3041         {
3042                 /* Reset the "success" counter */
3043                 stat_match[i] = 0;
3044                 cval[i] = 3;
3045
3046                 /* Race/Class bonus */
3047                 j = rp_ptr->r_adj[i] + cp_ptr->c_adj[i] + ap_ptr->a_adj[i];
3048
3049                 /* Obtain the "maximal" stat */
3050                 m = adjust_stat(17, j);
3051
3052                 /* Above 18 */
3053                 if (m > 18)
3054                 {
3055                         sprintf(cur, "18/%02d", (m - 18));
3056                 }
3057                 
3058                 /* From 3 to 18 */
3059                 else
3060                 {
3061                         sprintf(cur, "%2d", m);
3062                 }
3063
3064                 /* Obtain the current stat */
3065                 m = adjust_stat(cval[i], j);
3066
3067                 /* Above 18 */
3068                 if (m > 18)
3069                 {
3070                         sprintf(inp, "18/%02d", (m - 18));
3071                 }
3072                 
3073                 /* From 3 to 18 */
3074                 else
3075                 {
3076                         sprintf(inp, "%2d", m);
3077                 }
3078
3079                 /* Prepare a prompt */
3080                 sprintf(buf, "%6s       %2d   %+3d  %+3d  %+3d  =  %6s  %6s",
3081                         stat_names[i], cval[i], rp_ptr->r_adj[i], cp_ptr->c_adj[i],
3082                         ap_ptr->a_adj[i], inp, cur);
3083                 
3084                 /* Dump the prompt */
3085                 put_str(buf, 14 + i, 10);
3086         }
3087         
3088         /* Get a minimum stat */
3089         cs = 0;
3090         os = 6;
3091         while (TRUE)
3092         {
3093                 /* Move Cursol */
3094                 if (cs != os)
3095                 {
3096                         if(os == 6)
3097                         {
3098                                 c_put_str(TERM_WHITE, _("決定する", "Accept"), 21, 35);
3099                         }
3100                         else if(os < A_MAX)
3101                         {
3102                                 c_put_str(TERM_WHITE, cur, 14 + os, 10);
3103                         }
3104                         if(cs == 6)
3105                         {
3106                                 c_put_str(TERM_YELLOW, _("決定する", "Accept"), 21, 35);
3107                         }
3108                         else
3109                         {
3110                                 /* Race/Class bonus */
3111                                 j = rp_ptr->r_adj[cs] + cp_ptr->c_adj[cs] + ap_ptr->a_adj[cs];
3112
3113                                 /* Obtain the current stat */
3114                                 m = adjust_stat(cval[cs], j);
3115                                 
3116                                 /* Above 18 */
3117                                 if (m > 18)
3118                                 {
3119                                         sprintf(inp, "18/%02d", (m - 18));
3120                                 }
3121                                 
3122                                 /* From 3 to 18 */
3123                                 else
3124                                 {
3125                                         sprintf(inp, "%2d", m);
3126                                 }
3127                                 
3128                                 /* Prepare a prompt */
3129                                 sprintf(cur, "%6s       %2d   %+3d  %+3d  %+3d  =  %6s",
3130                                         stat_names[cs], cval[cs], rp_ptr->r_adj[cs],
3131                                         cp_ptr->c_adj[cs], ap_ptr->a_adj[cs], inp);
3132                                 c_put_str(TERM_YELLOW, cur, 14 + cs, 10);
3133                         }
3134                         os = cs;
3135                 }
3136                 
3137                 /* Prompt for the minimum stats */
3138                 c = inkey();
3139                 switch ( c ){
3140                 case 'Q':
3141                         birth_quit();
3142                 case 'S':
3143                         return FALSE;
3144                 case ESCAPE:
3145                         break;
3146                 case ' ':
3147                 case '\r':
3148                 case '\n':
3149                         if(cs == 6) break;
3150                         cs++;
3151                         c = '2';
3152                         break;
3153                 case '8':
3154                 case 'k':
3155                         if (cs > 0) cs--;
3156                         break;
3157                 case '2':
3158                 case 'j':
3159                         if (cs < A_MAX) cs++;
3160                         break;
3161                 case '4':
3162                 case 'h':
3163                         if (cs != 6)
3164                         {
3165                                 if (cval[cs] == 3)
3166                                 {
3167                                         cval[cs] = 17;
3168                                         os = 7;
3169                                 }
3170                                 else if (cval[cs] > 3)
3171                                 {
3172                                         cval[cs]--;
3173                                         os = 7;
3174                                 }
3175                                 else return FALSE;
3176                         }
3177                         break;
3178                 case '6':
3179                 case 'l':
3180                         if (cs != 6)
3181                         {
3182                                 if (cval[cs] == 17)
3183                                 {
3184                                         cval[cs] = 3;
3185                                         os = 7;
3186                                 }
3187                                 else if (cval[cs] < 17)
3188                                 {
3189                                         cval[cs]++;
3190                                         os = 7;
3191                                 }
3192                                 else return FALSE;
3193                         }
3194                         break;
3195                 case 'm':
3196                         if(cs != 6)
3197                         {
3198                                 cval[cs] = 17;
3199                                 os = 7;
3200                         }
3201                         break;
3202                 case 'n':
3203                         if(cs != 6)
3204                         {
3205                                 cval[cs] = 3;
3206                                 os = 7;
3207                         }
3208                         break;
3209                 case '?':
3210 #ifdef JP
3211                         show_help("jbirth.txt#AutoRoller");
3212 #else
3213                         show_help("birth.txt#AutoRoller");
3214 #endif
3215                         break;
3216                 case '=':
3217                         screen_save();
3218 #ifdef JP
3219                         do_cmd_options_aux(OPT_PAGE_BIRTH, "初期オプション((*)はスコアに影響)");
3220 #else
3221                         do_cmd_options_aux(OPT_PAGE_BIRTH, "Birth Option((*)s effect score)");
3222 #endif
3223
3224                         screen_load();
3225                         break;
3226                 default:
3227                         bell();
3228                         break;
3229                 }
3230                 if(c == ESCAPE || ((c == ' ' || c == '\r' || c == '\n') && cs == 6))break;
3231         }
3232         
3233         for (i = 0; i < A_MAX; i++)
3234         {
3235                 /* Save the minimum stat */
3236                 stat_limit[i] = (s16b)cval[i];
3237         }
3238
3239         return TRUE;
3240 }
3241 #endif
3242
3243 #ifdef ALLOW_AUTOROLLER
3244 /*!
3245  * @brief オートローラで得たい年齢、身長、体重、社会的地位の基準を決める。
3246  * @return なし
3247  */
3248 static bool get_chara_limits(void)
3249 {
3250 #define MAXITEMS 8
3251
3252         int i, j, m, cs, os;
3253         int mval[MAXITEMS], cval[MAXITEMS];
3254         int max_percent, min_percent;
3255         char c;
3256         char buf[80], cur[80];
3257         concptr itemname[] = {
3258                 _("年齢", "age"),
3259                 _("身長(インチ)", "height"),
3260                 _("体重(ポンド)", "weight"),
3261                 _("社会的地位", "social class")
3262         };
3263
3264         clear_from(10);
3265         
3266         /* Prompt for the minimum stats */
3267         put_str(_("2/4/6/8で項目選択、+/-で値の増減、Enterで次へ", "2/4/6/8 for Select, +/- for Change value, Enter for Goto next"), 11, 10);
3268         put_str(_("注意:身長と体重の最大値/最小値ぎりぎりの値は非常に出現確率が低くなります。", "Caution: Values near minimum or maximum is extremery rare."), 23, 2);
3269         
3270         if (p_ptr->psex == SEX_MALE)
3271         {
3272                 max_percent = (int)(rp_ptr->m_b_ht+rp_ptr->m_m_ht*4-1) * 100 / (int)(rp_ptr->m_b_ht);
3273                 min_percent = (int)(rp_ptr->m_b_ht-rp_ptr->m_m_ht*4+1) * 100 / (int)(rp_ptr->m_b_ht);
3274         }
3275         else
3276         {
3277                 max_percent = (int)(rp_ptr->f_b_ht+rp_ptr->f_m_ht*4-1) * 100 / (int)(rp_ptr->f_b_ht);
3278                 min_percent = (int)(rp_ptr->f_b_ht-rp_ptr->f_m_ht*4+1) * 100 / (int)(rp_ptr->f_b_ht);
3279         }
3280         
3281         put_str(_("体格/地位の最小値/最大値を設定して下さい。", "Set minimum/maximum attribute."), 10, 10);
3282         put_str(_("  項    目                 最小値  最大値", " Parameter                    Min     Max"), 13,20);
3283
3284         /* Output the maximum stats */
3285         for (i = 0; i < MAXITEMS; i++)
3286         {
3287                 /* Obtain the "maximal" stat */
3288                 switch (i)
3289                 {
3290                 case 0: /* Minimum age */
3291                         m = rp_ptr->b_age + 1;
3292                         break;
3293                 case 1: /* Maximum age */
3294                         m = rp_ptr->b_age + rp_ptr->m_age;
3295                         break;
3296
3297                 case 2: /* Minimum height */
3298                         if (p_ptr->psex == SEX_MALE) m = rp_ptr->m_b_ht-rp_ptr->m_m_ht*4+1;
3299                         else m = rp_ptr->f_b_ht-rp_ptr->f_m_ht*4+1;
3300                         break;
3301                 case 3: /* Maximum height */
3302                         if (p_ptr->psex == SEX_MALE) m = rp_ptr->m_b_ht+rp_ptr->m_m_ht*4-1;
3303                         else m = rp_ptr->f_b_ht+rp_ptr->f_m_ht*4-1;
3304                         break;
3305                 case 4: /* Minimum weight */
3306                         if (p_ptr->psex == SEX_MALE) m = (rp_ptr->m_b_wt * min_percent / 100) - (rp_ptr->m_m_wt * min_percent / 75) +1;
3307                         else m = (rp_ptr->f_b_wt * min_percent / 100) - (rp_ptr->f_m_wt * min_percent / 75) +1;
3308                         break;
3309                 case 5: /* Maximum weight */
3310                         if (p_ptr->psex == SEX_MALE) m = (rp_ptr->m_b_wt * max_percent / 100) + (rp_ptr->m_m_wt * max_percent / 75) -1;
3311                         else m = (rp_ptr->f_b_wt * max_percent / 100) + (rp_ptr->f_m_wt * max_percent / 75) -1;
3312                         break;
3313                 case 6: /* Minimum social class */
3314                         m = 1;
3315                         break;
3316                 case 7: /* Maximum social class */
3317                         m = 100;
3318                         break;
3319                 default:
3320                         m = 1;
3321                         break;
3322                 }
3323                 
3324                 /* Save the maximum or minimum */
3325                 mval[i] = m;
3326                 cval[i] = m;
3327         }
3328
3329         for (i = 0; i < 4; i++)
3330         {
3331                 /* Prepare a prompt */
3332                 sprintf(buf, "%-12s (%3d - %3d)", itemname[i], mval[i*2], mval[i*2+1]);
3333
3334                 /* Dump the prompt */
3335                 put_str(buf, 14 + i, 20);
3336
3337                 for (j = 0; j < 2; j++)
3338                 {
3339                         sprintf(buf, "     %3d", cval[i*2+j]);
3340                         put_str(buf, 14 + i, 45 + 8 * j);
3341                 }
3342         }
3343         
3344         /* Get a minimum stat */
3345         cs = 0;
3346         os = MAXITEMS;
3347         while (TRUE)
3348         {
3349                 /* Move Cursol */
3350                 if (cs != os)
3351                 {
3352                         const char accept[] = _("決定する", "Accept");
3353
3354                         if(os == MAXITEMS)
3355                         {
3356                                 c_put_str(TERM_WHITE, accept, 19, 35);
3357                         }
3358                         else
3359                         {
3360                                 c_put_str(TERM_WHITE, cur, 14 + os/2, 45 + 8 * (os%2));
3361                         }
3362                         
3363                         if(cs == MAXITEMS)
3364                         {
3365                                 c_put_str(TERM_YELLOW, accept, 19, 35);
3366                         }
3367                         else
3368                         {
3369                                 /* Prepare a prompt */
3370                                 sprintf(cur, "     %3d", cval[cs]);
3371                                 c_put_str(TERM_YELLOW, cur, 14 + cs/2, 45 + 8 * (cs%2));
3372                         }
3373                         os = cs;
3374                 }
3375                 
3376                 /* Prompt for the minimum stats */
3377                 c = inkey();
3378                 switch (c){
3379                 case 'Q':
3380                         birth_quit();
3381                 case 'S':
3382                         return (FALSE);
3383                 case ESCAPE:
3384                         break; /*後でもう一回breakせんと*/
3385                 case ' ':
3386                 case '\r':
3387                 case '\n':
3388                         if(cs == MAXITEMS) break;
3389                         cs++;
3390                         c = '6';
3391                         break;
3392                 case '8':
3393                 case 'k':
3394                         if (cs-2 >= 0) cs -= 2;
3395                         break;
3396                 case '2':
3397                 case 'j':
3398                         if (cs < MAXITEMS) cs += 2;
3399                         if (cs > MAXITEMS) cs = MAXITEMS;
3400                         break;
3401                 case '4':
3402                 case 'h':
3403                         if (cs > 0) cs--;
3404                         break;
3405                 case '6':
3406                 case 'l':
3407                         if (cs < MAXITEMS) cs++;
3408                         break;
3409                 case '-':
3410                 case '<':
3411                         if (cs != MAXITEMS)
3412                         {
3413                                 if(cs%2)
3414                                 {
3415                                         if(cval[cs] > cval[cs-1])
3416                                         {
3417                                                 cval[cs]--;
3418                                                 os = 127;
3419                                         }
3420                                 }
3421                                 else
3422                                 {
3423                                         if(cval[cs] > mval[cs])
3424                                         {
3425                                                 cval[cs]--;
3426                                                 os = 127;
3427                                         }
3428                                 }
3429                         }
3430                         break;
3431                 case '+':
3432                 case '>':
3433                         if (cs != MAXITEMS)
3434                         {
3435                                 if(cs%2)
3436                                 {
3437                                         if(cval[cs] < mval[cs])
3438                                         {
3439                                                 cval[cs]++;
3440                                                 os = 127;
3441                                         }
3442                                 }
3443                                 else
3444                                 {
3445                                         if(cval[cs] < cval[cs+1])
3446                                         {
3447                                                 cval[cs]++;
3448                                                 os = 127;
3449                                         }
3450                                 }
3451                         }
3452                         break;
3453                 case 'm':
3454                         if(cs != MAXITEMS)
3455                         {
3456                                 if(cs%2)
3457                                 {
3458                                         if(cval[cs] < mval[cs])
3459                                         {
3460                                                 cval[cs] = mval[cs];
3461                                                 os = 127;
3462                                         }
3463                                 }
3464                                 else
3465                                 {
3466                                         if(cval[cs] < cval[cs+1])
3467                                         {
3468                                                 cval[cs] = cval[cs+1];
3469                                                 os = 127;
3470                                         }
3471                                 }
3472                         }
3473                         break;
3474                 case 'n':
3475                         if(cs != MAXITEMS)
3476                         {
3477                                 if(cs%2)
3478                                 {
3479                                         if(cval[cs] > cval[cs-1])
3480                                         {
3481                                                 cval[cs] = cval[cs-1];
3482                                                 os = 255;
3483                                         }
3484                                 }
3485                                 else
3486                                 {
3487                                         if(cval[cs] > mval[cs])
3488                                         {
3489                                                 cval[cs] = mval[cs];
3490                                                 os = 255;
3491                                         }
3492                                 }
3493                         }
3494                         break;
3495                 case '?':
3496 #ifdef JP
3497                         show_help("jbirth.txt#AutoRoller");
3498 #else
3499                         show_help("birth.txt#AutoRoller");
3500 #endif
3501                         break;
3502                 case '=':
3503                         screen_save();
3504                         do_cmd_options_aux(OPT_PAGE_BIRTH, _("初期オプション((*)はスコアに影響)", "Birth Option((*)s effect score)"));
3505                         screen_load();
3506                         break;
3507                 default:
3508                         bell();
3509                         break;
3510                 }
3511                 if(c == ESCAPE || ((c == ' ' || c == '\r' || c == '\n') && cs == MAXITEMS))break;
3512         }
3513
3514         /* Input the minimum stats */
3515         chara_limit.agemin = (s16b)cval[0];
3516         chara_limit.agemax = (s16b)cval[1];
3517         chara_limit.htmin = (s16b)cval[2];
3518         chara_limit.htmax = (s16b)cval[3];
3519         chara_limit.wtmin = (s16b)cval[4];
3520         chara_limit.wtmax = (s16b)cval[5];
3521         chara_limit.scmin = (s16b)cval[6];
3522         chara_limit.scmax = (s16b)cval[7];
3523
3524         return TRUE;
3525 }
3526 #endif
3527
3528 #define HISTPREF_LIMIT 1024
3529 static char *histpref_buf = NULL;
3530
3531 /*!
3532  * @brief 生い立ちメッセージの内容をバッファに加える。 / Hook function for reading the histpref.prf file.
3533  * @return なし
3534  */
3535 void add_history_from_pref_line(concptr t)
3536 {
3537         /* Do nothing if the buffer is not ready */
3538         if (!histpref_buf) return;
3539
3540         my_strcat(histpref_buf, t, HISTPREF_LIMIT);
3541 }
3542
3543 /*!
3544  * @brief 生い立ちメッセージをファイルからロードする。
3545  * @return なし
3546  */
3547 static bool do_cmd_histpref(void)
3548 {
3549         char buf[80];
3550         errr err;
3551         int i, j, n;
3552         char *s, *t;
3553         char temp[64 * 4];
3554         char histbuf[HISTPREF_LIMIT];
3555
3556         if (!get_check(_("生い立ち設定ファイルをロードしますか? ", "Load background history preference file? "))) return FALSE;
3557
3558         /* Prepare the buffer */
3559         histbuf[0] = '\0';
3560         histpref_buf = histbuf;
3561
3562 #ifdef JP
3563         sprintf(buf, "histedit-%s.prf", p_ptr->base_name);
3564 #else
3565         sprintf(buf, "histpref-%s.prf", p_ptr->base_name);
3566 #endif
3567         err = process_histpref_file(buf);
3568
3569         /* Process 'hist????.prf' if 'hist????-<name>.prf' doesn't exist */
3570         if (0 > err)
3571         {
3572 #ifdef JP
3573                 strcpy(buf, "histedit.prf");
3574 #else
3575                 strcpy(buf, "histpref.prf");
3576 #endif
3577                 err = process_histpref_file(buf);
3578         }
3579
3580         if (err)
3581         {
3582                 msg_print(_("生い立ち設定ファイルの読み込みに失敗しました。", "Failed to load background history preference."));
3583                 msg_print(NULL);
3584
3585                 /* Kill the buffer */
3586                 histpref_buf = NULL;
3587
3588                 return FALSE;
3589         }
3590         else if (!histpref_buf[0])
3591         {
3592                 msg_print(_("有効な生い立ち設定はこのファイルにありません。", "There does not exist valid background history preference."));
3593                 msg_print(NULL);
3594
3595                 /* Kill the buffer */
3596                 histpref_buf = NULL;
3597
3598                 return FALSE;
3599         }
3600
3601         /* Clear the previous history strings */
3602         for (i = 0; i < 4; i++) p_ptr->history[i][0] = '\0';
3603
3604         /* Skip leading spaces */
3605         for (s = histpref_buf; *s == ' '; s++) /* loop */;
3606
3607         /* Get apparent length */
3608         n = strlen(s);
3609
3610         /* Kill trailing spaces */
3611         while ((n > 0) && (s[n - 1] == ' ')) s[--n] = '\0';
3612
3613         roff_to_buf(s, 60, temp, sizeof(temp));
3614         t = temp;
3615         for (i = 0; i < 4; i++)
3616         {
3617                 if (t[0] == 0) break;
3618                 else
3619                 {
3620                         strcpy(p_ptr->history[i], t);
3621                         t += strlen(t) + 1;
3622                 }
3623         }
3624
3625         /* Fill the remaining spaces */
3626         for (i = 0; i < 4; i++)
3627         {
3628                 for (j = 0; p_ptr->history[i][j]; j++) /* loop */;
3629
3630                 for (; j < 59; j++) p_ptr->history[i][j] = ' ';
3631                 p_ptr->history[i][59] = '\0';
3632         }
3633
3634         /* Kill the buffer */
3635         histpref_buf = NULL;
3636
3637         return TRUE;
3638 }
3639
3640 /*!
3641  * @brief 生い立ちメッセージを編集する。/Character background edit-mode
3642  * @return なし
3643  */
3644 static void edit_history(void)
3645 {
3646         char old_history[4][60];
3647         TERM_LEN y = 0, x = 0;
3648         int i, j;
3649
3650         /* Edit character background */
3651         for (i = 0; i < 4; i++)
3652         {
3653                 sprintf(old_history[i], "%s", p_ptr->history[i]);
3654         }
3655         /* Turn 0 to space */
3656         for (i = 0; i < 4; i++)
3657         {
3658                 for (j = 0; p_ptr->history[i][j]; j++) /* loop */;
3659
3660                 for (; j < 59; j++) p_ptr->history[i][j] = ' ';
3661                 p_ptr->history[i][59] = '\0';
3662         }
3663         display_player(1);
3664 #ifdef JP
3665         c_put_str(TERM_L_GREEN, "(キャラクターの生い立ち - 編集モード)", 11, 20);
3666         put_str("[ カーソルキーで移動、Enterで終了、Ctrl-Aでファイル読み込み ]", 17, 10);
3667 #else
3668         c_put_str(TERM_L_GREEN, "(Character Background - Edit Mode)", 11, 20);
3669         put_str("[ Cursor key for Move, Enter for End, Ctrl-A for Read pref ]", 17, 10);
3670 #endif
3671
3672         while (TRUE)
3673         {
3674                 int skey;
3675                 char c;
3676
3677                 for (i = 0; i < 4; i++)
3678                 {
3679                         put_str(p_ptr->history[i], i + 12, 10);
3680                 }
3681 #ifdef JP
3682                 if (iskanji2(p_ptr->history[y], x))
3683                         c_put_str(TERM_L_BLUE, format("%c%c", p_ptr->history[y][x],p_ptr->history[y][x+1]), y + 12, x + 10);
3684                 else
3685 #endif
3686                 c_put_str(TERM_L_BLUE, format("%c", p_ptr->history[y][x]), y + 12, x + 10);
3687
3688                 /* Place cursor just after cost of current stat */
3689                 Term_gotoxy(x + 10, y + 12);
3690
3691                 /* Get special key code */
3692                 skey = inkey_special(TRUE);
3693
3694                 /* Get a character code */
3695                 if (!(skey & SKEY_MASK)) c = (char)skey;
3696                 else c = 0;
3697
3698                 if (skey == SKEY_UP || c == KTRL('p'))
3699                 {
3700                         y--;
3701                         if (y < 0) y = 3;
3702 #ifdef JP
3703                         if ((x > 0) && (iskanji2(p_ptr->history[y], x-1))) x--;
3704 #endif
3705                 }
3706                 else if (skey == SKEY_DOWN || c == KTRL('n'))
3707                 {
3708                         y++;
3709                         if (y > 3) y = 0;
3710 #ifdef JP
3711                         if ((x > 0) && (iskanji2(p_ptr->history[y], x-1))) x--;
3712 #endif
3713                 }
3714                 else if (skey == SKEY_RIGHT || c == KTRL('f'))
3715                 {
3716 #ifdef JP
3717                         if (iskanji2(p_ptr->history[y], x)) x++;
3718 #endif
3719                         x++;
3720                         if (x > 58)
3721                         {
3722                                 x = 0;
3723                                 if (y < 3) y++;
3724                         }
3725                 }
3726                 else if (skey == SKEY_LEFT || c == KTRL('b'))
3727                 {
3728                         x--;
3729                         if (x < 0)
3730                         {
3731                                 if (y)
3732                                 {
3733                                         y--;
3734                                         x = 58;
3735                                 }
3736                                 else x = 0;
3737                         }
3738
3739 #ifdef JP
3740                         if ((x > 0) && (iskanji2(p_ptr->history[y], x-1))) x--;
3741 #endif
3742                 }
3743                 else if (c == '\r' || c == '\n')
3744                 {
3745                         Term_erase(0, 11, 255);
3746                         Term_erase(0, 17, 255);
3747 #ifdef JP
3748                         put_str("(キャラクターの生い立ち - 編集済み)", 11, 20);
3749 #else
3750                         put_str("(Character Background - Edited)", 11, 20);
3751 #endif
3752                         break;
3753                 }
3754                 else if (c == ESCAPE)
3755                 {
3756                         clear_from(11);
3757 #ifdef JP
3758                         put_str("(キャラクターの生い立ち)", 11, 25);
3759 #else
3760                         put_str("(Character Background)", 11, 25);
3761 #endif
3762
3763                         for (i = 0; i < 4; i++)
3764                         {
3765                                 sprintf(p_ptr->history[i], "%s", old_history[i]);
3766                                 put_str(p_ptr->history[i], i + 12, 10);
3767                         }
3768                         break;
3769                 }
3770                 else if (c == KTRL('A'))
3771                 {
3772                         if (do_cmd_histpref())
3773                         {
3774 #ifdef JP
3775                                 if ((x > 0) && (iskanji2(p_ptr->history[y], x - 1))) x--;
3776 #endif
3777                         }
3778                 }
3779                 else if (c == '\010')
3780                 {
3781                         x--;
3782                         if (x < 0)
3783                         {
3784                                 if (y)
3785                                 {
3786                                         y--;
3787                                         x = 58;
3788                                 }
3789                                 else x = 0;
3790                         }
3791
3792                         p_ptr->history[y][x] = ' ';
3793 #ifdef JP
3794                         if ((x > 0) && (iskanji2(p_ptr->history[y], x - 1)))
3795                         {
3796                                 x--;
3797                                 p_ptr->history[y][x] = ' ';
3798                         }
3799 #endif
3800                 }
3801 #ifdef JP
3802                 else if (iskanji(c) || isprint(c))
3803 #else
3804                 else if (isprint(c)) /* BUGFIX */
3805 #endif
3806                 {
3807 #ifdef JP
3808                         if (iskanji2(p_ptr->history[y], x))
3809                         {
3810                                 p_ptr->history[y][x+1] = ' ';
3811                         }
3812
3813                         if (iskanji(c))
3814                         {
3815                                 if (x > 57)
3816                                 {
3817                                         x = 0;
3818                                         y++;
3819                                         if (y > 3) y = 0;
3820                                 }
3821
3822                                 if (iskanji2(p_ptr->history[y], x+1))
3823                                 {
3824                                         p_ptr->history[y][x+2] = ' ';
3825                                 }
3826
3827                                 p_ptr->history[y][x++] = c;
3828
3829                                 c = inkey();
3830                         }
3831 #endif
3832                         p_ptr->history[y][x++] = c;
3833                         if (x > 58)
3834                         {
3835                                 x = 0;
3836                                 y++;
3837                                 if (y > 3) y = 0;
3838                         }
3839                 }
3840         } /* while (TRUE) */
3841
3842 }
3843
3844
3845 /*!
3846  * @brief player_birth()関数のサブセット/Helper function for 'player_birth()'
3847  * @details
3848  * The delay may be reduced, but is recommended to keep players
3849  * from continuously rolling up characters, which can be VERY
3850  * expensive CPU wise.  And it cuts down on player stupidity.
3851  * @return なし
3852  */
3853 static bool player_birth_aux(void)
3854 {
3855         int i, k, n, cs, os;
3856
3857         BIT_FLAGS mode = 0;
3858
3859         bool flag = FALSE;
3860         bool prev = FALSE;
3861
3862         concptr str;
3863
3864         char c;
3865
3866 #if 0
3867         char p1 = '(';
3868 #endif
3869
3870         char p2 = ')';
3871         char b1 = '[';
3872         char b2 = ']';
3873
3874         char buf[80], cur[80];
3875
3876
3877         /*** Intro ***/
3878         Term_clear();
3879
3880         /* Title everything */
3881         put_str(_("名前  :", "Name  :"), 1,26);
3882         put_str(_("性別        :", "Sex         :"), 3, 1);
3883         put_str(_("種族        :", "Race        :"), 4, 1);
3884         put_str(_("職業        :", "Class       :"), 5, 1);
3885
3886         /* Dump the default name */
3887         c_put_str(TERM_L_BLUE, p_ptr->name, 1, 34);
3888
3889         /*** Instructions ***/
3890
3891         /* Display some helpful information */
3892         put_str(_("キャラクターを作成します。('S'やり直す, 'Q'終了, '?'ヘルプ)", "Make your charactor. ('S' Restart, 'Q' Quit, '?' Help)"), 8, 10);
3893
3894         /*** Player sex ***/
3895
3896         /* Extra info */
3897         put_str(_("注意:《性別》の違いはゲーム上ほとんど影響を及ぼしません。", "Note: Your 'sex' does not have any significant gameplay effects."), 23, 5);
3898
3899         /* Prompt for "Sex" */
3900         for (n = 0; n < MAX_SEXES; n++)
3901         {
3902                 /* Analyze */
3903                 sp_ptr = &sex_info[n];
3904
3905                 /* Display */
3906 #ifdef JP
3907                 sprintf(buf, "%c%c%s", I2A(n), p2, sp_ptr->title);
3908 #else
3909                 sprintf(buf, "%c%c %s", I2A(n), p2, sp_ptr->title);
3910 #endif
3911                 put_str(buf, 12 + (n/5), 2 + 15 * (n%5));
3912         }
3913
3914 #ifdef JP
3915         sprintf(cur, "%c%c%s", '*', p2, "ランダム");
3916 #else
3917         sprintf(cur, "%c%c %s", '*', p2, "Random");
3918 #endif
3919
3920         /* Choose */
3921         k = -1;
3922         cs = 0;
3923         os = MAX_SEXES;
3924         while (1)
3925         {
3926                 if (cs != os)
3927                 {
3928                         put_str(cur, 12 + (os/5), 2 + 15 * (os%5));
3929                         if(cs == MAX_SEXES)
3930 #ifdef JP
3931                                 sprintf(cur, "%c%c%s", '*', p2, "ランダム");
3932 #else
3933                                 sprintf(cur, "%c%c %s", '*', p2, "Random");
3934 #endif
3935                         else
3936                         {
3937                                 sp_ptr = &sex_info[cs];
3938                                 str = sp_ptr->title;
3939 #ifdef JP
3940                                 sprintf(cur, "%c%c%s", I2A(cs), p2, str);
3941 #else
3942                                 sprintf(cur, "%c%c %s", I2A(cs), p2, str);
3943 #endif
3944                         }
3945                         c_put_str(TERM_YELLOW, cur, 12 + (cs/5), 2 + 15 * (cs%5));
3946                         os = cs;
3947                 }
3948
3949                 if (k >= 0) break;
3950
3951 #ifdef JP
3952                 sprintf(buf, "性別を選んで下さい (%c-%c) ('='初期オプション設定): ", I2A(0), I2A(n-1));
3953 #else
3954                 sprintf(buf, "Choose a sex (%c-%c) ('=' for options): ", I2A(0), I2A(n-1));
3955 #endif
3956
3957                 put_str(buf, 10, 10);
3958                 c = inkey();
3959                 if (c == 'Q') birth_quit();
3960                 if (c == 'S') return (FALSE);
3961                 if (c == ' ' || c == '\r' || c == '\n')
3962                 {
3963                         if(cs == MAX_SEXES)
3964                                 k = randint0(MAX_SEXES);
3965                         else
3966                                 k = cs;
3967                         break;
3968                 }
3969                 if (c == '*')
3970                 {
3971                         k = randint0(MAX_SEXES);
3972                         break;
3973                 }
3974                 if (c == '4')
3975                 {
3976                         if (cs > 0) cs--;
3977                 }
3978                 if (c == '6')
3979                 {
3980                         if (cs < MAX_SEXES) cs++;
3981                 }
3982                 k = (islower(c) ? A2I(c) : -1);
3983                 if ((k >= 0) && (k < MAX_SEXES))
3984                 {
3985                         cs = k;
3986                         continue;
3987                 }
3988                 else k = -1;
3989                 if (c == '?') do_cmd_help();
3990                 else if (c == '=')
3991                 {
3992                         screen_save();
3993 #ifdef JP
3994                         do_cmd_options_aux(OPT_PAGE_BIRTH, "初期オプション((*)はスコアに影響)");
3995 #else
3996                         do_cmd_options_aux(OPT_PAGE_BIRTH, "Birth Option((*)s effect score)");
3997 #endif
3998
3999                         screen_load();
4000                 }
4001                 else if(c != '4' && c != '6')bell();
4002         }
4003
4004         /* Set sex */
4005         p_ptr->psex = (byte_hack)k;
4006         sp_ptr = &sex_info[p_ptr->psex];
4007
4008         /* Display */
4009         c_put_str(TERM_L_BLUE, sp_ptr->title, 3, 15);
4010
4011         /* Clean up */
4012         clear_from(10);
4013
4014         /* Choose the players race */
4015         p_ptr->prace = 0;
4016         while(1)
4017         {
4018                 char temp[80*10];
4019                 concptr t;
4020
4021                 if (!get_player_race()) return FALSE;
4022
4023                 clear_from(10);
4024
4025                 roff_to_buf(race_jouhou[p_ptr->prace], 74, temp, sizeof(temp));
4026                 t = temp;
4027
4028                 for (i = 0; i< 10; i++)
4029                 {
4030                         if(t[0] == 0)
4031                                 break; 
4032                         else
4033                         {
4034                                 prt(t, 12+i, 3);
4035                                 t += strlen(t) + 1;
4036                         }
4037                 }
4038 #ifdef JP
4039                 if (get_check_strict("よろしいですか?", CHECK_DEFAULT_Y)) break;
4040 #else
4041                 if (get_check_strict("Are you sure? ", CHECK_DEFAULT_Y)) break;
4042 #endif
4043                 clear_from(10);
4044                 c_put_str(TERM_WHITE, "              ", 4, 15);
4045         }
4046
4047         /* Clean up */
4048         clear_from(10);
4049
4050         /* Choose the players class */
4051         p_ptr->pclass = 0;
4052         while(1)
4053         {
4054                 char temp[80*9];
4055                 concptr t;
4056
4057                 if (!get_player_class()) return FALSE;
4058
4059                 clear_from(10);
4060                 roff_to_buf(class_jouhou[p_ptr->pclass], 74, temp, sizeof(temp));
4061                 t = temp;
4062
4063                 for (i = 0; i< 9; i++)
4064                 {
4065                         if(t[0] == 0)
4066                                 break; 
4067                         else
4068                         {
4069                                 prt(t, 12+i, 3);
4070                                 t += strlen(t) + 1;
4071                         }
4072                 }
4073
4074 #ifdef JP
4075                 if (get_check_strict("よろしいですか?", CHECK_DEFAULT_Y)) break;
4076 #else
4077                 if (get_check_strict("Are you sure? ", CHECK_DEFAULT_Y)) break;
4078 #endif
4079                 c_put_str(TERM_WHITE, "              ", 5, 15);
4080         }
4081
4082         /* Choose the magic realms */
4083         if (!get_player_realms()) return FALSE;
4084
4085         /* Choose the players seikaku */
4086         p_ptr->pseikaku = 0;
4087         while(1)
4088         {
4089                 char temp[80*8];
4090                 concptr t;
4091
4092                 if (!get_player_seikaku()) return FALSE;
4093
4094                 clear_from(10);
4095                 roff_to_buf(seikaku_jouhou[p_ptr->pseikaku], 74, temp, sizeof(temp));
4096                 t = temp;
4097
4098                 for (i = 0; i< A_MAX; i++)
4099                 {
4100                         if(t[0] == 0)
4101                                 break; 
4102                         else
4103                         {
4104                                 prt(t, 12+i, 3);
4105                                 t += strlen(t) + 1;
4106                         }
4107                 }
4108 #ifdef JP
4109                 if (get_check_strict("よろしいですか?", CHECK_DEFAULT_Y)) break;
4110 #else
4111                 if (get_check_strict("Are you sure? ", CHECK_DEFAULT_Y)) break;
4112 #endif
4113                 c_put_str(TERM_L_BLUE, p_ptr->name, 1, 34);
4114                 prt("", 1, 34+strlen(p_ptr->name));
4115         }
4116
4117         /* Clean up */
4118         clear_from(10);
4119         put_str("                                   ", 3, 40);
4120         put_str("                                   ", 4, 40);
4121         put_str("                                   ", 5, 40);
4122
4123         screen_save();
4124 #ifdef JP
4125         do_cmd_options_aux(OPT_PAGE_BIRTH, "初期オプション((*)はスコアに影響)");
4126 #else
4127         do_cmd_options_aux(OPT_PAGE_BIRTH, "Birth Option((*)s effect score)");
4128 #endif
4129
4130         screen_load();
4131
4132 #ifdef ALLOW_AUTOROLLER
4133
4134         /*** Autoroll ***/
4135
4136         if (autoroller || autochara)
4137         {
4138                 /* Clear fields */
4139                 auto_round = 0L;
4140         }
4141
4142         if (autoroller)
4143         {
4144                 if (!get_stat_limits()) return FALSE;
4145         }
4146
4147         if (autochara)
4148         {
4149                 if (!get_chara_limits()) return FALSE;
4150         }
4151
4152 #endif /* ALLOW_AUTOROLLER */
4153
4154         /* Clear */
4155         clear_from(10);
4156
4157         /* Reset current_world_ptr->game_turn; before auto-roll and after choosing race */
4158         init_turn();
4159
4160         /*** Generate ***/
4161
4162         /* Roll */
4163         while (TRUE)
4164         {
4165                 int col;
4166
4167                 col = 42;
4168
4169                 if (autoroller || autochara)
4170                 {
4171                         Term_clear();
4172
4173                         /* Label count */
4174 #ifdef JP
4175                         put_str("回数 :", 10, col+13);
4176 #else
4177                         put_str("Round:", 10, col+13);
4178 #endif
4179
4180
4181                         /* Indicate the state */
4182 #ifdef JP
4183                         put_str("(ESCで停止)", 12, col+13);
4184 #else
4185                         put_str("(Hit ESC to stop)", 12, col+13);
4186 #endif
4187                 }
4188
4189                 /* Otherwise just get a character */
4190                 else
4191                 {
4192                         /* Get a new character */
4193                         get_stats();
4194
4195                         /* Roll for age/height/weight */
4196                         get_ahw();
4197
4198                         /* Roll for social class */
4199                         get_history();
4200                 }
4201
4202                 /* Feedback */
4203                 if (autoroller)
4204                 {
4205                         /* Label */
4206 #ifdef JP
4207                         put_str("最小値", 2, col+5);
4208 #else
4209                         put_str(" Limit", 2, col+5);
4210 #endif
4211
4212
4213                         /* Label */
4214 #ifdef JP
4215                         put_str("成功率", 2, col+13);
4216 #else
4217                         put_str("  Freq", 2, col+13);
4218 #endif
4219
4220
4221                         /* Label */
4222 #ifdef JP
4223                         put_str("現在値", 2, col+24);
4224 #else
4225                         put_str("  Roll", 2, col+24);
4226 #endif
4227
4228
4229                         /* Put the minimal stats */
4230                         for (i = 0; i < A_MAX; i++)
4231                         {
4232                                 int j, m;
4233
4234                                 /* Label stats */
4235                                 put_str(stat_names[i], 3+i, col);
4236
4237                                 /* Race/Class bonus */
4238                                 j = rp_ptr->r_adj[i] + cp_ptr->c_adj[i] + ap_ptr->a_adj[i];
4239
4240                                 /* Obtain the current stat */
4241                                 m = adjust_stat(stat_limit[i], j);
4242
4243                                 /* Put the stat */
4244                                 cnv_stat(m, buf);
4245                                 c_put_str(TERM_L_BLUE, buf, 3+i, col+5);
4246                         }
4247                 }
4248
4249                 /* Auto-roll */
4250                 while (autoroller || autochara)
4251                 {
4252                         bool accept = TRUE;
4253
4254                         /* Get a new character */
4255                         get_stats();
4256
4257                         /* Advance the round */
4258                         auto_round++;
4259
4260                         /* Hack -- Prevent overflow */
4261                         if (auto_round >= 1000000000L)
4262                         {
4263                                 auto_round = 1;
4264
4265                                 if (autoroller)
4266                                 {
4267                                         for (i = 0; i < A_MAX; i++)
4268                                         {
4269                                                 stat_match[i] = 0;
4270                                         }
4271                                 }
4272                         }
4273
4274                         if (autoroller)
4275                         {
4276                                 /* Check and count acceptable stats */
4277                                 for (i = 0; i < A_MAX; i++)
4278                                 {
4279                                         /* This stat is okay */
4280                                         if (p_ptr->stat_max[i] >= stat_limit[i])
4281                                         {
4282                                                 stat_match[i]++;
4283                                         }
4284
4285                                         /* This stat is not okay */
4286                                         else
4287                                         {
4288                                                 accept = FALSE;
4289                                         }
4290                                 }
4291                         }
4292
4293                         /* Break if "happy" */
4294                         if (accept)
4295                         {
4296                                 /* Roll for age/height/weight */
4297                                 get_ahw();
4298
4299                                 /* Roll for social class */
4300                                 get_history();
4301
4302                                 if (autochara)
4303                                 {
4304                                         if ((p_ptr->age < chara_limit.agemin) || (p_ptr->age > chara_limit.agemax)) accept = FALSE;
4305                                         if ((p_ptr->ht < chara_limit.htmin) || (p_ptr->ht > chara_limit.htmax)) accept = FALSE;
4306                                         if ((p_ptr->wt < chara_limit.wtmin) || (p_ptr->wt > chara_limit.wtmax)) accept = FALSE;
4307                                         if ((p_ptr->sc < chara_limit.scmin) || (p_ptr->sc > chara_limit.scmax)) accept = FALSE;
4308                                 }
4309                                 if (accept) break;
4310                         }
4311
4312                         /* Take note every x rolls */
4313                         flag = (!(auto_round % AUTOROLLER_STEP));
4314
4315                         /* Update display occasionally */
4316                         if (flag)
4317                         {
4318                                 /* Dump data */
4319                                 birth_put_stats();
4320
4321                                 /* Dump round */
4322                                 put_str(format("%10ld", auto_round), 10, col+20);
4323
4324 #ifdef AUTOROLLER_DELAY
4325                                 /* Delay 1/10 second */
4326                                 if (flag) Term_xtra(TERM_XTRA_DELAY, 10);
4327 #endif
4328
4329                                 /* Make sure they see everything */
4330                                 Term_fresh();
4331
4332                                 /* Do not wait for a key */
4333                                 inkey_scan = TRUE;
4334
4335                                 /* Check for a keypress */
4336                                 if (inkey())
4337                                 {
4338                                         /* Roll for age/height/weight */
4339                                         get_ahw();
4340
4341                                         /* Roll for social class */
4342                                         get_history();
4343
4344                                         break;
4345                                 }
4346                         }
4347                 }
4348
4349                 if (autoroller || autochara) sound(SOUND_LEVEL);
4350
4351                 /* Flush input */
4352                 flush();
4353
4354                 /*** Display ***/
4355
4356                 /* Mode */
4357                 mode = 0;
4358
4359                 /* Roll for base hitpoints */
4360                 get_extra(TRUE);
4361
4362                 /* Roll for gold */
4363                 get_money();
4364
4365                 /* Hack -- get a chaos patron even if you are not a chaos warrior */
4366                 p_ptr->chaos_patron = (s16b)randint0(MAX_PATRON);
4367
4368                 /* Input loop */
4369                 while (TRUE)
4370                 {
4371                         /* Calculate the bonuses and hitpoints */
4372                         p_ptr->update |= (PU_BONUS | PU_HP);
4373                         update_creature(p_ptr);
4374
4375                         p_ptr->chp = p_ptr->mhp;
4376                         p_ptr->csp = p_ptr->msp;
4377
4378                         /* Display the player */
4379                         display_player(mode);
4380
4381                         /* Prepare a prompt (must squeeze everything in) */
4382                         Term_gotoxy(2, 23);
4383                         Term_addch(TERM_WHITE, b1);
4384                         Term_addstr(-1, TERM_WHITE, _("'r' 次の数値", "'r'eroll"));
4385
4386                         if (prev) Term_addstr(-1, TERM_WHITE, _(", 'p' 前の数値", "'p'previous"));
4387                         if (mode) Term_addstr(-1, TERM_WHITE, _(", 'h' その他の情報", ", 'h' Misc."));
4388                         else Term_addstr(-1, TERM_WHITE, _(", 'h' 生い立ちを表示", ", 'h'istory"));
4389                         Term_addstr(-1, TERM_WHITE, _(", Enter この数値に決定", ", or Enter to accept"));
4390                         Term_addch(TERM_WHITE, b2);
4391
4392                         /* Prompt and get a command */
4393                         c = inkey();
4394
4395                         /* Quit */
4396                         if (c == 'Q') birth_quit();
4397
4398                         /* Start over */
4399                         if (c == 'S') return (FALSE);
4400
4401                         /* Escape accepts the roll */
4402                         if (c == '\r' || c == '\n' || c == ESCAPE) break;
4403
4404                         /* Reroll this character */
4405                         if ((c == ' ') || (c == 'r')) break;
4406
4407                         /* Previous character */
4408                         if (prev && (c == 'p'))
4409                         {
4410                                 load_prev_data(TRUE);
4411                                 continue;
4412                         }
4413
4414                         /* Toggle the display */
4415                         if ((c == 'H') || (c == 'h'))
4416                         {
4417                                 mode = ((mode != 0) ? 0 : 1);
4418                                 continue;
4419                         }
4420
4421                         /* Help */
4422                         if (c == '?')
4423                         {
4424 #ifdef JP
4425                                 show_help("jbirth.txt#AutoRoller");
4426 #else
4427                                 show_help("birth.txt#AutoRoller");
4428 #endif
4429                                 continue;
4430                         }
4431                         else if (c == '=')
4432                         {
4433                                 screen_save();
4434                                 do_cmd_options_aux(OPT_PAGE_BIRTH, _("初期オプション((*)はスコアに影響)", "Birth Option((*)s effect score)"));
4435                                 screen_load();
4436                                 continue;
4437                         }
4438
4439                         /* Warning */
4440                         bell();
4441                 }
4442
4443                 /* Are we done? */
4444                 if (c == '\r' || c == '\n' || c == ESCAPE) break;
4445
4446                 /* Save this for the "previous" character */
4447                 save_prev_data(&previous_char);
4448                 previous_char.quick_ok = FALSE;
4449
4450                 /* Note that a previous roll exists */
4451                 prev = TRUE;
4452         }
4453
4454         /* Clear prompt */
4455         clear_from(23);
4456
4457         /* Get a name, recolor it, prepare savefile */
4458         get_name();
4459
4460         /* Process the player name */
4461         process_player_name(current_world_ptr->creating_savefile);
4462
4463         /*** Edit character background ***/
4464         edit_history();
4465
4466         /*** Finish up ***/
4467
4468         get_max_stats();
4469
4470         get_virtues();
4471
4472         /* Prompt for it */
4473 #ifdef JP
4474         prt("[ 'Q' 中断, 'S' 初めから, Enter ゲーム開始 ]", 23, 14);
4475 #else
4476         prt("['Q'uit, 'S'tart over, or Enter to continue]", 23, 10);
4477 #endif
4478
4479
4480         /* Get a key */
4481         c = inkey();
4482
4483         /* Quit */
4484         if (c == 'Q') birth_quit();
4485
4486         /* Start over */
4487         if (c == 'S') return (FALSE);
4488
4489
4490         /* Initialize random quests */
4491         init_dungeon_quests();
4492
4493         /* Save character data for quick start */
4494         save_prev_data(&previous_char);
4495         previous_char.quick_ok = TRUE;
4496
4497         /* Accept */
4498         return (TRUE);
4499 }
4500
4501 /*!
4502  * @brief クイックスタート処理の問い合わせと実行を行う。/Ask whether the player use Quick Start or not.
4503  * @return なし
4504  */
4505 static bool ask_quick_start(void)
4506 {
4507         /* Doesn't have previous data */
4508         if (!previous_char.quick_ok) return FALSE;
4509
4510         Term_clear();
4511
4512         /* Extra info */
4513         put_str(_("クイック・スタートを使うと以前と全く同じキャラクターで始められます。", "Do you want to use the quick start function(same character as your last one)."), 11, 2);
4514
4515         /* Choose */
4516         while (1)
4517         {
4518                 char c;
4519
4520                 put_str(_("クイック・スタートを使いますか?[y/N]", "Use quick start? [y/N]"), 14, 10);
4521                 c = inkey();
4522
4523                 if (c == 'Q') quit(NULL);
4524                 else if (c == 'S') return (FALSE);
4525                 else if (c == '?')
4526                 {
4527 #ifdef JP
4528                         show_help("jbirth.txt#QuickStart");
4529 #else
4530                         show_help("birth.txt#QuickStart");
4531 #endif
4532                 }
4533                 else if ((c == 'y') || (c == 'Y'))
4534                 {
4535                         /* Yes */
4536                         break;
4537                 }
4538                 else
4539                 {
4540                         /* No */
4541                         return FALSE;
4542                 }
4543         }
4544
4545         load_prev_data(FALSE);
4546         init_turn();
4547         init_dungeon_quests();
4548
4549         sp_ptr = &sex_info[p_ptr->psex];
4550         rp_ptr = &race_info[p_ptr->prace];
4551         cp_ptr = &class_info[p_ptr->pclass];
4552         mp_ptr = &m_info[p_ptr->pclass];
4553         ap_ptr = &seikaku_info[p_ptr->pseikaku];
4554
4555         /* Calc hitdie, but don't roll */
4556         get_extra(FALSE);
4557
4558         p_ptr->update |= (PU_BONUS | PU_HP);
4559         update_creature(p_ptr);
4560         p_ptr->chp = p_ptr->mhp;
4561         p_ptr->csp = p_ptr->msp;
4562
4563         /* Process the player name */
4564         process_player_name(FALSE);
4565
4566         return TRUE;
4567 }
4568
4569
4570 /*!
4571  * @brief プレイヤー作成処理のメインルーチン/ Create a new character.
4572  * @details
4573  * Note that we may be called with "junk" leftover in the various
4574  * fields, so we must be sure to clear them first.
4575  * @return なし
4576  */
4577 void player_birth(void)
4578 {
4579         int i, j;
4580         char buf[80];
4581
4582         current_world_ptr->play_time = 0;
4583
4584         /* 
4585          * Wipe monsters in old dungeon
4586          * This wipe destroys value of current_floor_ptr->m_list[].cur_num .
4587          */
4588         wipe_m_list();
4589
4590         /* Wipe the player */
4591         player_wipe_without_name();
4592
4593         /* Create a new character */
4594
4595         /* Quick start? */
4596         if (!ask_quick_start())
4597         {
4598                 play_music(TERM_XTRA_MUSIC_BASIC, MUSIC_BASIC_DEFAULT);
4599
4600                 /* No, normal start */
4601                 while (1)
4602                 {
4603                         /* Roll up a new character */
4604                         if (player_birth_aux()) break;
4605
4606                         /* Wipe the player */
4607                         player_wipe_without_name();
4608                 }
4609         }
4610
4611         /* Note player birth in the message recall */
4612         message_add(" ");
4613         message_add("  ");
4614         message_add("====================");
4615         message_add(" ");
4616         message_add("  ");
4617
4618         do_cmd_write_nikki(NIKKI_GAMESTART, 1, _("-------- 新規ゲーム開始 --------", "-------- Start New Game --------"));
4619         do_cmd_write_nikki(NIKKI_HIGAWARI, 0, NULL);
4620
4621         sprintf(buf,_("                            性別に%sを選択した。", "                            choose %s personality."), sex_info[p_ptr->psex].title);
4622         do_cmd_write_nikki(NIKKI_BUNSHOU, 1, buf);
4623
4624         sprintf(buf,_("                            種族に%sを選択した。", "                            choose %s race."), race_info[p_ptr->prace].title);
4625         do_cmd_write_nikki(NIKKI_BUNSHOU, 1, buf);
4626
4627         sprintf(buf,_("                            職業に%sを選択した。", "                            choose %s class."), class_info[p_ptr->pclass].title);
4628         do_cmd_write_nikki(NIKKI_BUNSHOU, 1, buf);
4629
4630         if (p_ptr->realm1)
4631         {
4632                 sprintf(buf,_("                            魔法の領域に%s%sを選択した。", "                            choose %s%s realm."),realm_names[p_ptr->realm1], p_ptr->realm2 ? format("と%s",realm_names[p_ptr->realm2]) : "");
4633                 do_cmd_write_nikki(NIKKI_BUNSHOU, 1, buf);
4634         }
4635
4636         sprintf(buf,_("                            性格に%sを選択した。", "                            choose %s."), seikaku_info[p_ptr->pseikaku].title);
4637         do_cmd_write_nikki(NIKKI_BUNSHOU, 1, buf);
4638
4639         /* Init the shops */
4640         for (i = 1; i < max_towns; i++)
4641         {
4642                 for (j = 0; j < MAX_STORES; j++)
4643                 {
4644                         store_init(i, j);
4645                 }
4646         }
4647
4648         /* Generate the random seeds for the wilderness */
4649         seed_wilderness();
4650
4651         /* Give beastman a mutation at character birth */
4652         if (p_ptr->prace == RACE_BEASTMAN) p_ptr->hack_mutation = TRUE;
4653         else p_ptr->hack_mutation = FALSE;
4654
4655         /* Set the message window flag as default */
4656         if (!window_flag[1])
4657                 window_flag[1] |= PW_MESSAGE;
4658
4659         /* Set the inv/equip window flag as default */
4660         if (!window_flag[2])
4661                 window_flag[2] |= PW_INVEN;
4662 }
4663
4664 /*!
4665  * @brief プレイヤー作成処理中のステータス表示処理
4666  * @param fff ファイルポインタ
4667  * @return なし
4668  */
4669 void dump_yourself(FILE *fff)
4670 {
4671         char temp[80*10];
4672         int i;
4673         concptr t;
4674
4675         if (!fff) return;
4676
4677         roff_to_buf(race_jouhou[p_ptr->prace], 78, temp, sizeof(temp));
4678         fprintf(fff, "\n\n");
4679         fprintf(fff, _("種族: %s\n", "Race: %s\n"), race_info[p_ptr->prace].title);
4680
4681         t = temp;
4682         for (i = 0; i < 10; i++)
4683         {
4684                 if(t[0] == 0)
4685                         break; 
4686                 fprintf(fff, "%s\n",t);
4687                 t += strlen(t) + 1;
4688         }
4689         roff_to_buf(class_jouhou[p_ptr->pclass], 78, temp, sizeof(temp));
4690         fprintf(fff, "\n");
4691         fprintf(fff, _("職業: %s\n", "Class: %s\n"), class_info[p_ptr->pclass].title);
4692
4693         t = temp;
4694         for (i = 0; i < 10; i++)
4695         {
4696                 if(t[0] == 0)
4697                         break; 
4698                 fprintf(fff, "%s\n",t);
4699                 t += strlen(t) + 1;
4700         }
4701         roff_to_buf(seikaku_jouhou[p_ptr->pseikaku], 78, temp, sizeof(temp));
4702         fprintf(fff, "\n");
4703         fprintf(fff, _("性格: %s\n", "Pesonality: %s\n"), seikaku_info[p_ptr->pseikaku].title);
4704
4705         t = temp;
4706         for (i = 0; i < A_MAX; i++)
4707         {
4708                 if(t[0] == 0)
4709                         break; 
4710                 fprintf(fff, "%s\n",t);
4711                 t += strlen(t) + 1;
4712         }
4713         fprintf(fff, "\n");
4714         if (p_ptr->realm1)
4715         {
4716                 roff_to_buf(realm_jouhou[technic2magic(p_ptr->realm1)-1], 78, temp, sizeof(temp));
4717                 fprintf(fff, _("魔法: %s\n", "Realm: %s\n"), realm_names[p_ptr->realm1]);
4718
4719                 t = temp;
4720                 for (i = 0; i < A_MAX; i++)
4721                 {
4722                         if(t[0] == 0)
4723                                 break; 
4724                         fprintf(fff, "%s\n",t);
4725                         t += strlen(t) + 1;
4726                 }
4727         }
4728         fprintf(fff, "\n");
4729         if (p_ptr->realm2)
4730         {
4731                 roff_to_buf(realm_jouhou[technic2magic(p_ptr->realm2)-1], 78, temp, sizeof(temp));
4732                 fprintf(fff, _("魔法: %s\n", "Realm: %s\n"), realm_names[p_ptr->realm2]);
4733
4734                 t = temp;
4735                 for (i = 0; i < A_MAX; i++)
4736                 {
4737                         if(t[0] == 0)
4738                                 break; 
4739                         fprintf(fff, "%s\n",t);
4740                         t += strlen(t) + 1;
4741                 }
4742         }
4743 }