CHEWY: Fixed first variation of objekt::load

This commit is contained in:
Paul Gilbert 2021-09-13 22:40:02 -07:00
parent 7482a64ed0
commit a7fee5e2ec
4 changed files with 109 additions and 33 deletions

View File

@ -31,6 +31,7 @@ MODULE_OBJS = \
metaengine.o \
movclass.o \
ngstypes.o \
objekt.o \
objekte.o \
r_event.o \
room.o \

65
engines/chewy/objekt.cpp Normal file
View File

@ -0,0 +1,65 @@
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
#include "chewy/objekt.h"
namespace Chewy {
bool RoomMovObjekt::load(Common::SeekableReadStream *src) {
RoomNr = src->readSint16LE();
X = src->readSint16LE();
Y = src->readSint16LE();
XOff = src->readByte();
YOff = src->readByte();
TxtNr = src->readSint16LE();
NeuObj = src->readSint16LE();
ActionObj = src->readSint16LE();
ZustandAk = src->readByte();
ZustandOff = src->readByte();
ZustandFlipFlop = src->readByte();
AutoMov = src->readByte();
AniFlag = src->readByte();
Del = src->readByte();
Attribut = src->readByte();
HeldHide = src->readByte();
ZEbene = src->readSint16LE();
return true;
}
bool IibDateiHeader::load(Common::SeekableReadStream *src) {
src->read(Id, 4);
src->read(Tafname, 14);
Size = src->readUint32LE();
return true;
}
bool SibDateiHeader::load(Common::SeekableReadStream *src) {
src->read(Id, 4);
Anz = src->readUint16LE();
return true;
}
} // namespace Chewy

View File

@ -23,6 +23,8 @@
#ifndef CHEWY_OBJEKT_H
#define CHEWY_OBJEKT_H
#include "common/stream.h"
namespace Chewy {
struct RoomMovObjekt {
@ -33,34 +35,28 @@ struct RoomMovObjekt {
uint8 XOff;
uint8 YOff;
int16 TxtNr;
int16 NeuObj;
int16 ActionObj;
uint8 ZustandAk;
uint8 ZustandOff;
uint8 ZustandFlipFlop;
uint8 AutoMov;
uint8 AniFlag;
uint8 Del;
uint8 Attribut;
uint8 HeldHide;
int16 ZEbene;
bool load(Common::SeekableReadStream *src);
static size_t size() { return 24; }
};
struct IibDateiHeader {
char Id[4];
char Tafname[14];
uint32 Size;
bool load(Common::SeekableReadStream *src);
};
struct RoomStaticInventar {
@ -96,6 +92,8 @@ struct RoomStaticInventar {
struct SibDateiHeader {
char Id[4];
int16 Anz;
bool load(Common::SeekableReadStream *src);
};
struct RoomExit {

View File

@ -90,19 +90,27 @@ objekt::~objekt() {
}
int16 objekt::load(const char *fname_, RoomMovObjekt *rmo) {
Stream *handle;
handle = chewy_fopen(fname_, "rb");
if (handle) {
if (!chewy_fread(&iib_datei_header, sizeof(IibDateiHeader), 1, handle)) {
Common::File f;
bool valid = true;
if (f.open(fname_)) {
if (!iib_datei_header.load(&f)) {
fcode = READFEHLER;
modul = DATEI;
} else if (!scumm_strnicmp(iib_datei_header.Id, "IIB", 3)) {
if (iib_datei_header.Size) {
if (!chewy_fread(rmo, (size_t)iib_datei_header.Size, 1, handle)) {
assert(iib_datei_header.Size % RoomMovObjekt::size() == 0);
for (int i = 0; i < iib_datei_header.Size / RoomMovObjekt::size() && valid;
++i, ++rmo) {
valid = rmo->load(&f);
}
if (!valid) {
fcode = READFEHLER;
modul = DATEI;
} else {
max_inventar_obj = (int16) iib_datei_header.Size / sizeof(RoomMovObjekt);
max_inventar_obj = (int16)iib_datei_header.Size / RoomMovObjekt::size();
}
} else
max_inventar_obj = 0;
@ -110,25 +118,26 @@ int16 objekt::load(const char *fname_, RoomMovObjekt *rmo) {
fcode = READFEHLER;
modul = DATEI;
}
chewy_fclose(handle);
f.close();
} else {
fcode = OPENFEHLER;
modul = DATEI;
}
return (max_inventar_obj);
return max_inventar_obj;
}
int16 objekt::load(const char *fname_, RoomStaticInventar *rsi) {
Stream *handle;
handle = chewy_fopen(fname_, "rb");
if (handle) {
Common::File f;
if (!chewy_fread(&sib_datei_header, sizeof(SibDateiHeader), 1, handle)) {
if (f.open(fname_)) {
if (!chewy_fread(&sib_datei_header, sizeof(SibDateiHeader), 1, &f)) {
fcode = READFEHLER;
modul = DATEI;
} else if (!scumm_strnicmp(sib_datei_header.Id, "SIB", 3)) {
if (sib_datei_header.Anz) {
if (!chewy_fread(rsi, (size_t)(sib_datei_header.Anz * sizeof(RoomStaticInventar)), 1, handle)) {
if (!chewy_fread(rsi, (size_t)(sib_datei_header.Anz * sizeof(RoomStaticInventar)), 1, &f)) {
fcode = READFEHLER;
modul = DATEI;
} else {
@ -140,25 +149,26 @@ int16 objekt::load(const char *fname_, RoomStaticInventar *rsi) {
fcode = READFEHLER;
modul = DATEI;
}
chewy_fclose(handle);
f.close();
} else {
fcode = OPENFEHLER;
modul = DATEI;
}
return (max_static_inventar);
return max_static_inventar;
}
int16 objekt::load(const char *fname_, RoomExit *RoomEx) {
Stream *handle;
handle = chewy_fopen(fname_, "rb");
if (handle) {
Common::File f;
if (!chewy_fread(&eib_datei_header, sizeof(EibDateiHeader), 1, handle)) {
if (f.open(fname_)) {
if (!chewy_fread(&eib_datei_header, sizeof(EibDateiHeader), 1, &f)) {
fcode = READFEHLER;
modul = DATEI;
} else if (!scumm_strnicmp(eib_datei_header.Id, "EIB", 3)) {
if (sib_datei_header.Anz) {
if (!chewy_fread(RoomEx, (size_t)(eib_datei_header.Anz * sizeof(RoomExit)), 1, handle)) {
if (!chewy_fread(RoomEx, (size_t)(eib_datei_header.Anz * sizeof(RoomExit)), 1, &f)) {
fcode = READFEHLER;
modul = DATEI;
} else {
@ -170,12 +180,14 @@ int16 objekt::load(const char *fname_, RoomExit *RoomEx) {
fcode = READFEHLER;
modul = DATEI;
}
chewy_fclose(handle);
f.close();
} else {
fcode = OPENFEHLER;
modul = DATEI;
}
return (max_exit);
return max_exit;
}
void objekt::sort() {