diff options
Diffstat (limited to 'engines/hopkins')
-rw-r--r-- | engines/hopkins/globals.cpp | 12 | ||||
-rw-r--r-- | engines/hopkins/globals.h | 6 | ||||
-rw-r--r-- | engines/hopkins/lines.cpp | 344 | ||||
-rw-r--r-- | engines/hopkins/lines.h | 6 | ||||
-rw-r--r-- | engines/hopkins/objects.cpp | 26 |
5 files changed, 203 insertions, 191 deletions
diff --git a/engines/hopkins/globals.cpp b/engines/hopkins/globals.cpp index b7e13011c0..8253593e99 100644 --- a/engines/hopkins/globals.cpp +++ b/engines/hopkins/globals.cpp @@ -338,9 +338,9 @@ void Globals::clearAll() { ZONEP[idx].field4 = 0; } - essai0 = g_PTRNUL; - essai1 = g_PTRNUL; - essai2 = g_PTRNUL; + essai0 = (int16 *)g_PTRNUL; + essai1 = (int16 *)g_PTRNUL; + essai2 = (int16 *)g_PTRNUL; BufLig = g_PTRNUL; chemin = g_PTRNUL; @@ -368,9 +368,9 @@ void Globals::clearAll() { SAUVEGARDE = (Sauvegarde *)malloc(sizeof(Sauvegarde)); memset(SAUVEGARDE, 0, sizeof(Sauvegarde)); - essai0 = BUFFERTAPE; - essai1 = BUFFERTAPE + 25000; - essai2 = BUFFERTAPE + 50000; + essai0 = (int16 *)BUFFERTAPE; + essai1 = (int16 *)(BUFFERTAPE + 25000); + essai2 = (int16 *)(BUFFERTAPE + 50000); BufLig = (BUFFERTAPE + 75000); largeur_boite = 240; TEXTE_FORMATE = 300; diff --git a/engines/hopkins/globals.h b/engines/hopkins/globals.h index fad08c9e0f..a3b9347de5 100644 --- a/engines/hopkins/globals.h +++ b/engines/hopkins/globals.h @@ -355,9 +355,9 @@ public: byte *SPRITE_ECRAN; Sauvegarde *SAUVEGARDE; byte *BUFFERTAPE; - byte *essai0; - byte *essai1; - byte *essai2; + int16 *essai0; + int16 *essai1; + int16 *essai2; byte *Bufferobjet; int INVENTAIRE[36]; TriItem Tri[51]; diff --git a/engines/hopkins/lines.cpp b/engines/hopkins/lines.cpp index e189141e88..8fbee5c32f 100644 --- a/engines/hopkins/lines.cpp +++ b/engines/hopkins/lines.cpp @@ -640,7 +640,7 @@ void LinesManager::INIPARCOURS() { } while (v8 != 400); } -int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, int a7) { +int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, int a7) { int v7; int v8; int i; @@ -681,9 +681,9 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, in v11 = (int16)READ_LE_UINT16(v10 + 4 * i); v50 = (int16)READ_LE_UINT16(v10 + 4 * i + 2); v12 = v8; - WRITE_LE_UINT16(a6 + 2 * v12, v11); - WRITE_LE_UINT16(a6 + 2 * v12 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v12 + 4, Ligne[a1].field6); + a6[v12] = v11; + a6[v12 + 1] = v50; + a6[v12 + 2] = Ligne[a1].field6; v8 += a7; } v34 = a1 + 1; @@ -696,9 +696,10 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, in v15 = (int16)READ_LE_UINT16(v14 + 4 * v13); v50 = (int16)READ_LE_UINT16(v14 + 4 * v13 + 2); v16 = v8; - WRITE_LE_UINT16(a6 + 2 * v16, v15); - WRITE_LE_UINT16(a6 + 2 * v16 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v16 + 4, Ligne[v34].field6); + + a6[v16] = v15; + a6[v16 + 1] = v50; + a6[v16 + 2] = Ligne[v34].field6; v8 += a7; ++v13; } while (Ligne[v34].field0 > v13); @@ -715,9 +716,9 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, in v19 = (int16)READ_LE_UINT16(v18 + 4 * j); v50 = (int16)READ_LE_UINT16(v18 + 4 * j + 2); v20 = v8; - WRITE_LE_UINT16(a6 + 2 * v20, v19); - WRITE_LE_UINT16(a6 + 2 * v20 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v20 + 4, Ligne[v36].field8); + a6[v20] = v19; + a6[v20 + 1] = v50; + a6[v20 + 2] = Ligne[v36].field8; v8 += a7; } v35 = v36 - 1; @@ -728,9 +729,9 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, in v23 = (int16)READ_LE_UINT16(v22 + 4 * k); v50 = (int16)READ_LE_UINT16(v22 + 4 * k + 2); v24 = v8; - WRITE_LE_UINT16(a6 + 2 * v24, v23); - WRITE_LE_UINT16(a6 + 2 * v24 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v24 + 4, Ligne[v35].field8); + a6[v24] = v23; + a6[v24 + 1] = v50; + a6[v24 + 2] = Ligne[v35].field8; v8 += a7; } --v35; @@ -748,9 +749,9 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, in v31 = (int16)READ_LE_UINT16(v30 + 4 * v29); v50 = (int16)READ_LE_UINT16(v30 + 4 * v29 + 2); v32 = v8; - WRITE_LE_UINT16(a6 + 2 * v32, v31); - WRITE_LE_UINT16(a6 + 2 * v32 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v32 + 4, Ligne[a4].field6); + a6[v32] = v31; + a6[v32 + 1] = v50; + a6[v32 + 2] = Ligne[a4].field6; v8 += a7; ++v29; } while (a5 > v29); @@ -762,9 +763,9 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, in v27 = (int16)READ_LE_UINT16(v26 + 4 * v25); v50 = (int16)READ_LE_UINT16(v26 + 4 * v25 + 2); v28 = v8; - WRITE_LE_UINT16(a6 + 2 * v28, v27); - WRITE_LE_UINT16(a6 + 2 * v28 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v28 + 4, Ligne[a4].field8); + a6[v28] = v27; + a6[v28 + 1] = v50; + a6[v28 + 2] = Ligne[a4].field8; v8 += a7; --v25; } while (a5 < v25); @@ -773,7 +774,7 @@ int LinesManager::CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, in return v8; } -int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, int a7, int a8, int a9) { +int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6, int a7, int a8, int a9) { int v9; int v10; int i; @@ -816,9 +817,10 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, i v13 = (int16)READ_LE_UINT16(v12 + 4 * i); v50 = (int16)READ_LE_UINT16(v12 + 4 * i + 2); v14 = v40; - WRITE_LE_UINT16(a6 + 2 * v14, v13); - WRITE_LE_UINT16(a6 + 2 * v14 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v14 + 4, Ligne[a1].field6); + + a6[v14] = v13; + a6[v14 + 1] = v50; + a6[v14 + 2] = Ligne[a1].field6; v40 += a7; } v15 = a1 + 1; @@ -832,9 +834,9 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, i v18 = (int16)READ_LE_UINT16(v17 + 4 * v16); v50 = (int16)READ_LE_UINT16(v17 + 4 * v16 + 2); v19 = v40; - WRITE_LE_UINT16(a6 + 2 * v19, v18); - WRITE_LE_UINT16(a6 + 2 * v19 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v19 + 4, Ligne[v15].field6); + a6[v19] = v18; + a6[v19 + 1] = v50; + a6[v19 + 2] = Ligne[v15].field6; v40 += a7; ++v16; } while (Ligne[v15].field0 > v16); @@ -848,13 +850,14 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, i } if (a4 > v9) { for (j = v10; j > 0; --j) { - v21 = Ligne[v9].fieldC;; + v21 = Ligne[v9].fieldC; v22 = (int16)READ_LE_UINT16(v21 + 4 * j); v50 = (int16)READ_LE_UINT16(v21 + 4 * j + 2); v23 = v40; - WRITE_LE_UINT16(a6 + 2 * v23, v22); - WRITE_LE_UINT16(a6 + 2 * v23 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v23 + 4, Ligne[v9].field8); + + a6[v23] = v22; + a6[v23 + 1] = v50; + a6[v23 + 2] = Ligne[v9].field8; v40 += a7; } v24 = v9 - 1; @@ -866,9 +869,9 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, i v27 = (int16)READ_LE_UINT16(v26 + 4 * k); v50 = (int16)READ_LE_UINT16(v26 + 4 * k + 2); v28 = v40; - WRITE_LE_UINT16(a6 + 2 * v28, v27); - WRITE_LE_UINT16(a6 + 2 * v28 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v28 + 4, Ligne[v24].field8); + a6[v28] = v27; + a6[v28 + 1] = v50; + a6[v28 + 2] = Ligne[v24].field8; v40 += a7; } --v24; @@ -888,9 +891,10 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, i v35 = (int16)READ_LE_UINT16(v34 + 4 * v33); v50 = (int16)READ_LE_UINT16(v34 + 4 * v33 + 2); v36 = v40; - WRITE_LE_UINT16(a6 + 2 * v36, v35); - WRITE_LE_UINT16(a6 + 2 * v36 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v36 + 4, Ligne[v39].field6); + + a6[v36] = v35; + a6[v36 + 1] = v50; + a6[v36 + 2] = Ligne[v39].field6; v40 += a7; ++v33; } while (a5 > v33); @@ -903,9 +907,9 @@ int LinesManager::CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, i v31 = (int16)READ_LE_UINT16(v30 + 4 * v29); v50 = (int16)READ_LE_UINT16(v30 + 4 * v29 + 2); v32 = v40; - WRITE_LE_UINT16(a6 + 2 * v32, v31); - WRITE_LE_UINT16(a6 + 2 * v32 + 2, v50); - WRITE_LE_UINT16(a6 + 2 * v32 + 4, Ligne[v38].field8); + a6[v32] = v31; + a6[v32 + 1] = v50; + a6[v32 + 2] = Ligne[v38].field8; v40 += a7; --v29; } while (a5 < v29); @@ -1127,7 +1131,7 @@ int LinesManager::MIRACLE(int a1, int a2, int a3, int a4, int a5) { do { if (colision2_ligne(v41, v40 - v22, &v47, &v46, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v46) { - v23 = GENIAL(v46, v47, v41, v40 - v22, v41, v40 - v39, v7, (byte *)&_vm->_globals.super_parcours[0], 4); + v23 = GENIAL(v46, v47, v41, v40 - v22, v41, v40 - v39, v7, &_vm->_globals.super_parcours[0], 4); if (v23 == -1) return 0; v7 = v23; @@ -1155,7 +1159,7 @@ LABEL_186: do { if (colision2_ligne(v41, v25 + v40, &v47, &v46, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v46) { - v26 = GENIAL(v46, v47, v41, v25 + v40, v41, v37 + v40, v7, (byte *)&_vm->_globals.super_parcours[0], 4); + v26 = GENIAL(v46, v47, v41, v25 + v40, v41, v37 + v40, v7, &_vm->_globals.super_parcours[0], 4); if (v26 == -1) return 0; v7 = v26; @@ -1179,7 +1183,7 @@ LABEL_186: do { if (colision2_ligne(v41 - v28, v40, &v47, &v46, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v46) { - v29 = GENIAL(v46, v47, v41 - v28, v40, v41 - v18, v40, v7, (byte *)&_vm->_globals.super_parcours[0], 4); + v29 = GENIAL(v46, v47, v41 - v28, v40, v41 - v18, v40, v7, &_vm->_globals.super_parcours[0], 4); if (v29 == -1) return 0; v7 = v29; @@ -1203,7 +1207,7 @@ LABEL_186: do { if (colision2_ligne(v31 + v41, v40, &v47, &v46, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v46) { - v32 = GENIAL(v46, v47, v31 + v41, v40, v38 + v41, v40, v7, (byte *)&_vm->_globals.super_parcours[0], 4); + v32 = GENIAL(v46, v47, v31 + v41, v40, v38 + v41, v40, v7, &_vm->_globals.super_parcours[0], 4); if (v32 == -1) return 0; v7 = v32; @@ -1226,7 +1230,7 @@ LABEL_186: return 0; } -int LinesManager::GENIAL(int a1, int a2, int a3, int a4, int a5, int a6, int a7, byte *a8, int a9) { +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; int v11; @@ -1326,9 +1330,9 @@ int LinesManager::GENIAL(int a1, int a2, int a3, int a4, int a5, int a6, int a7, if (_vm->_globals.STOP_BUG > 10) { v9 = a7; LABEL_112: - WRITE_LE_UINT16(a8 + 2 * v9, (uint16)-1); - WRITE_LE_UINT16(a8 + 2 * v9 + 2, (uint16)-1); - WRITE_LE_UINT16(a8 + 2 * v9 + 4, (uint16)-1); + a8[v9] = -1; + a8[v9 + 1] = -1; + a8[v9 + 2] = -1; return -1; } v10 = Ligne[a1].fieldC; @@ -2151,7 +2155,7 @@ LABEL_201: if ((uint16)colision2_ligne(a1, a2 - v56, &v125, &v124, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v124) { v57 = v112; - v58 = GENIAL(v124, v125, a1, a2 - v56, a1, a2 - v111, v112, (byte *)&_vm->_globals.super_parcours[0], 4); + v58 = GENIAL(v124, v125, a1, a2 - v56, a1, a2 - v111, v112, &_vm->_globals.super_parcours[0], 4); if (v58 == -1) goto LABEL_282; v112 = v58; @@ -2175,7 +2179,7 @@ LABEL_201: if ((uint16)colision2_ligne(a1, v60 + a2, &v125, &v124, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v124) { v57 = v112; - v61 = GENIAL(v124, v125, a1, v60 + a2, a1, v111 + a2, v112, (byte *)&_vm->_globals.super_parcours[0], 4); + v61 = GENIAL(v124, v125, a1, v60 + a2, a1, v111 + a2, v112, &_vm->_globals.super_parcours[0], 4); if (v61 == -1) goto LABEL_282; v112 = v61; @@ -2199,7 +2203,7 @@ LABEL_201: if ((uint16)colision2_ligne(a1 - v63, a2, &v125, &v124, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v124) { v57 = v112; - v64 = GENIAL(v124, v125, a1 - v63, a2, a1 - v111, a2, v112, (byte *)&_vm->_globals.super_parcours[0], 4); + v64 = GENIAL(v124, v125, a1 - v63, a2, a1 - v111, a2, v112, &_vm->_globals.super_parcours[0], 4); if (v64 == -1) goto LABEL_282; v112 = v64; @@ -2223,7 +2227,7 @@ LABEL_201: if ((uint16)colision2_ligne(v66 + a1, a2, &v125, &v124, _vm->_objectsManager.DERLIGNE + 1, TOTAL_LIGNES) == 1 && _vm->_objectsManager.DERLIGNE < v124) { v57 = v112; - v67 = GENIAL(v124, v125, v66 + a1, a2, v111 + a1, a2, v112, (byte *)&_vm->_globals.super_parcours[0], 4); + v67 = GENIAL(v124, v125, v66 + a1, a2, v111 + a1, a2, v112, &_vm->_globals.super_parcours[0], 4); if (v67 == -1) goto LABEL_282; v112 = v67; @@ -2434,7 +2438,7 @@ int LinesManager::PARC_PERS(int a1, int a2, int a3, int a4, int a5, int a6, int int v14; int v15; int v16; - byte *v17; + int16 *v17; int v18; int v19; int v20; @@ -2443,68 +2447,68 @@ int LinesManager::PARC_PERS(int a1, int a2, int a3, int a4, int a5, int a6, int int v23; int v24; int v25; - byte *v26; + int16 *v26; int v27; - byte *v28; - byte *v29; + int16 *v28; + int16 *v29; int v30; int v31; - byte *v32; + int16 *v32; int v33; int v34; - byte *v35; + int16 *v35; int v36; int v37; - byte *v38; + int16 *v38; int v39; int v40; int v41; - byte *v42; + int16 *v42; int v43; int v44; int v45; int v46; - byte *v47; + int16 *v47; int v48; - byte *v49; - byte *v50; + int16 *v49; + int16 *v50; int v51; int v52; - byte *v53; + int16 *v53; int v54; int v55; int v56; - byte *v57; + int16 *v57; int v58; int v59; - byte *v60; + int16 *v60; int v61; int v62; int v63; - byte *v64; + int16 *v64; int v65; int v66; int v67; int v68; - byte *v69; + int16 *v69; int v70; - byte *v71; - byte *v72; + int16 *v71; + int16 *v72; int v73; int v74; int v76; - byte *v77; - byte *v78; + int16 *v77; + int16 *v78; int v79; - byte *v80; + int16 *v80; int v81; - byte *v82; + int16 *v82; int v83; - byte *v84; + int16 *v84; int v85; - byte *v86; + int16 *v86; int v87; - byte *v88; + int16 *v88; int v89; int v90; int v91; @@ -2611,9 +2615,10 @@ int LinesManager::PARC_PERS(int a1, int a2, int a3, int a4, int a5, int a6, int LABEL_149: v27 = v115; v28 = _vm->_globals.essai0; - WRITE_LE_UINT16(_vm->_globals.essai0 + 2 * v27, (uint16)-1); - WRITE_LE_UINT16(v28 + 2 * v27 + 2, (uint16)-1); - WRITE_LE_UINT16(v28 + 2 * v27 + 4, (uint16)-1); + v28[v27] = -1; + v28[v27 + 1] = -1; + v28[v27 + 2] = -1; + LABEL_150: if (v115) { v127 = 0; @@ -2621,14 +2626,15 @@ LABEL_150: v29 = _vm->_globals.essai0; do { v30 = v137; - _vm->_globals.super_parcours[v30] = (int16)READ_LE_UINT16(v29 + 2 * v116); - _vm->_globals.super_parcours[v30 + 1] = (int16)READ_LE_UINT16(v29 + 2 * v116 + 2); - _vm->_globals.super_parcours[v30 + 2] = (int16)READ_LE_UINT16(v29 + 2 * v116 + 4); + _vm->_globals.super_parcours[v30] = v29[v116]; + _vm->_globals.super_parcours[v30 + 1] = v29[v116 + 1]; + _vm->_globals.super_parcours[v30 + 2] = v29[v116 + 2]; _vm->_globals.super_parcours[v30 + 3] = 0; v116 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v29 + 2 * v116) == -1) { - if ((int16)READ_LE_UINT16(v29 + 2 * v116 + 2) == -1) + + if (v29[v116] == -1) { + if (v29[v116 + 1] == -1) v127 = 1; } } while (v127 != 1); @@ -2775,9 +2781,9 @@ LABEL_103: while (colision2_ligne(v104, v103, &v143, &v142, 0, TOTAL_LIGNES) != 1) { v25 = v115; v26 = _vm->_globals.essai0; - WRITE_LE_UINT16(_vm->_globals.essai0 + 2 * v25, v104); - WRITE_LE_UINT16(v26 + 2 * v25 + 2, v103); - WRITE_LE_UINT16(v26 + 2 * v25 + 4, v91); + v26[v25] = v104; + v26[v25 + 1] = v103; + v26[v25 + 2] = v91; v106 += v102; v105 += v100; v104 = v106 / 1000; @@ -2814,8 +2820,9 @@ LABEL_67: if (colision2_ligne(v15, v110, &v143, &v142, 0, TOTAL_LIGNES) == 1) break; v16 = v115; + v17 = _vm->_globals.essai0; - WRITE_LE_UINT16(_vm->_globals.essai0 + 2 * v16, v112); + v17[v16] = v112; WRITE_LE_UINT16(v17 + 2 * v16 + 2, v110); WRITE_LE_UINT16(v17 + 2 * v16 + 4, v91); v115 += 3; @@ -2833,9 +2840,10 @@ LABEL_70: LABEL_157: v31 = v115; v32 = _vm->_globals.essai0; - WRITE_LE_UINT16(_vm->_globals.essai0 + 2 * v31, (uint16)-1); - WRITE_LE_UINT16(v32 + 2 * v31 + 2, (uint16)-1); - WRITE_LE_UINT16(v32 + 2 * v31 + 4, (uint16)-1); + v32[v31] = -1; + v32[v31 + 1] = -1; + v32[v31 + 2] = -1; + v117 = 0; v33 = v98; v92 = v97; @@ -2850,9 +2858,9 @@ LABEL_165: while (colision2_ligne(v36, v92, &v141, &v140, 0, TOTAL_LIGNES) != 1) { v37 = v117; v38 = _vm->_globals.essai1; - WRITE_LE_UINT16(_vm->_globals.essai1 + 2 * v37, v36); - WRITE_LE_UINT16(v38 + 2 * v37 + 2, v92); - WRITE_LE_UINT16(v38 + 2 * v37 + 4, 7); + v38[v37] = v36; + v38[v37 + 1] = v92; + v38[v37 + 2] = 7; v117 += 3; --v36; if (a3 >= v36) @@ -2886,9 +2894,9 @@ LABEL_181: } v46 = v117; v47 = _vm->_globals.essai1; - WRITE_LE_UINT16(_vm->_globals.essai1 + 2 * v46, a3); - WRITE_LE_UINT16(v47 + 2 * v46 + 2, v43); - WRITE_LE_UINT16(v47 + 2 * v46 + 4, 1); + v47[v46] = a3; + v47[v46 + 1] = v43; + v47[v46 + 2] = 1; v117 += 3; --v43; } while (a4 < v43); @@ -2896,9 +2904,9 @@ LABEL_181: LABEL_194: v48 = v117; v49 = _vm->_globals.essai1; - WRITE_LE_UINT16(_vm->_globals.essai1 + 2 * v48, (uint16)-1); - WRITE_LE_UINT16(v49 + 2 * v48 + 2, (uint16)-1); - WRITE_LE_UINT16(v49 + 2 * v48 + 4, (uint16)-1); + v49[v48] = -1; + v49[v48 + 1] = -1; + v49[v48 + 2] = -1; LABEL_195: if (v117) { v128 = 0; @@ -2906,13 +2914,13 @@ LABEL_195: v50 = _vm->_globals.essai1; do { v51 = v137; - _vm->_globals.super_parcours[v51] = (int16)READ_LE_UINT16(v50 + 2 * v118); - _vm->_globals.super_parcours[v51 + 1] = (int16)READ_LE_UINT16(v50 + 2 * v118 + 2); - _vm->_globals.super_parcours[v51 + 2] = (int16)READ_LE_UINT16(v50 + 2 * v118 + 4); + _vm->_globals.super_parcours[v51] = v50[v118]; + _vm->_globals.super_parcours[v51 + 1] = v50[v118 + 1]; + _vm->_globals.super_parcours[v51 + 2] = v50[v118 + 2]; _vm->_globals.super_parcours[v51 + 3] = 0; v118 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v50 + 2 * v118) == -1 && (int16)READ_LE_UINT16(v50 + 2 * v118 + 2) == -1) + if (v50[v118] == -1 && v50[v118 + 1] == -1) v128 = 1; } while (v128 != 1); } @@ -2942,10 +2950,11 @@ LABEL_189: goto LABEL_202; } v41 = v117; + v42 = _vm->_globals.essai1; - WRITE_LE_UINT16(_vm->_globals.essai1 + 2 * v41, a3); - WRITE_LE_UINT16(v42 + 2 * v41 + 2, v39); - WRITE_LE_UINT16(v42 + 2 * v41 + 4, 5); + v42[v41] = a3; + v42[v41 + 1] = v39; + v42[v41 + 2] = 5; v117 += 3; ++v39; if (a4 <= v39) @@ -2955,9 +2964,9 @@ LABEL_189: while (colision2_ligne(v33, v92, &v141, &v140, 0, TOTAL_LIGNES) != 1) { v34 = v117; v35 = _vm->_globals.essai1; - WRITE_LE_UINT16(_vm->_globals.essai1 + 2 * v34,v33); - WRITE_LE_UINT16(v35 + 2 * v34 + 2, v92); - WRITE_LE_UINT16(v35 + 2 * v34 + 4, 3); + v35[v34] = v33; + v35[v34 + 1] = v92; + v35[v34 + 2] = 3; v117 += 3; ++v33; if (a3 <= v33) @@ -2969,9 +2978,9 @@ LABEL_168: LABEL_202: v52 = v117; v53 = _vm->_globals.essai1; - WRITE_LE_UINT16(_vm->_globals.essai1 + 2 * v52, (uint16)-1); - WRITE_LE_UINT16(v53 + 2 * v52 + 2, (uint16)-1); - WRITE_LE_UINT16(v53 + 2 * v52 + 4, (uint16)-1); + v53[v52] = -1; + v53[v52 + 1] = -1; + v53[v52 + 2] = -1; v117 = 0; v54 = v98; v93 = v97; @@ -2984,9 +2993,9 @@ LABEL_203: while (colision2_ligne(v114, v55, &v139, &v138, 0, TOTAL_LIGNES) != 1) { v56 = v117; v57 = _vm->_globals.essai2; - WRITE_LE_UINT16(_vm->_globals.essai2 + 2 * v56, v114); - WRITE_LE_UINT16(v57 + 2 * v56 + 2, v55); - WRITE_LE_UINT16(v57 + 2 * v56 + 4, 5); + v57[v56] = v114; + v57[v56 + 1] = v55; + v57[v56 + 2] = 5; v117 += 3; ++v55; if (a4 <= v55) @@ -3019,7 +3028,7 @@ LABEL_249: WRITE_LE_UINT16(v77 + 2 * v76 + 4, (uint16)-1); if (v136 != 1) { if (a6 > v144) { - if ((int16)READ_LE_UINT16(_vm->_globals.essai0) != -1 && v142 > v144 && v140 <= v142 && v138 <= v142 && a6 >= v142) { + if (_vm->_globals.essai0[0] != -1 && v142 > v144 && v140 <= v142 && v138 <= v142 && a6 >= v142) { NV_LIGNEDEP = v142; NV_LIGNEOFS = v143; v130 = 0; @@ -3027,13 +3036,13 @@ LABEL_249: v78 = _vm->_globals.essai0; do { v79 = v137; - _vm->_globals.super_parcours[v79] = (int16)READ_LE_UINT16(v78 + 2 * v120); - _vm->_globals.super_parcours[v79 + 1] = (int16)READ_LE_UINT16(v78 + 2 * v120 + 2); - _vm->_globals.super_parcours[v79 + 2] = (int16)READ_LE_UINT16(v78 + 2 * v120 + 4); + _vm->_globals.super_parcours[v79] = v78[v120]; + _vm->_globals.super_parcours[v79 + 1] = v78[v120 + 1]; + _vm->_globals.super_parcours[v79 + 2] = v78[v120 + 2]; _vm->_globals.super_parcours[v79 + 3] = 0; v120 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v78 + 2 * v120) == -1 && (int16)READ_LE_UINT16(v78 + 2 * v120 + 2) == -1) + if (v78[v120] == -1 && v78[v120 + 1] == -1) v130 = 1; } while (v130 != 1); LABEL_323: @@ -3048,13 +3057,13 @@ LABEL_323: v121 = 0; do { v81 = v137; - _vm->_globals.super_parcours[v81] = (int16)READ_LE_UINT16(v80 + 2 * v121); - _vm->_globals.super_parcours[v81 + 1] = (int16)READ_LE_UINT16(v80 + 2 * v121 + 2); - _vm->_globals.super_parcours[v81 + 2] = (int16)READ_LE_UINT16(v80 + 2 * v121 + 4); + _vm->_globals.super_parcours[v81] = v80[v121]; + _vm->_globals.super_parcours[v81 + 1] = v80[v121 + 1]; + _vm->_globals.super_parcours[v81 + 2] = v80[v121 + 2]; _vm->_globals.super_parcours[v81 + 3] = 0; v121 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v80 + 2 * v121) == -1 && (int16)READ_LE_UINT16(v80 + 2 * v121 + 2) == -1) + if (v80[v121] == -1 && v80[v121 + 1] == -1) v131 = 1; } while (v131 != 1); LABEL_301: @@ -3070,13 +3079,13 @@ LABEL_301: v122 = 0; do { v83 = v137; - _vm->_globals.super_parcours[v83] = (int16)READ_LE_UINT16(v82 + 2 * v122); - _vm->_globals.super_parcours[v83 + 1] = (int16)READ_LE_UINT16(v82 + 2 * v122 + 2); - _vm->_globals.super_parcours[v83 + 2] = (int16)READ_LE_UINT16(v82 + 2 * v122 + 4); + _vm->_globals.super_parcours[v83] = v82[v122]; + _vm->_globals.super_parcours[v83 + 1] = v82[v122 + 1]; + _vm->_globals.super_parcours[v83 + 2] = v82[v122 + 2]; _vm->_globals.super_parcours[v83 + 3] = 0; v122 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v82 + 2 * v122) == -1 && (int16)READ_LE_UINT16(v82 + 2 * v122 + 2) == -1) + if (v82[v122] == -1 && v82[v122 + 1] == -1) v132 = 1; } while (v132 != 1); LABEL_312: @@ -3092,7 +3101,7 @@ LABEL_312: v142 = 1300; if (v138 == -1) v142 = 1300; - if ((int16)READ_LE_UINT16(_vm->_globals.essai1) != -1 && v140 < v144 && v138 >= v140 && v142 >= v140 && a6 <= v140) { + if (_vm->_globals.essai1[0] != -1 && v140 < v144 && v138 >= v140 && v142 >= v140 && a6 <= v140) { NV_LIGNEDEP = v140; NV_LIGNEOFS = v141; v133 = 0; @@ -3100,37 +3109,37 @@ LABEL_312: v84 = _vm->_globals.essai1; do { v85 = v137; - _vm->_globals.super_parcours[v85] = (int16)READ_LE_UINT16(v84 + 2 * v123); - _vm->_globals.super_parcours[v85 + 1] = (int16)READ_LE_UINT16(v84 + 2 * v123 + 2); - _vm->_globals.super_parcours[v85 + 2] = (int16)READ_LE_UINT16(v84 + 2 * v123 + 4); + _vm->_globals.super_parcours[v85] = v84[v123]; + _vm->_globals.super_parcours[v85 + 1] = v84[v123 + 1]; + _vm->_globals.super_parcours[v85 + 2] = v84[v123 + 2]; _vm->_globals.super_parcours[v85 + 3] = 0; v123 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v84 + 2 * v123) == -1 && (int16)READ_LE_UINT16(v84 + 2 * v123 + 2) == -1) + if (v84[v123] == -1 && v84[v123 + 1] == -1) v133 = 1; } while (v133 != 1); goto LABEL_301; } v86 = _vm->_globals.essai2; - if ((int16)READ_LE_UINT16(_vm->_globals.essai2) != -1 && v144 > v138 && v140 >= v138 && v142 >= v138 && a6 <= v138) { + if (_vm->_globals.essai2[0] != -1 && v144 > v138 && v140 >= v138 && v142 >= v138 && a6 <= v138) { NV_LIGNEDEP = v138; NV_LIGNEOFS = v139; v134 = 0; v124 = 0; do { v87 = v137; - _vm->_globals.super_parcours[v87] = (int16)READ_LE_UINT16(v86 + 2 * v124); - _vm->_globals.super_parcours[v87 + 1] = (int16)READ_LE_UINT16(v86 + 2 * v124 + 2); - _vm->_globals.super_parcours[v87 + 2] = (int16)READ_LE_UINT16(v86 + 2 * v124 + 4); + _vm->_globals.super_parcours[v87] = v86[v124]; + _vm->_globals.super_parcours[v87 + 1] = v86[v124 + 1]; + _vm->_globals.super_parcours[v87 + 2] = v86[v124 + 2]; _vm->_globals.super_parcours[v87 + 3] = 0; v124 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v86 + 2 * v124) == -1 && (int16)READ_LE_UINT16(v86 + 2 * v124 + 2) == -1) + if (v86[v124] == -1 && v86[v124 + 1] == -1) v134 = 1; } while (v134 != 1); goto LABEL_312; } - if ((int16)READ_LE_UINT16(_vm->_globals.essai1) != -1 && v144 > v142 && v140 >= v142 && v138 >= v142 && a6 <= v142) { + if (_vm->_globals.essai1[0] != -1 && v144 > v142 && v140 >= v142 && v138 >= v142 && a6 <= v142) { NV_LIGNEDEP = v142; NV_LIGNEOFS = v143; v135 = 0; @@ -3138,13 +3147,13 @@ LABEL_312: v88 = _vm->_globals.essai0; do { v89 = v137; - _vm->_globals.super_parcours[v89] = (int16)READ_LE_UINT16(v88 + 2 * v125); - _vm->_globals.super_parcours[v89 + 1] = (int16)READ_LE_UINT16(v88 + 2 * v125 + 2); - _vm->_globals.super_parcours[v89 + 2] = (int16)READ_LE_UINT16(v88 + 2 * v125 + 4); + _vm->_globals.super_parcours[v89] = v88[v125]; + _vm->_globals.super_parcours[v89 + 1] = v88[v125 + 1]; + _vm->_globals.super_parcours[v89 + 2] = v88[v125 + 2]; _vm->_globals.super_parcours[v89 + 3] = 0; v125 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v88 + 2 * v125) == -1 && (int16)READ_LE_UINT16(v88 + 2 * v125 + 2) == -1) + if (v88[v125] == -1 && v88[v125 + 1] == -1) v135 = 1; } while (v135 != 1); goto LABEL_323; @@ -3179,10 +3188,11 @@ LABEL_235: goto LABEL_249; } v63 = v117; + v64 = _vm->_globals.essai2; - WRITE_LE_UINT16(_vm->_globals.essai2 + 2 * v63, v61); - WRITE_LE_UINT16(v64 + 2 * v63 + 2, a4); - WRITE_LE_UINT16(v64 + 2 * v63 + 4, 3); + v64[v63] = v61; + v64[v63 + 1] = a4; + v64[v63 + 2] = 3; v117 += 3; ++v61; } while (a3 > v61); @@ -3210,9 +3220,9 @@ LABEL_235: } v68 = v117; v69 = _vm->_globals.essai2; - WRITE_LE_UINT16(_vm->_globals.essai2 + 2 * v68, v65); - WRITE_LE_UINT16(v69 + 2 * v68 + 2, a4); - WRITE_LE_UINT16(v69 + 2 * v68 + 4, 7); + v69[v68] = v65; + v69[v68 + 1] = a4; + v69[v68 + 2] = 7; v117 += 3; --v65; } while (a3 < v65); @@ -3221,9 +3231,9 @@ LABEL_235: LABEL_241: v70 = v117; v71 = _vm->_globals.essai2; - WRITE_LE_UINT16(_vm->_globals.essai2 + 2 * v70, (uint16)-1); - WRITE_LE_UINT16(v71 + 2 * v70 + 2, (uint16)-1); - WRITE_LE_UINT16(v71 + 2 * v70 + 4, (uint16)-1); + v71[v70] = -1; + v71[v70 + 1] = -1; + v71[v70 + 2] = -1; LABEL_242: if (v117) { v129 = 0; @@ -3231,13 +3241,13 @@ LABEL_242: v72 = _vm->_globals.essai2; do { v73 = v137; - _vm->_globals.super_parcours[v73] = (int16)READ_LE_UINT16(v72 + 2 * v119); - _vm->_globals.super_parcours[v73 + 1] = (int16)READ_LE_UINT16(v72 + 2 * v119 + 2); - _vm->_globals.super_parcours[v73 + 2] = (int16)READ_LE_UINT16(v72 + 2 * v119 + 4); + _vm->_globals.super_parcours[v73] = v72[v119]; + _vm->_globals.super_parcours[v73 + 1] = v72[v119 + 1]; + _vm->_globals.super_parcours[v73 + 2] = v72[v119 + 2]; _vm->_globals.super_parcours[v73 + 3] = 0; v119 += 3; v137 += 4; - if ((int16)READ_LE_UINT16(v72 + 2 * v119) == -1 && (int16)READ_LE_UINT16(v72 + 2 * v119 + 2) == -1) + if (v72[v119] == -1 && v72[v119 + 1] == -1) v129 = 1; } while (v129 != 1); } @@ -3592,8 +3602,8 @@ int LinesManager::PLAN_TEST(int a1, int a2, int a3, int a4, int a5, int a6) { int v21; int v22; int v23; - byte *v25; - byte *v26; + int16 *v25; + int16 *v26; int v27; int v28; int v29; @@ -3743,10 +3753,10 @@ LABEL_60: } if (a6 == 1) { v18 = v41; - WRITE_LE_UINT16(v25 + 2 * v18, v16); - WRITE_LE_UINT16(v25 + 2 * v18 + 2, v29); - WRITE_LE_UINT16(v25 + 2 * v18 + 4, Ligne[v32].field6); - WRITE_LE_UINT16(v25 + 2 * v18 + 6, 0); + v25[v18] = v16; + v25[v18 + 1] = v29; + v25[v18 + 2] = Ligne[v32].field6; + v25[v18 + 3] = 0; } v41 += 4; ++v14; @@ -3764,10 +3774,10 @@ LABEL_60: v30 = (int16)READ_LE_UINT16(v20 + 4 * v19 + 2); if (a6) { v23 = v41; - WRITE_LE_UINT16(v26 + 2 * v23, v21); - WRITE_LE_UINT16(v26 + 2 * v23 + 2, v30); - WRITE_LE_UINT16(v26 + 2 * v23 + 4, Ligne[v31].field8); - WRITE_LE_UINT16(v26 + 2 * v23 + 6, 0); + v26[v23] = v21; + v26[v23 + 1] = v30; + v26[v23 + 2] = Ligne[v31].field8; + v26[v23 + 3] = 0; } else { v22 = v41; _vm->_globals.super_parcours[v22] = v21; diff --git a/engines/hopkins/lines.h b/engines/hopkins/lines.h index cded40646e..da9c897c28 100644 --- a/engines/hopkins/lines.h +++ b/engines/hopkins/lines.h @@ -81,10 +81,10 @@ public: int colision2_ligne(int a1, int a2, int *a3, int *a4, int a5, int a6); int Scolision2_ligne(int a1, int a2, int *a3, int *a4, int a5, int a6); void INIPARCOURS(); - int CONTOURNE1(int a1, int a2, int a3, int a4, int a5, byte *a6, int a7, int a8, int a9); - int CONTOURNE(int a1, int a2, int a3, int a4, int a5, byte *a6, int a7); + int CONTOURNE1(int a1, int a2, int a3, int a4, int a5, int16 *a6, int a7, int a8, int a9); + int CONTOURNE(int a1, int a2, int a3, int a4, int a5, int16 *a6, int a7); int MIRACLE(int a1, int a2, int a3, int a4, int a5); - int GENIAL(int a1, int a2, int a3, int a4, int a5, int a6, int a7, byte *a8, int a9); + int GENIAL(int a1, int a2, int a3, int a4, int a5, int a6, int a7, int16 *a8, int a9); byte *PARCOURS2(int a1, int a2, int a3, int a4); int PARC_PERS(int a1, int a2, int a3, int a4, int a5, int a6, int a7); int VERIF_SMOOTH(int a1, int a2, int a3, int a4); diff --git a/engines/hopkins/objects.cpp b/engines/hopkins/objects.cpp index 63238844c6..f7e72b0cef 100644 --- a/engines/hopkins/objects.cpp +++ b/engines/hopkins/objects.cpp @@ -2786,9 +2786,9 @@ void ObjectsManager::BTGAUCHE() { int v0; int v1; int v2; - byte *v3; + int16 *v3; byte *v4; - byte *v5; + int16 *v5; int v6; int v7; int v8; @@ -2859,14 +2859,15 @@ void ObjectsManager::BTGAUCHE() { v3 = _vm->_globals.essai2; v4 = _vm->_globals.chemin; do { - WRITE_LE_UINT16(v3 + 2 * v2, (int16)READ_LE_UINT16(v4 + 2 * v2)); + v3[v2] = READ_LE_UINT16(v4 + 2 * v2); ++v2; } while ((int16)READ_LE_UINT16(v4 + 2 * v2) != -1); + v5 = _vm->_globals.essai2; - WRITE_LE_UINT16(_vm->_globals.essai2 + 2 * v2, (uint16)-1); - WRITE_LE_UINT16(v5 + 2 * v2 + 2, (uint16)-1); - WRITE_LE_UINT16(v5 + 2 * v2 + 4, (uint16)-1); - WRITE_LE_UINT16(v5 + 2 * v2 + 6, (uint16)-1); + v5[v2] = -1; + v5[v2 + 1] = -1; + v5[v2 + 2] = -1; + v5[v2 + 3] = -1; } if (GOACTION == 1) { VERIFZONE(); @@ -3576,7 +3577,7 @@ byte *ObjectsManager::PARC_VOITURE(int a1, int a2, int a3, int a4) { int v30; int v31; int v32; - byte *v33; + int16 *v33; int v34; int v35; int i; @@ -3796,11 +3797,12 @@ byte *ObjectsManager::PARC_VOITURE(int a1, int a2, int a3, int a4) { _vm->_globals.super_parcours[v32 + 1] = v29; _vm->_globals.super_parcours[v32 + 2] = v66; _vm->_globals.super_parcours[v32 + 3] = 0; + v33 = _vm->_globals.essai0; - WRITE_LE_UINT16(_vm->_globals.essai0 + 2 * v32, v28); - WRITE_LE_UINT16(v33 + 2 * v32 + 2, v29); - WRITE_LE_UINT16(v33 + 2 * v32 + 4, v66); - WRITE_LE_UINT16(v33 + 2 * v32 + 6, 0); + v33[v32] = v28; + v33[v32 + 1] = v29; + v33[v32 + 2] = v66; + v33[v32 + 3] = 0; v67 += 4; if (v28 == -1) goto LABEL_90; |