annotate Items.cpp @ 222:8113753ed2ae

more item init fixing
author Gloval
date Sun, 17 Feb 2013 11:29:10 +0400
parents 821fd955c379
children 1bd823f52e3a
rev   line source
0
Ritor1
parents:
diff changeset
1 #include <stdlib.h>
Ritor1
parents:
diff changeset
2
Ritor1
parents:
diff changeset
3 #include "Items.h"
Ritor1
parents:
diff changeset
4 #include "MapInfo.h"
Ritor1
parents:
diff changeset
5 #include "FrameTableInc.h"
Ritor1
parents:
diff changeset
6 #include "Allocator.h"
Ritor1
parents:
diff changeset
7 #include "LOD.h"
Ritor1
parents:
diff changeset
8 #include "Monsters.h"
Ritor1
parents:
diff changeset
9 #include "Party.h"
Ritor1
parents:
diff changeset
10 #include "FactionTable.h"
Ritor1
parents:
diff changeset
11 #include "StorylineTextTable.h"
189
038a4d09406f new texts file, fix text rendender error
Gloval
parents: 0
diff changeset
12 #include "texts.h"
0
Ritor1
parents:
diff changeset
13 #include "mm7_data.h"
Ritor1
parents:
diff changeset
14
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 ItemGen *ptr_50C9A4;
Ritor1
parents:
diff changeset
20
Ritor1
parents:
diff changeset
21 struct ItemsTable *pItemsTable;
Ritor1
parents:
diff changeset
22
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 //----- (00439DF3) --------------------------------------------------------
Ritor1
parents:
diff changeset
28 int ItemGen::_439DF3_get_additional_damage(int *a2, int *a3)
Ritor1
parents:
diff changeset
29 {
Ritor1
parents:
diff changeset
30 int *v3; // edi@1
Ritor1
parents:
diff changeset
31 ItemGen *v4; // ebx@1
Ritor1
parents:
diff changeset
32 signed int v5; // esi@1
Ritor1
parents:
diff changeset
33 unsigned int v7; // ecx@5
Ritor1
parents:
diff changeset
34 signed int v8; // ebx@7
Ritor1
parents:
diff changeset
35 int v9; // edx@22
Ritor1
parents:
diff changeset
36 int v10; // eax@24
Ritor1
parents:
diff changeset
37 int v11; // edx@25
Ritor1
parents:
diff changeset
38 int v12; // ebx@28
Ritor1
parents:
diff changeset
39 int v13; // ebx@29
Ritor1
parents:
diff changeset
40 int v14; // ebx@30
Ritor1
parents:
diff changeset
41 int v15; // ebx@31
Ritor1
parents:
diff changeset
42 int v16; // ebx@32
Ritor1
parents:
diff changeset
43 signed int v17; // [sp-4h] [bp-10h]@24
Ritor1
parents:
diff changeset
44
Ritor1
parents:
diff changeset
45 auto a1 = this;
Ritor1
parents:
diff changeset
46 v3 = a2;
Ritor1
parents:
diff changeset
47 v4 = a1;
Ritor1
parents:
diff changeset
48 v5 = 0;
Ritor1
parents:
diff changeset
49 *a2 = 0;
Ritor1
parents:
diff changeset
50 if ( !a1->uItemID )
Ritor1
parents:
diff changeset
51 return 0;
Ritor1
parents:
diff changeset
52 UpdateTempBonus(pParty->uTimePlayed);
Ritor1
parents:
diff changeset
53 if ( v4->uItemID == 501 )
Ritor1
parents:
diff changeset
54 {
Ritor1
parents:
diff changeset
55 LABEL_45:
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 )
Ritor1
parents:
diff changeset
75 goto LABEL_36;
Ritor1
parents:
diff changeset
76 v8 = v4->uAdditionalValue;
Ritor1
parents:
diff changeset
77 if ( v8 > 46 )
Ritor1
parents:
diff changeset
78 {
Ritor1
parents:
diff changeset
79 LABEL_42:
Ritor1
parents:
diff changeset
80 v5 = 0;
Ritor1
parents:
diff changeset
81 goto LABEL_37;
Ritor1
parents:
diff changeset
82 }
Ritor1
parents:
diff changeset
83 if ( v8 == 46 )
Ritor1
parents:
diff changeset
84 {
Ritor1
parents:
diff changeset
85 *v3 = 0;
Ritor1
parents:
diff changeset
86 return rand() % 11 + 10;
Ritor1
parents:
diff changeset
87 }
Ritor1
parents:
diff changeset
88 if ( v8 > 11 )
Ritor1
parents:
diff changeset
89 {
Ritor1
parents:
diff changeset
90 v12 = v8 - 12;
Ritor1
parents:
diff changeset
91 if ( !v12 )
Ritor1
parents:
diff changeset
92 {
Ritor1
parents:
diff changeset
93 *v3 = 0;
Ritor1
parents:
diff changeset
94 return GetDiceResult(v7, 6u);
Ritor1
parents:
diff changeset
95 }
Ritor1
parents:
diff changeset
96 v13 = v12 - 1;
Ritor1
parents:
diff changeset
97 if ( !v13 )
Ritor1
parents:
diff changeset
98 {
Ritor1
parents:
diff changeset
99 *v3 = 8;
Ritor1
parents:
diff changeset
100 return 5;
Ritor1
parents:
diff changeset
101 }
Ritor1
parents:
diff changeset
102 v14 = v13 - 1;
Ritor1
parents:
diff changeset
103 if ( v14 )
Ritor1
parents:
diff changeset
104 {
Ritor1
parents:
diff changeset
105 v15 = v14 - 1;
Ritor1
parents:
diff changeset
106 if ( v15 )
Ritor1
parents:
diff changeset
107 {
Ritor1
parents:
diff changeset
108 v16 = v15 - 1;
Ritor1
parents:
diff changeset
109 if ( !v16 || v16 == 25 )
Ritor1
parents:
diff changeset
110 {
Ritor1
parents:
diff changeset
111 *v3 = 10;
Ritor1
parents:
diff changeset
112 *a3 = 1;
Ritor1
parents:
diff changeset
113 return v5;
Ritor1
parents:
diff changeset
114 }
Ritor1
parents:
diff changeset
115 goto LABEL_42;
Ritor1
parents:
diff changeset
116 }
Ritor1
parents:
diff changeset
117 *v3 = 2;
Ritor1
parents:
diff changeset
118 return 12;
Ritor1
parents:
diff changeset
119 }
Ritor1
parents:
diff changeset
120 LABEL_36:
Ritor1
parents:
diff changeset
121 v5 = 8;
Ritor1
parents:
diff changeset
122 LABEL_37:
Ritor1
parents:
diff changeset
123 *v3 = v5;
Ritor1
parents:
diff changeset
124 return v5;
Ritor1
parents:
diff changeset
125 }
Ritor1
parents:
diff changeset
126 if ( v8 == 11 )
Ritor1
parents:
diff changeset
127 {
Ritor1
parents:
diff changeset
128 *v3 = 0;
Ritor1
parents:
diff changeset
129 v7 = 2;
Ritor1
parents:
diff changeset
130 return GetDiceResult(v7, 6u);
Ritor1
parents:
diff changeset
131 }
Ritor1
parents:
diff changeset
132 if ( v8 == 4 )
Ritor1
parents:
diff changeset
133 {
Ritor1
parents:
diff changeset
134 *v3 = 2;
Ritor1
parents:
diff changeset
135 v11 = rand() % 2;
Ritor1
parents:
diff changeset
136 return v11 + 3;
Ritor1
parents:
diff changeset
137 }
Ritor1
parents:
diff changeset
138 if ( v8 == 5 )
Ritor1
parents:
diff changeset
139 {
Ritor1
parents:
diff changeset
140 *v3 = 2;
Ritor1
parents:
diff changeset
141 v10 = rand();
Ritor1
parents:
diff changeset
142 v17 = 3;
Ritor1
parents:
diff changeset
143 return v10 % v17 + 6;
Ritor1
parents:
diff changeset
144 }
Ritor1
parents:
diff changeset
145 if ( v8 == 6 )
Ritor1
parents:
diff changeset
146 {
Ritor1
parents:
diff changeset
147 *v3 = 2;
Ritor1
parents:
diff changeset
148 v9 = rand() % 4;
Ritor1
parents:
diff changeset
149 return v9 + 9;
Ritor1
parents:
diff changeset
150 }
Ritor1
parents:
diff changeset
151 if ( v8 == 7 )
Ritor1
parents:
diff changeset
152 {
Ritor1
parents:
diff changeset
153 *v3 = 1;
Ritor1
parents:
diff changeset
154 return rand() % 4 + 2;
Ritor1
parents:
diff changeset
155 }
Ritor1
parents:
diff changeset
156 if ( v8 == 8 )
Ritor1
parents:
diff changeset
157 {
Ritor1
parents:
diff changeset
158 *v3 = 1;
Ritor1
parents:
diff changeset
159 return rand() % 7 + 4;
Ritor1
parents:
diff changeset
160 }
Ritor1
parents:
diff changeset
161 if ( v8 == 9 )
Ritor1
parents:
diff changeset
162 goto LABEL_45;
Ritor1
parents:
diff changeset
163 if ( v8 != 10 )
Ritor1
parents:
diff changeset
164 goto LABEL_42;
Ritor1
parents:
diff changeset
165 *v3 = 0;
Ritor1
parents:
diff changeset
166 v7 = 1;
Ritor1
parents:
diff changeset
167 return GetDiceResult(v7, 6u);
Ritor1
parents:
diff changeset
168 }
Ritor1
parents:
diff changeset
169
Ritor1
parents:
diff changeset
170
Ritor1
parents:
diff changeset
171 //----- (00402F07) --------------------------------------------------------
Ritor1
parents:
diff changeset
172 void ItemGen::Reset()
Ritor1
parents:
diff changeset
173 {
Ritor1
parents:
diff changeset
174 this->field_1A = 0;
Ritor1
parents:
diff changeset
175 this->uAttributes = 0;
Ritor1
parents:
diff changeset
176 this->uNumCharges = 0;
Ritor1
parents:
diff changeset
177 this->uAdditionalValue = 0;
Ritor1
parents:
diff changeset
178 this->_bonus_strength = 0;
Ritor1
parents:
diff changeset
179 this->_bonus_type = 0;
Ritor1
parents:
diff changeset
180 this->uItemID = 0;
Ritor1
parents:
diff changeset
181 this->uBodyAnchor = 0;
Ritor1
parents:
diff changeset
182 this->uExpireTime = 0i64;
Ritor1
parents:
diff changeset
183 }
Ritor1
parents:
diff changeset
184
Ritor1
parents:
diff changeset
185 //----- (00458260) --------------------------------------------------------
Ritor1
parents:
diff changeset
186 void ItemGen::UpdateTempBonus(__int64 uTimePlayed)
Ritor1
parents:
diff changeset
187 {
Ritor1
parents:
diff changeset
188 unsigned int v2; // eax@1
Ritor1
parents:
diff changeset
189
Ritor1
parents:
diff changeset
190 v2 = this->uAttributes;
Ritor1
parents:
diff changeset
191 if ( v2 & ITEM_TEMP_BONUS )
Ritor1
parents:
diff changeset
192 {
Ritor1
parents:
diff changeset
193 if ( uTimePlayed > (signed __int64)this->uExpireTime )
Ritor1
parents:
diff changeset
194 {
Ritor1
parents:
diff changeset
195 this->_bonus_type = 0;
Ritor1
parents:
diff changeset
196 LOBYTE(v2) = v2 & 0xF7;
Ritor1
parents:
diff changeset
197 this->uAdditionalValue = 0;
Ritor1
parents:
diff changeset
198 this->uAttributes = v2;
Ritor1
parents:
diff changeset
199 }
Ritor1
parents:
diff changeset
200 }
Ritor1
parents:
diff changeset
201 }
Ritor1
parents:
diff changeset
202
Ritor1
parents:
diff changeset
203 //----- (0045814E) --------------------------------------------------------
Ritor1
parents:
diff changeset
204 char *ItemsTable::Release()
Ritor1
parents:
diff changeset
205 {
Ritor1
parents:
diff changeset
206 ItemsTable *v1; // edi@1
Ritor1
parents:
diff changeset
207 char *result; // eax@23
Ritor1
parents:
diff changeset
208
Ritor1
parents:
diff changeset
209 v1 = this;
Ritor1
parents:
diff changeset
210 if ( pMonstersTXT_Raw )
Ritor1
parents:
diff changeset
211 pAllocator->FreeChunk(pMonstersTXT_Raw);
Ritor1
parents:
diff changeset
212 if ( pMonsterPlacementTXT_Raw )
Ritor1
parents:
diff changeset
213 pAllocator->FreeChunk(pMonsterPlacementTXT_Raw);
Ritor1
parents:
diff changeset
214 if ( pSkillDescTXT_Raw )
Ritor1
parents:
diff changeset
215 pAllocator->FreeChunk(pSkillDescTXT_Raw);
Ritor1
parents:
diff changeset
216 if ( v1->pSpcItemsTXT_Raw )
Ritor1
parents:
diff changeset
217 pAllocator->FreeChunk(v1->pSpcItemsTXT_Raw);
Ritor1
parents:
diff changeset
218 if ( v1->pStdItemsTXT_Raw )
Ritor1
parents:
diff changeset
219 pAllocator->FreeChunk(v1->pStdItemsTXT_Raw);
Ritor1
parents:
diff changeset
220 if ( v1->pRndItemsTXT_Raw )
Ritor1
parents:
diff changeset
221 pAllocator->FreeChunk(v1->pRndItemsTXT_Raw);
Ritor1
parents:
diff changeset
222 if ( v1->pItemsTXT_Raw )
Ritor1
parents:
diff changeset
223 pAllocator->FreeChunk(v1->pItemsTXT_Raw);
Ritor1
parents:
diff changeset
224 if ( pHostileTXT_Raw )
Ritor1
parents:
diff changeset
225 pAllocator->FreeChunk(pHostileTXT_Raw);
Ritor1
parents:
diff changeset
226 if ( pHistoryTXT_Raw )
Ritor1
parents:
diff changeset
227 pAllocator->FreeChunk(pHistoryTXT_Raw);
Ritor1
parents:
diff changeset
228 if ( pPotionsTXT_Raw )
Ritor1
parents:
diff changeset
229 pAllocator->FreeChunk(pPotionsTXT_Raw);
Ritor1
parents:
diff changeset
230 if ( pPotionNotesTXT_Raw )
Ritor1
parents:
diff changeset
231 pAllocator->FreeChunk(pPotionNotesTXT_Raw);
Ritor1
parents:
diff changeset
232 v1->pSpcItemsTXT_Raw = 0;
Ritor1
parents:
diff changeset
233 pSkillDescTXT_Raw = 0;
Ritor1
parents:
diff changeset
234 v1->pStdItemsTXT_Raw = 0;
Ritor1
parents:
diff changeset
235 v1->pRndItemsTXT_Raw = pSkillDescTXT_Raw;
Ritor1
parents:
diff changeset
236 result = pSkillDescTXT_Raw;
Ritor1
parents:
diff changeset
237 v1->pItemsTXT_Raw = pSkillDescTXT_Raw;
Ritor1
parents:
diff changeset
238 return result;
Ritor1
parents:
diff changeset
239 }
Ritor1
parents:
diff changeset
240
Ritor1
parents:
diff changeset
241
Ritor1
parents:
diff changeset
242 //----- (00456D84) --------------------------------------------------------
Ritor1
parents:
diff changeset
243 void ItemsTable::Initialize()
Ritor1
parents:
diff changeset
244 {
Ritor1
parents:
diff changeset
245 //ItemsTable *v1; // edi@1
Ritor1
parents:
diff changeset
246 char *v2; // eax@1
Ritor1
parents:
diff changeset
247 char *v3; // eax@2
Ritor1
parents:
diff changeset
248 char v4; // cl@3
Ritor1
parents:
diff changeset
249 int v5; // esi@3
Ritor1
parents:
diff changeset
250 char *v6; // esi@21
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
251 unsigned char *v7; // eax@21
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
252 unsigned char *v8; // ecx@22
0
Ritor1
parents:
diff changeset
253 char *v9; // eax@26
Ritor1
parents:
diff changeset
254 char v10; // dl@27
Ritor1
parents:
diff changeset
255 int v11; // ecx@27
Ritor1
parents:
diff changeset
256 int v12; // esi@31
Ritor1
parents:
diff changeset
257 char *v13; // eax@39
Ritor1
parents:
diff changeset
258 int v14; // esi@40
Ritor1
parents:
diff changeset
259 char v15; // cl@41
Ritor1
parents:
diff changeset
260 int v16; // eax@41
Ritor1
parents:
diff changeset
261 char v17; // zf@53
Ritor1
parents:
diff changeset
262 int v18; // eax@57
Ritor1
parents:
diff changeset
263 int *v19; // esi@66
Ritor1
parents:
diff changeset
264 char *v20; // edx@66
Ritor1
parents:
diff changeset
265 int v21; // eax@66
Ritor1
parents:
diff changeset
266 char *v22; // ecx@68
Ritor1
parents:
diff changeset
267 char *v23; // eax@71
Ritor1
parents:
diff changeset
268 int v24; // esi@71
Ritor1
parents:
diff changeset
269 char *v25; // ebx@72
Ritor1
parents:
diff changeset
270 char v26; // cl@73
Ritor1
parents:
diff changeset
271 int v27; // eax@73
Ritor1
parents:
diff changeset
272 char *v28; // ST3C_4@160
Ritor1
parents:
diff changeset
273 char *v29; // ST3C_4@163
Ritor1
parents:
diff changeset
274 char *v30; // eax@175
Ritor1
parents:
diff changeset
275 char *v31; // eax@188
Ritor1
parents:
diff changeset
276 char v32; // al@190
Ritor1
parents:
diff changeset
277 char *v33; // eax@199
Ritor1
parents:
diff changeset
278 const char *v34; // ebx@199
Ritor1
parents:
diff changeset
279 int v35; // esi@199
Ritor1
parents:
diff changeset
280 char *v36; // eax@200
Ritor1
parents:
diff changeset
281 char v37; // dl@201
Ritor1
parents:
diff changeset
282 int v38; // ecx@201
Ritor1
parents:
diff changeset
283 char *v39; // esi@229
Ritor1
parents:
diff changeset
284 char *v40; // eax@229
Ritor1
parents:
diff changeset
285 char *v41; // ecx@230
Ritor1
parents:
diff changeset
286 char *v42; // esi@233
Ritor1
parents:
diff changeset
287 char *v43; // eax@234
Ritor1
parents:
diff changeset
288 char v44; // dl@235
Ritor1
parents:
diff changeset
289 int v45; // ecx@235
Ritor1
parents:
diff changeset
290 signed int v46; // edi@287
Ritor1
parents:
diff changeset
291 char *v47; // ecx@288
Ritor1
parents:
diff changeset
292 char v48; // dl@289
Ritor1
parents:
diff changeset
293 int v49; // eax@289
Ritor1
parents:
diff changeset
294 int v50; // esi@293
Ritor1
parents:
diff changeset
295 signed int v51; // edi@312
Ritor1
parents:
diff changeset
296 char *v52; // ecx@312
Ritor1
parents:
diff changeset
297 char v53; // dl@313
Ritor1
parents:
diff changeset
298 int v54; // eax@313
Ritor1
parents:
diff changeset
299 int v55; // esi@317
Ritor1
parents:
diff changeset
300 signed int v56; // edi@348
Ritor1
parents:
diff changeset
301 char *v57; // eax@348
Ritor1
parents:
diff changeset
302 char v58; // dl@349
Ritor1
parents:
diff changeset
303 int v59; // ecx@349
Ritor1
parents:
diff changeset
304 int v60; // esi@353
Ritor1
parents:
diff changeset
305 char *Str; // [sp+Ch] [bp-18h]@1
Ritor1
parents:
diff changeset
306 signed int Stra; // [sp+Ch] [bp-18h]@22
Ritor1
parents:
diff changeset
307 signed int Strb; // [sp+Ch] [bp-18h]@25
Ritor1
parents:
diff changeset
308 signed int Strc; // [sp+Ch] [bp-18h]@39
Ritor1
parents:
diff changeset
309 signed int Strd; // [sp+Ch] [bp-18h]@66
Ritor1
parents:
diff changeset
310 signed int Stre; // [sp+Ch] [bp-18h]@156
Ritor1
parents:
diff changeset
311 const char **Strf; // [sp+Ch] [bp-18h]@176
Ritor1
parents:
diff changeset
312 const char **Strg; // [sp+Ch] [bp-18h]@182
Ritor1
parents:
diff changeset
313 signed int Strh; // [sp+Ch] [bp-18h]@230
Ritor1
parents:
diff changeset
314 signed int Stri; // [sp+Ch] [bp-18h]@311
Ritor1
parents:
diff changeset
315 char **Strj; // [sp+Ch] [bp-18h]@347
Ritor1
parents:
diff changeset
316 int v72; // [sp+10h] [bp-14h]@7
Ritor1
parents:
diff changeset
317 signed int v73; // [sp+10h] [bp-14h]@21
Ritor1
parents:
diff changeset
318 int v74; // [sp+10h] [bp-14h]@45
Ritor1
parents:
diff changeset
319 int v75; // [sp+10h] [bp-14h]@77
Ritor1
parents:
diff changeset
320 int v76; // [sp+10h] [bp-14h]@205
Ritor1
parents:
diff changeset
321 signed int v77; // [sp+10h] [bp-14h]@229
Ritor1
parents:
diff changeset
322 int v78; // [sp+10h] [bp-14h]@239
Ritor1
parents:
diff changeset
323 signed int v79; // [sp+14h] [bp-10h]@1
Ritor1
parents:
diff changeset
324 char *v80; // [sp+14h] [bp-10h]@39
Ritor1
parents:
diff changeset
325 char *v81; // [sp+14h] [bp-10h]@175
Ritor1
parents:
diff changeset
326 char *v82; // [sp+14h] [bp-10h]@188
Ritor1
parents:
diff changeset
327 int v83; // [sp+18h] [bp-Ch]@67
Ritor1
parents:
diff changeset
328 size_t v84; // [sp+18h] [bp-Ch]@156
Ritor1
parents:
diff changeset
329 signed int v85; // [sp+18h] [bp-Ch]@176
Ritor1
parents:
diff changeset
330 signed int v86; // [sp+18h] [bp-Ch]@182
Ritor1
parents:
diff changeset
331 signed int v87; // [sp+18h] [bp-Ch]@233
Ritor1
parents:
diff changeset
332 signed int v88; // [sp+1Ch] [bp-8h]@2
Ritor1
parents:
diff changeset
333 signed int v89; // [sp+1Ch] [bp-8h]@26
Ritor1
parents:
diff changeset
334 signed int v90; // [sp+1Ch] [bp-8h]@40
Ritor1
parents:
diff changeset
335 signed int v91; // [sp+1Ch] [bp-8h]@72
Ritor1
parents:
diff changeset
336 signed int v92; // [sp+1Ch] [bp-8h]@200
Ritor1
parents:
diff changeset
337 signed int v93; // [sp+1Ch] [bp-8h]@234
Ritor1
parents:
diff changeset
338 signed int v94; // [sp+1Ch] [bp-8h]@288
Ritor1
parents:
diff changeset
339 signed int v95; // [sp+1Ch] [bp-8h]@312
Ritor1
parents:
diff changeset
340 signed int v96; // [sp+1Ch] [bp-8h]@348
Ritor1
parents:
diff changeset
341 signed int v97; // [sp+20h] [bp-4h]@2
Ritor1
parents:
diff changeset
342 signed int v98; // [sp+20h] [bp-4h]@26
Ritor1
parents:
diff changeset
343 signed int v99; // [sp+20h] [bp-4h]@40
Ritor1
parents:
diff changeset
344 signed int v100; // [sp+20h] [bp-4h]@72
Ritor1
parents:
diff changeset
345 signed int v101; // [sp+20h] [bp-4h]@200
Ritor1
parents:
diff changeset
346 signed int v102; // [sp+20h] [bp-4h]@234
Ritor1
parents:
diff changeset
347 signed int v103; // [sp+20h] [bp-4h]@288
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
348 int i,j;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
349 char* test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
350 char c;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
351 bool break_loop;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
352 unsigned int temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
353 char* tmp_pos;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
354 int decode_step;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
355 int item_counter;
0
Ritor1
parents:
diff changeset
356 //v1 = this;
Ritor1
parents:
diff changeset
357
Ritor1
parents:
diff changeset
358 pMapStats = new MapStats;
Ritor1
parents:
diff changeset
359 pMapStats->Initialize();
Ritor1
parents:
diff changeset
360
Ritor1
parents:
diff changeset
361 pMonsterStats = new MonsterStats;
Ritor1
parents:
diff changeset
362 pMonsterStats->Initialize();
Ritor1
parents:
diff changeset
363 pMonsterStats->InitializePlacements();
Ritor1
parents:
diff changeset
364
Ritor1
parents:
diff changeset
365 pSpellStats = new SpellStats;
Ritor1
parents:
diff changeset
366 pSpellStats->Initialize();
Ritor1
parents:
diff changeset
367
Ritor1
parents:
diff changeset
368 LoadPotions();
Ritor1
parents:
diff changeset
369 LoadPotionNotes();
Ritor1
parents:
diff changeset
370
Ritor1
parents:
diff changeset
371 pFactionTable = new FactionTable;
Ritor1
parents:
diff changeset
372 pFactionTable->Initialize();
Ritor1
parents:
diff changeset
373
Ritor1
parents:
diff changeset
374 pStorylineText = new StorylineText;
Ritor1
parents:
diff changeset
375 pStorylineText->Initialize();
Ritor1
parents:
diff changeset
376
Ritor1
parents:
diff changeset
377 pStdItemsTXT_Raw = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
378 pStdItemsTXT_Raw = (char *)pEvents_LOD->LoadRaw("stditems.txt", 0);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
379 strtok(pStdItemsTXT_Raw, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
380 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
381 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
382 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
383 //Standard Bonuses by Group
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
384 for (i=0;i<24;++i)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
385 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
386 test_string = strtok(NULL, "\r") + 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
387 break_loop = false;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
388 decode_step=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
389 do
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
390 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
391 c = *(unsigned char*)test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
392 temp_str_len = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
393 while((c!='\t')&&(c>0))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
394 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
395 ++temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
396 c=test_string[temp_str_len];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
397 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
398 tmp_pos=test_string+temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
399 if (*tmp_pos == 0)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
400 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
401 *tmp_pos = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
402 if (temp_str_len)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
403 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
404 switch (decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
405 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
406 case 0:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
407 pEnchantments[i].pBonusStat=RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
408 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
409 case 1:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
410 pEnchantments[i].pOfName= RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
411 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
412 default:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
413 pEnchantments[i].to_item[decode_step-2]=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
414 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
415 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
416 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
417 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
418 if (!decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
419 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
420 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
421 ++decode_step;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
422 test_string=tmp_pos+1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
423 } while ((decode_step<11)&&!break_loop);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
424 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
425 //Value Mod= (+100 / Plus of Item)?
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
426
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
427 memset(&pEnchantmentsSumm, 0, 36);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
428 for(i=0;i<9;++i)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
429 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
430 for (j=0;j<24;++j)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
431 pEnchantmentsSumm[i]+=pEnchantments[j].to_item[i];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
432 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
433
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
434 //Bonus range for Standard by Level
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
435 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
436 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
437 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
438 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
439 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
440 for(i=0;i<6;++i) //counted from 1
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
441 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
442 test_string = strtok(NULL, "\r") + 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
443 break_loop = false;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
444 decode_step=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
445 do
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
446 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
447 c = *(unsigned char*)test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
448 temp_str_len = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
449 while((c!='\t')&&(c>0))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
450 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
451 ++temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
452 c=test_string[temp_str_len];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
453 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
454 tmp_pos=test_string+temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
455 if (*tmp_pos == 0)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
456 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
457 *tmp_pos = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
458 if (decode_step==2)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
459 bonus_ranges[i].minR = atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
460 else if (decode_step==3)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
461 bonus_ranges[i].maxR =atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
462 ++decode_step;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
463 test_string=tmp_pos+1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
464 } while ((decode_step<4)&&!break_loop);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
465 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
466
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
467
0
Ritor1
parents:
diff changeset
468 pSpcItemsTXT_Raw = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
469 pSpcItemsTXT_Raw = (char *)pEvents_LOD->LoadRaw("spcitems.txt", 0);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
470 strtok(pSpcItemsTXT_Raw, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
471 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
472 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
473 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
474 for (i=0;i<72;++i)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
475 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
476 test_string = strtok(NULL, "\r") + 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
477 break_loop = false;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
478 decode_step=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
479 do
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
480 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
481 c = *(unsigned char*)test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
482 temp_str_len = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
483 while((c!='\t')&&(c>0))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
484 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
485 ++temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
486 c=test_string[temp_str_len];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
487 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
488 tmp_pos=test_string+temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
489 if (*tmp_pos == 0)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
490 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
491 *tmp_pos = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
492 if (temp_str_len)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
493 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
494 switch (decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
495 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
496 case 0:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
497 pSpecialEnchantments[i].pBonusStatement=RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
498 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
499 case 1:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
500 pSpecialEnchantments[i].pNameAdd= RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
501 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
502 case 14:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
503 int res;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
504 res=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
505 if(!res)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
506 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
507 ++test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
508 while (*test_string==' ')//fix X 2 case
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
509 ++test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
510 res=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
511 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
512 pSpecialEnchantments[i].iValue=res;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
513 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
514 case 15:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
515 pSpecialEnchantments[i].iTreasureLevel= tolower(*test_string) - 97;;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
516 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
517 default:
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
518 pSpecialEnchantments[i].to_item_apply[decode_step-2]=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
519 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
520 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
521 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
522 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
523 if (!decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
524 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
525 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
526 ++decode_step;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
527 test_string=tmp_pos+1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
528 } while ((decode_step<16)&&!break_loop);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
529 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
530
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
531 pSpecialEnchantments_count = 71;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
532 memset(&pSpecialEnchantmentsSumm, 0, 96);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
533 for(i=0;i<12;++i)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
534 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
535 for (j=0;j<pSpecialEnchantments_count;++j)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
536 pSpecialEnchantmentsSumm[i]+=pSpecialEnchantments[j].to_item_apply[i];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
537 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
538
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
539
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
540
0
Ritor1
parents:
diff changeset
541 Initialize2DA();
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
542
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
543 pItemsTXT_Raw = NULL;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
544 pItemsTXT_Raw = (char*) pEvents_LOD->LoadRaw("items.txt", 0);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
545 strtok(pItemsTXT_Raw, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
546 strtok(NULL, "\r");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
547 uAllItemsCount = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
548 item_counter = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
549 while (true)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
550 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
551 test_string = strtok(NULL, "\r") + 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
552 break_loop = false;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
553 decode_step=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
554 do
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
555 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
556 c = *(unsigned char*)test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
557 temp_str_len = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
558 while((c!='\t')&&(c>0))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
559 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
560 ++temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
561 c=test_string[temp_str_len];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
562 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
563 tmp_pos=test_string+temp_str_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
564 if (*tmp_pos == 0)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
565 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
566 *tmp_pos = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
567 if (temp_str_len)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
568 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
569 switch (decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
570 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
571 case 0: //Item #
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
572 item_counter=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
573 uAllItemsCount=item_counter;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
574 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
575 case 1: //Pic File
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
576 pItems[item_counter].pIconName = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
577 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
578 case 2: //Name
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
579 pItems[item_counter].pName = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
580 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
581 case 3: //Value
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
582 pItems[item_counter].uValue=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
583 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
584 case 4: //Equip Stat
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
585 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
586 if ( !_strcmpi(test_string, "weapon") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
587 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
588 pItems[item_counter].uEquipType = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
589 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
590 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
591 if ( !_strcmpi(test_string, "weapon2") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
592 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
593 pItems[item_counter].uEquipType = 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
594 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
595 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
596 if ( !_strcmpi(test_string, "weapon1or2") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
597 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
598 pItems[item_counter].uEquipType = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
599 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
600 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
601 if ( !(_strcmpi(test_string, "missile")&&_strcmpi(test_string, "bow")))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
602 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
603 pItems[item_counter].uEquipType = 2;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
604 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
605 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
606 if ( !_strcmpi(test_string, "armor") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
607 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
608 pItems[item_counter].uEquipType = 3;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
609 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
610 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
611 if ( !_strcmpi(test_string, "shield") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
612 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
613 pItems[item_counter].uEquipType = 4;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
614 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
615 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
616 if ( !_strcmpi(test_string, "helm") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
617 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
618 pItems[item_counter].uEquipType = 5;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
619 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
620 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
621 if ( !_strcmpi(test_string, "belt") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
622 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
623 pItems[item_counter].uEquipType = 6;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
624 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
625 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
626 if ( !_strcmpi(test_string, "cloak") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
627 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
628 pItems[item_counter].uEquipType = 7;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
629 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
630 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
631 if ( !_strcmpi(test_string, "gauntlets") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
632 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
633 pItems[item_counter].uEquipType = 8;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
634 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
635 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
636 if ( !_strcmpi(test_string, "boots") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
637 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
638 pItems[item_counter].uEquipType = 9;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
639 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
640 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
641 if ( !_strcmpi(test_string, "ring") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
642 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
643 pItems[item_counter].uEquipType = 10;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
644 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
645 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
646 if ( !_strcmpi(test_string, "amulet") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
647 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
648 pItems[item_counter].uEquipType = 11;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
649 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
650 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
651 if ( !_strcmpi(test_string, "weaponw") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
652 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
653 pItems[item_counter].uEquipType = 12;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
654 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
655 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
656 if ( !(_strcmpi(test_string, "herb")&&_strcmpi(test_string, "reagent")))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
657 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
658 pItems[item_counter].uEquipType = 13;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
659 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
660 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
661 if ( !_strcmpi(test_string, "bottle") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
662 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
663 pItems[item_counter].uEquipType = 14;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
664 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
665 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
666 if ( !_strcmpi(test_string, "sscroll") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
667 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
668 pItems[item_counter].uEquipType = 15;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
669 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
670 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
671 if ( !_strcmpi(test_string, "book") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
672 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
673 pItems[item_counter].uEquipType = 16;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
674 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
675 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
676 if ( !_strcmpi(test_string, "mscroll") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
677 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
678 pItems[item_counter].uEquipType = 17;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
679 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
680 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
681 if ( !_strcmpi(test_string, "gold") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
682 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
683 pItems[item_counter].uEquipType = 18;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
684 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
685 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
686 if ( !_strcmpi(test_string, "gem") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
687 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
688 pItems[item_counter].uEquipType = 19;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
689 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
690 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
691 pItems[item_counter].uEquipType = 20;
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 5: //Skill Group
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
695 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
696 if ( !_strcmpi(test_string, "staff") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
697 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
698 pItems[item_counter].uSkillType = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
699 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
700 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
701 if ( !_strcmpi(test_string, "sword") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
702 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
703 pItems[item_counter].uSkillType = 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
704 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
705 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
706 if ( !_strcmpi(test_string, "dagger") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
707 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
708 pItems[item_counter].uSkillType = 2;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
709 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
710 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
711 if ( !_strcmpi(test_string, "axe") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
712 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
713 pItems[item_counter].uSkillType = 3;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
714 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
715 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
716 if ( !_strcmpi(test_string, "spear") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
717 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
718 pItems[item_counter].uSkillType = 4;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
719 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
720 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
721 if ( !_strcmpi(test_string, "bow") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
722 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
723 pItems[item_counter].uSkillType = 5;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
724 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
725 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
726 if ( !_strcmpi(test_string, "mace") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
727 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
728 pItems[item_counter].uSkillType = 6;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
729 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
730 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
731 if ( !_strcmpi(test_string, "blaster") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
732 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
733 pItems[item_counter].uSkillType = 7;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
734 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
735 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
736 if ( !_strcmpi(test_string, "shield") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
737 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
738 pItems[item_counter].uSkillType = 8;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
739 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
740 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
741 if ( !_strcmpi(test_string, "leather") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
742 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
743 pItems[item_counter].uSkillType = 9;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
744 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
745 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
746 if ( !_strcmpi(test_string, "chain") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
747 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
748 pItems[item_counter].uSkillType = 10;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
749 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
750 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
751 if ( !_strcmpi(test_string, "plate") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
752 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
753 pItems[item_counter].uSkillType = 11;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
754 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
755 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
756 if ( !_strcmpi(test_string, "club") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
757 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
758 pItems[item_counter].uSkillType = 37;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
759 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
760 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
761 pItems[item_counter].uSkillType = 38;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
762 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
763 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
764 case 6: //Mod1
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
765 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
766 int ii;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
767 char* test_char;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
768 int tst_len;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
769 tst_len=strlen(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
770 pItems[item_counter].uDamageDice=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
771 pItems[item_counter].uDamageRoll=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
772 test_char=test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
773 for (ii=0; ii<tst_len; ++ii)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
774 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
775 if (tolower(*test_char)=='d')
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
776 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
777 *test_char=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
778 pItems[item_counter].uDamageDice=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
779 pItems[item_counter].uDamageRoll=atoi(test_char+1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
780 *test_char='d';
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
781 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
782 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
783 ++test_char;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
784 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
785 test_char=test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
786 if ((ii==tst_len)&&(tolower(*test_char)=='s'))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
787 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
788 pItems[item_counter].uDamageDice=atoi(test_char+1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
789 pItems[item_counter].uDamageRoll=1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
790 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
791 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
792 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
793 case 7: //Mod2
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
794 pItems[item_counter].uDamageMod=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
795 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
796 case 8: //material
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
797 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
798 if ( !_strcmpi(test_string, "artifact") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
799 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
800 pItems[item_counter].uMaterial = 1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
801 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
802 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
803 if ( !_strcmpi(test_string, "relic") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
804 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
805 pItems[item_counter].uMaterial = 2;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
806 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
807 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
808 if ( !_strcmpi(test_string, "special") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
809 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
810 pItems[item_counter].uMaterial = 3;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
811 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
812 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
813 pItems[item_counter].uMaterial = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
814 break;}
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
815 case 9: //ID/Rep/St
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
816 pItems[item_counter].uItemID_Rep_St=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
817 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
818 case 10: //Not identified name
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
819 pItems[item_counter].pUnidentifiedName = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
820 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
821 case 11: //Sprite Index
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
822 pItems[item_counter].uSpriteID=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
823 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
824 case 12: //VarA
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
825 pItems[item_counter]._additional_value=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
826 pItems[item_counter]._bonus_type=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
827 if (pItems[item_counter].uMaterial==3)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
828 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
829 for(int ii=0; ii<24; ++ii)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
830 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
831 if (stricmp(test_string,pEnchantments[ii].pBonusStat))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
832 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
833 pItems[item_counter]._bonus_type=ii+1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
834 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
835 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
836 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
837 if (!pItems[item_counter]._bonus_type)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
838 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
839 for(int ii=0; ii<72; ++ii)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
840 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
841 if (stricmp(test_string,pSpecialEnchantments[ii].pBonusStatement))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
842 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
843 pItems[item_counter]._additional_value=ii+1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
844 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
845 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
846 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
847 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
848
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
849 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
850 case 13: //VarB
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
851 if ((pItems[item_counter].uMaterial==3)&&(pItems[item_counter]._bonus_type))
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
852 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
853 char b_s=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
854 if (b_s)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
855 pItems[item_counter]._bonus_strength=b_s;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
856 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
857 pItems[item_counter]._bonus_strength=1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
858 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
859 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
860 pItems[item_counter]._bonus_strength=0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
861 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
862 case 14: //Equip X
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
863 pItems[item_counter].uEquipX=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
864 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
865 case 15: //Equip Y
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
866 pItems[item_counter].uEquipY=atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
867 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
868 case 16: //Notes
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
869 pItems[item_counter].pDescription = RemoveQuotes(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
870 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
871
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
872 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
873 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
874 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
875 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
876 if (!decode_step)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
877 break_loop = true;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
878 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
879 ++decode_step;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
880 test_string=tmp_pos+1;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
881 } while ((decode_step<17)&&!break_loop);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
882 ++item_counter;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
883 if (item_counter>799)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
884 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
885 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
886
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
887 /*
0
Ritor1
parents:
diff changeset
888 while ( 2 )
Ritor1
parents:
diff changeset
889 {
Ritor1
parents:
diff changeset
890 v100 = 0;
Ritor1
parents:
diff changeset
891 v25 = strtok(0, "\r") + 1;
Ritor1
parents:
diff changeset
892 v91 = 0;
Ritor1
parents:
diff changeset
893 while ( 2 )
Ritor1
parents:
diff changeset
894 {
Ritor1
parents:
diff changeset
895 v26 = *v25;
Ritor1
parents:
diff changeset
896 v27 = 0;
Ritor1
parents:
diff changeset
897 while ( v26 != 9 && v26 )
Ritor1
parents:
diff changeset
898 {
Ritor1
parents:
diff changeset
899 ++v27;
Ritor1
parents:
diff changeset
900 v26 = v25[v27];
Ritor1
parents:
diff changeset
901 }
Ritor1
parents:
diff changeset
902 v75 = (int)&v25[v27];
Ritor1
parents:
diff changeset
903 if ( !v25[v27] )
Ritor1
parents:
diff changeset
904 v91 = 1;
Ritor1
parents:
diff changeset
905 v25[v27] = 0;
Ritor1
parents:
diff changeset
906 if ( v27 )
Ritor1
parents:
diff changeset
907 {
Ritor1
parents:
diff changeset
908 switch ( v100 )
Ritor1
parents:
diff changeset
909 {
Ritor1
parents:
diff changeset
910 case 0:
Ritor1
parents:
diff changeset
911 v24 = atoi(v25);
Ritor1
parents:
diff changeset
912 break;
Ritor1
parents:
diff changeset
913 case 1:
Ritor1
parents:
diff changeset
914 pItems[v24].pIconName = (char *)RemoveQuotes(v25);
Ritor1
parents:
diff changeset
915 break;
Ritor1
parents:
diff changeset
916 case 2:
Ritor1
parents:
diff changeset
917 pItems[v24].pName = (char *)RemoveQuotes(v25);
Ritor1
parents:
diff changeset
918 break;
Ritor1
parents:
diff changeset
919 case 3:
Ritor1
parents:
diff changeset
920 pItems[v24].uValue = atoi(v25);
Ritor1
parents:
diff changeset
921 break;
Ritor1
parents:
diff changeset
922 case 4:
Ritor1
parents:
diff changeset
923 if ( !_strcmpi(v25, "weapon") )
Ritor1
parents:
diff changeset
924 goto LABEL_89;
Ritor1
parents:
diff changeset
925 if ( _strcmpi(v25, "weapon2") )
Ritor1
parents:
diff changeset
926 {
Ritor1
parents:
diff changeset
927 if ( _strcmpi(v25, "weapon1or2") )
Ritor1
parents:
diff changeset
928 {
Ritor1
parents:
diff changeset
929 if ( _strcmpi(v25, "missile") && _strcmpi(v25, "bow") )
Ritor1
parents:
diff changeset
930 {
Ritor1
parents:
diff changeset
931 if ( _strcmpi(v25, "armor") )
Ritor1
parents:
diff changeset
932 {
Ritor1
parents:
diff changeset
933 if ( _strcmpi(v25, "shield") )
Ritor1
parents:
diff changeset
934 {
Ritor1
parents:
diff changeset
935 if ( _strcmpi(v25, "helm") )
Ritor1
parents:
diff changeset
936 {
Ritor1
parents:
diff changeset
937 if ( _strcmpi(v25, "belt") )
Ritor1
parents:
diff changeset
938 {
Ritor1
parents:
diff changeset
939 if ( _strcmpi(v25, "cloak") )
Ritor1
parents:
diff changeset
940 {
Ritor1
parents:
diff changeset
941 if ( _strcmpi(v25, "gauntlets") )
Ritor1
parents:
diff changeset
942 {
Ritor1
parents:
diff changeset
943 if ( _strcmpi(v25, "boots") )
Ritor1
parents:
diff changeset
944 {
Ritor1
parents:
diff changeset
945 if ( _strcmpi(v25, "ring") )
Ritor1
parents:
diff changeset
946 {
Ritor1
parents:
diff changeset
947 if ( _strcmpi(v25, "amulet") )
Ritor1
parents:
diff changeset
948 {
Ritor1
parents:
diff changeset
949 if ( _strcmpi(v25, "weaponw") )
Ritor1
parents:
diff changeset
950 {
Ritor1
parents:
diff changeset
951 if ( _strcmpi(v25, "herb") && _strcmpi(v25, "reagent") )
Ritor1
parents:
diff changeset
952 {
Ritor1
parents:
diff changeset
953 if ( _strcmpi(v25, "bottle") )
Ritor1
parents:
diff changeset
954 {
Ritor1
parents:
diff changeset
955 if ( _strcmpi(v25, "sscroll") )
Ritor1
parents:
diff changeset
956 {
Ritor1
parents:
diff changeset
957 if ( _strcmpi(v25, "book") )
Ritor1
parents:
diff changeset
958 {
Ritor1
parents:
diff changeset
959 if ( _strcmpi(v25, "mscroll") )
Ritor1
parents:
diff changeset
960 {
Ritor1
parents:
diff changeset
961 if ( _strcmpi(v25, "gold") )
Ritor1
parents:
diff changeset
962 {
Ritor1
parents:
diff changeset
963 if ( _strcmpi(v25, "gem") )
Ritor1
parents:
diff changeset
964 pItems[v24].uEquipType = 20;
Ritor1
parents:
diff changeset
965 else
Ritor1
parents:
diff changeset
966 pItems[v24].uEquipType = 19;
Ritor1
parents:
diff changeset
967 }
Ritor1
parents:
diff changeset
968 else
Ritor1
parents:
diff changeset
969 {
Ritor1
parents:
diff changeset
970 pItems[v24].uEquipType = 18;
Ritor1
parents:
diff changeset
971 }
Ritor1
parents:
diff changeset
972 }
Ritor1
parents:
diff changeset
973 else
Ritor1
parents:
diff changeset
974 {
Ritor1
parents:
diff changeset
975 pItems[v24].uEquipType = 17;
Ritor1
parents:
diff changeset
976 }
Ritor1
parents:
diff changeset
977 }
Ritor1
parents:
diff changeset
978 else
Ritor1
parents:
diff changeset
979 {
Ritor1
parents:
diff changeset
980 pItems[v24].uEquipType = 16;
Ritor1
parents:
diff changeset
981 }
Ritor1
parents:
diff changeset
982 }
Ritor1
parents:
diff changeset
983 else
Ritor1
parents:
diff changeset
984 {
Ritor1
parents:
diff changeset
985 pItems[v24].uEquipType = 15;
Ritor1
parents:
diff changeset
986 }
Ritor1
parents:
diff changeset
987 }
Ritor1
parents:
diff changeset
988 else
Ritor1
parents:
diff changeset
989 {
Ritor1
parents:
diff changeset
990 pItems[v24].uEquipType = 14;
Ritor1
parents:
diff changeset
991 }
Ritor1
parents:
diff changeset
992 }
Ritor1
parents:
diff changeset
993 else
Ritor1
parents:
diff changeset
994 {
Ritor1
parents:
diff changeset
995 pItems[v24].uEquipType = 13;
Ritor1
parents:
diff changeset
996 }
Ritor1
parents:
diff changeset
997 }
Ritor1
parents:
diff changeset
998 else
Ritor1
parents:
diff changeset
999 {
Ritor1
parents:
diff changeset
1000 pItems[v24].uEquipType = 12;
Ritor1
parents:
diff changeset
1001 }
Ritor1
parents:
diff changeset
1002 }
Ritor1
parents:
diff changeset
1003 else
Ritor1
parents:
diff changeset
1004 {
Ritor1
parents:
diff changeset
1005 pItems[v24].uEquipType = 11;
Ritor1
parents:
diff changeset
1006 }
Ritor1
parents:
diff changeset
1007 }
Ritor1
parents:
diff changeset
1008 else
Ritor1
parents:
diff changeset
1009 {
Ritor1
parents:
diff changeset
1010 pItems[v24].uEquipType = 10;
Ritor1
parents:
diff changeset
1011 }
Ritor1
parents:
diff changeset
1012 }
Ritor1
parents:
diff changeset
1013 else
Ritor1
parents:
diff changeset
1014 {
Ritor1
parents:
diff changeset
1015 pItems[v24].uEquipType = 9;
Ritor1
parents:
diff changeset
1016 }
Ritor1
parents:
diff changeset
1017 }
Ritor1
parents:
diff changeset
1018 else
Ritor1
parents:
diff changeset
1019 {
Ritor1
parents:
diff changeset
1020 pItems[v24].uEquipType = 8;
Ritor1
parents:
diff changeset
1021 }
Ritor1
parents:
diff changeset
1022 }
Ritor1
parents:
diff changeset
1023 else
Ritor1
parents:
diff changeset
1024 {
Ritor1
parents:
diff changeset
1025 pItems[v24].uEquipType = 7;
Ritor1
parents:
diff changeset
1026 }
Ritor1
parents:
diff changeset
1027 }
Ritor1
parents:
diff changeset
1028 else
Ritor1
parents:
diff changeset
1029 {
Ritor1
parents:
diff changeset
1030 pItems[v24].uEquipType = 6;
Ritor1
parents:
diff changeset
1031 }
Ritor1
parents:
diff changeset
1032 }
Ritor1
parents:
diff changeset
1033 else
Ritor1
parents:
diff changeset
1034 {
Ritor1
parents:
diff changeset
1035 pItems[v24].uEquipType = 5;
Ritor1
parents:
diff changeset
1036 }
Ritor1
parents:
diff changeset
1037 }
Ritor1
parents:
diff changeset
1038 else
Ritor1
parents:
diff changeset
1039 {
Ritor1
parents:
diff changeset
1040 pItems[v24].uEquipType = 4;
Ritor1
parents:
diff changeset
1041 }
Ritor1
parents:
diff changeset
1042 }
Ritor1
parents:
diff changeset
1043 else
Ritor1
parents:
diff changeset
1044 {
Ritor1
parents:
diff changeset
1045 pItems[v24].uEquipType = 3;
Ritor1
parents:
diff changeset
1046 }
Ritor1
parents:
diff changeset
1047 }
Ritor1
parents:
diff changeset
1048 else
Ritor1
parents:
diff changeset
1049 {
Ritor1
parents:
diff changeset
1050 pItems[v24].uEquipType = 2;
Ritor1
parents:
diff changeset
1051 }
Ritor1
parents:
diff changeset
1052 }
Ritor1
parents:
diff changeset
1053 else
Ritor1
parents:
diff changeset
1054 {
Ritor1
parents:
diff changeset
1055 LABEL_89:
Ritor1
parents:
diff changeset
1056 pItems[v24].uEquipType = 0;
Ritor1
parents:
diff changeset
1057 }
Ritor1
parents:
diff changeset
1058 }
Ritor1
parents:
diff changeset
1059 else
Ritor1
parents:
diff changeset
1060 {
Ritor1
parents:
diff changeset
1061 pItems[v24].uEquipType = 1;
Ritor1
parents:
diff changeset
1062 }
Ritor1
parents:
diff changeset
1063 break;
Ritor1
parents:
diff changeset
1064 case 5:
Ritor1
parents:
diff changeset
1065 if ( _strcmpi(v25, "staff") )
Ritor1
parents:
diff changeset
1066 {
Ritor1
parents:
diff changeset
1067 if ( _strcmpi(v25, "sword") )
Ritor1
parents:
diff changeset
1068 {
Ritor1
parents:
diff changeset
1069 if ( _strcmpi(v25, "dagger") )
Ritor1
parents:
diff changeset
1070 {
Ritor1
parents:
diff changeset
1071 if ( _strcmpi(v25, "axe") )
Ritor1
parents:
diff changeset
1072 {
Ritor1
parents:
diff changeset
1073 if ( _strcmpi(v25, "spear") )
Ritor1
parents:
diff changeset
1074 {
Ritor1
parents:
diff changeset
1075 if ( _strcmpi(v25, "bow") )
Ritor1
parents:
diff changeset
1076 {
Ritor1
parents:
diff changeset
1077 if ( _strcmpi(v25, "mace") )
Ritor1
parents:
diff changeset
1078 {
Ritor1
parents:
diff changeset
1079 if ( _strcmpi(v25, "blaster") )
Ritor1
parents:
diff changeset
1080 {
Ritor1
parents:
diff changeset
1081 if ( _strcmpi(v25, "shield") )
Ritor1
parents:
diff changeset
1082 {
Ritor1
parents:
diff changeset
1083 if ( _strcmpi(v25, "leather") )
Ritor1
parents:
diff changeset
1084 {
Ritor1
parents:
diff changeset
1085 if ( _strcmpi(v25, "chain") )
Ritor1
parents:
diff changeset
1086 {
Ritor1
parents:
diff changeset
1087 if ( _strcmpi(v25, "plate") )
Ritor1
parents:
diff changeset
1088 {
Ritor1
parents:
diff changeset
1089 if ( _strcmpi(v25, "club") )
Ritor1
parents:
diff changeset
1090 pItems[v24].uSkillType = 38;
Ritor1
parents:
diff changeset
1091 else
Ritor1
parents:
diff changeset
1092 pItems[v24].uSkillType = 37;
Ritor1
parents:
diff changeset
1093 }
Ritor1
parents:
diff changeset
1094 else
Ritor1
parents:
diff changeset
1095 {
Ritor1
parents:
diff changeset
1096 pItems[v24].uSkillType = 11;
Ritor1
parents:
diff changeset
1097 }
Ritor1
parents:
diff changeset
1098 }
Ritor1
parents:
diff changeset
1099 else
Ritor1
parents:
diff changeset
1100 {
Ritor1
parents:
diff changeset
1101 pItems[v24].uSkillType = 10;
Ritor1
parents:
diff changeset
1102 }
Ritor1
parents:
diff changeset
1103 }
Ritor1
parents:
diff changeset
1104 else
Ritor1
parents:
diff changeset
1105 {
Ritor1
parents:
diff changeset
1106 pItems[v24].uSkillType = 9;
Ritor1
parents:
diff changeset
1107 }
Ritor1
parents:
diff changeset
1108 }
Ritor1
parents:
diff changeset
1109 else
Ritor1
parents:
diff changeset
1110 {
Ritor1
parents:
diff changeset
1111 pItems[v24].uSkillType = 8;
Ritor1
parents:
diff changeset
1112 }
Ritor1
parents:
diff changeset
1113 }
Ritor1
parents:
diff changeset
1114 else
Ritor1
parents:
diff changeset
1115 {
Ritor1
parents:
diff changeset
1116 pItems[v24].uSkillType = 7;
Ritor1
parents:
diff changeset
1117 }
Ritor1
parents:
diff changeset
1118 }
Ritor1
parents:
diff changeset
1119 else
Ritor1
parents:
diff changeset
1120 {
Ritor1
parents:
diff changeset
1121 pItems[v24].uSkillType = 6;
Ritor1
parents:
diff changeset
1122 }
Ritor1
parents:
diff changeset
1123 }
Ritor1
parents:
diff changeset
1124 else
Ritor1
parents:
diff changeset
1125 {
Ritor1
parents:
diff changeset
1126 pItems[v24].uSkillType = 5;
Ritor1
parents:
diff changeset
1127 }
Ritor1
parents:
diff changeset
1128 }
Ritor1
parents:
diff changeset
1129 else
Ritor1
parents:
diff changeset
1130 {
Ritor1
parents:
diff changeset
1131 pItems[v24].uSkillType = 4;
Ritor1
parents:
diff changeset
1132 }
Ritor1
parents:
diff changeset
1133 }
Ritor1
parents:
diff changeset
1134 else
Ritor1
parents:
diff changeset
1135 {
Ritor1
parents:
diff changeset
1136 pItems[v24].uSkillType = 3;
Ritor1
parents:
diff changeset
1137 }
Ritor1
parents:
diff changeset
1138 }
Ritor1
parents:
diff changeset
1139 else
Ritor1
parents:
diff changeset
1140 {
Ritor1
parents:
diff changeset
1141 pItems[v24].uSkillType = 2;
Ritor1
parents:
diff changeset
1142 }
Ritor1
parents:
diff changeset
1143 }
Ritor1
parents:
diff changeset
1144 else
Ritor1
parents:
diff changeset
1145 {
Ritor1
parents:
diff changeset
1146 pItems[v24].uSkillType = 1;
Ritor1
parents:
diff changeset
1147 }
Ritor1
parents:
diff changeset
1148 }
Ritor1
parents:
diff changeset
1149 else
Ritor1
parents:
diff changeset
1150 {
Ritor1
parents:
diff changeset
1151 pItems[v24].uSkillType = 0;
Ritor1
parents:
diff changeset
1152 }
Ritor1
parents:
diff changeset
1153 break;
Ritor1
parents:
diff changeset
1154 case 6:
Ritor1
parents:
diff changeset
1155 Stre = 0;
Ritor1
parents:
diff changeset
1156 v84 = strlen(v25);
Ritor1
parents:
diff changeset
1157 if ( (signed int)v84 > 0 )
Ritor1
parents:
diff changeset
1158 {
Ritor1
parents:
diff changeset
1159 while ( tolower((unsigned __int8)v25[Stre]) != 'd' )
Ritor1
parents:
diff changeset
1160 {
Ritor1
parents:
diff changeset
1161 ++Stre;
Ritor1
parents:
diff changeset
1162 if ( Stre >= (signed int)v84 )
Ritor1
parents:
diff changeset
1163 goto LABEL_161;
Ritor1
parents:
diff changeset
1164 }
Ritor1
parents:
diff changeset
1165 v25[Stre] = 0;
Ritor1
parents:
diff changeset
1166 v28 = (char *)&pItems[v24];
Ritor1
parents:
diff changeset
1167 v28[34] = atoi(v25);
Ritor1
parents:
diff changeset
1168 v28[35] = atoi(&v25[Stre + 1]);
Ritor1
parents:
diff changeset
1169 v25[Stre] = 'd';
Ritor1
parents:
diff changeset
1170 }
Ritor1
parents:
diff changeset
1171 LABEL_161:
Ritor1
parents:
diff changeset
1172 if ( Stre == v84 && tolower((unsigned __int8)*v25) != 115 )
Ritor1
parents:
diff changeset
1173 {
Ritor1
parents:
diff changeset
1174 v29 = (char *)&pItems[v24];
Ritor1
parents:
diff changeset
1175 v29[34] = atoi(v25);
Ritor1
parents:
diff changeset
1176 v29[35] = 1;
Ritor1
parents:
diff changeset
1177 }
Ritor1
parents:
diff changeset
1178 break;
Ritor1
parents:
diff changeset
1179 case 7:
Ritor1
parents:
diff changeset
1180 pItems[v24].uDamageMod = atoi(v25);
Ritor1
parents:
diff changeset
1181 break;
Ritor1
parents:
diff changeset
1182 case 8:
Ritor1
parents:
diff changeset
1183 if ( _strcmpi(v25, "artifact") )
Ritor1
parents:
diff changeset
1184 {
Ritor1
parents:
diff changeset
1185 if ( _strcmpi(v25, "relic") )
Ritor1
parents:
diff changeset
1186 {
Ritor1
parents:
diff changeset
1187 if ( _strcmpi(v25, "special") )
Ritor1
parents:
diff changeset
1188 pItems[v24].uMaterial = 0;
Ritor1
parents:
diff changeset
1189 else
Ritor1
parents:
diff changeset
1190 pItems[v24].uMaterial = 3;
Ritor1
parents:
diff changeset
1191 }
Ritor1
parents:
diff changeset
1192 else
Ritor1
parents:
diff changeset
1193 {
Ritor1
parents:
diff changeset
1194 pItems[v24].uMaterial = 2;
Ritor1
parents:
diff changeset
1195 }
Ritor1
parents:
diff changeset
1196 }
Ritor1
parents:
diff changeset
1197 else
Ritor1
parents:
diff changeset
1198 {
Ritor1
parents:
diff changeset
1199 pItems[v24].uMaterial = 1;
Ritor1
parents:
diff changeset
1200 }
Ritor1
parents:
diff changeset
1201 break;
Ritor1
parents:
diff changeset
1202 case 9:
Ritor1
parents:
diff changeset
1203 BYTE2(pItems[v24 + 1].uItemID) = atoi(v25);
Ritor1
parents:
diff changeset
1204 break;
Ritor1
parents:
diff changeset
1205 case 10:
Ritor1
parents:
diff changeset
1206 pItems[v24].pUnidentifiedName = (char *)RemoveQuotes(v25);
Ritor1
parents:
diff changeset
1207 break;
Ritor1
parents:
diff changeset
1208 case 11:
Ritor1
parents:
diff changeset
1209 pItems[v24].uSpriteID = atoi(v25);
Ritor1
parents:
diff changeset
1210 break;
Ritor1
parents:
diff changeset
1211 case 12:
Ritor1
parents:
diff changeset
1212 v30 = (char *)&pItems[v24];
Ritor1
parents:
diff changeset
1213 v81 = v30;
Ritor1
parents:
diff changeset
1214 if ( v30[37] == 3 )
Ritor1
parents:
diff changeset
1215 {
Ritor1
parents:
diff changeset
1216 v85 = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1217 Strf = (const char **)&pEnchantments[0].pOfName;
0
Ritor1
parents:
diff changeset
1218 while ( _strcmpi(*Strf, v25) )
Ritor1
parents:
diff changeset
1219 {
Ritor1
parents:
diff changeset
1220 ++v85;
Ritor1
parents:
diff changeset
1221 Strf += 5;
Ritor1
parents:
diff changeset
1222 if ( v85 >= 24 )
Ritor1
parents:
diff changeset
1223 goto LABEL_181;
Ritor1
parents:
diff changeset
1224 }
Ritor1
parents:
diff changeset
1225 v81[39] = v85 + 1;
Ritor1
parents:
diff changeset
1226 LABEL_181:
Ritor1
parents:
diff changeset
1227 if ( !v81[39] )
Ritor1
parents:
diff changeset
1228 {
Ritor1
parents:
diff changeset
1229 v86 = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1230 Strg = (const char **)&pSpecialEnchantments[0].pNameAdd;
0
Ritor1
parents:
diff changeset
1231 while ( _strcmpi(*Strg, v25) )
Ritor1
parents:
diff changeset
1232 {
Ritor1
parents:
diff changeset
1233 ++v86;
Ritor1
parents:
diff changeset
1234 Strg += 7;
Ritor1
parents:
diff changeset
1235 if ( v86 >= 72 )
Ritor1
parents:
diff changeset
1236 goto LABEL_196;
Ritor1
parents:
diff changeset
1237 }
Ritor1
parents:
diff changeset
1238 v81[38] = v86 + 1;
Ritor1
parents:
diff changeset
1239 }
Ritor1
parents:
diff changeset
1240 }
Ritor1
parents:
diff changeset
1241 else
Ritor1
parents:
diff changeset
1242 {
Ritor1
parents:
diff changeset
1243 v30[38] = 0;
Ritor1
parents:
diff changeset
1244 v30[39] = 0;
Ritor1
parents:
diff changeset
1245 }
Ritor1
parents:
diff changeset
1246 break;
Ritor1
parents:
diff changeset
1247 case 13:
Ritor1
parents:
diff changeset
1248 v31 = (char *)&pItems[v24];
Ritor1
parents:
diff changeset
1249 v82 = v31;
Ritor1
parents:
diff changeset
1250 if ( v31[37] == 3 && v31[39] )
Ritor1
parents:
diff changeset
1251 {
Ritor1
parents:
diff changeset
1252 v32 = atoi(v25);
Ritor1
parents:
diff changeset
1253 v82[40] = v32;
Ritor1
parents:
diff changeset
1254 if ( !v32 )
Ritor1
parents:
diff changeset
1255 v82[40] = 1;
Ritor1
parents:
diff changeset
1256 }
Ritor1
parents:
diff changeset
1257 else
Ritor1
parents:
diff changeset
1258 {
Ritor1
parents:
diff changeset
1259 v31[40] = 0;
Ritor1
parents:
diff changeset
1260 }
Ritor1
parents:
diff changeset
1261 break;
Ritor1
parents:
diff changeset
1262 case 14:
Ritor1
parents:
diff changeset
1263 pItems[v24].uEquipX = atoi(v25);
Ritor1
parents:
diff changeset
1264 break;
Ritor1
parents:
diff changeset
1265 case 15:
Ritor1
parents:
diff changeset
1266 pItems[v24].uEquipY = atoi(v25);
Ritor1
parents:
diff changeset
1267 break;
Ritor1
parents:
diff changeset
1268 case 16:
Ritor1
parents:
diff changeset
1269 pItems[v24].pDescription = (char *)RemoveQuotes(v25);
Ritor1
parents:
diff changeset
1270 break;
Ritor1
parents:
diff changeset
1271 default:
Ritor1
parents:
diff changeset
1272 break;
Ritor1
parents:
diff changeset
1273 }
Ritor1
parents:
diff changeset
1274 }
Ritor1
parents:
diff changeset
1275 LABEL_196:
Ritor1
parents:
diff changeset
1276 ++v100;
Ritor1
parents:
diff changeset
1277 v25 = (char *)(v75 + 1);
Ritor1
parents:
diff changeset
1278 if ( v100 <= 16 && !v91 )
Ritor1
parents:
diff changeset
1279 continue;
Ritor1
parents:
diff changeset
1280 break;
Ritor1
parents:
diff changeset
1281 }
Ritor1
parents:
diff changeset
1282 ++v24;
Ritor1
parents:
diff changeset
1283 if ( v24 < 800 )
Ritor1
parents:
diff changeset
1284 continue;
Ritor1
parents:
diff changeset
1285 break;
Ritor1
parents:
diff changeset
1286 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1287 */
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1288
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1289 pRndItemsTXT_Raw = NULL;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1290 uAllItemsCount = item_counter;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1291 pRndItemsTXT_Raw = (char *)pEvents_LOD->LoadRaw("rnditems.txt", 0);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1292 strtok(pRndItemsTXT_Raw, "\r");
0
Ritor1
parents:
diff changeset
1293 strtok(0, "\r");
Ritor1
parents:
diff changeset
1294 strtok(0, "\r");
Ritor1
parents:
diff changeset
1295 strtok(0, "\r");
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1296
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1297 v35 = 0;
0
Ritor1
parents:
diff changeset
1298 do
Ritor1
parents:
diff changeset
1299 {
Ritor1
parents:
diff changeset
1300 v101 = 0;
Ritor1
parents:
diff changeset
1301 v36 = strtok(0, "\r") + 1;
Ritor1
parents:
diff changeset
1302 v92 = 0;
Ritor1
parents:
diff changeset
1303 do
Ritor1
parents:
diff changeset
1304 {
Ritor1
parents:
diff changeset
1305 v37 = *v36;
Ritor1
parents:
diff changeset
1306 v38 = 0;
Ritor1
parents:
diff changeset
1307 while ( v37 != 9 && v37 )
Ritor1
parents:
diff changeset
1308 {
Ritor1
parents:
diff changeset
1309 ++v38;
Ritor1
parents:
diff changeset
1310 v37 = v36[v38];
Ritor1
parents:
diff changeset
1311 }
Ritor1
parents:
diff changeset
1312 v76 = (int)&v36[v38];
Ritor1
parents:
diff changeset
1313 if ( !v36[v38] )
Ritor1
parents:
diff changeset
1314 v92 = 1;
Ritor1
parents:
diff changeset
1315 *(unsigned char *)v76 = 0;
Ritor1
parents:
diff changeset
1316 if ( v38 )
Ritor1
parents:
diff changeset
1317 {
Ritor1
parents:
diff changeset
1318 if ( v101 )
Ritor1
parents:
diff changeset
1319 {
Ritor1
parents:
diff changeset
1320 switch ( v101 )
Ritor1
parents:
diff changeset
1321 {
Ritor1
parents:
diff changeset
1322 case 2:
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1323 // pItems[v35].field_2C = atoi(v36);
0
Ritor1
parents:
diff changeset
1324 break;
Ritor1
parents:
diff changeset
1325 case 3:
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1326 // pItems[v35].field_2D = atoi(v36);
0
Ritor1
parents:
diff changeset
1327 break;
Ritor1
parents:
diff changeset
1328 case 4:
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1329 // pItems[v35].field_2E = atoi(v36);
0
Ritor1
parents:
diff changeset
1330 break;
Ritor1
parents:
diff changeset
1331 case 5:
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1332 // pItems[v35].field_2F = atoi(v36);
0
Ritor1
parents:
diff changeset
1333 break;
Ritor1
parents:
diff changeset
1334 case 6:
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1335 //*((unsigned char *)&pItems[0].uItemID + 16 * (3 * v35 + 3)) = atoi(v36);
0
Ritor1
parents:
diff changeset
1336 break;
Ritor1
parents:
diff changeset
1337 case 7:
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1338 // BYTE1(pItems[v35 + 1].uItemID) = atoi(v36);
0
Ritor1
parents:
diff changeset
1339 break;
Ritor1
parents:
diff changeset
1340 }
Ritor1
parents:
diff changeset
1341 }
Ritor1
parents:
diff changeset
1342 else
Ritor1
parents:
diff changeset
1343 {
Ritor1
parents:
diff changeset
1344 v35 = atoi(v36);
Ritor1
parents:
diff changeset
1345 }
Ritor1
parents:
diff changeset
1346 }
Ritor1
parents:
diff changeset
1347 else
Ritor1
parents:
diff changeset
1348 {
Ritor1
parents:
diff changeset
1349 if ( !v101 )
Ritor1
parents:
diff changeset
1350 v92 = 1;
Ritor1
parents:
diff changeset
1351 }
Ritor1
parents:
diff changeset
1352 ++v101;
Ritor1
parents:
diff changeset
1353 v36 = (char *)(v76 + 1);
Ritor1
parents:
diff changeset
1354 }
Ritor1
parents:
diff changeset
1355 while ( v101 <= 7 && !v92 );
Ritor1
parents:
diff changeset
1356 ++v35;
Ritor1
parents:
diff changeset
1357 }
Ritor1
parents:
diff changeset
1358 while ( v35 < 619 );
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1359
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1360
0
Ritor1
parents:
diff changeset
1361 if ( pRndItemsTXT_Raw )
Ritor1
parents:
diff changeset
1362 {
Ritor1
parents:
diff changeset
1363 pAllocator->FreeChunk(pRndItemsTXT_Raw);
Ritor1
parents:
diff changeset
1364 pRndItemsTXT_Raw = 0;
Ritor1
parents:
diff changeset
1365 }
Ritor1
parents:
diff changeset
1366 v39 = (char *)field_11684;
Ritor1
parents:
diff changeset
1367 memset(field_11684, 0, 0x18u);
Ritor1
parents:
diff changeset
1368 v40 = &pItems[0].field_2C;
Ritor1
parents:
diff changeset
1369 v77 = 6;
Ritor1
parents:
diff changeset
1370 do
Ritor1
parents:
diff changeset
1371 {
Ritor1
parents:
diff changeset
1372 v41 = v40;
Ritor1
parents:
diff changeset
1373 Strh = 800;
Ritor1
parents:
diff changeset
1374 do
Ritor1
parents:
diff changeset
1375 {
Ritor1
parents:
diff changeset
1376 *(unsigned int *)v39 += (unsigned __int8)*v41;
Ritor1
parents:
diff changeset
1377 v41 += 48;
Ritor1
parents:
diff changeset
1378 --Strh;
Ritor1
parents:
diff changeset
1379 }
Ritor1
parents:
diff changeset
1380 while ( Strh );
Ritor1
parents:
diff changeset
1381 v39 += 4;
Ritor1
parents:
diff changeset
1382 ++v40;
Ritor1
parents:
diff changeset
1383 --v77;
Ritor1
parents:
diff changeset
1384 }
Ritor1
parents:
diff changeset
1385 while ( v77 );
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1386
0
Ritor1
parents:
diff changeset
1387 v42 = 0;
Ritor1
parents:
diff changeset
1388 strtok(0, "\r");
Ritor1
parents:
diff changeset
1389 strtok(0, "\r");
Ritor1
parents:
diff changeset
1390 strtok(0, "\r");
Ritor1
parents:
diff changeset
1391 strtok(0, "\r");
Ritor1
parents:
diff changeset
1392 strtok(0, "\r");
Ritor1
parents:
diff changeset
1393 v87 = 0;
Ritor1
parents:
diff changeset
1394 do
Ritor1
parents:
diff changeset
1395 {
Ritor1
parents:
diff changeset
1396 v43 = strtok(v42, "\r") + 1;
Ritor1
parents:
diff changeset
1397 v102 = (signed int)v42;
Ritor1
parents:
diff changeset
1398 v93 = (signed int)v42;
Ritor1
parents:
diff changeset
1399 do
Ritor1
parents:
diff changeset
1400 {
Ritor1
parents:
diff changeset
1401 v44 = *v43;
Ritor1
parents:
diff changeset
1402 v45 = 0;
Ritor1
parents:
diff changeset
1403 while ( v44 != 9 && v44 )
Ritor1
parents:
diff changeset
1404 {
Ritor1
parents:
diff changeset
1405 ++v45;
Ritor1
parents:
diff changeset
1406 v44 = v43[v45];
Ritor1
parents:
diff changeset
1407 }
Ritor1
parents:
diff changeset
1408 v78 = (int)&v43[v45];
Ritor1
parents:
diff changeset
1409 if ( !v43[v45] )
Ritor1
parents:
diff changeset
1410 v93 = 1;
Ritor1
parents:
diff changeset
1411 v42 = 0;
Ritor1
parents:
diff changeset
1412 *(unsigned char *)v78 = 0;
Ritor1
parents:
diff changeset
1413 if ( v45 )
Ritor1
parents:
diff changeset
1414 {
Ritor1
parents:
diff changeset
1415 switch ( v102 )
Ritor1
parents:
diff changeset
1416 {
Ritor1
parents:
diff changeset
1417 case 2:
Ritor1
parents:
diff changeset
1418 if ( v87 )
Ritor1
parents:
diff changeset
1419 {
Ritor1
parents:
diff changeset
1420 if ( v87 == 1 )
Ritor1
parents:
diff changeset
1421 {
Ritor1
parents:
diff changeset
1422 *(unsigned int *)&field_1169C[24] = atoi(v43);
Ritor1
parents:
diff changeset
1423 }
Ritor1
parents:
diff changeset
1424 else
Ritor1
parents:
diff changeset
1425 {
Ritor1
parents:
diff changeset
1426 if ( v87 == 2 )
Ritor1
parents:
diff changeset
1427 *(unsigned int *)&field_1169C[48] = atoi(v43);
Ritor1
parents:
diff changeset
1428 }
Ritor1
parents:
diff changeset
1429 }
Ritor1
parents:
diff changeset
1430 else
Ritor1
parents:
diff changeset
1431 {
Ritor1
parents:
diff changeset
1432 *(unsigned int *)&field_1169C[0] = atoi(v43);
Ritor1
parents:
diff changeset
1433 }
Ritor1
parents:
diff changeset
1434 break;
Ritor1
parents:
diff changeset
1435 case 3:
Ritor1
parents:
diff changeset
1436 if ( v87 )
Ritor1
parents:
diff changeset
1437 {
Ritor1
parents:
diff changeset
1438 if ( v87 == 1 )
Ritor1
parents:
diff changeset
1439 {
Ritor1
parents:
diff changeset
1440 *(unsigned int *)&field_1169C[28] = atoi(v43);
Ritor1
parents:
diff changeset
1441 }
Ritor1
parents:
diff changeset
1442 else
Ritor1
parents:
diff changeset
1443 {
Ritor1
parents:
diff changeset
1444 if ( v87 == 2 )
Ritor1
parents:
diff changeset
1445 *(unsigned int *)&field_1169C[52] = atoi(v43);
Ritor1
parents:
diff changeset
1446 }
Ritor1
parents:
diff changeset
1447 }
Ritor1
parents:
diff changeset
1448 else
Ritor1
parents:
diff changeset
1449 {
Ritor1
parents:
diff changeset
1450 *(unsigned int *)&field_1169C[4] = atoi(v43);
Ritor1
parents:
diff changeset
1451 }
Ritor1
parents:
diff changeset
1452 break;
Ritor1
parents:
diff changeset
1453 case 4:
Ritor1
parents:
diff changeset
1454 if ( v87 )
Ritor1
parents:
diff changeset
1455 {
Ritor1
parents:
diff changeset
1456 if ( v87 == 1 )
Ritor1
parents:
diff changeset
1457 {
Ritor1
parents:
diff changeset
1458 *(unsigned int *)&field_1169C[32] = atoi(v43);
Ritor1
parents:
diff changeset
1459 }
Ritor1
parents:
diff changeset
1460 else
Ritor1
parents:
diff changeset
1461 {
Ritor1
parents:
diff changeset
1462 if ( v87 == 2 )
Ritor1
parents:
diff changeset
1463 *(unsigned int *)&field_1169C[56] = atoi(v43);
Ritor1
parents:
diff changeset
1464 }
Ritor1
parents:
diff changeset
1465 }
Ritor1
parents:
diff changeset
1466 else
Ritor1
parents:
diff changeset
1467 {
Ritor1
parents:
diff changeset
1468 *(unsigned int *)&field_1169C[8] = atoi(v43);
Ritor1
parents:
diff changeset
1469 }
Ritor1
parents:
diff changeset
1470 break;
Ritor1
parents:
diff changeset
1471 case 5:
Ritor1
parents:
diff changeset
1472 if ( v87 )
Ritor1
parents:
diff changeset
1473 {
Ritor1
parents:
diff changeset
1474 if ( v87 == 1 )
Ritor1
parents:
diff changeset
1475 {
Ritor1
parents:
diff changeset
1476 *(unsigned int *)&field_1169C[36] = atoi(v43);
Ritor1
parents:
diff changeset
1477 }
Ritor1
parents:
diff changeset
1478 else
Ritor1
parents:
diff changeset
1479 {
Ritor1
parents:
diff changeset
1480 if ( v87 == 2 )
Ritor1
parents:
diff changeset
1481 field_116D8[0] = atoi(v43);
Ritor1
parents:
diff changeset
1482 }
Ritor1
parents:
diff changeset
1483 }
Ritor1
parents:
diff changeset
1484 else
Ritor1
parents:
diff changeset
1485 {
Ritor1
parents:
diff changeset
1486 *(unsigned int *)&field_1169C[12] = atoi(v43);
Ritor1
parents:
diff changeset
1487 }
Ritor1
parents:
diff changeset
1488 break;
Ritor1
parents:
diff changeset
1489 case 6:
Ritor1
parents:
diff changeset
1490 if ( v87 )
Ritor1
parents:
diff changeset
1491 {
Ritor1
parents:
diff changeset
1492 if ( v87 == 1 )
Ritor1
parents:
diff changeset
1493 {
Ritor1
parents:
diff changeset
1494 *(unsigned int *)&field_1169C[40] = atoi(v43);
Ritor1
parents:
diff changeset
1495 }
Ritor1
parents:
diff changeset
1496 else
Ritor1
parents:
diff changeset
1497 {
Ritor1
parents:
diff changeset
1498 if ( v87 == 2 )
Ritor1
parents:
diff changeset
1499 field_116D8[1] = atoi(v43);
Ritor1
parents:
diff changeset
1500 }
Ritor1
parents:
diff changeset
1501 }
Ritor1
parents:
diff changeset
1502 else
Ritor1
parents:
diff changeset
1503 {
Ritor1
parents:
diff changeset
1504 *(unsigned int *)&field_1169C[16] = atoi(v43);
Ritor1
parents:
diff changeset
1505 }
Ritor1
parents:
diff changeset
1506 break;
Ritor1
parents:
diff changeset
1507 case 7:
Ritor1
parents:
diff changeset
1508 if ( v87 )
Ritor1
parents:
diff changeset
1509 {
Ritor1
parents:
diff changeset
1510 if ( v87 == 1 )
Ritor1
parents:
diff changeset
1511 {
Ritor1
parents:
diff changeset
1512 *(unsigned int *)&field_1169C[44] = atoi(v43);
Ritor1
parents:
diff changeset
1513 }
Ritor1
parents:
diff changeset
1514 else
Ritor1
parents:
diff changeset
1515 {
Ritor1
parents:
diff changeset
1516 if ( v87 == 2 )
Ritor1
parents:
diff changeset
1517 field_116D8[2] = atoi(v43);
Ritor1
parents:
diff changeset
1518 }
Ritor1
parents:
diff changeset
1519 }
Ritor1
parents:
diff changeset
1520 else
Ritor1
parents:
diff changeset
1521 {
Ritor1
parents:
diff changeset
1522 *(unsigned int *)&field_1169C[20] = atoi(v43);
Ritor1
parents:
diff changeset
1523 }
Ritor1
parents:
diff changeset
1524 break;
Ritor1
parents:
diff changeset
1525 }
Ritor1
parents:
diff changeset
1526 }
Ritor1
parents:
diff changeset
1527 ++v102;
Ritor1
parents:
diff changeset
1528 v43 = (char *)(v78 + 1);
Ritor1
parents:
diff changeset
1529 }
Ritor1
parents:
diff changeset
1530 while ( v102 <= 7 && !v93 );
Ritor1
parents:
diff changeset
1531 ++v87;
Ritor1
parents:
diff changeset
1532 }
Ritor1
parents:
diff changeset
1533 while ( v87 < 3 );
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1534
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1535
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1536
0
Ritor1
parents:
diff changeset
1537 pSkillDescTXT_Raw = 0;
Ritor1
parents:
diff changeset
1538 pSkillDescTXT_Raw = (char *)pEvents_LOD->LoadRaw("skilldes.txt", 0);
Ritor1
parents:
diff changeset
1539 strtok(pSkillDescTXT_Raw, "\r");
Ritor1
parents:
diff changeset
1540 v46 = 0;
Ritor1
parents:
diff changeset
1541 do
Ritor1
parents:
diff changeset
1542 {
Ritor1
parents:
diff changeset
1543 v103 = 0;
Ritor1
parents:
diff changeset
1544 v94 = 0;
Ritor1
parents:
diff changeset
1545 v47 = strtok(0, "\r") + 1;
Ritor1
parents:
diff changeset
1546 do
Ritor1
parents:
diff changeset
1547 {
Ritor1
parents:
diff changeset
1548 v48 = *v47;
Ritor1
parents:
diff changeset
1549 v49 = 0;
Ritor1
parents:
diff changeset
1550 while ( v48 != 9 && v48 )
Ritor1
parents:
diff changeset
1551 {
Ritor1
parents:
diff changeset
1552 ++v49;
Ritor1
parents:
diff changeset
1553 v48 = v47[v49];
Ritor1
parents:
diff changeset
1554 }
Ritor1
parents:
diff changeset
1555 v50 = (int)&v47[v49];
Ritor1
parents:
diff changeset
1556 if ( !v47[v49] )
Ritor1
parents:
diff changeset
1557 v94 = 1;
Ritor1
parents:
diff changeset
1558 *(unsigned char *)v50 = 0;
Ritor1
parents:
diff changeset
1559 if ( v49 )
Ritor1
parents:
diff changeset
1560 {
Ritor1
parents:
diff changeset
1561 switch ( v103 )
Ritor1
parents:
diff changeset
1562 {
Ritor1
parents:
diff changeset
1563 case 1:
Ritor1
parents:
diff changeset
1564 pSkillDesc[v46] = (char *)RemoveQuotes(v47);
Ritor1
parents:
diff changeset
1565 break;
Ritor1
parents:
diff changeset
1566 case 2:
Ritor1
parents:
diff changeset
1567 pNormalSkillDesc[v46] = (char *)RemoveQuotes(v47);
Ritor1
parents:
diff changeset
1568 break;
Ritor1
parents:
diff changeset
1569 case 3:
Ritor1
parents:
diff changeset
1570 pExpertSkillDesc[v46] = (char *)RemoveQuotes(v47);
Ritor1
parents:
diff changeset
1571 break;
Ritor1
parents:
diff changeset
1572 case 4:
Ritor1
parents:
diff changeset
1573 pMasterSkillDesc[v46] = (char *)RemoveQuotes(v47);
Ritor1
parents:
diff changeset
1574 break;
Ritor1
parents:
diff changeset
1575 case 5:
Ritor1
parents:
diff changeset
1576 pGrandSkillDesc[v46] = (char *)RemoveQuotes(v47);
Ritor1
parents:
diff changeset
1577 break;
Ritor1
parents:
diff changeset
1578 }
Ritor1
parents:
diff changeset
1579 }
Ritor1
parents:
diff changeset
1580 else
Ritor1
parents:
diff changeset
1581 {
Ritor1
parents:
diff changeset
1582 if ( !v103 )
Ritor1
parents:
diff changeset
1583 v94 = 1;
Ritor1
parents:
diff changeset
1584 }
Ritor1
parents:
diff changeset
1585 ++v103;
Ritor1
parents:
diff changeset
1586 v47 = (char *)(v50 + 1);
Ritor1
parents:
diff changeset
1587 }
Ritor1
parents:
diff changeset
1588 while ( v103 <= 5 && !v94 );
Ritor1
parents:
diff changeset
1589 ++v46;
Ritor1
parents:
diff changeset
1590 }
Ritor1
parents:
diff changeset
1591 while ( v46 < 37 );
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1592
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1593
0
Ritor1
parents:
diff changeset
1594 pStatsTXT_Raw = 0;
Ritor1
parents:
diff changeset
1595 pStatsTXT_Raw = (char *)pEvents_LOD->LoadRaw("stats.txt", 0);
Ritor1
parents:
diff changeset
1596 strtok(pStatsTXT_Raw, "\r");
Ritor1
parents:
diff changeset
1597 Stri = 0;
Ritor1
parents:
diff changeset
1598 do
Ritor1
parents:
diff changeset
1599 {
Ritor1
parents:
diff changeset
1600 v51 = 0;
Ritor1
parents:
diff changeset
1601 v95 = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1602 v52 = strtok(0, pStatsTXT_Raw) + 1;
0
Ritor1
parents:
diff changeset
1603 do
Ritor1
parents:
diff changeset
1604 {
Ritor1
parents:
diff changeset
1605 v53 = *v52;
Ritor1
parents:
diff changeset
1606 v54 = 0;
Ritor1
parents:
diff changeset
1607 if ( *v52 != 9 )
Ritor1
parents:
diff changeset
1608 {
Ritor1
parents:
diff changeset
1609 do
Ritor1
parents:
diff changeset
1610 {
Ritor1
parents:
diff changeset
1611 if ( !v53 )
Ritor1
parents:
diff changeset
1612 break;
Ritor1
parents:
diff changeset
1613 ++v54;
Ritor1
parents:
diff changeset
1614 v53 = v52[v54];
Ritor1
parents:
diff changeset
1615 }
Ritor1
parents:
diff changeset
1616 while ( v53 != 9 );
Ritor1
parents:
diff changeset
1617 v34 = "\r";
Ritor1
parents:
diff changeset
1618 }
Ritor1
parents:
diff changeset
1619 v55 = (int)&v52[v54];
Ritor1
parents:
diff changeset
1620 if ( !v52[v54] )
Ritor1
parents:
diff changeset
1621 v95 = 1;
Ritor1
parents:
diff changeset
1622 *(unsigned char *)v55 = 0;
Ritor1
parents:
diff changeset
1623 if ( v54 )
Ritor1
parents:
diff changeset
1624 {
Ritor1
parents:
diff changeset
1625 if ( v51 )
Ritor1
parents:
diff changeset
1626 {
Ritor1
parents:
diff changeset
1627 switch ( Stri )
Ritor1
parents:
diff changeset
1628 {
Ritor1
parents:
diff changeset
1629 case 0:
Ritor1
parents:
diff changeset
1630 case 1:
Ritor1
parents:
diff changeset
1631 case 2:
Ritor1
parents:
diff changeset
1632 case 3:
Ritor1
parents:
diff changeset
1633 case 4:
Ritor1
parents:
diff changeset
1634 case 5:
Ritor1
parents:
diff changeset
1635 case 6:
Ritor1
parents:
diff changeset
1636 pAttributeDescriptions[Stri] = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1637 break;
Ritor1
parents:
diff changeset
1638 case 7:
Ritor1
parents:
diff changeset
1639 pHealthPointsAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1640 break;
Ritor1
parents:
diff changeset
1641 case 8:
Ritor1
parents:
diff changeset
1642 pArmourClassAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1643 break;
Ritor1
parents:
diff changeset
1644 case 9:
Ritor1
parents:
diff changeset
1645 pSpellPointsAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1646 break;
Ritor1
parents:
diff changeset
1647 case 10:
Ritor1
parents:
diff changeset
1648 pPlayerConditionAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1649 break;
Ritor1
parents:
diff changeset
1650 case 11:
Ritor1
parents:
diff changeset
1651 pFastSpellAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1652 break;
Ritor1
parents:
diff changeset
1653 case 12:
Ritor1
parents:
diff changeset
1654 pPlayerAgeAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1655 break;
Ritor1
parents:
diff changeset
1656 case 13:
Ritor1
parents:
diff changeset
1657 pPlayerLevelAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1658 break;
Ritor1
parents:
diff changeset
1659 case 14:
Ritor1
parents:
diff changeset
1660 pPlayerExperienceAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1661 break;
Ritor1
parents:
diff changeset
1662 case 15:
Ritor1
parents:
diff changeset
1663 pAttackBonusAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1664 break;
Ritor1
parents:
diff changeset
1665 case 16:
Ritor1
parents:
diff changeset
1666 pAttackDamageAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1667 break;
Ritor1
parents:
diff changeset
1668 case 17:
Ritor1
parents:
diff changeset
1669 pMissleBonusAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1670 break;
Ritor1
parents:
diff changeset
1671 case 18:
Ritor1
parents:
diff changeset
1672 pMissleDamageAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1673 break;
Ritor1
parents:
diff changeset
1674 case 19:
Ritor1
parents:
diff changeset
1675 pFireResistanceAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1676 break;
Ritor1
parents:
diff changeset
1677 case 20:
Ritor1
parents:
diff changeset
1678 pAirResistanceAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1679 break;
Ritor1
parents:
diff changeset
1680 case 21:
Ritor1
parents:
diff changeset
1681 pWaterResistanceAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1682 break;
Ritor1
parents:
diff changeset
1683 case 22:
Ritor1
parents:
diff changeset
1684 pEarthResistanceAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1685 break;
Ritor1
parents:
diff changeset
1686 case 23:
Ritor1
parents:
diff changeset
1687 pMindResistanceAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1688 break;
Ritor1
parents:
diff changeset
1689 case 24:
Ritor1
parents:
diff changeset
1690 pBodyResistanceAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1691 break;
Ritor1
parents:
diff changeset
1692 case 25:
Ritor1
parents:
diff changeset
1693 pSkillPointsAttributeDescription = (char *)RemoveQuotes(v52);
Ritor1
parents:
diff changeset
1694 break;
Ritor1
parents:
diff changeset
1695 default:
Ritor1
parents:
diff changeset
1696 break;
Ritor1
parents:
diff changeset
1697 }
Ritor1
parents:
diff changeset
1698 }
Ritor1
parents:
diff changeset
1699 }
Ritor1
parents:
diff changeset
1700 else
Ritor1
parents:
diff changeset
1701 {
Ritor1
parents:
diff changeset
1702 if ( !v51 )
Ritor1
parents:
diff changeset
1703 v95 = 1;
Ritor1
parents:
diff changeset
1704 }
Ritor1
parents:
diff changeset
1705 ++v51;
Ritor1
parents:
diff changeset
1706 v52 = (char *)(v55 + 1);
Ritor1
parents:
diff changeset
1707 }
Ritor1
parents:
diff changeset
1708 while ( v51 < 2 && !v95 );
Ritor1
parents:
diff changeset
1709 ++Stri;
Ritor1
parents:
diff changeset
1710 }
Ritor1
parents:
diff changeset
1711 while ( Stri < 26 );
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1712
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1713
0
Ritor1
parents:
diff changeset
1714 pClassTXT_Raw = 0;
Ritor1
parents:
diff changeset
1715 pClassTXT_Raw = (char *)pEvents_LOD->LoadRaw("class.txt", 0);
Ritor1
parents:
diff changeset
1716 strtok(pClassTXT_Raw, v34);
Ritor1
parents:
diff changeset
1717 Strj = pClassDescriptions;
Ritor1
parents:
diff changeset
1718 do
Ritor1
parents:
diff changeset
1719 {
Ritor1
parents:
diff changeset
1720 v56 = 0;
Ritor1
parents:
diff changeset
1721 v57 = strtok(0, v34) + 1;
Ritor1
parents:
diff changeset
1722 v96 = 0;
Ritor1
parents:
diff changeset
1723 do
Ritor1
parents:
diff changeset
1724 {
Ritor1
parents:
diff changeset
1725 v58 = *v57;
Ritor1
parents:
diff changeset
1726 v59 = 0;
Ritor1
parents:
diff changeset
1727 if ( *v57 != 9 )
Ritor1
parents:
diff changeset
1728 {
Ritor1
parents:
diff changeset
1729 do
Ritor1
parents:
diff changeset
1730 {
Ritor1
parents:
diff changeset
1731 if ( !v58 )
Ritor1
parents:
diff changeset
1732 break;
Ritor1
parents:
diff changeset
1733 ++v59;
Ritor1
parents:
diff changeset
1734 v58 = v57[v59];
Ritor1
parents:
diff changeset
1735 }
Ritor1
parents:
diff changeset
1736 while ( v58 != 9 );
Ritor1
parents:
diff changeset
1737 v34 = "\r";
Ritor1
parents:
diff changeset
1738 }
Ritor1
parents:
diff changeset
1739 v60 = (int)&v57[v59];
Ritor1
parents:
diff changeset
1740 if ( !v57[v59] )
Ritor1
parents:
diff changeset
1741 v96 = 1;
Ritor1
parents:
diff changeset
1742 *(unsigned char *)v60 = 0;
Ritor1
parents:
diff changeset
1743 if ( v59 )
Ritor1
parents:
diff changeset
1744 {
Ritor1
parents:
diff changeset
1745 if ( v56 )
Ritor1
parents:
diff changeset
1746 *Strj = (char *)RemoveQuotes(v57);
Ritor1
parents:
diff changeset
1747 }
Ritor1
parents:
diff changeset
1748 else
Ritor1
parents:
diff changeset
1749 {
Ritor1
parents:
diff changeset
1750 if ( !v56 )
Ritor1
parents:
diff changeset
1751 v96 = 1;
Ritor1
parents:
diff changeset
1752 }
Ritor1
parents:
diff changeset
1753 ++v56;
Ritor1
parents:
diff changeset
1754 v57 = (char *)(v60 + 1);
Ritor1
parents:
diff changeset
1755 }
Ritor1
parents:
diff changeset
1756 while ( v56 < 2 && !v96 );
Ritor1
parents:
diff changeset
1757 ++Strj;
Ritor1
parents:
diff changeset
1758 }
Ritor1
parents:
diff changeset
1759 while ( (signed int)Strj <= (signed int)&pClassDescriptions[35] );
Ritor1
parents:
diff changeset
1760 }
Ritor1
parents:
diff changeset
1761
Ritor1
parents:
diff changeset
1762 //----- (00456D17) --------------------------------------------------------
Ritor1
parents:
diff changeset
1763 void ItemsTable::SetSpecialBonus(ItemGen *pItem)
Ritor1
parents:
diff changeset
1764 {
Ritor1
parents:
diff changeset
1765 ItemDesc *v2; // eax@1
Ritor1
parents:
diff changeset
1766
Ritor1
parents:
diff changeset
1767 v2 = &this->pItems[pItem->uItemID];
Ritor1
parents:
diff changeset
1768 if ( v2->uMaterial == 3 )
Ritor1
parents:
diff changeset
1769 {
Ritor1
parents:
diff changeset
1770 pItem->_bonus_type = v2->_bonus_type;
Ritor1
parents:
diff changeset
1771 pItem->uAdditionalValue = v2->_additional_value;
Ritor1
parents:
diff changeset
1772 pItem->_bonus_strength = v2->_bonus_strength;
Ritor1
parents:
diff changeset
1773 }
Ritor1
parents:
diff changeset
1774 }
Ritor1
parents:
diff changeset
1775
Ritor1
parents:
diff changeset
1776 //----- (00456D43) --------------------------------------------------------
Ritor1
parents:
diff changeset
1777 bool ItemsTable::_456D43_is_material_equals_3(ItemGen *pItem)
Ritor1
parents:
diff changeset
1778 {
Ritor1
parents:
diff changeset
1779 return this->pItems[pItem->uItemID].uMaterial == 3;
Ritor1
parents:
diff changeset
1780 }
Ritor1
parents:
diff changeset
1781
Ritor1
parents:
diff changeset
1782 //----- (00456D5E) --------------------------------------------------------
Ritor1
parents:
diff changeset
1783 bool ItemsTable::_456D5E_is_some_material(ItemGen *pItem)
Ritor1
parents:
diff changeset
1784 {
Ritor1
parents:
diff changeset
1785 unsigned __int8 v2; // al@1
Ritor1
parents:
diff changeset
1786
Ritor1
parents:
diff changeset
1787 v2 = this->pItems[pItem->uItemID].uMaterial;
Ritor1
parents:
diff changeset
1788 return v2 == 3 || v2 == 1 || v2 == 2;
Ritor1
parents:
diff changeset
1789 }
Ritor1
parents:
diff changeset
1790
Ritor1
parents:
diff changeset
1791
Ritor1
parents:
diff changeset
1792 //----- (00453B3C) --------------------------------------------------------
Ritor1
parents:
diff changeset
1793 void ItemsTable::LoadPotions()
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1794 {
0
Ritor1
parents:
diff changeset
1795
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1796 CHAR Text[90]; // [sp+Ch] [bp-6Ch]@26
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1797 char* test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1798 unsigned int uRow;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1799 unsigned int uColumn;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1800 unsigned __int8 potion_value;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1801
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1802 if ( pPotionsTXT_Raw )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1803 pAllocator->FreeChunk(pPotionsTXT_Raw);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1804 pPotionsTXT_Raw = NULL;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1805 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
1806 test_string = strtok(pPotionsTXT_Raw,"\t\r\n");
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1807 while ( 1 )
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1808 {
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1809 if ( !test_string )
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1810 {
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1811 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
1812 return;
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1813 }
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1814 if ( !strcmp(test_string, "222") )
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1815 break;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1816
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1817 test_string = strtok(NULL, "\t\r\n");
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1818 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1819 while ( 1 )
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1820 {
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1821 test_string = strtok(NULL, "\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1822
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1823 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1824 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1825 MessageBoxA(0, "Error Pre-Parsing Potion Table", "Load Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1826 return;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1827 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1828 if ( !strcmp(test_string, "222") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1829 break;
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1830 }
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1831
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1832 for (uRow = 0;uRow < 50; ++uRow)
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1833 {
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1834 int skip_count;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1835 for (skip_count = 0;skip_count < 6; ++skip_count)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1836 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1837 if ( !strtok(NULL, "\r\t\n") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1838 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1839 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1840 if ( skip_count != 6 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1841 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1842 for (uColumn = 0; uColumn < 50; ++uColumn)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1843 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1844 test_string = strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1845 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1846 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1847 potion_value = atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1848 char c=*test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1849 if ( !potion_value )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1850 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1851 if ( tolower(c) == 'e' )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1852 potion_value = atoi(test_string + 1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1853 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1854 potion_value = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1855 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1856 this->potion_data[uRow][uColumn]=potion_value;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1857 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1858 if ( uColumn != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1859 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1860 strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1861 }
193
821fd955c379 fixed potion data parsing. Somehow 3d render was affected
Gloval
parents: 189
diff changeset
1862
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1863 if ( uRow != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1864 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1865 wsprintfA(Text, "Error Parsing Potion Table at Row: %d Column: %d", uRow, uColumn);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1866 MessageBoxA(0, Text, "Parsing Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1867 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1868 if ( pPotionsTXT_Raw )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1869 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1870 pAllocator->FreeChunk(pPotionsTXT_Raw);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1871 pPotionsTXT_Raw = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1872 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1873 }
0
Ritor1
parents:
diff changeset
1874
Ritor1
parents:
diff changeset
1875 //----- (00453CE5) --------------------------------------------------------
Ritor1
parents:
diff changeset
1876 void ItemsTable::LoadPotionNotes()
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1877 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1878
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1879 CHAR Text[90];
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1880 char* test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1881 unsigned int uRow;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1882 unsigned int uColumn;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1883 unsigned __int8 potion_note;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1884
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1885 if ( pPotionNotesTXT_Raw )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1886 pAllocator->FreeChunk(pPotionNotesTXT_Raw);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1887 pPotionNotesTXT_Raw = NULL;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1888 pPotionNotesTXT_Raw = (char *)pEvents_LOD->LoadRaw("potnotes.txt", 0);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1889 test_string = strtok(pPotionNotesTXT_Raw ,"\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1890 while ( 1 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1891 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1892 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1893 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1894 MessageBoxA(0, "Error Pre-Parsing Potion Table", "Load Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1895 return;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1896 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1897 if ( !strcmp(test_string, "222") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1898 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1899 test_string = strtok(NULL, "\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1900 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1901 while ( 1 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1902 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1903 test_string = strtok(NULL, "\t\r\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1904
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1905 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1906 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1907 MessageBoxA(0, "Error Pre-Parsing Potion Table", "Load Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1908 return;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1909 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1910 if ( !strcmp(test_string, "222") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1911 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1912 }
0
Ritor1
parents:
diff changeset
1913
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1914 for (uRow = 0;uRow < 50; ++uRow)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1915 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1916 int skip_count;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1917 for (skip_count = 0;skip_count < 6; ++skip_count)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1918 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1919 if ( !strtok(NULL, "\r\t\n") )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1920 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1921 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1922 if ( skip_count != 6 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1923 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1924 for (uColumn = 0; uColumn < 50; ++uColumn)
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1925 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1926 test_string = strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1927 if ( !test_string )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1928 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1929 potion_note = atoi(test_string);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1930 char c=*test_string;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1931 if ( !potion_note )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1932 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1933 if ( tolower(c) == 'e' )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1934 potion_note = atoi(test_string + 1);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1935 else
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1936 potion_note = 0;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1937 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1938 this->potion_note[uRow][uColumn]=potion_note;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1939 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1940 if ( uColumn != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1941 break;
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1942 strtok(NULL, "\r\t\n");
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1943 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1944 if ( uRow != 50 )
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1945 {
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1946 wsprintfA(Text, "Error Parsing Potion Table at Row: %d Column: %d", uRow, uColumn);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1947 MessageBoxA(0, Text, "Parsing Error", MB_ICONHAND|MB_CANCELTRYCONTINUE);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1948 }
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1949 }
0
Ritor1
parents:
diff changeset
1950
Ritor1
parents:
diff changeset
1951
Ritor1
parents:
diff changeset
1952 //----- (00456442) --------------------------------------------------------
Ritor1
parents:
diff changeset
1953 unsigned int ItemGen::GetValue()
Ritor1
parents:
diff changeset
1954 {
Ritor1
parents:
diff changeset
1955 ItemGen *v1; // esi@1
Ritor1
parents:
diff changeset
1956 unsigned int uBaseValue; // edi@1
Ritor1
parents:
diff changeset
1957 int v3; // eax@4
Ritor1
parents:
diff changeset
1958 int v4; // esi@5
Ritor1
parents:
diff changeset
1959 unsigned int result; // eax@7
Ritor1
parents:
diff changeset
1960
Ritor1
parents:
diff changeset
1961 v1 = this;
Ritor1
parents:
diff changeset
1962 uBaseValue = pItemsTable->pItems[this->uItemID].uValue;
Ritor1
parents:
diff changeset
1963 if ( this->uAttributes & ITEM_TEMP_BONUS || pItemsTable->_456D5E_is_some_material(this) )
Ritor1
parents:
diff changeset
1964 goto LABEL_12;
Ritor1
parents:
diff changeset
1965 if ( v1->_bonus_type )
Ritor1
parents:
diff changeset
1966 {
Ritor1
parents:
diff changeset
1967 v3 = 100 * v1->_bonus_strength;
Ritor1
parents:
diff changeset
1968 return uBaseValue + v3;
Ritor1
parents:
diff changeset
1969 }
Ritor1
parents:
diff changeset
1970 v4 = v1->uAdditionalValue;
Ritor1
parents:
diff changeset
1971 if ( !v4 )
Ritor1
parents:
diff changeset
1972 {
Ritor1
parents:
diff changeset
1973 LABEL_12:
Ritor1
parents:
diff changeset
1974 result = uBaseValue;
Ritor1
parents:
diff changeset
1975 }
Ritor1
parents:
diff changeset
1976 else
Ritor1
parents:
diff changeset
1977 {
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
1978 v3 = *(unsigned int *)&pItemsTable->pEnchantments[23].to_item[28 * v4 + 8];
0
Ritor1
parents:
diff changeset
1979 if ( (unsigned int)v3 > 0xA )
Ritor1
parents:
diff changeset
1980 return uBaseValue + v3;
Ritor1
parents:
diff changeset
1981 result = uBaseValue * v3;
Ritor1
parents:
diff changeset
1982 }
Ritor1
parents:
diff changeset
1983 return result;
Ritor1
parents:
diff changeset
1984 }
Ritor1
parents:
diff changeset
1985
Ritor1
parents:
diff changeset
1986 //----- (00456499) --------------------------------------------------------
Ritor1
parents:
diff changeset
1987 const char *ItemGen::GetDisplayName()
Ritor1
parents:
diff changeset
1988 {
Ritor1
parents:
diff changeset
1989 const char *result; // eax@2
Ritor1
parents:
diff changeset
1990
Ritor1
parents:
diff changeset
1991 if ( this->uAttributes & ITEM_IDENTIFIED )
Ritor1
parents:
diff changeset
1992 result = GetIdentifiedName();
Ritor1
parents:
diff changeset
1993 else
Ritor1
parents:
diff changeset
1994 result = pItemsTable->pItems[uItemID].pUnidentifiedName;
Ritor1
parents:
diff changeset
1995 return result;
Ritor1
parents:
diff changeset
1996 }
Ritor1
parents:
diff changeset
1997
Ritor1
parents:
diff changeset
1998 //----- (004564B3) --------------------------------------------------------
Ritor1
parents:
diff changeset
1999 const char *ItemGen::GetIdentifiedName()
Ritor1
parents:
diff changeset
2000 {
Ritor1
parents:
diff changeset
2001 ItemGen *v1; // esi@1
Ritor1
parents:
diff changeset
2002 unsigned int v2; // eax@1
Ritor1
parents:
diff changeset
2003 unsigned __int8 v3; // cl@1
Ritor1
parents:
diff changeset
2004 char *v4; // edi@4
Ritor1
parents:
diff changeset
2005 char v5; // al@6
Ritor1
parents:
diff changeset
2006 const char *v6; // esi@8
Ritor1
parents:
diff changeset
2007 int v7; // eax@15
Ritor1
parents:
diff changeset
2008 const char *v9; // [sp-Ch] [bp-14h]@14
Ritor1
parents:
diff changeset
2009 const char *v10; // [sp-8h] [bp-10h]@4
Ritor1
parents:
diff changeset
2010 char *v11; // [sp-4h] [bp-Ch]@4
Ritor1
parents:
diff changeset
2011
Ritor1
parents:
diff changeset
2012 v1 = this;
Ritor1
parents:
diff changeset
2013 v2 = this->uItemID;
Ritor1
parents:
diff changeset
2014 v3 = pItemsTable->pItems[v2].uEquipType;
Ritor1
parents:
diff changeset
2015 if ( v3 >= EQUIP_REAGENT && (v3 <= EQUIP_POTION || v3 == EQUIP_GOLD) )
Ritor1
parents:
diff changeset
2016 {
Ritor1
parents:
diff changeset
2017 v11 = pItemsTable->pItems[v2].pName;
Ritor1
parents:
diff changeset
2018 v4 = item__getname_buffer;
Ritor1
parents:
diff changeset
2019 v10 = "%s";
Ritor1
parents:
diff changeset
2020 LABEL_10:
Ritor1
parents:
diff changeset
2021 sprintf(v4, v10, v11);
Ritor1
parents:
diff changeset
2022 return v4;
Ritor1
parents:
diff changeset
2023 }
Ritor1
parents:
diff changeset
2024 v4 = item__getname_buffer;
Ritor1
parents:
diff changeset
2025 sprintf(item__getname_buffer, "%s", pItemsTable->pItems[v2].pName);
Ritor1
parents:
diff changeset
2026 if ( v1->uItemID == 601 )
Ritor1
parents:
diff changeset
2027 {
Ritor1
parents:
diff changeset
2028 v5 = v1->field_1A;
Ritor1
parents:
diff changeset
2029 if ( (unsigned __int8)v5 >= 1u )
Ritor1
parents:
diff changeset
2030 {
Ritor1
parents:
diff changeset
2031 if ( (unsigned __int8)v5 <= 4u )
Ritor1
parents:
diff changeset
2032 {
Ritor1
parents:
diff changeset
2033 v6 = pPlayers[(unsigned __int8)v5]->pName;
Ritor1
parents:
diff changeset
2034 strlen(pPlayers[(unsigned __int8)v5]->pName);
Ritor1
parents:
diff changeset
2035 v11 = (char *)v6;
Ritor1
parents:
diff changeset
2036 if ( v6[strlen(v6) - 1] == 115 )
Ritor1
parents:
diff changeset
2037 v10 = pGlobalTXT_LocalizationStrings[655];
Ritor1
parents:
diff changeset
2038 else
Ritor1
parents:
diff changeset
2039 v10 = pGlobalTXT_LocalizationStrings[654];
Ritor1
parents:
diff changeset
2040 goto LABEL_10;
Ritor1
parents:
diff changeset
2041 }
Ritor1
parents:
diff changeset
2042 }
Ritor1
parents:
diff changeset
2043 }
Ritor1
parents:
diff changeset
2044 if ( !pItemsTable->_456D5E_is_some_material(v1) )
Ritor1
parents:
diff changeset
2045 {
Ritor1
parents:
diff changeset
2046 if ( v1->_bonus_type )
Ritor1
parents:
diff changeset
2047 {
Ritor1
parents:
diff changeset
2048 strcat(item__getname_buffer, " ");
Ritor1
parents:
diff changeset
2049 v9 = (const char *)*((unsigned int *)&pItemsTable->pItems[799].uEquipType + 5 * v1->_bonus_type);
Ritor1
parents:
diff changeset
2050 }
Ritor1
parents:
diff changeset
2051 else
Ritor1
parents:
diff changeset
2052 {
Ritor1
parents:
diff changeset
2053 v7 = v1->uAdditionalValue;
Ritor1
parents:
diff changeset
2054 if ( !v7 )
Ritor1
parents:
diff changeset
2055 return v4;
Ritor1
parents:
diff changeset
2056 if ( v7 == 16
Ritor1
parents:
diff changeset
2057 || v7 == 39
Ritor1
parents:
diff changeset
2058 || v7 == 40
Ritor1
parents:
diff changeset
2059 || v7 == 45
Ritor1
parents:
diff changeset
2060 || v7 == 56
Ritor1
parents:
diff changeset
2061 || v7 == 57
Ritor1
parents:
diff changeset
2062 || v7 == 58
Ritor1
parents:
diff changeset
2063 || v7 == 60
Ritor1
parents:
diff changeset
2064 || v7 == 61
Ritor1
parents:
diff changeset
2065 || v7 == 59
Ritor1
parents:
diff changeset
2066 || v7 == 63
Ritor1
parents:
diff changeset
2067 || v7 == 64
Ritor1
parents:
diff changeset
2068 || v7 == 67
Ritor1
parents:
diff changeset
2069 || v7 == 68 )
Ritor1
parents:
diff changeset
2070 {
Ritor1
parents:
diff changeset
2071 sprintf(
Ritor1
parents:
diff changeset
2072 item__getname_buffer,
Ritor1
parents:
diff changeset
2073 "%s %s",
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2074 *(unsigned int *)&pItemsTable->pEnchantments[22].to_item[28 * v7 + 8],
0
Ritor1
parents:
diff changeset
2075 pItemsTable->pItems[v1->uItemID].pName);
Ritor1
parents:
diff changeset
2076 return v4;
Ritor1
parents:
diff changeset
2077 }
Ritor1
parents:
diff changeset
2078 strcat(item__getname_buffer, " ");
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2079 v9 = *(const char **)&pItemsTable->pEnchantments[22].to_item[28 * v1->uAdditionalValue + 8];
0
Ritor1
parents:
diff changeset
2080 }
Ritor1
parents:
diff changeset
2081 strcat(item__getname_buffer, v9);
Ritor1
parents:
diff changeset
2082 }
Ritor1
parents:
diff changeset
2083 return v4;
Ritor1
parents:
diff changeset
2084 }
Ritor1
parents:
diff changeset
2085
Ritor1
parents:
diff changeset
2086
Ritor1
parents:
diff changeset
2087 //----- (00456620) --------------------------------------------------------
Ritor1
parents:
diff changeset
2088 void ItemsTable::GenerateItem(int a2, int a3, ItemGen *pItem)
Ritor1
parents:
diff changeset
2089 {
Ritor1
parents:
diff changeset
2090 ItemGen *v4; // esi@1
Ritor1
parents:
diff changeset
2091 ItemsTable *v5; // edi@1
Ritor1
parents:
diff changeset
2092 int v6; // ebx@3
Ritor1
parents:
diff changeset
2093 int *v7; // ecx@33
Ritor1
parents:
diff changeset
2094 int v8; // eax@34
Ritor1
parents:
diff changeset
2095 int v9; // eax@39
Ritor1
parents:
diff changeset
2096 int v10; // ebx@43
Ritor1
parents:
diff changeset
2097 int v11; // ecx@47
Ritor1
parents:
diff changeset
2098 unsigned int *v12; // edx@48
Ritor1
parents:
diff changeset
2099 unsigned int v13; // eax@49
Ritor1
parents:
diff changeset
2100 signed int v14; // ebx@52
Ritor1
parents:
diff changeset
2101 int v15; // eax@53
Ritor1
parents:
diff changeset
2102 signed int v16; // eax@55
Ritor1
parents:
diff changeset
2103 int v17; // ebx@57
Ritor1
parents:
diff changeset
2104 int v18; // edx@62
Ritor1
parents:
diff changeset
2105 signed int v19; // ebx@70
Ritor1
parents:
diff changeset
2106 unsigned __int8 v20; // al@81
Ritor1
parents:
diff changeset
2107 int v21; // eax@84
Ritor1
parents:
diff changeset
2108 int v22; // ebx@85
Ritor1
parents:
diff changeset
2109 int v23; // eax@86
Ritor1
parents:
diff changeset
2110 int v24; // ebx@86
Ritor1
parents:
diff changeset
2111 int v25; // edx@86
Ritor1
parents:
diff changeset
2112 int v26; // edx@89
Ritor1
parents:
diff changeset
2113 unsigned int v27; // eax@89
Ritor1
parents:
diff changeset
2114 int i; // ebx@89
Ritor1
parents:
diff changeset
2115 unsigned int v29; // ecx@90
Ritor1
parents:
diff changeset
2116 int v30; // ebx@91
Ritor1
parents:
diff changeset
2117 int v31; // eax@91
Ritor1
parents:
diff changeset
2118 int v32; // ecx@91
Ritor1
parents:
diff changeset
2119 int v33; // eax@91
Ritor1
parents:
diff changeset
2120 int v34; // eax@97
Ritor1
parents:
diff changeset
2121 unsigned __int8 v35; // sf@97
Ritor1
parents:
diff changeset
2122 unsigned __int8 v36; // of@97
Ritor1
parents:
diff changeset
2123 int v37; // ebx@98
Ritor1
parents:
diff changeset
2124 int v38; // edx@99
Ritor1
parents:
diff changeset
2125 signed int v39; // ebx@101
Ritor1
parents:
diff changeset
2126 int v40; // ecx@102
Ritor1
parents:
diff changeset
2127 char v41; // zf@107
Ritor1
parents:
diff changeset
2128 char v42; // al@108
Ritor1
parents:
diff changeset
2129 char v43; // al@111
Ritor1
parents:
diff changeset
2130 int *v44; // edx@118
Ritor1
parents:
diff changeset
2131 int v45; // eax@120
Ritor1
parents:
diff changeset
2132 int v46; // edx@120
Ritor1
parents:
diff changeset
2133 int *j; // eax@121
Ritor1
parents:
diff changeset
2134 unsigned int v48; // ecx@123
Ritor1
parents:
diff changeset
2135 int v49; // eax@123
Ritor1
parents:
diff changeset
2136 int v50; // eax@123
Ritor1
parents:
diff changeset
2137 unsigned char Dst[0xC80]; // [sp+Ch] [bp-C88h]@33
Ritor1
parents:
diff changeset
2138 int v52; // [sp+C8Ch] [bp-8h]@33
Ritor1
parents:
diff changeset
2139 int v53; // [sp+C90h] [bp-4h]@1
Ritor1
parents:
diff changeset
2140 int v54; // [sp+C9Ch] [bp+8h]@3
Ritor1
parents:
diff changeset
2141 int v55; // [sp+CA0h] [bp+Ch]@34
Ritor1
parents:
diff changeset
2142 signed int v56; // [sp+CA0h] [bp+Ch]@55
Ritor1
parents:
diff changeset
2143 int v57; // [sp+CA0h] [bp+Ch]@62
Ritor1
parents:
diff changeset
2144 int *v58; // [sp+CA0h] [bp+Ch]@102
Ritor1
parents:
diff changeset
2145 int v59; // [sp+CA0h] [bp+Ch]@123
Ritor1
parents:
diff changeset
2146 signed int a2a; // [sp+CA4h] [bp+10h]@33
Ritor1
parents:
diff changeset
2147 int a2b; // [sp+CA4h] [bp+10h]@101
Ritor1
parents:
diff changeset
2148 int a2c; // [sp+CA4h] [bp+10h]@120
Ritor1
parents:
diff changeset
2149
Ritor1
parents:
diff changeset
2150 v53 = -1;
Ritor1
parents:
diff changeset
2151 v4 = pItem;
Ritor1
parents:
diff changeset
2152 v5 = this;
Ritor1
parents:
diff changeset
2153 if ( !pItem )
Ritor1
parents:
diff changeset
2154 v4 = (ItemGen *)pAllocator->AllocNamedChunk(pItem, 0x24u, "newItemGen");
Ritor1
parents:
diff changeset
2155 memset(v4, 0, 0x24u);
Ritor1
parents:
diff changeset
2156 v6 = a2 - 1;
Ritor1
parents:
diff changeset
2157 v54 = a2 - 1;
Ritor1
parents:
diff changeset
2158 if ( a3 )
Ritor1
parents:
diff changeset
2159 {
Ritor1
parents:
diff changeset
2160 switch ( a3 )
Ritor1
parents:
diff changeset
2161 {
Ritor1
parents:
diff changeset
2162 case 20:
Ritor1
parents:
diff changeset
2163 a3 = EQUIP_ONE_OR_TWO_HANDS;
Ritor1
parents:
diff changeset
2164 break;
Ritor1
parents:
diff changeset
2165 case 21:
Ritor1
parents:
diff changeset
2166 a3 = 3;
Ritor1
parents:
diff changeset
2167 break;
Ritor1
parents:
diff changeset
2168 case 22:
Ritor1
parents:
diff changeset
2169 v53 = 38;
Ritor1
parents:
diff changeset
2170 break;
Ritor1
parents:
diff changeset
2171 case 23:
Ritor1
parents:
diff changeset
2172 v53 = 1;
Ritor1
parents:
diff changeset
2173 break;
Ritor1
parents:
diff changeset
2174 case 24:
Ritor1
parents:
diff changeset
2175 v53 = 2;
Ritor1
parents:
diff changeset
2176 break;
Ritor1
parents:
diff changeset
2177 case 25:
Ritor1
parents:
diff changeset
2178 v53 = 3;
Ritor1
parents:
diff changeset
2179 break;
Ritor1
parents:
diff changeset
2180 case 26:
Ritor1
parents:
diff changeset
2181 v53 = 4;
Ritor1
parents:
diff changeset
2182 break;
Ritor1
parents:
diff changeset
2183 case 27:
Ritor1
parents:
diff changeset
2184 v53 = 5;
Ritor1
parents:
diff changeset
2185 break;
Ritor1
parents:
diff changeset
2186 case 28:
Ritor1
parents:
diff changeset
2187 v53 = 6;
Ritor1
parents:
diff changeset
2188 break;
Ritor1
parents:
diff changeset
2189 case 30:
Ritor1
parents:
diff changeset
2190 v53 = 0;
Ritor1
parents:
diff changeset
2191 break;
Ritor1
parents:
diff changeset
2192 case 31:
Ritor1
parents:
diff changeset
2193 v53 = 9;
Ritor1
parents:
diff changeset
2194 break;
Ritor1
parents:
diff changeset
2195 case 32:
Ritor1
parents:
diff changeset
2196 v53 = 10;
Ritor1
parents:
diff changeset
2197 break;
Ritor1
parents:
diff changeset
2198 case 33:
Ritor1
parents:
diff changeset
2199 v53 = 0xBu;
Ritor1
parents:
diff changeset
2200 break;
Ritor1
parents:
diff changeset
2201 case 34:
Ritor1
parents:
diff changeset
2202 a3 = 4;
Ritor1
parents:
diff changeset
2203 break;
Ritor1
parents:
diff changeset
2204 case 35:
Ritor1
parents:
diff changeset
2205 a3 = 5;
Ritor1
parents:
diff changeset
2206 break;
Ritor1
parents:
diff changeset
2207 case 36:
Ritor1
parents:
diff changeset
2208 a3 = 6;
Ritor1
parents:
diff changeset
2209 break;
Ritor1
parents:
diff changeset
2210 case 37:
Ritor1
parents:
diff changeset
2211 a3 = 7;
Ritor1
parents:
diff changeset
2212 break;
Ritor1
parents:
diff changeset
2213 case 38:
Ritor1
parents:
diff changeset
2214 a3 = 8;
Ritor1
parents:
diff changeset
2215 break;
Ritor1
parents:
diff changeset
2216 case 39:
Ritor1
parents:
diff changeset
2217 a3 = EQUIP_BOOTS;
Ritor1
parents:
diff changeset
2218 break;
Ritor1
parents:
diff changeset
2219 case 40:
Ritor1
parents:
diff changeset
2220 a3 = EQUIP_RING;
Ritor1
parents:
diff changeset
2221 break;
Ritor1
parents:
diff changeset
2222 case 41:
Ritor1
parents:
diff changeset
2223 a3 = 0xBu;
Ritor1
parents:
diff changeset
2224 break;
Ritor1
parents:
diff changeset
2225 case 42:
Ritor1
parents:
diff changeset
2226 a3 = EQUIP_C;
Ritor1
parents:
diff changeset
2227 break;
Ritor1
parents:
diff changeset
2228 case 43:
Ritor1
parents:
diff changeset
2229 a3 = EQUIP_F;
Ritor1
parents:
diff changeset
2230 break;
Ritor1
parents:
diff changeset
2231 case 44:
Ritor1
parents:
diff changeset
2232 a3 = EQUIP_POTION;
Ritor1
parents:
diff changeset
2233 break;
Ritor1
parents:
diff changeset
2234 case 45:
Ritor1
parents:
diff changeset
2235 a3 = EQUIP_REAGENT;
Ritor1
parents:
diff changeset
2236 break;
Ritor1
parents:
diff changeset
2237 case 46:
Ritor1
parents:
diff changeset
2238 a3 = EQUIP_GEM;
Ritor1
parents:
diff changeset
2239 break;
Ritor1
parents:
diff changeset
2240 case 29:
Ritor1
parents:
diff changeset
2241 v53 = 37;
Ritor1
parents:
diff changeset
2242 break;
Ritor1
parents:
diff changeset
2243 default:
Ritor1
parents:
diff changeset
2244 --a3;
Ritor1
parents:
diff changeset
2245 break;
Ritor1
parents:
diff changeset
2246 }
Ritor1
parents:
diff changeset
2247 memset(&Dst, 0, 0xC80u);
Ritor1
parents:
diff changeset
2248 v52 = 0;
Ritor1
parents:
diff changeset
2249 v7 = (int *)&Dst;
Ritor1
parents:
diff changeset
2250 a2a = 1;
Ritor1
parents:
diff changeset
2251 if ( v53 == -1 )
Ritor1
parents:
diff changeset
2252 {
Ritor1
parents:
diff changeset
2253 v53 = (int)&v5->pItems[1].uEquipType;
Ritor1
parents:
diff changeset
2254 v9 = (int)(&v5->pItems[1].field_2C + v6);
Ritor1
parents:
diff changeset
2255 do
Ritor1
parents:
diff changeset
2256 {
Ritor1
parents:
diff changeset
2257 if ( *(unsigned char *)v53 == a3 )
Ritor1
parents:
diff changeset
2258 {
Ritor1
parents:
diff changeset
2259 *v7 = a2a;
Ritor1
parents:
diff changeset
2260 ++v7;
Ritor1
parents:
diff changeset
2261 v52 += *(unsigned char *)v9;
Ritor1
parents:
diff changeset
2262 }
Ritor1
parents:
diff changeset
2263 ++a2a;
Ritor1
parents:
diff changeset
2264 v53 += 48;
Ritor1
parents:
diff changeset
2265 v9 += 48;
Ritor1
parents:
diff changeset
2266 }
Ritor1
parents:
diff changeset
2267 while ( a2a < 500 );
Ritor1
parents:
diff changeset
2268 }
Ritor1
parents:
diff changeset
2269 else
Ritor1
parents:
diff changeset
2270 {
Ritor1
parents:
diff changeset
2271 v55 = (int)&v5->pItems[1].uSkillType;
Ritor1
parents:
diff changeset
2272 v8 = (int)(&v5->pItems[1].field_2C + v6);
Ritor1
parents:
diff changeset
2273 do
Ritor1
parents:
diff changeset
2274 {
Ritor1
parents:
diff changeset
2275 if ( *(unsigned char *)v55 == v53 )
Ritor1
parents:
diff changeset
2276 {
Ritor1
parents:
diff changeset
2277 *v7 = a2a;
Ritor1
parents:
diff changeset
2278 ++v7;
Ritor1
parents:
diff changeset
2279 v52 += *(unsigned char *)v8;
Ritor1
parents:
diff changeset
2280 }
Ritor1
parents:
diff changeset
2281 ++a2a;
Ritor1
parents:
diff changeset
2282 v55 += 48;
Ritor1
parents:
diff changeset
2283 v8 += 48;
Ritor1
parents:
diff changeset
2284 }
Ritor1
parents:
diff changeset
2285 while ( a2a < 500 );
Ritor1
parents:
diff changeset
2286 }
Ritor1
parents:
diff changeset
2287 v10 = 0;
Ritor1
parents:
diff changeset
2288 if ( v52 )
Ritor1
parents:
diff changeset
2289 v10 = rand() % v52;
Ritor1
parents:
diff changeset
2290 v4->uItemID = *(uint *)Dst;
Ritor1
parents:
diff changeset
2291 if ( !Dst )
Ritor1
parents:
diff changeset
2292 v4->uItemID = 1;
Ritor1
parents:
diff changeset
2293 v11 = *(&v5->pItems[v4->uItemID].field_2C + v54);
Ritor1
parents:
diff changeset
2294 if ( v11 < v10 )
Ritor1
parents:
diff changeset
2295 {
Ritor1
parents:
diff changeset
2296 v12 = (uint *)Dst;
Ritor1
parents:
diff changeset
2297 do
Ritor1
parents:
diff changeset
2298 {
Ritor1
parents:
diff changeset
2299 ++v12;
Ritor1
parents:
diff changeset
2300 v13 = *v12;
Ritor1
parents:
diff changeset
2301 v4->uItemID = *v12;
Ritor1
parents:
diff changeset
2302 v11 += *(&v5->pItems[v13].field_2C + v54);
Ritor1
parents:
diff changeset
2303 }
Ritor1
parents:
diff changeset
2304 while ( v11 < v10 );
Ritor1
parents:
diff changeset
2305 }
Ritor1
parents:
diff changeset
2306 if ( v5->pItems[v4->uItemID].uEquipType == EQUIP_POTION && v4->uItemID != ITEM_POTION_BOTTLE )
Ritor1
parents:
diff changeset
2307 {
Ritor1
parents:
diff changeset
2308 v4->_bonus_type = 0;
Ritor1
parents:
diff changeset
2309 v14 = 2;
Ritor1
parents:
diff changeset
2310 do
Ritor1
parents:
diff changeset
2311 {
Ritor1
parents:
diff changeset
2312 v4->_bonus_type += rand() % 4 + 1;
Ritor1
parents:
diff changeset
2313 v15 = v4->_bonus_type;
Ritor1
parents:
diff changeset
2314 --v14;
Ritor1
parents:
diff changeset
2315 }
Ritor1
parents:
diff changeset
2316 while ( v14 );
Ritor1
parents:
diff changeset
2317 LABEL_72:
Ritor1
parents:
diff changeset
2318 v4->_bonus_type = v15 * (v54 + 1);
Ritor1
parents:
diff changeset
2319 goto LABEL_73;
Ritor1
parents:
diff changeset
2320 }
Ritor1
parents:
diff changeset
2321 }
Ritor1
parents:
diff changeset
2322 else
Ritor1
parents:
diff changeset
2323 {
Ritor1
parents:
diff changeset
2324 v16 = 0;
Ritor1
parents:
diff changeset
2325 v56 = 0;
Ritor1
parents:
diff changeset
2326 do
Ritor1
parents:
diff changeset
2327 v56 += pParty->field_7BA[v16++];
Ritor1
parents:
diff changeset
2328 while ( v16 < 29 );
Ritor1
parents:
diff changeset
2329 v17 = rand() % 29;
Ritor1
parents:
diff changeset
2330 if ( v54 == 5 && rand() % 100 < 5 && !pParty->field_7BA[v17] && v56 < 13 )
Ritor1
parents:
diff changeset
2331 {
Ritor1
parents:
diff changeset
2332 pParty->field_7BA[v17] = 1;
Ritor1
parents:
diff changeset
2333 v4->uAttributes = 0;
Ritor1
parents:
diff changeset
2334 v4->uItemID = v17 + 500;
Ritor1
parents:
diff changeset
2335 v5->SetSpecialBonus(v4);
Ritor1
parents:
diff changeset
2336 return;
Ritor1
parents:
diff changeset
2337 }
Ritor1
parents:
diff changeset
2338 v57 = 0;
Ritor1
parents:
diff changeset
2339 v18 = rand() % v5->field_11684[v54];
Ritor1
parents:
diff changeset
2340 v4->uItemID = 0;
Ritor1
parents:
diff changeset
2341 if ( v18 > 0 )
Ritor1
parents:
diff changeset
2342 {
Ritor1
parents:
diff changeset
2343 do
Ritor1
parents:
diff changeset
2344 v57 += *(&v5->pItems[v4->uItemID++ + 1].field_2C + v54);
Ritor1
parents:
diff changeset
2345 while ( v57 < v18 );
Ritor1
parents:
diff changeset
2346 }
Ritor1
parents:
diff changeset
2347 if ( !v18 )
Ritor1
parents:
diff changeset
2348 v4->uItemID = 1;
Ritor1
parents:
diff changeset
2349 if ( !v4->uItemID )
Ritor1
parents:
diff changeset
2350 v4->uItemID = 1;
Ritor1
parents:
diff changeset
2351 if ( v5->pItems[v4->uItemID].uEquipType == EQUIP_POTION && v4->uItemID != ITEM_POTION_BOTTLE )
Ritor1
parents:
diff changeset
2352 {
Ritor1
parents:
diff changeset
2353 v4->_bonus_type = 0;
Ritor1
parents:
diff changeset
2354 v19 = 2;
Ritor1
parents:
diff changeset
2355 do
Ritor1
parents:
diff changeset
2356 {
Ritor1
parents:
diff changeset
2357 v4->_bonus_type += rand() % 4 + 1;
Ritor1
parents:
diff changeset
2358 v15 = v4->_bonus_type;
Ritor1
parents:
diff changeset
2359 --v19;
Ritor1
parents:
diff changeset
2360 }
Ritor1
parents:
diff changeset
2361 while ( v19 );
Ritor1
parents:
diff changeset
2362 goto LABEL_72;
Ritor1
parents:
diff changeset
2363 }
Ritor1
parents:
diff changeset
2364 }
Ritor1
parents:
diff changeset
2365 LABEL_73:
Ritor1
parents:
diff changeset
2366 if ( v4->uItemID == ITEM_SPELLBOOK_LIGHT_DIVINE_INTERVENTION
Ritor1
parents:
diff changeset
2367 && !(unsigned __int16)_449B57_test_bit(pParty->_award_bits, 239) )
Ritor1
parents:
diff changeset
2368 v4->uItemID = ITEM_SPELLBOOK_LIGHT_SUN_BURST;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2369 if ( pItemsTable->pItems[v4->uItemID + 1].uItemID_Rep_St )
0
Ritor1
parents:
diff changeset
2370 v4->uAttributes = 0;
Ritor1
parents:
diff changeset
2371 else
Ritor1
parents:
diff changeset
2372 v4->uAttributes = 1;
Ritor1
parents:
diff changeset
2373 if ( v5->pItems[v4->uItemID].uEquipType != EQUIP_POTION )
Ritor1
parents:
diff changeset
2374 {
Ritor1
parents:
diff changeset
2375 v4->uAdditionalValue = 0;
Ritor1
parents:
diff changeset
2376 v4->_bonus_type = 0;
Ritor1
parents:
diff changeset
2377 }
Ritor1
parents:
diff changeset
2378 v20 = v5->pItems[v4->uItemID].uEquipType;
Ritor1
parents:
diff changeset
2379 if ( v20 <= EQUIP_BOW )
Ritor1
parents:
diff changeset
2380 {
Ritor1
parents:
diff changeset
2381 v37 = (int)&v5->field_1169C[4 * v54 + 48];
Ritor1
parents:
diff changeset
2382 if ( !*(unsigned int *)v37 )
Ritor1
parents:
diff changeset
2383 return;
Ritor1
parents:
diff changeset
2384 v38 = rand() % 100;
Ritor1
parents:
diff changeset
2385 v36 = __OFSUB__(v38, *(unsigned int *)v37);
Ritor1
parents:
diff changeset
2386 v35 = v38 - *(unsigned int *)v37 < 0;
Ritor1
parents:
diff changeset
2387 }
Ritor1
parents:
diff changeset
2388 else
Ritor1
parents:
diff changeset
2389 {
Ritor1
parents:
diff changeset
2390 if ( v20 > EQUIP_AMULET )
Ritor1
parents:
diff changeset
2391 {
Ritor1
parents:
diff changeset
2392 if ( v20 == EQUIP_C )
Ritor1
parents:
diff changeset
2393 {
Ritor1
parents:
diff changeset
2394 v21 = rand() % 6 + pItemsTable->pItems[v4->uItemID].uDamageMod + 1;
Ritor1
parents:
diff changeset
2395 v4->uNumCharges = v21;
Ritor1
parents:
diff changeset
2396 v4->uMaxCharges = v21;
Ritor1
parents:
diff changeset
2397 }
Ritor1
parents:
diff changeset
2398 return;
Ritor1
parents:
diff changeset
2399 }
Ritor1
parents:
diff changeset
2400 v22 = (int)&v5->field_1169C[4 * v54];
Ritor1
parents:
diff changeset
2401 if ( !*(unsigned int *)v22 )
Ritor1
parents:
diff changeset
2402 return;
Ritor1
parents:
diff changeset
2403 v23 = rand();
Ritor1
parents:
diff changeset
2404 v24 = *(unsigned int *)v22;
Ritor1
parents:
diff changeset
2405 v25 = v23 % 100;
Ritor1
parents:
diff changeset
2406 if ( v23 % 100 < v24 )
Ritor1
parents:
diff changeset
2407 goto LABEL_127;
Ritor1
parents:
diff changeset
2408 if ( !*(unsigned int *)&v5->field_1169C[4 * v54 + 24] )
Ritor1
parents:
diff changeset
2409 return;
Ritor1
parents:
diff changeset
2410 if ( v25 < v24 )
Ritor1
parents:
diff changeset
2411 {
Ritor1
parents:
diff changeset
2412 LABEL_127:
Ritor1
parents:
diff changeset
2413 v26 = rand() % v5->field_116D8[v5->pItems[v4->uItemID].uEquipType];
Ritor1
parents:
diff changeset
2414 v27 = v4->uItemID;
Ritor1
parents:
diff changeset
2415 v4->_bonus_type = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2416 for ( i = v5->pEnchantments[0].to_item[v5->pItems[v27].uEquipType + 1];
0
Ritor1
parents:
diff changeset
2417 i < v26;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2418 i += v5->pEnchantments[v4->_bonus_type].to_item[v5->pItems[v29].uEquipType + 1] )
0
Ritor1
parents:
diff changeset
2419 {
Ritor1
parents:
diff changeset
2420 v29 = v4->uItemID;
Ritor1
parents:
diff changeset
2421 ++v4->_bonus_type;
Ritor1
parents:
diff changeset
2422 }
Ritor1
parents:
diff changeset
2423 ++v4->_bonus_type;
Ritor1
parents:
diff changeset
2424 v30 = v5->field_116D8[2 * v54 + 12];
Ritor1
parents:
diff changeset
2425 v31 = rand();
Ritor1
parents:
diff changeset
2426 v32 = v4->_bonus_type - 1;
Ritor1
parents:
diff changeset
2427 v33 = v31 % (v5->field_116D8[2 * v54 + 13] - v30 + 1) + v30;
Ritor1
parents:
diff changeset
2428 v4->_bonus_strength = v33;
Ritor1
parents:
diff changeset
2429 if ( v32 == 21 || v32 == 22 || v32 == 23 )
Ritor1
parents:
diff changeset
2430 v4->_bonus_strength = v33 >> 1;
Ritor1
parents:
diff changeset
2431 if ( v4->_bonus_strength <= 0 )
Ritor1
parents:
diff changeset
2432 v4->_bonus_strength = 1;
Ritor1
parents:
diff changeset
2433 return;
Ritor1
parents:
diff changeset
2434 }
Ritor1
parents:
diff changeset
2435 v34 = v24 + *(unsigned int *)&v5->field_1169C[4 * v54 + 24];
Ritor1
parents:
diff changeset
2436 v36 = __OFSUB__(v25, v34);
Ritor1
parents:
diff changeset
2437 v35 = v25 - v34 < 0;
Ritor1
parents:
diff changeset
2438 }
Ritor1
parents:
diff changeset
2439 if ( !(v35 ^ v36) )
Ritor1
parents:
diff changeset
2440 return;
Ritor1
parents:
diff changeset
2441 memset(&Dst, 0, 0xC80u);
Ritor1
parents:
diff changeset
2442 v39 = 0;
Ritor1
parents:
diff changeset
2443 a2b = 0;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2444 if ( v5->pSpecialEnchantments_count > 0 )
0
Ritor1
parents:
diff changeset
2445 {
Ritor1
parents:
diff changeset
2446 v52 = -16 - (uint)v5;
Ritor1
parents:
diff changeset
2447 v58 = (int *)&Dst;
Ritor1
parents:
diff changeset
2448 v40 = (int)&v5->pSpecialEnchantments[1];
Ritor1
parents:
diff changeset
2449 do
Ritor1
parents:
diff changeset
2450 {
Ritor1
parents:
diff changeset
2451 switch ( v54 )
Ritor1
parents:
diff changeset
2452 {
Ritor1
parents:
diff changeset
2453 case 2:
Ritor1
parents:
diff changeset
2454 if ( !*(unsigned char *)v40 )
Ritor1
parents:
diff changeset
2455 goto LABEL_117;
Ritor1
parents:
diff changeset
2456 v41 = *(unsigned char *)v40 == 1;
Ritor1
parents:
diff changeset
2457 break;
Ritor1
parents:
diff changeset
2458 case 3:
Ritor1
parents:
diff changeset
2459 v43 = *(unsigned char *)v40;
Ritor1
parents:
diff changeset
2460 if ( !*(unsigned char *)v40 || v43 == 1 )
Ritor1
parents:
diff changeset
2461 {
Ritor1
parents:
diff changeset
2462 LABEL_117:
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2463 v39 += *((unsigned char *)&v5->uAllItemsCount + v40 + v52 + v5->pItems[v4->uItemID].uEquipType);
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2464 if ( *((unsigned char *)&v5->uAllItemsCount + v40 + v52 + v5->pItems[v4->uItemID].uEquipType) )
0
Ritor1
parents:
diff changeset
2465 {
Ritor1
parents:
diff changeset
2466 v44 = v58;
Ritor1
parents:
diff changeset
2467 ++v58;
Ritor1
parents:
diff changeset
2468 *v44 = a2b;
Ritor1
parents:
diff changeset
2469 }
Ritor1
parents:
diff changeset
2470 goto LABEL_119;
Ritor1
parents:
diff changeset
2471 }
Ritor1
parents:
diff changeset
2472 v41 = v43 == 2;
Ritor1
parents:
diff changeset
2473 break;
Ritor1
parents:
diff changeset
2474 case 4:
Ritor1
parents:
diff changeset
2475 v42 = *(unsigned char *)v40;
Ritor1
parents:
diff changeset
2476 if ( *(unsigned char *)v40 == 1 || v42 == 2 )
Ritor1
parents:
diff changeset
2477 goto LABEL_117;
Ritor1
parents:
diff changeset
2478 v41 = v42 == 3;
Ritor1
parents:
diff changeset
2479 break;
Ritor1
parents:
diff changeset
2480 default:
Ritor1
parents:
diff changeset
2481 if ( v54 != 5 )
Ritor1
parents:
diff changeset
2482 goto LABEL_119;
Ritor1
parents:
diff changeset
2483 v41 = *(unsigned char *)v40 == 3;
Ritor1
parents:
diff changeset
2484 break;
Ritor1
parents:
diff changeset
2485 }
Ritor1
parents:
diff changeset
2486 if ( v41 )
Ritor1
parents:
diff changeset
2487 goto LABEL_117;
Ritor1
parents:
diff changeset
2488 LABEL_119:
Ritor1
parents:
diff changeset
2489 ++a2b;
Ritor1
parents:
diff changeset
2490 v40 += 28;
Ritor1
parents:
diff changeset
2491 }
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2492 while ( a2b < v5->pSpecialEnchantments_count );
0
Ritor1
parents:
diff changeset
2493 }
Ritor1
parents:
diff changeset
2494 v45 = rand();
Ritor1
parents:
diff changeset
2495 v4->uAdditionalValue = *(uint *)Dst;
Ritor1
parents:
diff changeset
2496 v46 = v45 % v39 + 1;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2497 a2c = *((unsigned char *)&v5->uAllItemsCount + 28 * (*(uint *)Dst + 1389) + v5->pItems[v4->uItemID].uEquipType);
0
Ritor1
parents:
diff changeset
2498 if ( a2c < v46 )
Ritor1
parents:
diff changeset
2499 {
Ritor1
parents:
diff changeset
2500 for ( j = (int *)&Dst; ; j = (int *)v59 )
Ritor1
parents:
diff changeset
2501 {
Ritor1
parents:
diff changeset
2502 v48 = v4->uItemID;
Ritor1
parents:
diff changeset
2503 v49 = (int)(j + 1);
Ritor1
parents:
diff changeset
2504 v59 = v49;
Ritor1
parents:
diff changeset
2505 v50 = *(unsigned int *)v49;
Ritor1
parents:
diff changeset
2506 v4->uAdditionalValue = v50;
222
8113753ed2ae more item init fixing
Gloval
parents: 193
diff changeset
2507 a2c += *((unsigned char *)&v5->uAllItemsCount + 28 * (v50 + 1389) + v5->pItems[v48].uEquipType);
0
Ritor1
parents:
diff changeset
2508 if ( a2c >= v46 )
Ritor1
parents:
diff changeset
2509 break;
Ritor1
parents:
diff changeset
2510 }
Ritor1
parents:
diff changeset
2511 }
Ritor1
parents:
diff changeset
2512 ++v4->uAdditionalValue;
Ritor1
parents:
diff changeset
2513 }
Ritor1
parents:
diff changeset
2514
Ritor1
parents:
diff changeset
2515 //----- (004505CC) --------------------------------------------------------
Ritor1
parents:
diff changeset
2516 bool ItemGen::GenerateArtifact()
Ritor1
parents:
diff changeset
2517 {
Ritor1
parents:
diff changeset
2518 ItemGen *v1; // edi@1
Ritor1
parents:
diff changeset
2519 signed int uNumArtifactsNotFound; // esi@1
Ritor1
parents:
diff changeset
2520 int v3; // eax@1
Ritor1
parents:
diff changeset
2521 bool result; // eax@6
Ritor1
parents:
diff changeset
2522 int v5[32]; // [sp+8h] [bp-A0h]@3
Ritor1
parents:
diff changeset
2523 char Dst[32]; // [sp+88h] [bp-20h]@1
Ritor1
parents:
diff changeset
2524
Ritor1
parents:
diff changeset
2525 auto a2 = this;
Ritor1
parents:
diff changeset
2526 v1 = a2;
Ritor1
parents:
diff changeset
2527 memset(Dst, 0, 0x20u);
Ritor1
parents:
diff changeset
2528 uNumArtifactsNotFound = 0;
Ritor1
parents:
diff changeset
2529 v3 = 500;
Ritor1
parents:
diff changeset
2530 do
Ritor1
parents:
diff changeset
2531 {
Ritor1
parents:
diff changeset
2532 if ( !pParty->field_3C.pIsArtifactFound[v3] )
Ritor1
parents:
diff changeset
2533 v5[uNumArtifactsNotFound++] = v3;
Ritor1
parents:
diff changeset
2534 ++v3;
Ritor1
parents:
diff changeset
2535 }
Ritor1
parents:
diff changeset
2536 while ( v3 < 529 );
Ritor1
parents:
diff changeset
2537 v1->Reset();
Ritor1
parents:
diff changeset
2538 if ( uNumArtifactsNotFound )
Ritor1
parents:
diff changeset
2539 {
Ritor1
parents:
diff changeset
2540 v1->uItemID = v5[rand() % uNumArtifactsNotFound];
Ritor1
parents:
diff changeset
2541 pItemsTable->SetSpecialBonus(v1);
Ritor1
parents:
diff changeset
2542 result = 1;
Ritor1
parents:
diff changeset
2543 }
Ritor1
parents:
diff changeset
2544 else
Ritor1
parents:
diff changeset
2545 {
Ritor1
parents:
diff changeset
2546 result = 0;
Ritor1
parents:
diff changeset
2547 }
Ritor1
parents:
diff changeset
2548 return result;
Ritor1
parents:
diff changeset
2549 }
Ritor1
parents:
diff changeset
2550 // 4505CC: using guessed type int var_A0[32];