annotate Items.cpp @ 228:46ae2602aceb

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