aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/hopkins/globals.cpp2
-rw-r--r--engines/hopkins/lines.cpp392
-rw-r--r--engines/hopkins/lines.h2
-rw-r--r--engines/hopkins/objects.cpp56
4 files changed, 237 insertions, 215 deletions
diff --git a/engines/hopkins/globals.cpp b/engines/hopkins/globals.cpp
index 8253593e99..35d1e61115 100644
--- a/engines/hopkins/globals.cpp
+++ b/engines/hopkins/globals.cpp
@@ -350,7 +350,7 @@ void Globals::clearAll() {
_vm->_linesManager.Ligne[idx].field4 = 0;
_vm->_linesManager.Ligne[idx].field6 = 0;
_vm->_linesManager.Ligne[idx].field8 = 0;
- _vm->_linesManager.Ligne[idx].fieldC = g_PTRNUL;
+ _vm->_linesManager.Ligne[idx].lineData = (int16 *)g_PTRNUL;
_vm->_linesManager.LigneZone[idx].count = 0;
_vm->_linesManager.LigneZone[idx].field2 = 0;
diff --git a/engines/hopkins/lines.cpp b/engines/hopkins/lines.cpp
index 8fbee5c32f..968bfe8e64 100644
--- a/engines/hopkins/lines.cpp
+++ b/engines/hopkins/lines.cpp
@@ -219,16 +219,16 @@ void LinesManager::RESET_OBSTACLE() {
for (int idx =0; idx < 400; ++idx) {
RETIRE_LIGNE(idx);
Ligne[idx].field0 = 0;
- Ligne[idx].fieldC = g_PTRNUL;
+ Ligne[idx].lineData = (int16 *)g_PTRNUL;
}
}
void LinesManager::RETIRE_LIGNE(int idx) {
if (idx > 400)
error("Attempting to add a line obstacle > MAX_LIGNE.");
- if (Ligne[idx].fieldC != g_PTRNUL)
- _vm->_globals.dos_free2(Ligne[idx].fieldC);
- Ligne[idx].fieldC = g_PTRNUL;
+ if (Ligne[idx].lineData != (int16 *)g_PTRNUL)
+ _vm->_globals.dos_free2((byte *)Ligne[idx].lineData);
+ Ligne[idx].lineData = (int16 *)g_PTRNUL;
}
void LinesManager::AJOUTE_LIGNE(int idx, int a2, int a3, int a4, int a5, int a6, int a7) {
@@ -242,10 +242,10 @@ void LinesManager::AJOUTE_LIGNE(int idx, int a2, int a3, int a4, int a5, int a6,
int v24;
int v25;
int v26;
- byte *v27;
+ int16 *v27;
int v30;
int v31;
- byte *v32;
+ int16 *v32;
int v33;
int v34;
int v35;
@@ -260,8 +260,8 @@ void LinesManager::AJOUTE_LIGNE(int idx, int a2, int a3, int a4, int a5, int a6,
if (TOTAL_LIGNES < idx)
TOTAL_LIGNES = idx;
- if (Ligne[idx].fieldC != g_PTRNUL)
- _vm->_globals.dos_free2(Ligne[idx].fieldC);
+ if (Ligne[idx].lineData != (int16 *)g_PTRNUL)
+ _vm->_globals.dos_free2((byte *)Ligne[idx].lineData);
v7 = a3 - a5;
if (a3 - a5 < 0)
v7 = -v7;
@@ -273,11 +273,13 @@ void LinesManager::AJOUTE_LIGNE(int idx, int a2, int a3, int a4, int a5, int a6,
v33 = v9 + 1;
if (v8 > (int)(v9 + 1))
v34 = v8;
+
v10 = _vm->_globals.dos_malloc2(4 * v34 + 8);
- Ligne[idx].fieldC = v10;
if (v10 == g_PTRNUL)
error("AJOUTE LIGNE OBSTACLE");
- v32 = Ligne[idx].fieldC;
+ Ligne[idx].lineData = (int16 *)v10;
+
+ v32 = Ligne[idx].lineData;
v36 = 1000 * v8;
v39 = 1000 * v8 / (v34 - 1);
v37 = 1000 * v33 / (v34 - 1);
@@ -356,9 +358,10 @@ void LinesManager::AJOUTE_LIGNE(int idx, int a2, int a3, int a4, int a5, int a6,
v26 = 0;
if (v35 > 0) {
do {
- WRITE_LE_UINT16(v32, v31);
- WRITE_LE_UINT16(v32 + 2, v30);
- v32 += 4;
+ v32[0] = v31;
+ v32[1] = v30;
+ v32 += 2;
+
v24 += v40;
v25 += v38;
v31 = v24 / 1000;
@@ -366,11 +369,12 @@ void LinesManager::AJOUTE_LIGNE(int idx, int a2, int a3, int a4, int a5, int a6,
++v26;
} while (v35 > v26);
}
- WRITE_LE_UINT16(v32, a5);
- WRITE_LE_UINT16(v32 + 2, a6);
- v27 = v32 + 4;
- WRITE_LE_UINT16(v27, (uint16)-1);
- WRITE_LE_UINT16(v27 + 2, (uint16)-1);
+ v32[0] = a5;
+ v32[1] = a6;
+
+ v27 = v32 + 2;
+ v27[0] = -1;
+ v27[1] = -1;
Ligne[idx].field0 = v35 + 1;
Ligne[idx].field2 = a7;
@@ -379,13 +383,13 @@ void LinesManager::AJOUTE_LIGNE(int idx, int a2, int a3, int a4, int a5, int a6,
int LinesManager::colision2_ligne(int a1, int a2, int *a3, int *a4, int a5, int a6) {
int v6;
- byte *v7;
+ int16 *v7;
int v8;
int v9;
int v10;
int v11;
int v12;
- byte *v13;
+ int16 *v13;
int v14;
int result;
int v16;
@@ -409,15 +413,16 @@ LABEL_29:
v20 = a2 + 4;
v19 = a2 - 4;
while (1) {
- v7 = Ligne[v6].fieldC;
- if (v7 != g_PTRNUL) {
+ v7 = Ligne[v6].lineData;
+
+ if (v7 != (int16 *)g_PTRNUL) {
v23 = 1;
v8 = 2 * Ligne[v6].field0;
- v9 = (int16)READ_LE_UINT16(v7);
- v16 = (int16)READ_LE_UINT16(v7 + 2);
- v10 = (int16)READ_LE_UINT16(v7 + 2 * v8 - 4);
- v18 = (int16)READ_LE_UINT16(v7 + 2 * v8 - 2);
- if ((int16)READ_LE_UINT16(v7) >= v10)
+ v9 = v7[0];
+ v16 = v7[1];
+ v10 = v7[v8 - 2];
+ v18 = v7[v8 - 1];
+ if (v7[0] >= v10)
goto LABEL_32;
if (v22 < v9 || v21 > v10)
v23 = 0;
@@ -449,10 +454,12 @@ LABEL_28:
goto LABEL_29;
}
while (1) {
- v12 = (int16)READ_LE_UINT16(v7);
- v13 = v7 + 2;
- v14 = (int16)READ_LE_UINT16(v13);
- v7 = v13 + 2;
+ v12 = v7[0];
+
+ v13 = v7 + 1;
+ v14 = v13[0];
+ v7 = v13 + 1;
+
if (a1 == v12 || a1 + 1 == v12) {
if (a2 == v14 || a2 + 1 == v14)
break;
@@ -470,13 +477,13 @@ LABEL_28:
int LinesManager::Scolision2_ligne(int a1, int a2, int *a3, int *a4, int a5, int a6) {
int v6;
- byte *v7;
+ int16 *v7;
int v8;
int v9;
int v10;
int v11;
int v12;
- byte *v13;
+ int16 *v13;
int result;
int v15;
int v16;
@@ -499,16 +506,17 @@ LABEL_47:
v21 = a1 - 10;
v20 = a2 + 10;
v19 = a2 - 10;
- while (1) {
- v7 = Ligne[v6].fieldC;
- if (g_PTRNUL != v7) {
+ for (;;) {
+ v7 = Ligne[v6].lineData;
+
+ if (v7 != (int16 *)g_PTRNUL) {
v23 = 1;
v8 = 2 * Ligne[v6].field0;
- v9 = (int16)READ_LE_UINT16(v7);
- v15 = (int16)READ_LE_UINT16(v7 + 2);
- v10 = (int16)READ_LE_UINT16(v7 + 2 * v8 - 4);
- v17 = (int16)READ_LE_UINT16(v7 + 2 * v8 - 2);
- if ((int16)READ_LE_UINT16(v7) >= v10)
+ v9 = v7[0];
+ v15 = v7[1];
+ v10 = v7[v8 - 2];
+ v17 = v7[v8 - 1];
+ if (v7[0] >= v10)
goto LABEL_50;
if (v22 < v9 || v21 > v10)
v23 = 0;
@@ -540,10 +548,10 @@ LABEL_46:
goto LABEL_47;
}
while (1) {
- v12 = (int16)READ_LE_UINT16(v7);
- v13 = v7 + 2;
- v16 = (int16)READ_LE_UINT16(v13);
- v7 = v13 + 2;
+ v12 = v7[0];
+ v13 = v7 + 1;
+ v16 = v13[0];
+ v7 = v13 + 1;
if (a1 == v12
|| v12 == a1 + 1
|| v12 == a1 + 2
@@ -583,11 +591,11 @@ void LinesManager::INIPARCOURS() {
int v0;
int v1;
int v2;
- byte *v3;
+ int16 *v3;
int v4;
int v5;
int v6;
- byte *v7;
+ int16 *v7;
int v8;
int v9;
int v11;
@@ -596,16 +604,17 @@ void LinesManager::INIPARCOURS() {
int v14;
int v15;
- v15 = (int16)READ_LE_UINT16(Ligne[0].fieldC);
- v14 = (int16)READ_LE_UINT16(Ligne[0].fieldC + 2);
+ v15 = Ligne[0].lineData[0];
+ v14 = Ligne[0].lineData[1];
v0 = 1;
v1 = 0;
do {
v2 = Ligne[v0].field0;
- v3 = Ligne[v0].fieldC;
- v4 = (int16)READ_LE_UINT16(v3 + 4 * v2 - 4);
- v5 = (int16)READ_LE_UINT16(v3 + 4 * v2 - 2);
+ v3 = Ligne[v0].lineData;
+
+ v4 = v3[2 * v2 - 2];
+ v5 = v3[2 * v2 - 1];
if (_vm->_graphicsManager.max_x == v4 || _vm->_graphicsManager.max_y == v5 || _vm->_graphicsManager.min_x == v4
|| _vm->_graphicsManager.min_y == v5)
v1 = 1;
@@ -616,8 +625,8 @@ void LinesManager::INIPARCOURS() {
error("ERROR - LAST LINE NOT FOUND");
v1 = v6;
}
- v7 = Ligne[v0 + 1].fieldC;
- if ((int16)READ_LE_UINT16(v7) != v4 && (int16)READ_LE_UINT16(v7 + 2) != v5)
+ v7 = Ligne[v0 + 1].lineData;
+ if (v7[0] != v4 && v7[1] != v5)
v1 = 1;
if (!v1)
++v0;
@@ -644,27 +653,27 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, i
int v7;
int v8;
int i;
- byte *v10;
+ int16 *v10;
int v11;
int v12;
int v13;
- byte *v14;
+ int16 *v14;
int v15;
int v16;
int j;
- byte *v18;
+ int16 *v18;
int v19;
int v20;
int k;
- byte *v22;
+ int16 *v22;
int v23;
int v24;
int v25;
- byte *v26;
+ int16 *v26;
int v27;
int v28;
int v29;
- byte *v30;
+ int16 *v30;
int v31;
int v32;
int v34;
@@ -677,9 +686,10 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, i
v8 = a3;
if (a1 < a4) {
for (i = a2; Ligne[a1].field0 > i; ++i) {
- v10 = Ligne[a1].fieldC;
- v11 = (int16)READ_LE_UINT16(v10 + 4 * i);
- v50 = (int16)READ_LE_UINT16(v10 + 4 * i + 2);
+ v10 = Ligne[a1].lineData;
+ v11 = v10[2 * i];
+ v50 = v10[2 * i + 1];
+
v12 = v8;
a6[v12] = v11;
a6[v12 + 1] = v50;
@@ -692,9 +702,9 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, i
v13 = 0;
if (Ligne[v34].field0 > 0) {
do {
- v14 = Ligne[v34].fieldC;
- v15 = (int16)READ_LE_UINT16(v14 + 4 * v13);
- v50 = (int16)READ_LE_UINT16(v14 + 4 * v13 + 2);
+ v14 = Ligne[v34].lineData;
+ v15 = v14[2 * v13];
+ v50 = v14[2 * v13 + 1];
v16 = v8;
a6[v16] = v15;
@@ -712,9 +722,10 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, i
}
if (v36 > a4) {
for (j = v7; j > 0; --j) {
- v18 = Ligne[v36].fieldC;
- v19 = (int16)READ_LE_UINT16(v18 + 4 * j);
- v50 = (int16)READ_LE_UINT16(v18 + 4 * j + 2);
+ v18 = Ligne[v36].lineData;
+ v19 = v18[2 * j];
+ v50 = v18[2 * j + 1];
+
v20 = v8;
a6[v20] = v19;
a6[v20 + 1] = v50;
@@ -725,9 +736,10 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, i
if ((int)(v36 - 1) > a4) {
do {
for (k = Ligne[v35].field0 - 1; k > 0; --k) {
- v22 = Ligne[v35].fieldC;
- v23 = (int16)READ_LE_UINT16(v22 + 4 * k);
- v50 = (int16)READ_LE_UINT16(v22 + 4 * k + 2);
+ v22 = Ligne[v35].lineData;
+ v23 = v22[2 * k];
+ v50 = v22[2 * k + 1];
+
v24 = v8;
a6[v24] = v23;
a6[v24 + 1] = v50;
@@ -745,9 +757,10 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, i
if (a5 > v7) {
v29 = v7;
do {
- v30 = Ligne[a4].fieldC;
- v31 = (int16)READ_LE_UINT16(v30 + 4 * v29);
- v50 = (int16)READ_LE_UINT16(v30 + 4 * v29 + 2);
+ v30 = Ligne[a4].lineData;
+ v31 = v30[2 * v29];
+ v50 = v30[2 * v29 + 1];
+
v32 = v8;
a6[v32] = v31;
a6[v32 + 1] = v50;
@@ -759,9 +772,10 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, i
} else {
v25 = v7;
do {
- v26 = Ligne[a4].fieldC;
- v27 = (int16)READ_LE_UINT16(v26 + 4 * v25);
- v50 = (int16)READ_LE_UINT16(v26 + 4 * v25 + 2);
+ v26 = Ligne[a4].lineData;
+ v27 = v26[2 * v25];
+ v50 = v26[2 * v25 + 1];
+
v28 = v8;
a6[v28] = v27;
a6[v28 + 1] = v50;
@@ -778,29 +792,29 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6,
int v9;
int v10;
int i;
- byte *v12;
+ int16 *v12;
int v13;
int v14;
int v15;
int v16;
- byte *v17;
+ int16 *v17;
int v18;
int v19;
int j;
- byte *v21;
+ int16 *v21;
int v22;
int v23;
int v24;
int k;
- byte *v26;
+ int16 *v26;
int v27;
int v28;
int v29;
- byte *v30;
+ int16 *v30;
int v31;
int v32;
int v33;
- byte *v34;
+ int16 *v34;
int v35;
int v36;
int v38;
@@ -813,11 +827,11 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6,
v40 = a3;
if (a4 < a1) {
for (i = a2; Ligne[a1].field0 > i; ++i) {
- v12 = Ligne[a1].fieldC;
- v13 = (int16)READ_LE_UINT16(v12 + 4 * i);
- v50 = (int16)READ_LE_UINT16(v12 + 4 * i + 2);
+ v12 = Ligne[a1].lineData;
+ v13 = v12[2 * i];
+ v50 = v12[2 * i + 1];
+
v14 = v40;
-
a6[v14] = v13;
a6[v14 + 1] = v50;
a6[v14 + 2] = Ligne[a1].field6;
@@ -830,9 +844,10 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6,
v16 = 0;
if (Ligne[v15].field0 > 0) {
do {
- v17 = Ligne[v15].fieldC;
- v18 = (int16)READ_LE_UINT16(v17 + 4 * v16);
- v50 = (int16)READ_LE_UINT16(v17 + 4 * v16 + 2);
+ v17 = Ligne[v15].lineData;
+ v18 = v17[2 * v16];
+ v50 = v17[2 * v16 + 1];
+
v19 = v40;
a6[v19] = v18;
a6[v19 + 1] = v50;
@@ -850,11 +865,11 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6,
}
if (a4 > v9) {
for (j = v10; j > 0; --j) {
- v21 = Ligne[v9].fieldC;
- v22 = (int16)READ_LE_UINT16(v21 + 4 * j);
- v50 = (int16)READ_LE_UINT16(v21 + 4 * j + 2);
+ v21 = Ligne[v9].lineData;
+ v22 = v21[2 * j];
+ v50 = v21[2 * j + 1];
+
v23 = v40;
-
a6[v23] = v22;
a6[v23 + 1] = v50;
a6[v23 + 2] = Ligne[v9].field8;
@@ -865,9 +880,10 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6,
v24 = a9;
while (a4 != v24) {
for (k = Ligne[v24].field0 - 1; k > 0; --k) {
- v26 = Ligne[v24].fieldC;
- v27 = (int16)READ_LE_UINT16(v26 + 4 * k);
- v50 = (int16)READ_LE_UINT16(v26 + 4 * k + 2);
+ v26 = Ligne[v24].lineData;
+ v27 = v26[2 * k];
+ v50 = v26[2 * k + 1];
+
v28 = v40;
a6[v28] = v27;
a6[v28 + 1] = v50;
@@ -887,11 +903,11 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6,
v33 = v10;
v39 = a4;
do {
- v34 = Ligne[v39].fieldC;
- v35 = (int16)READ_LE_UINT16(v34 + 4 * v33);
- v50 = (int16)READ_LE_UINT16(v34 + 4 * v33 + 2);
- v36 = v40;
+ v34 = Ligne[v39].lineData;
+ v35 = v34[2 * v33];
+ v50 = v34[2 * v33 + 1];
+ v36 = v40;
a6[v36] = v35;
a6[v36 + 1] = v50;
a6[v36 + 2] = Ligne[v39].field6;
@@ -903,9 +919,10 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6,
v29 = v10;
v38 = a4;
do {
- v30 = Ligne[v38].fieldC;
- v31 = (int16)READ_LE_UINT16(v30 + 4 * v29);
- v50 = (int16)READ_LE_UINT16(v30 + 4 * v29 + 2);
+ v30 = Ligne[v38].lineData;
+ v31 = v30[2 * v29];
+ v50 = v30[2 * v29 + 1];
+
v32 = v40;
a6[v32] = v31;
a6[v32 + 1] = v50;
@@ -1232,13 +1249,13 @@ LABEL_186:
int LinesManager::GENIAL(int a1, int a2, int a3, int a4, int a5, int a6, int a7, int16 *a8, int a9) {
int v9;
- byte *v10;
+ int16 *v10;
int v11;
- byte *v12;
- byte *v13;
+ int16 *v12;
+ int16 *v13;
int v14;
int v15;
- byte *v16;
+ int16 *v16;
int v17;
int v18;
int v19;
@@ -1250,7 +1267,7 @@ int LinesManager::GENIAL(int a1, int a2, int a3, int a4, int a5, int a6, int a7,
int v25;
int v26;
int v27;
- byte *v28;
+ int16 *v28;
int v29;
int v30;
int v31;
@@ -1335,62 +1352,65 @@ LABEL_112:
a8[v9 + 2] = -1;
return -1;
}
- v10 = Ligne[a1].fieldC;
- v98 = (int16)READ_LE_UINT16(v10);
- v97 = (int16)READ_LE_UINT16(v10 + 2);
+ v10 = Ligne[a1].lineData;
+ v98 = v10[0];
+ v97 = v10[1];
v92 = a1;
while (1) {
v86 = v92 - 1;
v11 = 2 * Ligne[v92 - 1].field0;
- v12 = Ligne[v92 - 1].fieldC;
- if (v12 == g_PTRNUL)
+
+ v12 = Ligne[v92 - 1].lineData;
+ if (v12 == (int16 *)g_PTRNUL)
break;
- while ((int16)READ_LE_UINT16(v12 + 2 * v11 - 4) != v98 || v97 != (int16)READ_LE_UINT16(v12 + 2 * v11 - 2)) {
+ while (v12[v11 - 2] != v98 || v97 != v12[v11 - 1]) {
--v86;
if (_vm->_objectsManager.DERLIGNE - 1 != v86) {
v11 = 2 * Ligne[v86].field0;
- v12 = Ligne[v86].fieldC;
- if (v12 != g_PTRNUL)
+ v12 = Ligne[v86].lineData;
+ if (v12 != (int16 *)g_PTRNUL)
continue;
}
goto LABEL_11;
}
+
v92 = v86;
- v98 = (int16)READ_LE_UINT16(v12);
- v97 = (int16)READ_LE_UINT16(v12 + 2);
+ v98 = v12[0];
+ v97 = v12[1];
}
LABEL_11:
- v13 = Ligne[a1].fieldC;
+ v13 = Ligne[a1].lineData;
v14 = 2 * Ligne[a1].field0;
- v95 = (int16)READ_LE_UINT16(v13 + 2 * v14 - 4);
- v93 = (int16)READ_LE_UINT16(v13 + 2 * v14 - 2);
+ v95 = v13[v14 - 2];
+ v93 = v13[v14 - 1];
v91 = a1;
- while (1) {
+
+ for (;;) {
v87 = v91 + 1;
v15 = 2 * Ligne[v91 + 1].field0;
- v16 = Ligne[v91 + 1].fieldC;
- if (g_PTRNUL == v16)
+ v16 = Ligne[v91 + 1].lineData;
+ if (v16 == (int16 *)g_PTRNUL)
break;
while (1) {
v65 = v15;
- v17 = (int16)READ_LE_UINT16(v16 + 2 * v15 - 4);
- if ((int16)READ_LE_UINT16(v16) == v95) {
- if (v93 == (int16)READ_LE_UINT16(v16 + 2))
+ v17 = v16[v15 - 2];
+ if (v16[0] == v95) {
+ if (v93 == v16[1])
break;
}
++v87;
if (v87 != TOTAL_LIGNES + 1) {
v15 = 2 * Ligne[v87].field0;
- v16 = Ligne[v87].fieldC;
- if (v16 != g_PTRNUL)
+ v16 = Ligne[v87].lineData;
+ if (v16 != (int16 *)g_PTRNUL)
continue;
}
goto LABEL_17;
}
v91 = v87;
v95 = v17;
- v93 = (int16)READ_LE_UINT16(v16 + 2 * v65 - 2);
+ v93 = v16[v65 - 1];
}
LABEL_17:
v18 = a3 - a5;
@@ -1422,6 +1442,7 @@ LABEL_17:
if (v85 + 1 > 0) {
v51 = _vm->_globals.BufLig;
do {
+error("v51 is an array, not an int");
v24 = v23;
*((uint16 *)v51 + v24) = v82;
*((uint16 *)v51 + v24 + 1) = v81;
@@ -1455,15 +1476,15 @@ LABEL_17:
}
for (i = v92; i < v91 + 1; ++i) {
v27 = 2 * Ligne[i].field0;
- v28 = Ligne[i].fieldC;
- if (g_PTRNUL == v28)
- error("erreur dans da routine genial");
- v29 = *(uint16 *)v28;
- v30 = (int16)READ_LE_UINT16(v28 + 2);
- v59 = (int16)READ_LE_UINT16(v28 + 2);
+ v28 = Ligne[i].lineData;
+ if (v28 == (int16 *)g_PTRNUL)
+ error("error in genial routine");
+ v29 = v28[0];
+ v30 = v28[1];
+ v59 = v28[1];
v31 = v27;
- v32 = (int16)READ_LE_UINT16(v28 + 2 * v27 - 4);
- v33 = (int16)READ_LE_UINT16(v28 + 2 * v31 - 2);
+ v32 = v28[v27 - 2];
+ v33 = v28[v31 - 1];
if (i == v92) {
v72 = v33;
if (v30 <= v33)
@@ -1727,32 +1748,32 @@ byte *LinesManager::PARCOURS2(int a1, int a2, int a3, int a4) {
int v67;
int v68;
int i;
- byte *v70;
+ int16 *v70;
int v71;
int v72;
int j;
- byte *v74;
+ int16 *v74;
int v75;
int v76;
int v77;
int v78;
int v79;
int v80;
- byte *v81;
+ int16 *v81;
int v82;
int v83;
- byte *v84;
+ int16 *v84;
int v85;
int v86;
int v87;
int v88;
int v89;
int v90;
- byte *v91;
+ int16 *v91;
int v92;
int v93;
int v94;
- byte *v95;
+ int16 *v95;
int v96;
int v97;
int v98;
@@ -2248,9 +2269,9 @@ LABEL_201:
LABEL_234:
if (v115 < v121) {
for (i = v114; Ligne[v115].field0 > i; ++i) {
- v70 = Ligne[v115].fieldC;
- v119 = (int16)READ_LE_UINT16(v70 + 4 * i);
- v118 = (int16)READ_LE_UINT16(v70 + 4 * i + 2);
+ v70 = Ligne[v115].lineData;
+ v119 = v70[2 * i];
+ v118 = v70[2 * i + 1];
v71 = v112;
_vm->_globals.super_parcours[v71] = v119;
_vm->_globals.super_parcours[v71 + 1] = v118;
@@ -2264,9 +2285,9 @@ LABEL_234:
v72 = 0;
v110 = v116;
for (j = v116; Ligne[j].field0 > v72; j = v116) {
- v74 = Ligne[v110].fieldC;
- v119 = (int16)READ_LE_UINT16(v74 + 4 * v72);
- v118 = (int16)READ_LE_UINT16(v74 + 4 * v72 + 2);
+ v74 = Ligne[v110].lineData;
+ v119 = v74[2 * v72];
+ v118 = v74[2 * v72 + 1];
v75 = v112;
_vm->_globals.super_parcours[v75] = v119;
_vm->_globals.super_parcours[v75 + 1] = v118;
@@ -2314,9 +2335,10 @@ LABEL_200:
if (v114 > 0) {
v98 = v115;
do {
- v81 = Ligne[v98].fieldC;
- v119 = (int16)READ_LE_UINT16(v81 + 4 * v80);
- v118 = (int16)READ_LE_UINT16(v81 + 4 * v80 + 2);
+ v81 = Ligne[v98].lineData;
+ v119 = v81[2 * v80];
+ v118 = v81[2 * v80 + 1];
+
v82 = v112;
_vm->_globals.super_parcours[v82] = v119;
_vm->_globals.super_parcours[v82 + 1] = v118;
@@ -2333,9 +2355,9 @@ LABEL_200:
if (v83 > -1) {
v109 = v117;
do {
- v84 = Ligne[v109].fieldC;
- v119 = (int16)READ_LE_UINT16(v84 + 4 * v83);
- v118 = (int16)READ_LE_UINT16(v84 + 4 * v83 + 2);
+ v84 = Ligne[v109].lineData;
+ v119 = v84[2 * v83];
+ v118 = v84[2 * v83 + 1];
v85 = v112;
_vm->_globals.super_parcours[v85] = v119;
_vm->_globals.super_parcours[v85 + 1] = v118;
@@ -2379,10 +2401,10 @@ LABEL_200:
v94 = v114;
v100 = v121;
do {
- v95 = Ligne[v100].fieldC;;
- v96 = (int16)READ_LE_UINT16(v95 + 4 * v94 + 2);
+ v95 = Ligne[v100].lineData;
+ v96 = v95[2 * v94 + 1];
v97 = v112;
- _vm->_globals.super_parcours[v97] = (int16)READ_LE_UINT16(v95 + 4 * v94);
+ _vm->_globals.super_parcours[v97] = v95[2 * v94];
_vm->_globals.super_parcours[v97 + 1] = v96;
_vm->_globals.super_parcours[v97 + 2] = Ligne[v100].field6;
_vm->_globals.super_parcours[v97 + 3] = 0;
@@ -2394,10 +2416,10 @@ LABEL_200:
v90 = v114;
v99 = v121;
do {
- v91 = Ligne[v99].fieldC;
- v92 = (int16)READ_LE_UINT16(v91 + 4 * v90 + 2);
+ v91 = Ligne[v99].lineData;
+ v92 = v91[2 * v90 + 1];
v93 = v112;
- _vm->_globals.super_parcours[v93] = (int16)READ_LE_UINT16(v91 + 4 * v90);
+ _vm->_globals.super_parcours[v93] = v91[2 * v90];
_vm->_globals.super_parcours[v93 + 1] = v92;
_vm->_globals.super_parcours[v93 + 2] = Ligne[v99].field8;
_vm->_globals.super_parcours[v93 + 3] = 0;
@@ -3593,12 +3615,12 @@ int LinesManager::PLAN_TEST(int a1, int a2, int a3, int a4, int a5, int a6) {
int v12;
int v13;
int v14;
- byte *v15;
+ int16 *v15;
int v16;
int v17;
int v18;
int v19;
- byte *v20;
+ int16 *v20;
int v21;
int v22;
int v23;
@@ -3741,9 +3763,9 @@ LABEL_60:
v32 = v34;
v25 = _vm->_globals.essai0;
do {
- v15 = Ligne[v32].fieldC;
- v16 = (int16)READ_LE_UINT16(v15 + 4 * v14);
- v29 = (int16)READ_LE_UINT16(v15 + 4 * v14 + 2);
+ v15 = Ligne[v32].lineData;
+ v16 = v15[2 * v14];
+ v29 = v15[2 * v14 + 1];
if (!a6) {
v17 = v41;
_vm->_globals.super_parcours[v17] = v16;
@@ -3769,9 +3791,9 @@ LABEL_60:
v31 = v34;
v26 = _vm->_globals.essai0;
do {
- v20 = Ligne[v31].fieldC;
- v21 = (int16)READ_LE_UINT16(v20 + 4 * v19);
- v30 = (int16)READ_LE_UINT16(v20 + 4 * v19 + 2);
+ v20 = Ligne[v31].lineData;
+ v21 = v20[2 * v19];
+ v30 = v20[2 * v19 + 1];
if (a6) {
v23 = v41;
v26[v23] = v21;
@@ -3797,17 +3819,17 @@ LABEL_60:
int LinesManager::TEST_LIGNE(int a1, int a2, int *a3, int *a4, int *a5) {
int i;
int v6;
- byte *v7;
+ int16 *v7;
int v8;
int v9;
int v10;
int v11;
- byte *v12;
+ int16 *v12;
int v13;
int v14;
int v15;
int v16;
- byte *v17;
+ int16 *v17;
int v18;
int v19;
int v20;
@@ -3824,11 +3846,11 @@ int LinesManager::TEST_LIGNE(int a1, int a2, int *a3, int *a4, int *a5) {
v25 = _vm->_objectsManager.DERLIGNE + 1;
for (i = (int)(_vm->_objectsManager.DERLIGNE + 1); i < _vm->_linesManager.TOTAL_LIGNES + 1; i = v25) {
v6 = i;
- v7 = Ligne[i].fieldC;
+ v7 = Ligne[i].lineData;
v8 = Ligne[v6].field0;
- v23 = (int16)READ_LE_UINT16(v7 + 4 * v8 - 4);
- v9 = (int16)READ_LE_UINT16(v7 + 4 * v8 - 2);
- if (*v7 == a1 && a2 == (int16)READ_LE_UINT16(v7 + 2)) {
+ v23 = v7[2 * v8 - 2];
+ v9 = v7[2 * v8 - 1];
+ if (v7[0] == a1 && a2 == v7[1]) {
v24 = v25;
v26 = 1;
*a3 = 1;
@@ -3848,9 +3870,9 @@ LABEL_12:
if (*a3 == 1) {
v10 = v24;
v11 = Ligne[v10].field0;
- v12 = Ligne[v10].fieldC;
- v13 = (int16)READ_LE_UINT16(v12 + 4 * v11 - 4);
- v14 = (int16)READ_LE_UINT16(v12 + 4 * v11 - 2);
+ v12 = Ligne[v10].lineData;
+ v13 = v12[2 * v11 - 2];
+ v14 = v12[2 * v11 - 1];
v15 = Ligne[v10].field6;
if (v15 == 5 || v15 == 1)
v14 += 2;
@@ -3863,9 +3885,9 @@ LABEL_12:
*a5 = v28;
}
if (v26 == 1 && *a3 == 2) {
- v17 = Ligne[v25].fieldC;
- v18 = *v17;
- v19 = (int16)READ_LE_UINT16(v17 + 2);
+ v17 = Ligne[v25].lineData;
+ v18 = v17[0];
+ v19 = v17[1];
v20 = Ligne[v24].field6;
if (v20 == 5 || v20 == 1)
v19 -= 2;
diff --git a/engines/hopkins/lines.h b/engines/hopkins/lines.h
index da9c897c28..f02cc4c427 100644
--- a/engines/hopkins/lines.h
+++ b/engines/hopkins/lines.h
@@ -42,7 +42,7 @@ struct LigneItem {
int field4;
int field6;
int field8;
- byte *fieldC;
+ int16 *lineData;
};
struct SmoothItem {
diff --git a/engines/hopkins/objects.cpp b/engines/hopkins/objects.cpp
index f7e72b0cef..100f836542 100644
--- a/engines/hopkins/objects.cpp
+++ b/engines/hopkins/objects.cpp
@@ -3581,28 +3581,28 @@ byte *ObjectsManager::PARC_VOITURE(int a1, int a2, int a3, int a4) {
int v34;
int v35;
int i;
- byte *v37;
+ int16 *v37;
int v38;
int v39;
int v40;
- byte *v41;
+ int16 *v41;
int v42;
int v43;
int k;
- byte *v45;
+ int16 *v45;
int v46;
int v47;
int v48;
int v49;
- byte *v50;
+ int16 *v50;
int v51;
int v52;
int v53;
- byte *v54;
+ int16 *v54;
int v55;
int v56;
int v57;
- byte *v58;
+ int16 *v58;
int v59;
int v60;
int v61;
@@ -3820,9 +3820,9 @@ LABEL_90:
v34 = v68;
v35 = v68;
for (i = _vm->_linesManager.Ligne[v69].field0; v35 < (i - 2); i = _vm->_linesManager.Ligne[v69].field0) {
- v37 = _vm->_linesManager.Ligne[v69].fieldC;
- v38 = (int16)READ_LE_UINT16(v37 + 4 * v35);
- int v37_2 = (int16)READ_LE_UINT16(v37 + 4 * v35 + 2);
+ v37 = _vm->_linesManager.Ligne[v69].lineData;
+ v38 = v37[2 * v35];
+ int v37_2 = v37[2 * v35 + 1];
v39 = v67;
_vm->_globals.super_parcours[v39] = v38;
_vm->_globals.super_parcours[v39 + 1] = v37_2;
@@ -3834,8 +3834,8 @@ LABEL_90:
}
for (j = v69 + 1; j < v73; ++j) {
if (_vm->_linesManager.PLAN_TEST(
- (int16)READ_LE_UINT16(_vm->_linesManager.Ligne[j].fieldC),
- (int16)READ_LE_UINT16(_vm->_linesManager.Ligne[j].fieldC + 2),
+ _vm->_linesManager.Ligne[j].lineData[0],
+ _vm->_linesManager.Ligne[j].lineData[1],
v67,
j,
v73,
@@ -3850,9 +3850,9 @@ LABEL_88:
v40 = 0;
if (_vm->_linesManager.Ligne[j].field0 - 2 > 0) {
do {
- v41 = _vm->_linesManager.Ligne[j].fieldC;
- v42 = (int16)READ_LE_UINT16(v41 + 4 * v40);
- int v41_2 = (int16)READ_LE_UINT16(v41 + 4 * v40 + 2);
+ v41 = _vm->_linesManager.Ligne[j].lineData;
+ v42 = v41[2 * v40];
+ int v41_2 = v41[2 * v40 + 1];
v43 = v67;
_vm->_globals.super_parcours[v43] = v42;
_vm->_globals.super_parcours[v43 + 1] = v41_2;
@@ -3868,9 +3868,9 @@ LABEL_88:
}
if (v69 > v73) {
for (k = v68; k > 0; --k) {
- v45 = _vm->_linesManager.Ligne[v69].fieldC;
- v46 = (int16)READ_LE_UINT16(v45 + 4 * k);
- int v45_2 = (int16)READ_LE_UINT16(v45 + 4 * k + 2);
+ v45 = _vm->_linesManager.Ligne[v69].lineData;
+ v46 = v45[2 * k];
+ int v45_2 = v45[2 * k + 1];
v47 = v67;
_vm->_globals.super_parcours[v47] = v46;
_vm->_globals.super_parcours[v47 + 1] = v45_2;
@@ -3881,8 +3881,8 @@ LABEL_88:
for (l = v69 - 1; l > v73; --l) {
v48 = l;
if (_vm->_linesManager.PLAN_TEST(
- (int16)READ_LE_UINT16(_vm->_linesManager.Ligne[l].fieldC + 4 * _vm->_linesManager.Ligne[v48].field0 - 4),
- (int16)READ_LE_UINT16(_vm->_linesManager.Ligne[l].fieldC + 4 * _vm->_linesManager.Ligne[v48].field0 - 2),
+ _vm->_linesManager.Ligne[l].lineData[2 * _vm->_linesManager.Ligne[v48].field0 - 2],
+ _vm->_linesManager.Ligne[l].lineData[2 * _vm->_linesManager.Ligne[v48].field0 - 1],
v67,
l,
v73,
@@ -3891,9 +3891,9 @@ LABEL_88:
v49 = _vm->_linesManager.Ligne[v48].field0 - 2;
if ((_vm->_linesManager.Ligne[v48].field0 - 2) > 0) {
do {
- v50 = _vm->_linesManager.Ligne[l].fieldC;
- v51 = (int16)READ_LE_UINT16(v50 + 4 * v49);
- int v50_2 = (int16)READ_LE_UINT16(v50 + 4 * v49 + 2);
+ v50 = _vm->_linesManager.Ligne[l].lineData;
+ v51 = v50[2 * v49];
+ int v50_2 = v50[2 * v49 + 1];
v52 = v67;
_vm->_globals.super_parcours[v52] = v51;
_vm->_globals.super_parcours[v52 + 1] = v50_2;
@@ -3912,9 +3912,9 @@ LABEL_88:
if (v68 < v72) {
v57 = v68;
do {
- v58 = _vm->_linesManager.Ligne[v73].fieldC;
- v59 = (int16)READ_LE_UINT16(v58 + 4 * v57);
- int v58_2 = (int16)READ_LE_UINT16(v58 + 4 * v57 + 2);
+ v58 = _vm->_linesManager.Ligne[v73].lineData;
+ v59 = v58[2 * v57];
+ int v58_2 = v58[2 * v57 + 1];
v60 = v67;
_vm->_globals.super_parcours[v60] = v59;
_vm->_globals.super_parcours[v60 + 1] = v58_2;
@@ -3927,9 +3927,9 @@ LABEL_88:
} else {
v53 = v68;
do {
- v54 = _vm->_linesManager.Ligne[v73].fieldC;
- v55 = (int16)READ_LE_UINT16(v54 + 4 * v53);
- int v54_2 = (int16)READ_LE_UINT16(v54 + 4 * v53 + 2);
+ v54 = _vm->_linesManager.Ligne[v73].lineData;
+ v55 = v54[2 * v53];
+ int v54_2 = v54[2 * v53 + 1];
v56 = v67;
_vm->_globals.super_parcours[2 * v56] = v55;
_vm->_globals.super_parcours[2 * v56 + 1] = v54_2;