annotate Items.cpp @ 375:c606cabd7cbf

Merge
author Gloval
date Fri, 22 Feb 2013 08:23:15 +0400
parents f0f66f690777 85edec9da96b
children 243418228760
rev   line source
0
Ritor1
parents:
diff changeset
1 #include <stdlib.h>
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
2 #include <assert.h>
0
Ritor1
parents:
diff changeset
3
Ritor1
parents:
diff changeset
4 #include "Items.h"
Ritor1
parents:
diff changeset
5 #include "MapInfo.h"
Ritor1
parents:
diff changeset
6 #include "FrameTableInc.h"
Ritor1
parents:
diff changeset
7 #include "Allocator.h"
Ritor1
parents:
diff changeset
8 #include "LOD.h"
Ritor1
parents:
diff changeset
9 #include "Monsters.h"
Ritor1
parents:
diff changeset
10 #include "Party.h"
Ritor1
parents:
diff changeset
11 #include "FactionTable.h"
Ritor1
parents:
diff changeset
12 #include "StorylineTextTable.h"
189
038a4d09406f new texts file, fix text rendender error
Gloval
parents: 0
diff changeset
13 #include "texts.h"
0
Ritor1
parents:
diff changeset
14 #include "mm7_data.h"
Ritor1
parents:
diff changeset
15
Ritor1
parents:
diff changeset
16
Ritor1
parents:
diff changeset
17
Ritor1
parents:
diff changeset
18
Ritor1
parents:
diff changeset
19
Ritor1
parents:
diff changeset
20 ItemGen *ptr_50C9A4;
Ritor1
parents:
diff changeset
21
315
2a09e1d6fc8f Some 0041D895 GameUI_DrawItemInfo overhaul
Nomad
parents: 296
diff changeset
22 struct ItemsTable *pItemsTable; // 005D29E0
0
Ritor1
parents:
diff changeset
23
Ritor1
parents:
diff changeset
24
Ritor1
parents:
diff changeset
25
Ritor1
parents:
diff changeset
26
Ritor1
parents:
diff changeset
27
Ritor1
parents:
diff changeset
28 //----- (00439DF3) --------------------------------------------------------
Ritor1
parents:
diff changeset
29 int ItemGen::_439DF3_get_additional_damage(int *a2, int *a3)
Ritor1
parents:
diff changeset
30 {
Ritor1
parents:
diff changeset
31 int *v3; // edi@1
Ritor1
parents:
diff changeset
32 ItemGen *v4; // ebx@1
Ritor1
parents:
diff changeset
33 signed int v5; // esi@1
Ritor1
parents:
diff changeset
34 unsigned int v7; // ecx@5
Ritor1
parents:
diff changeset
35 signed int v8; // ebx@7
Ritor1
parents:
diff changeset
36 int v9; // edx@22
Ritor1
parents:
diff changeset
37 int v10; // eax@24
Ritor1
parents:
diff changeset
38 int v11; // edx@25
Ritor1
parents:
diff changeset
39 int v12; // ebx@28
Ritor1
parents:
diff changeset
40 int v13; // ebx@29
Ritor1
parents:
diff changeset
41 int v14; // ebx@30
Ritor1
parents:
diff changeset
42 int v15; // ebx@31
Ritor1
parents:
diff changeset
43 int v16; // ebx@32
Ritor1
parents:
diff changeset
44 signed int v17; // [sp-4h] [bp-10h]@24
Ritor1
parents:
diff changeset
45
Ritor1
parents:
diff changeset
46 auto a1 = this;
Ritor1
parents:
diff changeset
47 v3 = a2;
Ritor1
parents:
diff changeset
48 v4 = a1;
Ritor1
parents:
diff changeset
49 v5 = 0;
Ritor1
parents:
diff changeset
50 *a2 = 0;
Ritor1
parents:
diff changeset
51 if ( !a1->uItemID )
Ritor1
parents:
diff changeset
52 return 0;
Ritor1
parents:
diff changeset
53 UpdateTempBonus(pParty->uTimePlayed);
Ritor1
parents:
diff changeset
54 if ( v4->uItemID == 501 )
Ritor1
parents:
diff changeset
55 {
Ritor1
parents:
diff changeset
56 *v3 = 1;
Ritor1
parents:
diff changeset
57 v10 = rand();
Ritor1
parents:
diff changeset
58 v17 = 10;
Ritor1
parents:
diff changeset
59 return v10 % v17 + 6;
Ritor1
parents:
diff changeset
60 }
Ritor1
parents:
diff changeset
61 if ( v4->uItemID == 507 )
Ritor1
parents:
diff changeset
62 {
Ritor1
parents:
diff changeset
63 *v3 = 0;
Ritor1
parents:
diff changeset
64 v11 = rand() % 16;
Ritor1
parents:
diff changeset
65 return v11 + 3;
Ritor1
parents:
diff changeset
66 }
Ritor1
parents:
diff changeset
67 v7 = 3;
Ritor1
parents:
diff changeset
68 if ( v4->uItemID == 510 )
Ritor1
parents:
diff changeset
69 {
Ritor1
parents:
diff changeset
70 *v3 = 2;
Ritor1
parents:
diff changeset
71 v9 = rand() % 4;
Ritor1
parents:
diff changeset
72 return v9 + 9;
Ritor1
parents:
diff changeset
73 }
Ritor1
parents:
diff changeset
74 if ( v4->uItemID == 517 )
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
75 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
76 v5 = 8;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
77 *v3 = v5;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
78 return v5;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
79 }
0
Ritor1
parents:
diff changeset
80 v8 = v4->uAdditionalValue;
Ritor1
parents:
diff changeset
81 if ( v8 > 46 )
Ritor1
parents:
diff changeset
82 {
Ritor1
parents:
diff changeset
83 v5 = 0;
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
84 *v3 = v5;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
85 return v5;
0
Ritor1
parents:
diff changeset
86 }
Ritor1
parents:
diff changeset
87 if ( v8 == 46 )
Ritor1
parents:
diff changeset
88 {
Ritor1
parents:
diff changeset
89 *v3 = 0;
Ritor1
parents:
diff changeset
90 return rand() % 11 + 10;
Ritor1
parents:
diff changeset
91 }
Ritor1
parents:
diff changeset
92 if ( v8 > 11 )
Ritor1
parents:
diff changeset
93 {
Ritor1
parents:
diff changeset
94 v12 = v8 - 12;
Ritor1
parents:
diff changeset
95 if ( !v12 )
Ritor1
parents:
diff changeset
96 {
Ritor1
parents:
diff changeset
97 *v3 = 0;
Ritor1
parents:
diff changeset
98 return GetDiceResult(v7, 6u);
Ritor1
parents:
diff changeset
99 }
Ritor1
parents:
diff changeset
100 v13 = v12 - 1;
Ritor1
parents:
diff changeset
101 if ( !v13 )
Ritor1
parents:
diff changeset
102 {
Ritor1
parents:
diff changeset
103 *v3 = 8;
Ritor1
parents:
diff changeset
104 return 5;
Ritor1
parents:
diff changeset
105 }
Ritor1
parents:
diff changeset
106 v14 = v13 - 1;
Ritor1
parents:
diff changeset
107 if ( v14 )
Ritor1
parents:
diff changeset
108 {
Ritor1
parents:
diff changeset
109 v15 = v14 - 1;
Ritor1
parents:
diff changeset
110 if ( v15 )
Ritor1
parents:
diff changeset
111 {
Ritor1
parents:
diff changeset
112 v16 = v15 - 1;
Ritor1
parents:
diff changeset
113 if ( !v16 || v16 == 25 )
Ritor1
parents:
diff changeset
114 {
Ritor1
parents:
diff changeset
115 *v3 = 10;
Ritor1
parents:
diff changeset
116 *a3 = 1;
Ritor1
parents:
diff changeset
117 return v5;
Ritor1
parents:
diff changeset
118 }
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
119 v5 = 0;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
120 *v3 = v5;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
121 return v5;
0
Ritor1
parents:
diff changeset
122 }
Ritor1
parents:
diff changeset
123 *v3 = 2;
Ritor1
parents:
diff changeset
124 return 12;
Ritor1
parents:
diff changeset
125 }
Ritor1
parents:
diff changeset
126 v5 = 8;
Ritor1
parents:
diff changeset
127 *v3 = v5;
Ritor1
parents:
diff changeset
128 return v5;
Ritor1
parents:
diff changeset
129 }
Ritor1
parents:
diff changeset
130 if ( v8 == 11 )
Ritor1
parents:
diff changeset
131 {
Ritor1
parents:
diff changeset
132 *v3 = 0;
Ritor1
parents:
diff changeset
133 v7 = 2;
Ritor1
parents:
diff changeset
134 return GetDiceResult(v7, 6u);
Ritor1
parents:
diff changeset
135 }
Ritor1
parents:
diff changeset
136 if ( v8 == 4 )
Ritor1
parents:
diff changeset
137 {
Ritor1
parents:
diff changeset
138 *v3 = 2;
Ritor1
parents:
diff changeset
139 v11 = rand() % 2;
Ritor1
parents:
diff changeset
140 return v11 + 3;
Ritor1
parents:
diff changeset
141 }
Ritor1
parents:
diff changeset
142 if ( v8 == 5 )
Ritor1
parents:
diff changeset
143 {
Ritor1
parents:
diff changeset
144 *v3 = 2;
Ritor1
parents:
diff changeset
145 v10 = rand();
Ritor1
parents:
diff changeset
146 v17 = 3;
Ritor1
parents:
diff changeset
147 return v10 % v17 + 6;
Ritor1
parents:
diff changeset
148 }
Ritor1
parents:
diff changeset
149 if ( v8 == 6 )
Ritor1
parents:
diff changeset
150 {
Ritor1
parents:
diff changeset
151 *v3 = 2;
Ritor1
parents:
diff changeset
152 v9 = rand() % 4;
Ritor1
parents:
diff changeset
153 return v9 + 9;
Ritor1
parents:
diff changeset
154 }
Ritor1
parents:
diff changeset
155 if ( v8 == 7 )
Ritor1
parents:
diff changeset
156 {
Ritor1
parents:
diff changeset
157 *v3 = 1;
Ritor1
parents:
diff changeset
158 return rand() % 4 + 2;
Ritor1
parents:
diff changeset
159 }
Ritor1
parents:
diff changeset
160 if ( v8 == 8 )
Ritor1
parents:
diff changeset
161 {
Ritor1
parents:
diff changeset
162 *v3 = 1;
Ritor1
parents:
diff changeset
163 return rand() % 7 + 4;
Ritor1
parents:
diff changeset
164 }
Ritor1
parents:
diff changeset
165 if ( v8 == 9 )
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
166 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
167 *v3 = 1;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
168 v10 = rand();
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
169 v17 = 10;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
170 return v10 % v17 + 6;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
171 }
0
Ritor1
parents:
diff changeset
172 if ( v8 != 10 )
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
173 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
174 v5 = 0;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
175 *v3 = v5;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
176 return v5;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
177 }
0
Ritor1
parents:
diff changeset
178 *v3 = 0;
Ritor1
parents:
diff changeset
179 v7 = 1;
Ritor1
parents:
diff changeset
180 return GetDiceResult(v7, 6u);
Ritor1
parents:
diff changeset
181 }
Ritor1
parents:
diff changeset
182
Ritor1
parents:
diff changeset
183
Ritor1
parents:
diff changeset
184 //----- (00402F07) --------------------------------------------------------
Ritor1
parents:
diff changeset
185 void ItemGen::Reset()
Ritor1
parents:
diff changeset
186 {
Ritor1
parents:
diff changeset
187 this->field_1A = 0;
Ritor1
parents:
diff changeset
188 this->uAttributes = 0;
Ritor1
parents:
diff changeset
189 this->uNumCharges = 0;
Ritor1
parents:
diff changeset
190 this->uAdditionalValue = 0;
Ritor1
parents:
diff changeset
191 this->_bonus_strength = 0;
Ritor1
parents:
diff changeset
192 this->_bonus_type = 0;
Ritor1
parents:
diff changeset
193 this->uItemID = 0;
Ritor1
parents:
diff changeset
194 this->uBodyAnchor = 0;
Ritor1
parents:
diff changeset
195 this->uExpireTime = 0i64;
Ritor1
parents:
diff changeset
196 }
Ritor1
parents:
diff changeset
197
Ritor1
parents:
diff changeset
198 //----- (00458260) --------------------------------------------------------
Ritor1
parents:
diff changeset
199 void ItemGen::UpdateTempBonus(__int64 uTimePlayed)
Ritor1
parents:
diff changeset
200 {
Ritor1
parents:
diff changeset
201 unsigned int v2; // eax@1
Ritor1
parents:
diff changeset
202
Ritor1
parents:
diff changeset
203 v2 = this->uAttributes;
Ritor1
parents:
diff changeset
204 if ( v2 & ITEM_TEMP_BONUS )
Ritor1
parents:
diff changeset
205 {
Ritor1
parents:
diff changeset
206 if ( uTimePlayed > (signed __int64)this->uExpireTime )
Ritor1
parents:
diff changeset
207 {
Ritor1
parents:
diff changeset
208 this->_bonus_type = 0;
Ritor1
parents:
diff changeset
209 LOBYTE(v2) = v2 & 0xF7;
Ritor1
parents:
diff changeset
210 this->uAdditionalValue = 0;
Ritor1
parents:
diff changeset
211 this->uAttributes = v2;
Ritor1
parents:
diff changeset
212 }
Ritor1
parents:
diff changeset
213 }
Ritor1
parents:
diff changeset
214 }
Ritor1
parents:
diff changeset
215
Ritor1
parents:
diff changeset
216 //----- (0045814E) --------------------------------------------------------
374
Gloval
parents: 365
diff changeset
217 void ItemsTable::Release()
0
Ritor1
parents:
diff changeset
218 {
Ritor1
parents:
diff changeset
219 if ( pMonstersTXT_Raw )
Ritor1
parents:
diff changeset
220 pAllocator->FreeChunk(pMonstersTXT_Raw);
Ritor1
parents:
diff changeset
221 if ( pMonsterPlacementTXT_Raw )
Ritor1
parents:
diff changeset
222 pAllocator->FreeChunk(pMonsterPlacementTXT_Raw);
Ritor1
parents:
diff changeset
223 if ( pSkillDescTXT_Raw )
Ritor1
parents:
diff changeset
224 pAllocator->FreeChunk(pSkillDescTXT_Raw);
374
Gloval
parents: 365
diff changeset
225 if (pSpcItemsTXT_Raw )
Gloval
parents: 365
diff changeset
226 pAllocator->FreeChunk(pSpcItemsTXT_Raw);
Gloval
parents: 365
diff changeset
227 if ( pStdItemsTXT_Raw )
Gloval
parents: 365
diff changeset
228 pAllocator->FreeChunk(pStdItemsTXT_Raw);
Gloval
parents: 365
diff changeset
229 if ( pRndItemsTXT_Raw )
Gloval
parents: 365
diff changeset
230 pAllocator->FreeChunk(pRndItemsTXT_Raw);
Gloval
parents: 365
diff changeset
231 if ( pItemsTXT_Raw )
Gloval
parents: 365
diff changeset
232 pAllocator->FreeChunk(pItemsTXT_Raw);
0
Ritor1
parents:
diff changeset
233 if ( pHostileTXT_Raw )
Ritor1
parents:
diff changeset
234 pAllocator->FreeChunk(pHostileTXT_Raw);
Ritor1
parents:
diff changeset
235 if ( pHistoryTXT_Raw )
Ritor1
parents:
diff changeset
236 pAllocator->FreeChunk(pHistoryTXT_Raw);
Ritor1
parents:
diff changeset
237 if ( pPotionsTXT_Raw )
Ritor1
parents:
diff changeset
238 pAllocator->FreeChunk(pPotionsTXT_Raw);
Ritor1
parents:
diff changeset
239 if ( pPotionNotesTXT_Raw )
Ritor1
parents:
diff changeset
240 pAllocator->FreeChunk(pPotionNotesTXT_Raw);
374
Gloval
parents: 365
diff changeset
241 pSpcItemsTXT_Raw = NULL;
Gloval
parents: 365
diff changeset
242 pSkillDescTXT_Raw = NULL;
Gloval
parents: 365
diff changeset
243 pStdItemsTXT_Raw = NULL;
Gloval
parents: 365
diff changeset
244 pRndItemsTXT_Raw = NULL;
Gloval
parents: 365
diff changeset
245 pItemsTXT_Raw = NULL;
Gloval
parents: 365
diff changeset
246
0
Ritor1
parents:
diff changeset
247 }
Ritor1
parents:
diff changeset
248
Ritor1
parents:
diff changeset
249
Ritor1
parents:
diff changeset
250 //----- (00456D84) --------------------------------------------------------
Ritor1
parents:
diff changeset
251 void ItemsTable::Initialize()
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
252 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
253 int i,j;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
254 char* test_string;
229
Gloval
parents: 224
diff changeset
255 unsigned char c;
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
256 bool break_loop;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
257 unsigned int temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
258 char* tmp_pos;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
259 int decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
260 int item_counter;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
261
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
262 pMapStats = new MapStats;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
263 pMapStats->Initialize();
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
264
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
265 pMonsterStats = new MonsterStats;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
266 pMonsterStats->Initialize();
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
267 pMonsterStats->InitializePlacements();
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
268
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
269 pSpellStats = new SpellStats;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
270 pSpellStats->Initialize();
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
271
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
272 LoadPotions();
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
273 LoadPotionNotes();
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
274
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
275 pFactionTable = new FactionTable;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
276 pFactionTable->Initialize();
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
277
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
278 pStorylineText = new StorylineText;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
279 pStorylineText->Initialize();
0
Ritor1
parents:
diff changeset
280
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
281 pStdItemsTXT_Raw = NULL;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
282 pStdItemsTXT_Raw = (char *)pEvents_LOD->LoadRaw("stditems.txt", 0);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
283 strtok(pStdItemsTXT_Raw, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
284 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
285 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
286 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
287 //Standard Bonuses by Group
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
288 for (i=0;i<24;++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
289 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
290 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
291 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
292 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
293 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
294 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
295 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
296 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
297 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
298 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
299 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
300 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
301 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
302 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
303 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
304 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
305 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
306 if (temp_str_len)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
307 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
308 switch (decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
309 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
310 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
311 pEnchantments[i].pBonusStat=RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
312 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
313 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
314 pEnchantments[i].pOfName= RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
315 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
316 default:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
317 pEnchantments[i].to_item[decode_step-2]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
318 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
319 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
320 else
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
321 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
322 if (!decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
323 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
324 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
325 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
326 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
327 } while ((decode_step<11)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
328 }
0
Ritor1
parents:
diff changeset
329
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
330 memset(&pEnchantmentsSumm, 0, 36);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
331 for(i=0;i<9;++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
332 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
333 for (j=0;j<24;++j)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
334 pEnchantmentsSumm[i]+=pEnchantments[j].to_item[i];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
335 }
0
Ritor1
parents:
diff changeset
336
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
337 //Bonus range for Standard by Level
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
338 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
339 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
340 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
341 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
342 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
343 for(i=0;i<6;++i) //counted from 1
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
344 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
345 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
346 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
347 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
348 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
349 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
350 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
351 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
352 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
353 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
354 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
355 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
356 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
357 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
358 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
359 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
360 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
361 if (decode_step==2)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
362 bonus_ranges[i].minR = atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
363 else if (decode_step==3)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
364 bonus_ranges[i].maxR =atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
365 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
366 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
367 } while ((decode_step<4)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
368 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
369
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
370
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
371 pSpcItemsTXT_Raw = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
372 pSpcItemsTXT_Raw = (char *)pEvents_LOD->LoadRaw("spcitems.txt", 0);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
373 strtok(pSpcItemsTXT_Raw, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
374 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
375 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
376 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
377 for (i=0;i<72;++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
378 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
379 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
380 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
381 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
382 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
383 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
384 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
385 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
386 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
387 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
388 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
389 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
390 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
391 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
392 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
393 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
394 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
395 if (temp_str_len)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
396 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
397 switch (decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
398 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
399 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
400 pSpecialEnchantments[i].pBonusStatement=RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
401 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
402 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
403 pSpecialEnchantments[i].pNameAdd= RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
404 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
405 case 14:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
406 int res;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
407 res=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
408 if(!res)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
409 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
410 ++test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
411 while (*test_string==' ')//fix X 2 case
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
412 ++test_string;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
413 res=atoi(test_string);
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
414 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
415 pSpecialEnchantments[i].iValue=res;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
416 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
417 case 15:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
418 pSpecialEnchantments[i].iTreasureLevel= tolower(*test_string) - 97;;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
419 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
420 default:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
421 pSpecialEnchantments[i].to_item_apply[decode_step-2]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
422 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
423 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
424 else
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
425 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
426 if (!decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
427 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
428 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
429 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
430 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
431 } while ((decode_step<16)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
432 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
433
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
434 pSpecialEnchantments_count = 71;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
435 memset(&pSpecialEnchantmentsSumm, 0, 96);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
436 for(i=0;i<12;++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
437 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
438 for (j=0;j<pSpecialEnchantments_count;++j)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
439 pSpecialEnchantmentsSumm[i]+=pSpecialEnchantments[j].to_item_apply[i];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
440 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
441
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
442 Initialize2DA();
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
443
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
444 pItemsTXT_Raw = NULL;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
445 pItemsTXT_Raw = (char*) pEvents_LOD->LoadRaw("items.txt", 0);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
446 strtok(pItemsTXT_Raw, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
447 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
448 uAllItemsCount = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
449 item_counter = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
450 while (true)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
451 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
452 test_string = strtok(NULL, "\r") + 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
453 break_loop = false;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
454 decode_step=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
455 do
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
456 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
457 c = *(unsigned char*)test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
458 temp_str_len = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
459 while((c!='\t')&&(c>0))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
460 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
461 ++temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
462 c=test_string[temp_str_len];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
463 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
464 tmp_pos=test_string+temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
465 if (*tmp_pos == 0)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
466 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
467 *tmp_pos = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
468 if (temp_str_len)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
469 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
470 switch (decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
471 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
472 case 0: //Item #
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
473 item_counter=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
474 uAllItemsCount=item_counter;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
475 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
476 case 1: //Pic File
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
477 pItems[item_counter].pIconName = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
478 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
479 case 2: //Name
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
480 pItems[item_counter].pName = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
481 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
482 case 3: //Value
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
483 pItems[item_counter].uValue=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
484 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
485 case 4: //Equip Stat
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
486 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
487 if ( !_strcmpi(test_string, "weapon") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
488 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
489 pItems[item_counter].uEquipType = EQUIP_ONE_OR_TWO_HANDS;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
490 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
491 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
492 if ( !_strcmpi(test_string, "weapon2") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
493 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
494 pItems[item_counter].uEquipType = EQUIP_TWO_HANDED;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
495 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
496 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
497 if ( !_strcmpi(test_string, "weapon1or2") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
498 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
499 pItems[item_counter].uEquipType = EQUIP_ONE_OR_TWO_HANDS;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
500 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
501 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
502 if ( !(_strcmpi(test_string, "missile")&&_strcmpi(test_string, "bow")))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
503 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
504 pItems[item_counter].uEquipType = EQUIP_BOW;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
505 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
506 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
507 if ( !_strcmpi(test_string, "armor") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
508 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
509 pItems[item_counter].uEquipType = EQUIP_ARMOUR;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
510 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
511 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
512 if ( !_strcmpi(test_string, "shield") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
513 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
514 pItems[item_counter].uEquipType = EQUIP_SHIELD;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
515 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
516 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
517 if ( !_strcmpi(test_string, "helm") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
518 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
519 pItems[item_counter].uEquipType = EQUIP_HELMET;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
520 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
521 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
522 if ( !_strcmpi(test_string, "belt") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
523 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
524 pItems[item_counter].uEquipType = EQUIP_BELT;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
525 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
526 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
527 if ( !_strcmpi(test_string, "cloak") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
528 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
529 pItems[item_counter].uEquipType = EQUIP_CLOAK;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
530 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
531 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
532 if ( !_strcmpi(test_string, "gauntlets") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
533 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
534 pItems[item_counter].uEquipType = EQUIP_GAUNTLETS;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
535 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
536 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
537 if ( !_strcmpi(test_string, "boots") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
538 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
539 pItems[item_counter].uEquipType = EQUIP_BOOTS;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
540 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
541 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
542 if ( !_strcmpi(test_string, "ring") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
543 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
544 pItems[item_counter].uEquipType = EQUIP_RING;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
545 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
546 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
547 if ( !_strcmpi(test_string, "amulet") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
548 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
549 pItems[item_counter].uEquipType = EQUIP_AMULET;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
550 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
551 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
552 if ( !_strcmpi(test_string, "weaponw") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
553 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
554 pItems[item_counter].uEquipType = EQUIP_WAND;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
555 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
556 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
557 if ( !(_strcmpi(test_string, "herb")&&_strcmpi(test_string, "reagent")))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
558 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
559 pItems[item_counter].uEquipType = EQUIP_REAGENT;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
560 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
561 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
562 if ( !_strcmpi(test_string, "bottle") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
563 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
564 pItems[item_counter].uEquipType = EQUIP_POTION;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
565 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
566 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
567 if ( !_strcmpi(test_string, "sscroll") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
568 {
374
Gloval
parents: 365
diff changeset
569 pItems[item_counter].uEquipType = EQUIP_SPELL_SCROLL;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
570 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
571 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
572 if ( !_strcmpi(test_string, "book") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
573 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
574 pItems[item_counter].uEquipType = EQUIP_BOOK;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
575 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
576 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
577 if ( !_strcmpi(test_string, "mscroll") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
578 {
374
Gloval
parents: 365
diff changeset
579 pItems[item_counter].uEquipType = EQUIP_MESSAGE_SCROLL;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
580 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
581 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
582 if ( !_strcmpi(test_string, "gold") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
583 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
584 pItems[item_counter].uEquipType = EQUIP_GOLD;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
585 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
586 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
587 if ( !_strcmpi(test_string, "gem") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
588 {
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
589 pItems[item_counter].uEquipType = EQUIP_GEM;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
590 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
591 }
365
0f35f908547f fixed missing dagger
Gloval
parents: 315
diff changeset
592 pItems[item_counter].uEquipType = EQUIP_NONE;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
593 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
594 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
595 case 5: //Skill Group
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
596 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
597 if ( !_strcmpi(test_string, "staff") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
598 {
374
Gloval
parents: 365
diff changeset
599 pItems[item_counter].uSkillType = PLAYER_SKILL_STAFF;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
600 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
601 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
602 if ( !_strcmpi(test_string, "sword") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
603 {
374
Gloval
parents: 365
diff changeset
604 pItems[item_counter].uSkillType = PLAYER_SKILL_SWORD;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
605 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
606 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
607 if ( !_strcmpi(test_string, "dagger") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
608 {
374
Gloval
parents: 365
diff changeset
609 pItems[item_counter].uSkillType = PLAYER_SKILL_DAGGER;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
610 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
611 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
612 if ( !_strcmpi(test_string, "axe") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
613 {
374
Gloval
parents: 365
diff changeset
614 pItems[item_counter].uSkillType = PLAYER_SKILL_AXE;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
615 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
616 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
617 if ( !_strcmpi(test_string, "spear") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
618 {
374
Gloval
parents: 365
diff changeset
619 pItems[item_counter].uSkillType = PLAYER_SKILL_SPEAR;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
620 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
621 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
622 if ( !_strcmpi(test_string, "bow") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
623 {
374
Gloval
parents: 365
diff changeset
624 pItems[item_counter].uSkillType = PLAYER_SKILL_BOW;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
625 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
626 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
627 if ( !_strcmpi(test_string, "mace") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
628 {
374
Gloval
parents: 365
diff changeset
629 pItems[item_counter].uSkillType = PLAYER_SKILL_MACE;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
630 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
631 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
632 if ( !_strcmpi(test_string, "blaster") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
633 {
374
Gloval
parents: 365
diff changeset
634 pItems[item_counter].uSkillType = PLAYER_SKILL_BLASTER;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
635 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
636 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
637 if ( !_strcmpi(test_string, "shield") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
638 {
374
Gloval
parents: 365
diff changeset
639 pItems[item_counter].uSkillType = PLAYER_SKILL_SHIELD;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
640 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
641 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
642 if ( !_strcmpi(test_string, "leather") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
643 {
374
Gloval
parents: 365
diff changeset
644 pItems[item_counter].uSkillType = PLAYER_SKILL_LEATHER;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
645 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
646 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
647 if ( !_strcmpi(test_string, "chain") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
648 {
374
Gloval
parents: 365
diff changeset
649 pItems[item_counter].uSkillType = PLAYER_SKILL_CHAIN;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
650 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
651 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
652 if ( !_strcmpi(test_string, "plate") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
653 {
374
Gloval
parents: 365
diff changeset
654 pItems[item_counter].uSkillType = PLAYER_SKILL_PLATE;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
655 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
656 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
657 if ( !_strcmpi(test_string, "club") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
658 {
374
Gloval
parents: 365
diff changeset
659 pItems[item_counter].uSkillType = PLAYER_SKILL_CLUB;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
660 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
661 }
374
Gloval
parents: 365
diff changeset
662 pItems[item_counter].uSkillType = PLAYER_SKILL_ANY;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
663 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
664 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
665 case 6: //Mod1
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
666 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
667 int ii;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
668 char* test_char;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
669 int tst_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
670 tst_len=strlen(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
671 pItems[item_counter].uDamageDice=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
672 pItems[item_counter].uDamageRoll=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
673 test_char=test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
674 for (ii=0; ii<tst_len; ++ii)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
675 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
676 if (tolower(*test_char)=='d')
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
677 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
678 *test_char=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
679 pItems[item_counter].uDamageDice=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
680 pItems[item_counter].uDamageRoll=atoi(test_char+1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
681 *test_char='d';
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
682 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
683 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
684 ++test_char;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
685 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
686 test_char=test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
687 if ((ii==tst_len)&&(tolower(*test_char)=='s'))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
688 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
689 pItems[item_counter].uDamageDice=atoi(test_char+1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
690 pItems[item_counter].uDamageRoll=1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
691 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
692 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
693 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
694 case 7: //Mod2
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
695 pItems[item_counter].uDamageMod=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
696 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
697 case 8: //material
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
698 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
699 if ( !_strcmpi(test_string, "artifact") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
700 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
701 pItems[item_counter].uMaterial = 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
702 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
703 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
704 if ( !_strcmpi(test_string, "relic") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
705 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
706 pItems[item_counter].uMaterial = 2;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
707 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
708 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
709 if ( !_strcmpi(test_string, "special") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
710 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
711 pItems[item_counter].uMaterial = 3;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
712 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
713 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
714 pItems[item_counter].uMaterial = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
715 break;}
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
716 case 9: //ID/Rep/St
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
717 pItems[item_counter].uItemID_Rep_St=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
718 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
719 case 10: //Not identified name
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
720 pItems[item_counter].pUnidentifiedName = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
721 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
722 case 11: //Sprite Index
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
723 pItems[item_counter].uSpriteID=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
724 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
725 case 12: //VarA
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
726 {
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
727 pItems[item_counter]._additional_value=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
728 pItems[item_counter]._bonus_type=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
729 if (pItems[item_counter].uMaterial==3)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
730 {
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
731 for(int ii=0; ii<24; ++ii)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
732 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
733 if (stricmp(test_string,pEnchantments[ii].pBonusStat))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
734 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
735 pItems[item_counter]._bonus_type=ii+1;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
736 break;
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
737 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
738 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
739 if (!pItems[item_counter]._bonus_type)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
740 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
741 for(int ii=0; ii<72; ++ii)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
742 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
743 if (stricmp(test_string,pSpecialEnchantments[ii].pBonusStatement))
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
744 {
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
745 pItems[item_counter]._additional_value=ii+1;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
746 }
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
747 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
748 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
749 }
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
750
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
751 break;
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
752 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
753 case 13: //VarB
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
754 if ((pItems[item_counter].uMaterial==3)&&(pItems[item_counter]._bonus_type))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
755 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
756 char b_s=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
757 if (b_s)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
758 pItems[item_counter]._bonus_strength=b_s;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
759 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
760 pItems[item_counter]._bonus_strength=1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
761 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
762 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
763 pItems[item_counter]._bonus_strength=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
764 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
765 case 14: //Equip X
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
766 pItems[item_counter].uEquipX=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
767 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
768 case 15: //Equip Y
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
769 pItems[item_counter].uEquipY=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
770 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
771 case 16: //Notes
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
772 pItems[item_counter].pDescription = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
773 break;
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
774
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
775 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
776 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
777 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
778 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
779 if (!decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
780 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
781 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
782 ++decode_step;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
783 test_string=tmp_pos+1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
784 } while ((decode_step<17)&&!break_loop);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
785 ++item_counter;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
786 if (item_counter>799)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
787 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
788 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
789
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
790
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
791 pRndItemsTXT_Raw = NULL;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
792 uAllItemsCount = item_counter;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
793 pRndItemsTXT_Raw = (char *)pEvents_LOD->LoadRaw("rnditems.txt", 0);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
794 strtok(pRndItemsTXT_Raw, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
795 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
796 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
797 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
798 item_counter = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
799 while (true)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
800 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
801 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
802 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
803 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
804 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
805 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
806 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
807 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
808 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
809 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
810 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
811 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
812 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
813 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
814 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
815 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
816 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
817 if (temp_str_len)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
818 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
819 switch (decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
820 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
821 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
822 item_counter=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
823 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
824 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
825 pItems[item_counter].uChanceByTreasureLvl1=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
826 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
827 case 3:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
828 pItems[item_counter].uChanceByTreasureLvl2=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
829 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
830 case 4:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
831 pItems[item_counter].uChanceByTreasureLvl3=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
832 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
833 case 5:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
834 pItems[item_counter].uChanceByTreasureLvl4=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
835 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
836 case 6:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
837 pItems[item_counter].uChanceByTreasureLvl5=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
838 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
839 case 7:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
840 pItems[item_counter].uChanceByTreasureLvl6=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
841 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
842 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
843 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
844 else
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
845 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
846 if (!decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
847 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
848 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
849 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
850 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
851 } while ((decode_step<8)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
852 ++item_counter;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
853 if (item_counter>618)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
854 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
855 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
856
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
857 if ( pRndItemsTXT_Raw )
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
858 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
859 pAllocator->FreeChunk(pRndItemsTXT_Raw);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
860 pRndItemsTXT_Raw = NULL;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
861 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
862 //ChanceByTreasureLvl Summ - anti cheating?
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
863 memset(&uChanceByTreasureLvlSumm, 0, 24);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
864 for(i=0;i<6;++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
865 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
866 for (j=0;j<800;++j)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
867 uChanceByTreasureLvlSumm[i]+=pItems[j].uChanceByTreasureLvl[i];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
868 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
869
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
870 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
871 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
872 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
873 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
874 strtok(NULL, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
875 for (i=0;i<3;++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
876 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
877 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
878 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
879 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
880 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
881 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
882 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
883 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
884 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
885 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
886 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
887 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
888 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
889 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
890 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
891 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
892 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
893 if (temp_str_len)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
894 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
895 switch (decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
896 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
897 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
898 switch (i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
899 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
900 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
901 uBonusChanceStandart[0]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
902 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
903 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
904 uBonusChanceSpecial[0]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
905 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
906 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
907 uBonusChanceWpSpecial[0]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
908 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
909 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
910 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
911 case 3:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
912 switch (i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
913 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
914 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
915 uBonusChanceStandart[1]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
916 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
917 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
918 uBonusChanceSpecial[1]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
919 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
920 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
921 uBonusChanceWpSpecial[1]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
922 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
923 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
924 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
925 case 4:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
926 switch (i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
927 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
928 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
929 uBonusChanceStandart[2]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
930 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
931 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
932 uBonusChanceSpecial[2]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
933 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
934 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
935 uBonusChanceWpSpecial[2]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
936 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
937 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
938 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
939 case 5:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
940 switch (i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
941 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
942 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
943 uBonusChanceStandart[3]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
944 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
945 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
946 uBonusChanceSpecial[3]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
947 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
948 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
949 uBonusChanceWpSpecial[3]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
950 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
951 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
952 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
953 case 6:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
954 switch (i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
955 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
956 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
957 uBonusChanceStandart[4]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
958 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
959 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
960 uBonusChanceSpecial[4]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
961 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
962 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
963 uBonusChanceWpSpecial[4]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
964 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
965 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
966 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
967 case 7:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
968 switch (i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
969 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
970 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
971 uBonusChanceStandart[5]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
972 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
973 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
974 uBonusChanceSpecial[5]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
975 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
976 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
977 uBonusChanceWpSpecial[5]=atoi(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
978 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
979 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
980 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
981 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
982 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
983 else
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
984 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
985 if (!decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
986 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
987 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
988 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
989 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
990 } while ((decode_step<8)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
991 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
992
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
993 pSkillDescTXT_Raw = NULL;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
994 pSkillDescTXT_Raw = (char *)pEvents_LOD->LoadRaw("skilldes.txt", 0);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
995 strtok(pSkillDescTXT_Raw, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
996 for (i=0; i<37; ++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
997 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
998 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
999 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1000 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1001 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1002 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1003 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1004 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1005 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1006 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1007 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1008 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1009 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1010 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1011 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1012 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1013 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1014 if (temp_str_len)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1015 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1016 switch (decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1017 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1018 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1019 pSkillDesc[i] = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1020 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1021 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1022 pNormalSkillDesc[i] = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1023 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1024 case 3:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1025 pExpertSkillDesc[i] = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1026 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1027 case 4:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1028 pMasterSkillDesc[i] = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1029 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1030 case 5:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1031 pGrandSkillDesc[i] = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1032 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1033 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1034 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1035 else
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1036 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1037 if (!decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1038 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1039 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1040 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1041 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1042 } while ((decode_step<6)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1043 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1044
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1045 pStatsTXT_Raw = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1046 pStatsTXT_Raw = (char *)pEvents_LOD->LoadRaw("stats.txt", 0);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1047 strtok(pStatsTXT_Raw, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1048 for (i=0; i<26; ++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1049 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1050 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1051 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1052 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1053 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1054 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1055 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1056 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1057 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1058 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1059 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1060 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1061 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1062 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1063 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1064 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1065 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1066 if (temp_str_len)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1067 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1068 switch (i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1069 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1070 case 0:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1071 case 1:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1072 case 2:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1073 case 3:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1074 case 4:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1075 case 5:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1076 case 6:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1077 pAttributeDescriptions[i] = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1078 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1079 case 7:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1080 pHealthPointsAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1081 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1082 case 8:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1083 pArmourClassAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1084 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1085 case 9:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1086 pSpellPointsAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1087 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1088 case 10:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1089 pPlayerConditionAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1090 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1091 case 11:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1092 pFastSpellAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1093 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1094 case 12:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1095 pPlayerAgeAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1096 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1097 case 13:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1098 pPlayerLevelAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1099 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1100 case 14:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1101 pPlayerExperienceAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1102 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1103 case 15:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1104 pAttackBonusAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1105 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1106 case 16:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1107 pAttackDamageAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1108 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1109 case 17:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1110 pMissleBonusAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1111 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1112 case 18:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1113 pMissleDamageAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1114 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1115 case 19:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1116 pFireResistanceAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1117 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1118 case 20:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1119 pAirResistanceAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1120 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1121 case 21:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1122 pWaterResistanceAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1123 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1124 case 22:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1125 pEarthResistanceAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1126 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1127 case 23:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1128 pMindResistanceAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1129 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1130 case 24:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1131 pBodyResistanceAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1132 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1133 case 25:
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1134 pSkillPointsAttributeDescription = RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1135 break;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1136 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1137 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1138 else
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1139 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1140 if (!decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1141 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1142 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1143 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1144 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1145 } while ((decode_step<2)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1146 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1147
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1148
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1149 pClassTXT_Raw = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1150 pClassTXT_Raw = (char *)pEvents_LOD->LoadRaw("class.txt", 0);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1151 strtok(pClassTXT_Raw, "\r");
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1152 for (i=0; i<36; ++i)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1153 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1154 test_string = strtok(NULL, "\r") + 1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1155 break_loop = false;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1156 decode_step=0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1157 do
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1158 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1159 c = *(unsigned char*)test_string;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1160 temp_str_len = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1161 while((c!='\t')&&(c>0))
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1162 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1163 ++temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1164 c=test_string[temp_str_len];
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1165 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1166 tmp_pos=test_string+temp_str_len;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1167 if (*tmp_pos == 0)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1168 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1169 *tmp_pos = 0;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1170 if (temp_str_len)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1171 {
229
Gloval
parents: 224
diff changeset
1172 //if(i)
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1173 pClassDescriptions[i]=RemoveQuotes(test_string);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1174 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1175 else
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1176 {
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1177 if (!decode_step)
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1178 break_loop = true;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1179 }
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1180 ++decode_step;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1181 test_string=tmp_pos+1;
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1182 } while ((decode_step<2)&&!break_loop);
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1183 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1184
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1185 }
0
Ritor1
parents:
diff changeset
1186
Ritor1
parents:
diff changeset
1187 //----- (00456D17) --------------------------------------------------------
Ritor1
parents:
diff changeset
1188 void ItemsTable::SetSpecialBonus(ItemGen *pItem)
Ritor1
parents:
diff changeset
1189 {
Ritor1
parents:
diff changeset
1190 ItemDesc *v2; // eax@1
Ritor1
parents:
diff changeset
1191
Ritor1
parents:
diff changeset
1192 v2 = &this->pItems[pItem->uItemID];
Ritor1
parents:
diff changeset
1193 if ( v2->uMaterial == 3 )
Ritor1
parents:
diff changeset
1194 {
Ritor1
parents:
diff changeset
1195 pItem->_bonus_type = v2->_bonus_type;
Ritor1
parents:
diff changeset
1196 pItem->uAdditionalValue = v2->_additional_value;
Ritor1
parents:
diff changeset
1197 pItem->_bonus_strength = v2->_bonus_strength;
Ritor1
parents:
diff changeset
1198 }
Ritor1
parents:
diff changeset
1199 }
Ritor1
parents:
diff changeset
1200
Ritor1
parents:
diff changeset
1201 //----- (00456D43) --------------------------------------------------------
Ritor1
parents:
diff changeset
1202 bool ItemsTable::_456D43_is_material_equals_3(ItemGen *pItem)
Ritor1
parents:
diff changeset
1203 {
Ritor1
parents:
diff changeset
1204 return this->pItems[pItem->uItemID].uMaterial == 3;
Ritor1
parents:
diff changeset
1205 }
Ritor1
parents:
diff changeset
1206
Ritor1
parents:
diff changeset
1207 //----- (00456D5E) --------------------------------------------------------
Ritor1
parents:
diff changeset
1208 bool ItemsTable::_456D5E_is_some_material(ItemGen *pItem)
Ritor1
parents:
diff changeset
1209 {
Ritor1
parents:
diff changeset
1210 unsigned __int8 v2; // al@1
Ritor1
parents:
diff changeset
1211
Ritor1
parents:
diff changeset
1212 v2 = this->pItems[pItem->uItemID].uMaterial;
Ritor1
parents:
diff changeset
1213 return v2 == 3 || v2 == 1 || v2 == 2;
Ritor1
parents:
diff changeset
1214 }
Ritor1
parents:
diff changeset
1215
Ritor1
parents:
diff changeset
1216
Ritor1
parents:
diff changeset
1217 //----- (00453B3C) --------------------------------------------------------
Ritor1
parents:
diff changeset
1218 void ItemsTable::LoadPotions()
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1219 {
0
Ritor1
parents:
diff changeset
1220
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1221 CHAR Text[90]; // [sp+Ch] [bp-6Ch]@26
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1222 char* test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1223 unsigned int uRow;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1224 unsigned int uColumn;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1225 unsigned __int8 potion_value;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1226
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1227 if ( pPotionsTXT_Raw )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1228 pAllocator->FreeChunk(pPotionsTXT_Raw);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1229 pPotionsTXT_Raw = NULL;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1230 pPotionsTXT_Raw = (char *)pEvents_LOD->LoadRaw("potion.txt", 0);
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1231 test_string = strtok(pPotionsTXT_Raw,"\t\r\n");
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1232 while ( 1 )
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1233 {
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1234 if ( !test_string )
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1235 {
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1236 MessageBoxA(0, "Error Pre-Parsing Potion Table", "Load Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1237 return;
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1238 }
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1239 if ( !strcmp(test_string, "222") )
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1240 break;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1241
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1242 test_string = strtok(NULL, "\t\r\n");
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1243 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1244 while ( 1 )
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1245 {
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1246 test_string = strtok(NULL, "\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1247
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1248 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1249 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1250 MessageBoxA(0, "Error Pre-Parsing Potion Table", "Load Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1251 return;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1252 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1253 if ( !strcmp(test_string, "222") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1254 break;
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1255 }
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1256
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1257 for (uRow = 0;uRow < 50; ++uRow)
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1258 {
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1259 int skip_count;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1260 for (skip_count = 0;skip_count < 6; ++skip_count)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1261 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1262 if ( !strtok(NULL, "\r\t\n") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1263 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1264 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1265 if ( skip_count != 6 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1266 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1267 for (uColumn = 0; uColumn < 50; ++uColumn)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1268 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1269 test_string = strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1270 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1271 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1272 potion_value = atoi(test_string);
233
0df4136b6aac store_line
Gloval
parents: 230
diff changeset
1273 unsigned char c=*test_string;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1274 if ( !potion_value )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1275 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1276 if ( tolower(c) == 'e' )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1277 potion_value = atoi(test_string + 1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1278 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1279 potion_value = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1280 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1281 this->potion_data[uRow][uColumn]=potion_value;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1282 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1283 if ( uColumn != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1284 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1285 strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1286 }
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1287
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1288 if ( uRow != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1289 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1290 wsprintfA(Text, "Error Parsing Potion Table at Row: %d Column: %d", uRow, uColumn);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1291 MessageBoxA(0, Text, "Parsing Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1292 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1293 if ( pPotionsTXT_Raw )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1294 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1295 pAllocator->FreeChunk(pPotionsTXT_Raw);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1296 pPotionsTXT_Raw = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1297 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1298 }
0
Ritor1
parents:
diff changeset
1299
Ritor1
parents:
diff changeset
1300 //----- (00453CE5) --------------------------------------------------------
Ritor1
parents:
diff changeset
1301 void ItemsTable::LoadPotionNotes()
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1302 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1303
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1304 CHAR Text[90];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1305 char* test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1306 unsigned int uRow;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1307 unsigned int uColumn;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1308 unsigned __int8 potion_note;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1309
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1310 if ( pPotionNotesTXT_Raw )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1311 pAllocator->FreeChunk(pPotionNotesTXT_Raw);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1312 pPotionNotesTXT_Raw = NULL;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1313 pPotionNotesTXT_Raw = (char *)pEvents_LOD->LoadRaw("potnotes.txt", 0);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1314 test_string = strtok(pPotionNotesTXT_Raw ,"\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1315 while ( 1 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1316 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1317 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1318 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1319 MessageBoxA(0, "Error Pre-Parsing Potion Table", "Load Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1320 return;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1321 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1322 if ( !strcmp(test_string, "222") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1323 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1324 test_string = strtok(NULL, "\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1325 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1326 while ( 1 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1327 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1328 test_string = strtok(NULL, "\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1329
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1330 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1331 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1332 MessageBoxA(0, "Error Pre-Parsing Potion Table", "Load Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1333 return;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1334 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1335 if ( !strcmp(test_string, "222") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1336 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1337 }
0
Ritor1
parents:
diff changeset
1338
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1339 for (uRow = 0;uRow < 50; ++uRow)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1340 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1341 int skip_count;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1342 for (skip_count = 0;skip_count < 6; ++skip_count)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1343 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1344 if ( !strtok(NULL, "\r\t\n") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1345 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1346 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1347 if ( skip_count != 6 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1348 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1349 for (uColumn = 0; uColumn < 50; ++uColumn)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1350 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1351 test_string = strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1352 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1353 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1354 potion_note = atoi(test_string);
233
0df4136b6aac store_line
Gloval
parents: 230
diff changeset
1355 unsigned char c=*test_string;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1356 if ( !potion_note )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1357 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1358 if ( tolower(c) == 'e' )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1359 potion_note = atoi(test_string + 1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1360 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1361 potion_note = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1362 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1363 this->potion_note[uRow][uColumn]=potion_note;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1364 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1365 if ( uColumn != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1366 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1367 strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1368 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1369 if ( uRow != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1370 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1371 wsprintfA(Text, "Error Parsing Potion Table at Row: %d Column: %d", uRow, uColumn);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1372 MessageBoxA(0, Text, "Parsing Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1373 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1374 }
0
Ritor1
parents:
diff changeset
1375
Ritor1
parents:
diff changeset
1376
Ritor1
parents:
diff changeset
1377 //----- (00456442) --------------------------------------------------------
Ritor1
parents:
diff changeset
1378 unsigned int ItemGen::GetValue()
Ritor1
parents:
diff changeset
1379 {
Ritor1
parents:
diff changeset
1380 ItemGen *v1; // esi@1
Ritor1
parents:
diff changeset
1381 unsigned int uBaseValue; // edi@1
Ritor1
parents:
diff changeset
1382 int v3; // eax@4
Ritor1
parents:
diff changeset
1383 int v4; // esi@5
Ritor1
parents:
diff changeset
1384 unsigned int result; // eax@7
Ritor1
parents:
diff changeset
1385
Ritor1
parents:
diff changeset
1386 v1 = this;
Ritor1
parents:
diff changeset
1387 uBaseValue = pItemsTable->pItems[this->uItemID].uValue;
Ritor1
parents:
diff changeset
1388 if ( this->uAttributes & ITEM_TEMP_BONUS || pItemsTable->_456D5E_is_some_material(this) )
243
a6a8fa73b4ec cleaning
zipi
parents: 233
diff changeset
1389 return uBaseValue;
0
Ritor1
parents:
diff changeset
1390 if ( v1->_bonus_type )
Ritor1
parents:
diff changeset
1391 {
Ritor1
parents:
diff changeset
1392 v3 = 100 * v1->_bonus_strength;
Ritor1
parents:
diff changeset
1393 return uBaseValue + v3;
Ritor1
parents:
diff changeset
1394 }
Ritor1
parents:
diff changeset
1395 v4 = v1->uAdditionalValue;
Ritor1
parents:
diff changeset
1396 if ( !v4 )
Ritor1
parents:
diff changeset
1397 {
Ritor1
parents:
diff changeset
1398 result = uBaseValue;
Ritor1
parents:
diff changeset
1399 }
Ritor1
parents:
diff changeset
1400 else
Ritor1
parents:
diff changeset
1401 {
243
a6a8fa73b4ec cleaning
zipi
parents: 233
diff changeset
1402 v3 = pItemsTable->pSpecialEnchantments[v4].iTreasureLevel;
0
Ritor1
parents:
diff changeset
1403 if ( (unsigned int)v3 > 0xA )
Ritor1
parents:
diff changeset
1404 return uBaseValue + v3;
Ritor1
parents:
diff changeset
1405 result = uBaseValue * v3;
Ritor1
parents:
diff changeset
1406 }
Ritor1
parents:
diff changeset
1407 return result;
Ritor1
parents:
diff changeset
1408 }
Ritor1
parents:
diff changeset
1409
Ritor1
parents:
diff changeset
1410 //----- (00456499) --------------------------------------------------------
Ritor1
parents:
diff changeset
1411 const char *ItemGen::GetDisplayName()
Ritor1
parents:
diff changeset
1412 {
366
85edec9da96b _4B910F_shop_interaction
Nomad
parents: 365
diff changeset
1413 if (Identified())
85edec9da96b _4B910F_shop_interaction
Nomad
parents: 365
diff changeset
1414 return GetIdentifiedName();
0
Ritor1
parents:
diff changeset
1415 else
366
85edec9da96b _4B910F_shop_interaction
Nomad
parents: 365
diff changeset
1416 return pItemsTable->pItems[uItemID].pUnidentifiedName;
0
Ritor1
parents:
diff changeset
1417 }
Ritor1
parents:
diff changeset
1418
Ritor1
parents:
diff changeset
1419 //----- (004564B3) --------------------------------------------------------
Ritor1
parents:
diff changeset
1420 const char *ItemGen::GetIdentifiedName()
Ritor1
parents:
diff changeset
1421 {
Ritor1
parents:
diff changeset
1422 ItemGen *v1; // esi@1
Ritor1
parents:
diff changeset
1423 unsigned int v2; // eax@1
Ritor1
parents:
diff changeset
1424 unsigned __int8 v3; // cl@1
Ritor1
parents:
diff changeset
1425 char *v4; // edi@4
Ritor1
parents:
diff changeset
1426 char v5; // al@6
Ritor1
parents:
diff changeset
1427 const char *v6; // esi@8
Ritor1
parents:
diff changeset
1428 int v7; // eax@15
Ritor1
parents:
diff changeset
1429 const char *v9; // [sp-Ch] [bp-14h]@14
Ritor1
parents:
diff changeset
1430 const char *v10; // [sp-8h] [bp-10h]@4
Ritor1
parents:
diff changeset
1431 char *v11; // [sp-4h] [bp-Ch]@4
Ritor1
parents:
diff changeset
1432
Ritor1
parents:
diff changeset
1433 v1 = this;
Ritor1
parents:
diff changeset
1434 v2 = this->uItemID;
Ritor1
parents:
diff changeset
1435 v3 = pItemsTable->pItems[v2].uEquipType;
Ritor1
parents:
diff changeset
1436 if ( v3 >= EQUIP_REAGENT && (v3 <= EQUIP_POTION || v3 == EQUIP_GOLD) )
Ritor1
parents:
diff changeset
1437 {
Ritor1
parents:
diff changeset
1438 v11 = pItemsTable->pItems[v2].pName;
Ritor1
parents:
diff changeset
1439 v4 = item__getname_buffer;
Ritor1
parents:
diff changeset
1440 v10 = "%s";
Ritor1
parents:
diff changeset
1441 sprintf(v4, v10, v11);
Ritor1
parents:
diff changeset
1442 return v4;
Ritor1
parents:
diff changeset
1443 }
Ritor1
parents:
diff changeset
1444 v4 = item__getname_buffer;
Ritor1
parents:
diff changeset
1445 sprintf(item__getname_buffer, "%s", pItemsTable->pItems[v2].pName);
Ritor1
parents:
diff changeset
1446 if ( v1->uItemID == 601 )
Ritor1
parents:
diff changeset
1447 {
Ritor1
parents:
diff changeset
1448 v5 = v1->field_1A;
Ritor1
parents:
diff changeset
1449 if ( (unsigned __int8)v5 >= 1u )
Ritor1
parents:
diff changeset
1450 {
Ritor1
parents:
diff changeset
1451 if ( (unsigned __int8)v5 <= 4u )
Ritor1
parents:
diff changeset
1452 {
Ritor1
parents:
diff changeset
1453 v6 = pPlayers[(unsigned __int8)v5]->pName;
Ritor1
parents:
diff changeset
1454 strlen(pPlayers[(unsigned __int8)v5]->pName);
Ritor1
parents:
diff changeset
1455 v11 = (char *)v6;
Ritor1
parents:
diff changeset
1456 if ( v6[strlen(v6) - 1] == 115 )
Ritor1
parents:
diff changeset
1457 v10 = pGlobalTXT_LocalizationStrings[655];
Ritor1
parents:
diff changeset
1458 else
Ritor1
parents:
diff changeset
1459 v10 = pGlobalTXT_LocalizationStrings[654];
243
a6a8fa73b4ec cleaning
zipi
parents: 233
diff changeset
1460 sprintf(v4, v10, v11);
a6a8fa73b4ec cleaning
zipi
parents: 233
diff changeset
1461 return v4;
0
Ritor1
parents:
diff changeset
1462 }
Ritor1
parents:
diff changeset
1463 }
Ritor1
parents:
diff changeset
1464 }
Ritor1
parents:
diff changeset
1465 if ( !pItemsTable->_456D5E_is_some_material(v1) )
Ritor1
parents:
diff changeset
1466 {
Ritor1
parents:
diff changeset
1467 if ( v1->_bonus_type )
Ritor1
parents:
diff changeset
1468 {
Ritor1
parents:
diff changeset
1469 strcat(item__getname_buffer, " ");
Ritor1
parents:
diff changeset
1470 v9 = (const char *)*((unsigned int *)&pItemsTable->pItems[799].uEquipType + 5 * v1->_bonus_type);
Ritor1
parents:
diff changeset
1471 }
Ritor1
parents:
diff changeset
1472 else
Ritor1
parents:
diff changeset
1473 {
Ritor1
parents:
diff changeset
1474 v7 = v1->uAdditionalValue;
Ritor1
parents:
diff changeset
1475 if ( !v7 )
Ritor1
parents:
diff changeset
1476 return v4;
Ritor1
parents:
diff changeset
1477 if ( v7 == 16
Ritor1
parents:
diff changeset
1478 || v7 == 39
Ritor1
parents:
diff changeset
1479 || v7 == 40
Ritor1
parents:
diff changeset
1480 || v7 == 45
Ritor1
parents:
diff changeset
1481 || v7 == 56
Ritor1
parents:
diff changeset
1482 || v7 == 57
Ritor1
parents:
diff changeset
1483 || v7 == 58
Ritor1
parents:
diff changeset
1484 || v7 == 60
Ritor1
parents:
diff changeset
1485 || v7 == 61
Ritor1
parents:
diff changeset
1486 || v7 == 59
Ritor1
parents:
diff changeset
1487 || v7 == 63
Ritor1
parents:
diff changeset
1488 || v7 == 64
Ritor1
parents:
diff changeset
1489 || v7 == 67
Ritor1
parents:
diff changeset
1490 || v7 == 68 )
Ritor1
parents:
diff changeset
1491 {
Ritor1
parents:
diff changeset
1492 sprintf(
Ritor1
parents:
diff changeset
1493 item__getname_buffer,
Ritor1
parents:
diff changeset
1494 "%s %s",
243
a6a8fa73b4ec cleaning
zipi
parents: 233
diff changeset
1495 pItemsTable->pSpecialEnchantments[v7].pBonusStatement,
0
Ritor1
parents:
diff changeset
1496 pItemsTable->pItems[v1->uItemID].pName);
Ritor1
parents:
diff changeset
1497 return v4;
Ritor1
parents:
diff changeset
1498 }
Ritor1
parents:
diff changeset
1499 strcat(item__getname_buffer, " ");
243
a6a8fa73b4ec cleaning
zipi
parents: 233
diff changeset
1500 v9 = pItemsTable->pSpecialEnchantments[v1->uAdditionalValue].pBonusStatement;
0
Ritor1
parents:
diff changeset
1501 }
Ritor1
parents:
diff changeset
1502 strcat(item__getname_buffer, v9);
Ritor1
parents:
diff changeset
1503 }
Ritor1
parents:
diff changeset
1504 return v4;
Ritor1
parents:
diff changeset
1505 }
Ritor1
parents:
diff changeset
1506
Ritor1
parents:
diff changeset
1507
Ritor1
parents:
diff changeset
1508 //----- (00456620) --------------------------------------------------------
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1509 void ItemsTable::GenerateItem(int treasure_level, int a3, ItemGen *out_item)
0
Ritor1
parents:
diff changeset
1510 {
294
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1511
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1512 ItemGen *v4; // esi@1
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1513 ItemsTable *v5; // edi@1
0
Ritor1
parents:
diff changeset
1514 int v6; // ebx@3
Ritor1
parents:
diff changeset
1515 int *v7; // ecx@33
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1516 //int v8; // eax@34
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1517 //int v9; // eax@39
0
Ritor1
parents:
diff changeset
1518 int v10; // ebx@43
Ritor1
parents:
diff changeset
1519 int v11; // ecx@47
Ritor1
parents:
diff changeset
1520 unsigned int *v12; // edx@48
Ritor1
parents:
diff changeset
1521 unsigned int v13; // eax@49
Ritor1
parents:
diff changeset
1522 signed int v14; // ebx@52
Ritor1
parents:
diff changeset
1523 int v15; // eax@53
Ritor1
parents:
diff changeset
1524 signed int v16; // eax@55
Ritor1
parents:
diff changeset
1525 int v17; // ebx@57
Ritor1
parents:
diff changeset
1526 int v18; // edx@62
Ritor1
parents:
diff changeset
1527 signed int v19; // ebx@70
Ritor1
parents:
diff changeset
1528 unsigned __int8 v20; // al@81
Ritor1
parents:
diff changeset
1529 int v21; // eax@84
Ritor1
parents:
diff changeset
1530 int v22; // ebx@85
Ritor1
parents:
diff changeset
1531 int v23; // eax@86
Ritor1
parents:
diff changeset
1532 int v24; // ebx@86
Ritor1
parents:
diff changeset
1533 int v25; // edx@86
Ritor1
parents:
diff changeset
1534 int v26; // edx@89
Ritor1
parents:
diff changeset
1535 unsigned int v27; // eax@89
Ritor1
parents:
diff changeset
1536 int i; // ebx@89
Ritor1
parents:
diff changeset
1537 unsigned int v29; // ecx@90
Ritor1
parents:
diff changeset
1538 int v30; // ebx@91
Ritor1
parents:
diff changeset
1539 int v31; // eax@91
Ritor1
parents:
diff changeset
1540 int v32; // ecx@91
Ritor1
parents:
diff changeset
1541 int v33; // eax@91
Ritor1
parents:
diff changeset
1542 int v34; // eax@97
Ritor1
parents:
diff changeset
1543 unsigned __int8 v35; // sf@97
Ritor1
parents:
diff changeset
1544 unsigned __int8 v36; // of@97
Ritor1
parents:
diff changeset
1545 int v37; // ebx@98
Ritor1
parents:
diff changeset
1546 int v38; // edx@99
Ritor1
parents:
diff changeset
1547 signed int v39; // ebx@101
Ritor1
parents:
diff changeset
1548 int v40; // ecx@102
Ritor1
parents:
diff changeset
1549 char v41; // zf@107
Ritor1
parents:
diff changeset
1550 char v42; // al@108
Ritor1
parents:
diff changeset
1551 char v43; // al@111
Ritor1
parents:
diff changeset
1552 int *v44; // edx@118
Ritor1
parents:
diff changeset
1553 int v45; // eax@120
Ritor1
parents:
diff changeset
1554 int v46; // edx@120
Ritor1
parents:
diff changeset
1555 int *j; // eax@121
Ritor1
parents:
diff changeset
1556 unsigned int v48; // ecx@123
Ritor1
parents:
diff changeset
1557 int v49; // eax@123
Ritor1
parents:
diff changeset
1558 int v50; // eax@123
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1559 int Dst[800]; // [sp+Ch] [bp-C88h]@33
0
Ritor1
parents:
diff changeset
1560 int v52; // [sp+C8Ch] [bp-8h]@33
294
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1561 int v53; // [sp+C90h] [bp-4h]@1
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1562 int v54; // [sp+C9Ch] [bp+8h]@3
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1563 //int v55; // [sp+CA0h] [bp+Ch]@34
0
Ritor1
parents:
diff changeset
1564 signed int v56; // [sp+CA0h] [bp+Ch]@55
Ritor1
parents:
diff changeset
1565 int v57; // [sp+CA0h] [bp+Ch]@62
Ritor1
parents:
diff changeset
1566 int *v58; // [sp+CA0h] [bp+Ch]@102
Ritor1
parents:
diff changeset
1567 int v59; // [sp+CA0h] [bp+Ch]@123
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1568 //signed int a2a; // [sp+CA4h] [bp+10h]@33
0
Ritor1
parents:
diff changeset
1569 int a2b; // [sp+CA4h] [bp+10h]@101
Ritor1
parents:
diff changeset
1570 int a2c; // [sp+CA4h] [bp+10h]@120
Ritor1
parents:
diff changeset
1571
294
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1572 v53 = -1;
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1573 v5 = this;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1574 if (!out_item)
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1575 out_item = (ItemGen *)pAllocator->AllocNamedChunk(out_item, sizeof(*out_item), "newItemGen");
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1576 memset(out_item, 0, sizeof(*out_item));
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1577
294
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1578 v4 = out_item;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1579 v6 = treasure_level - 1;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1580 //v54 = treasure_level - 1;
0
Ritor1
parents:
diff changeset
1581 if ( a3 )
Ritor1
parents:
diff changeset
1582 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1583 ITEM_EQUIP_TYPE requested_equip;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1584 PLAYER_SKILL_TYPE requested_skill = PLAYER_SKILL_INVALID;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1585 switch (a3)
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1586 {
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1587 case 20: requested_equip = EQUIP_ONE_OR_TWO_HANDS; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1588 case 21: requested_equip = EQUIP_ARMOUR; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1589 case 22: requested_skill = (PLAYER_SKILL_TYPE)38; __debugbreak();/*check this skill*/ break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1590 case 23: requested_skill = PLAYER_SKILL_SWORD; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1591 case 24: requested_skill = PLAYER_SKILL_DAGGER; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1592 case 25: requested_skill = PLAYER_SKILL_AXE; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1593 case 26: requested_skill = PLAYER_SKILL_SPEAR; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1594 case 27: requested_skill = PLAYER_SKILL_BOW; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1595 case 28: requested_skill = PLAYER_SKILL_MACE; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1596 case 29: requested_skill = (PLAYER_SKILL_TYPE)37; __debugbreak();/*check this skill*/break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1597 case 30: requested_skill = PLAYER_SKILL_STAFF; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1598 case 31: requested_skill = PLAYER_SKILL_LEATHER; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1599 case 32: requested_skill = PLAYER_SKILL_CHAIN; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1600 case 33: requested_skill = PLAYER_SKILL_PLATE; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1601 case 34: requested_equip = EQUIP_SHIELD; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1602 case 35: requested_equip = EQUIP_HELMET; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1603 case 36: requested_equip = EQUIP_BELT; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1604 case 37: requested_equip = EQUIP_CLOAK; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1605 case 38: requested_equip = EQUIP_GAUNTLETS; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1606 case 39: requested_equip = EQUIP_BOOTS; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1607 case 40: requested_equip = EQUIP_RING; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1608 case 41: requested_equip = EQUIP_AMULET; break;
295
640a176c030f sub_42ECB5
Nomad
parents: 245
diff changeset
1609 case 42: requested_equip = EQUIP_WAND; break;
374
Gloval
parents: 365
diff changeset
1610 case 43: requested_equip = EQUIP_SPELL_SCROLL; break;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1611 case 44: requested_equip = EQUIP_POTION; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1612 case 45: requested_equip = EQUIP_REAGENT; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1613 case 46: requested_equip = EQUIP_GEM; break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1614 default:
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1615 __debugbreak(); // check this condition
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1616 requested_equip = (ITEM_EQUIP_TYPE)(a3 - 1);
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1617 break;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1618 }
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1619 memset(Dst, 0, sizeof(Dst));
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1620 v52 = 0;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1621 v7 = Dst;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1622 //a2a = 1;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1623 if (requested_skill == PLAYER_SKILL_INVALID)
0
Ritor1
parents:
diff changeset
1624 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1625 for (uint i = 1; i < 500; ++i)
0
Ritor1
parents:
diff changeset
1626 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1627 if (pItems[i].uEquipType == requested_equip)
0
Ritor1
parents:
diff changeset
1628 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1629 *v7++ = i;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1630 v52 += pItems[i].uChanceByTreasureLvl[v6];
0
Ritor1
parents:
diff changeset
1631 }
Ritor1
parents:
diff changeset
1632 }
Ritor1
parents:
diff changeset
1633 }
Ritor1
parents:
diff changeset
1634 else
Ritor1
parents:
diff changeset
1635 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1636 for (uint i = 1; i < 500; ++i)
0
Ritor1
parents:
diff changeset
1637 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1638 if (pItems[i].uSkillType == requested_skill)
0
Ritor1
parents:
diff changeset
1639 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1640 *v7++ = i;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1641 v52 += pItems[i].uChanceByTreasureLvl[v6];
0
Ritor1
parents:
diff changeset
1642 }
Ritor1
parents:
diff changeset
1643 }
Ritor1
parents:
diff changeset
1644 }
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1645
0
Ritor1
parents:
diff changeset
1646 v10 = 0;
Ritor1
parents:
diff changeset
1647 if ( v52 )
Ritor1
parents:
diff changeset
1648 v10 = rand() % v52;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1649
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1650 v4->uItemID = *Dst;
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1651 if (!v4->uItemID)
0
Ritor1
parents:
diff changeset
1652 v4->uItemID = 1;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1653
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1654 v11 = pItems[v4->uItemID].uChanceByTreasureLvl[v6];
0
Ritor1
parents:
diff changeset
1655 if ( v11 < v10 )
Ritor1
parents:
diff changeset
1656 {
Ritor1
parents:
diff changeset
1657 v12 = (uint *)Dst;
Ritor1
parents:
diff changeset
1658 do
Ritor1
parents:
diff changeset
1659 {
Ritor1
parents:
diff changeset
1660 ++v12;
Ritor1
parents:
diff changeset
1661 v13 = *v12;
Ritor1
parents:
diff changeset
1662 v4->uItemID = *v12;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1663 v11 += pItems[v13].uChanceByTreasureLvl[v6];
0
Ritor1
parents:
diff changeset
1664 }
Ritor1
parents:
diff changeset
1665 while ( v11 < v10 );
Ritor1
parents:
diff changeset
1666 }
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1667 if (pItems[v4->uItemID].uEquipType == EQUIP_POTION && v4->uItemID != ITEM_POTION_BOTTLE )
0
Ritor1
parents:
diff changeset
1668 {
Ritor1
parents:
diff changeset
1669 v4->_bonus_type = 0;
Ritor1
parents:
diff changeset
1670 v14 = 2;
Ritor1
parents:
diff changeset
1671 do
Ritor1
parents:
diff changeset
1672 {
Ritor1
parents:
diff changeset
1673 v4->_bonus_type += rand() % 4 + 1;
Ritor1
parents:
diff changeset
1674 v15 = v4->_bonus_type;
Ritor1
parents:
diff changeset
1675 --v14;
Ritor1
parents:
diff changeset
1676 }
Ritor1
parents:
diff changeset
1677 while ( v14 );
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1678 v4->_bonus_type = v15 * treasure_level;
0
Ritor1
parents:
diff changeset
1679 }
Ritor1
parents:
diff changeset
1680 }
Ritor1
parents:
diff changeset
1681 else
Ritor1
parents:
diff changeset
1682 {
Ritor1
parents:
diff changeset
1683 v16 = 0;
Ritor1
parents:
diff changeset
1684 v56 = 0;
Ritor1
parents:
diff changeset
1685 do
Ritor1
parents:
diff changeset
1686 v56 += pParty->field_7BA[v16++];
Ritor1
parents:
diff changeset
1687 while ( v16 < 29 );
Ritor1
parents:
diff changeset
1688 v17 = rand() % 29;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1689 if ( v6 == 5 && rand() % 100 < 5 && !pParty->field_7BA[v17] && v56 < 13 )
0
Ritor1
parents:
diff changeset
1690 {
Ritor1
parents:
diff changeset
1691 pParty->field_7BA[v17] = 1;
Ritor1
parents:
diff changeset
1692 v4->uAttributes = 0;
Ritor1
parents:
diff changeset
1693 v4->uItemID = v17 + 500;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1694 SetSpecialBonus(v4);
0
Ritor1
parents:
diff changeset
1695 return;
Ritor1
parents:
diff changeset
1696 }
Ritor1
parents:
diff changeset
1697 v57 = 0;
294
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1698 v18 = rand() % v5->uChanceByTreasureLvlSumm[v54];// v5->field_11684[v54];
0
Ritor1
parents:
diff changeset
1699 v4->uItemID = 0;
Ritor1
parents:
diff changeset
1700 if ( v18 > 0 )
Ritor1
parents:
diff changeset
1701 {
Ritor1
parents:
diff changeset
1702 do
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1703 v57 += pItems[v4->uItemID++ + 1].uChanceByTreasureLvl[v6];
0
Ritor1
parents:
diff changeset
1704 while ( v57 < v18 );
Ritor1
parents:
diff changeset
1705 }
Ritor1
parents:
diff changeset
1706 if ( !v18 )
Ritor1
parents:
diff changeset
1707 v4->uItemID = 1;
Ritor1
parents:
diff changeset
1708 if ( !v4->uItemID )
Ritor1
parents:
diff changeset
1709 v4->uItemID = 1;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1710 if (pItems[v4->uItemID].uEquipType == EQUIP_POTION && v4->uItemID != ITEM_POTION_BOTTLE)
0
Ritor1
parents:
diff changeset
1711 {
Ritor1
parents:
diff changeset
1712 v4->_bonus_type = 0;
Ritor1
parents:
diff changeset
1713 v19 = 2;
Ritor1
parents:
diff changeset
1714 do
Ritor1
parents:
diff changeset
1715 {
Ritor1
parents:
diff changeset
1716 v4->_bonus_type += rand() % 4 + 1;
Ritor1
parents:
diff changeset
1717 v15 = v4->_bonus_type;
Ritor1
parents:
diff changeset
1718 --v19;
Ritor1
parents:
diff changeset
1719 }
Ritor1
parents:
diff changeset
1720 while ( v19 );
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1721 v4->_bonus_type = v15 * treasure_level;
0
Ritor1
parents:
diff changeset
1722 }
Ritor1
parents:
diff changeset
1723 }
Ritor1
parents:
diff changeset
1724 if ( v4->uItemID == ITEM_SPELLBOOK_LIGHT_DIVINE_INTERVENTION
Ritor1
parents:
diff changeset
1725 && !(unsigned __int16)_449B57_test_bit(pParty->_award_bits, 239) )
Ritor1
parents:
diff changeset
1726 v4->uItemID = ITEM_SPELLBOOK_LIGHT_SUN_BURST;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1727 if ( pItemsTable->pItems[v4->uItemID + 1].uItemID_Rep_St )
0
Ritor1
parents:
diff changeset
1728 v4->uAttributes = 0;
Ritor1
parents:
diff changeset
1729 else
Ritor1
parents:
diff changeset
1730 v4->uAttributes = 1;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1731 if ( pItems[v4->uItemID].uEquipType != EQUIP_POTION )
0
Ritor1
parents:
diff changeset
1732 {
Ritor1
parents:
diff changeset
1733 v4->uAdditionalValue = 0;
Ritor1
parents:
diff changeset
1734 v4->_bonus_type = 0;
Ritor1
parents:
diff changeset
1735 }
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1736 v20 = pItems[v4->uItemID].uEquipType;
0
Ritor1
parents:
diff changeset
1737 if ( v20 <= EQUIP_BOW )
Ritor1
parents:
diff changeset
1738 {
294
a672f297c163 item gen restore
Gloval
parents: 245
diff changeset
1739 v37 = v5->uBonusChanceWpSpecial[v54];
0
Ritor1
parents:
diff changeset
1740 if ( !*(unsigned int *)v37 )
Ritor1
parents:
diff changeset
1741 return;
Ritor1
parents:
diff changeset
1742 v38 = rand() % 100;
Ritor1
parents:
diff changeset
1743 v36 = __OFSUB__(v38, *(unsigned int *)v37);
Ritor1
parents:
diff changeset
1744 v35 = v38 - *(unsigned int *)v37 < 0;
Ritor1
parents:
diff changeset
1745 }
Ritor1
parents:
diff changeset
1746 else
Ritor1
parents:
diff changeset
1747 {
Ritor1
parents:
diff changeset
1748 if ( v20 > EQUIP_AMULET )
Ritor1
parents:
diff changeset
1749 {
295
640a176c030f sub_42ECB5
Nomad
parents: 245
diff changeset
1750 if ( v20 == EQUIP_WAND )
0
Ritor1
parents:
diff changeset
1751 {
Ritor1
parents:
diff changeset
1752 v21 = rand() % 6 + pItemsTable->pItems[v4->uItemID].uDamageMod + 1;
Ritor1
parents:
diff changeset
1753 v4->uNumCharges = v21;
Ritor1
parents:
diff changeset
1754 v4->uMaxCharges = v21;
Ritor1
parents:
diff changeset
1755 }
Ritor1
parents:
diff changeset
1756 return;
Ritor1
parents:
diff changeset
1757 }
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1758 v22 = (int)&uBonusChanceStandart[v6];
0
Ritor1
parents:
diff changeset
1759 if ( !*(unsigned int *)v22 )
Ritor1
parents:
diff changeset
1760 return;
Ritor1
parents:
diff changeset
1761 v23 = rand();
Ritor1
parents:
diff changeset
1762 v24 = *(unsigned int *)v22;
Ritor1
parents:
diff changeset
1763 v25 = v23 % 100;
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1764 if ( !uBonusChanceSpecial[v6] && !(v23 % 100 < v24))
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1765 return;
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1766 if ( v25 < v24 || v23 % 100 < v24)
0
Ritor1
parents:
diff changeset
1767 {
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1768 v26 = rand() % 10;//v5->field_116D8[v5->pItems[v4->uItemID].uEquipType];
0
Ritor1
parents:
diff changeset
1769 v27 = v4->uItemID;
Ritor1
parents:
diff changeset
1770 v4->_bonus_type = 0;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1771 for ( i = pEnchantments[0].to_item[pItems[v27].uEquipType + 1];
0
Ritor1
parents:
diff changeset
1772 i < v26;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1773 i += pEnchantments[v4->_bonus_type].to_item[pItems[v29].uEquipType + 1] )
0
Ritor1
parents:
diff changeset
1774 {
Ritor1
parents:
diff changeset
1775 v29 = v4->uItemID;
Ritor1
parents:
diff changeset
1776 ++v4->_bonus_type;
Ritor1
parents:
diff changeset
1777 }
Ritor1
parents:
diff changeset
1778 ++v4->_bonus_type;
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1779 v30 = 10;// v5->field_116D8[2 * v54 + 12];
0
Ritor1
parents:
diff changeset
1780 v31 = rand();
Ritor1
parents:
diff changeset
1781 v32 = v4->_bonus_type - 1;
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1782 v33 = v31 % 10;//(v5->field_116D8[2 * v54 + 13] - v30 + 1) + v30;
0
Ritor1
parents:
diff changeset
1783 v4->_bonus_strength = v33;
Ritor1
parents:
diff changeset
1784 if ( v32 == 21 || v32 == 22 || v32 == 23 )
Ritor1
parents:
diff changeset
1785 v4->_bonus_strength = v33 >> 1;
Ritor1
parents:
diff changeset
1786 if ( v4->_bonus_strength <= 0 )
Ritor1
parents:
diff changeset
1787 v4->_bonus_strength = 1;
Ritor1
parents:
diff changeset
1788 return;
Ritor1
parents:
diff changeset
1789 }
224
9917d3b4925e items init refactored
Gloval
parents: 223
diff changeset
1790 v34 = v24 + 10;//*(unsigned int *)&v5->field_1169C[4 * v54 + 24];
0
Ritor1
parents:
diff changeset
1791 v36 = __OFSUB__(v25, v34);
Ritor1
parents:
diff changeset
1792 v35 = v25 - v34 < 0;
Ritor1
parents:
diff changeset
1793 }
Ritor1
parents:
diff changeset
1794 if ( !(v35 ^ v36) )
Ritor1
parents:
diff changeset
1795 return;
Ritor1
parents:
diff changeset
1796 memset(&Dst, 0, 0xC80u);
Ritor1
parents:
diff changeset
1797 v39 = 0;
Ritor1
parents:
diff changeset
1798 a2b = 0;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1799 if ( pSpecialEnchantments_count > 0 )
0
Ritor1
parents:
diff changeset
1800 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1801 v52 = -16 - (uint)this;
0
Ritor1
parents:
diff changeset
1802 v58 = (int *)&Dst;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1803 v40 = (int)&pSpecialEnchantments[1];
0
Ritor1
parents:
diff changeset
1804 do
Ritor1
parents:
diff changeset
1805 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1806 switch ( v6 )
0
Ritor1
parents:
diff changeset
1807 {
Ritor1
parents:
diff changeset
1808 case 2:
Ritor1
parents:
diff changeset
1809 if ( !*(unsigned char *)v40 )
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1810 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1811 v39 += *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType);
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1812 if ( *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType) )
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1813 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1814 v44 = v58;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1815 ++v58;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1816 *v44 = a2b;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1817 }
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1818 ++a2b;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1819 v40 += 28;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1820 continue;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1821 }
0
Ritor1
parents:
diff changeset
1822 v41 = *(unsigned char *)v40 == 1;
Ritor1
parents:
diff changeset
1823 break;
Ritor1
parents:
diff changeset
1824 case 3:
Ritor1
parents:
diff changeset
1825 v43 = *(unsigned char *)v40;
Ritor1
parents:
diff changeset
1826 if ( !*(unsigned char *)v40 || v43 == 1 )
Ritor1
parents:
diff changeset
1827 {
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1828 v39 += *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType);
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1829 if ( *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType) )
0
Ritor1
parents:
diff changeset
1830 {
Ritor1
parents:
diff changeset
1831 v44 = v58;
Ritor1
parents:
diff changeset
1832 ++v58;
Ritor1
parents:
diff changeset
1833 *v44 = a2b;
Ritor1
parents:
diff changeset
1834 }
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1835 ++a2b;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1836 v40 += 28;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1837 continue;
0
Ritor1
parents:
diff changeset
1838 }
Ritor1
parents:
diff changeset
1839 v41 = v43 == 2;
Ritor1
parents:
diff changeset
1840 break;
Ritor1
parents:
diff changeset
1841 case 4:
Ritor1
parents:
diff changeset
1842 v42 = *(unsigned char *)v40;
Ritor1
parents:
diff changeset
1843 if ( *(unsigned char *)v40 == 1 || v42 == 2 )
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1844 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1845 v39 += *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType);
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1846 if ( *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType) )
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1847 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1848 v44 = v58;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1849 ++v58;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1850 *v44 = a2b;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1851 }
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1852 ++a2b;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1853 v40 += 28;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1854 continue;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1855 }
0
Ritor1
parents:
diff changeset
1856 v41 = v42 == 3;
Ritor1
parents:
diff changeset
1857 break;
Ritor1
parents:
diff changeset
1858 default:
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1859 if ( v6 != 5 )
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1860 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1861 ++a2b;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1862 v40 += 28;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1863 continue;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1864 }
0
Ritor1
parents:
diff changeset
1865 v41 = *(unsigned char *)v40 == 3;
Ritor1
parents:
diff changeset
1866 break;
Ritor1
parents:
diff changeset
1867 }
Ritor1
parents:
diff changeset
1868 if ( v41 )
245
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1869 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1870 v39 += *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType);
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1871 if ( *((unsigned char *)&uAllItemsCount + v40 + v52 + pItems[v4->uItemID].uEquipType) )
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1872 {
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1873 v44 = v58;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1874 ++v58;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1875 *v44 = a2b;
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1876 }
f070b49d40dd goto cleaning
zipi
parents: 243
diff changeset
1877 }
0
Ritor1
parents:
diff changeset
1878 LABEL_119:
Ritor1
parents:
diff changeset
1879 ++a2b;
Ritor1
parents:
diff changeset
1880 v40 += 28;
Ritor1
parents:
diff changeset
1881 }
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1882 while ( a2b < pSpecialEnchantments_count );
0
Ritor1
parents:
diff changeset
1883 }
Ritor1
parents:
diff changeset
1884 v45 = rand();
Ritor1
parents:
diff changeset
1885 v4->uAdditionalValue = *(uint *)Dst;
Ritor1
parents:
diff changeset
1886 v46 = v45 % v39 + 1;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1887 a2c = *((unsigned char *)&uAllItemsCount + 28 * (*(uint *)Dst + 1389) + pItems[v4->uItemID].uEquipType);
0
Ritor1
parents:
diff changeset
1888 if ( a2c < v46 )
Ritor1
parents:
diff changeset
1889 {
Ritor1
parents:
diff changeset
1890 for ( j = (int *)&Dst; ; j = (int *)v59 )
Ritor1
parents:
diff changeset
1891 {
Ritor1
parents:
diff changeset
1892 v48 = v4->uItemID;
Ritor1
parents:
diff changeset
1893 v49 = (int)(j + 1);
Ritor1
parents:
diff changeset
1894 v59 = v49;
Ritor1
parents:
diff changeset
1895 v50 = *(unsigned int *)v49;
Ritor1
parents:
diff changeset
1896 v4->uAdditionalValue = v50;
228
46ae2602aceb Item generation doesn't crash (thou still generates weird stuff)
Nomad
parents: 224
diff changeset
1897 a2c += *((unsigned char *)&uAllItemsCount + 28 * (v50 + 1389) + pItems[v48].uEquipType);
0
Ritor1
parents:
diff changeset
1898 if ( a2c >= v46 )
Ritor1
parents:
diff changeset
1899 break;
Ritor1
parents:
diff changeset
1900 }
Ritor1
parents:
diff changeset
1901 }
Ritor1
parents:
diff changeset
1902 ++v4->uAdditionalValue;
Ritor1
parents:
diff changeset
1903 }
Ritor1
parents:
diff changeset
1904
Ritor1
parents:
diff changeset
1905 //----- (004505CC) --------------------------------------------------------
Ritor1
parents:
diff changeset
1906 bool ItemGen::GenerateArtifact()
Ritor1
parents:
diff changeset
1907 {
Ritor1
parents:
diff changeset
1908 ItemGen *v1; // edi@1
Ritor1
parents:
diff changeset
1909 signed int uNumArtifactsNotFound; // esi@1
Ritor1
parents:
diff changeset
1910 int v3; // eax@1
Ritor1
parents:
diff changeset
1911 bool result; // eax@6
Ritor1
parents:
diff changeset
1912 int v5[32]; // [sp+8h] [bp-A0h]@3
Ritor1
parents:
diff changeset
1913 char Dst[32]; // [sp+88h] [bp-20h]@1
Ritor1
parents:
diff changeset
1914
Ritor1
parents:
diff changeset
1915 auto a2 = this;
Ritor1
parents:
diff changeset
1916 v1 = a2;
Ritor1
parents:
diff changeset
1917 memset(Dst, 0, 0x20u);
Ritor1
parents:
diff changeset
1918 uNumArtifactsNotFound = 0;
Ritor1
parents:
diff changeset
1919 v3 = 500;
Ritor1
parents:
diff changeset
1920 do
Ritor1
parents:
diff changeset
1921 {
Ritor1
parents:
diff changeset
1922 if ( !pParty->field_3C.pIsArtifactFound[v3] )
Ritor1
parents:
diff changeset
1923 v5[uNumArtifactsNotFound++] = v3;
Ritor1
parents:
diff changeset
1924 ++v3;
Ritor1
parents:
diff changeset
1925 }
Ritor1
parents:
diff changeset
1926 while ( v3 < 529 );
Ritor1
parents:
diff changeset
1927 v1->Reset();
Ritor1
parents:
diff changeset
1928 if ( uNumArtifactsNotFound )
Ritor1
parents:
diff changeset
1929 {
Ritor1
parents:
diff changeset
1930 v1->uItemID = v5[rand() % uNumArtifactsNotFound];
Ritor1
parents:
diff changeset
1931 pItemsTable->SetSpecialBonus(v1);
Ritor1
parents:
diff changeset
1932 result = 1;
Ritor1
parents:
diff changeset
1933 }
Ritor1
parents:
diff changeset
1934 else
Ritor1
parents:
diff changeset
1935 {
Ritor1
parents:
diff changeset
1936 result = 0;
Ritor1
parents:
diff changeset
1937 }
Ritor1
parents:
diff changeset
1938 return result;
Ritor1
parents:
diff changeset
1939 }
Ritor1
parents:
diff changeset
1940 // 4505CC: using guessed type int var_A0[32];