From 58966d6b90cf79ad7d6ed9ffb6e44eb74d38815f Mon Sep 17 00:00:00 2001 From: Max Horn Date: Sun, 17 Apr 2005 23:24:31 +0000 Subject: Move stuff around svn-id: r17661 --- scumm/object.cpp | 87 ++++++++++++++++++++++++++++---------------------------- 1 file changed, 43 insertions(+), 44 deletions(-) (limited to 'scumm/object.cpp') diff --git a/scumm/object.cpp b/scumm/object.cpp index c239c650ab..d966f829f8 100644 --- a/scumm/object.cpp +++ b/scumm/object.cpp @@ -170,29 +170,6 @@ int ScummEngine::getObjectIndex(int object) const { return -1; } -int ScummEngine::getObjectImageCount(int object) { - const byte *ptr; - const ImageHeader *imhd; - int objnum; - - objnum = getObjectIndex(object); - if (objnum == -1); - return 0; - - ptr = getOBIMFromObject(_objs[objnum]); - imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), ptr); - if (!imhd) - return 0; - - if (_version == 8) { - return (READ_LE_UINT32(&imhd->v8.image_count)); - } else if (_version == 7) { - return(READ_LE_UINT16(&imhd->v7.image_count)); - } else { - return (READ_LE_UINT16(&imhd->old.image_count)); - } -} - int ScummEngine::whereIsObject(int object) const { int i; @@ -1079,6 +1056,49 @@ const byte *ScummEngine::getObjectImage(const byte *ptr, int state) { return ptr; } +int ScummEngine::getObjectImageCount(int object) { + const byte *ptr; + const ImageHeader *imhd; + int objnum; + + objnum = getObjectIndex(object); + if (objnum == -1); + return 0; + + ptr = getOBIMFromObject(_objs[objnum]); + imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), ptr); + if (!imhd) + return 0; + + if (_version == 8) { + return (READ_LE_UINT32(&imhd->v8.image_count)); + } else if (_version == 7) { + return(READ_LE_UINT16(&imhd->v7.image_count)); + } else { + return (READ_LE_UINT16(&imhd->old.image_count)); + } +} + +int ScummEngine_v8::getObjectIdFromOBIM(const byte *obim) { + // In V8, IMHD has no obj_id, but rather a name string. We map the name + // back to an object id using a table derived from the DOBJ resource. + const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); + return _objectIDMap[imhd->v8.name]; +} + +int ScummEngine_v7::getObjectIdFromOBIM(const byte *obim) { + const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); + return READ_LE_UINT16(&imhd->v7.obj_id); +} + +int ScummEngine::getObjectIdFromOBIM(const byte *obim) { + if (_features & GF_SMALL_HEADER) + return READ_LE_UINT16(obim + 6); + + const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); + return READ_LE_UINT16(&imhd->old.obj_id); +} + void ScummEngine::addObjectToInventory(uint obj, uint room) { int idx, slot; uint32 size; @@ -1235,27 +1255,6 @@ void ScummEngine::findObjectInRoom(FindObjectInRoom *fo, byte findWhat, uint id, } } -int ScummEngine_v8::getObjectIdFromOBIM(const byte *obim) { - // In V8, IMHD has no obj_id, but rather a name string. We map the name - // back to an object id using a table derived from the DOBJ resource. - const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); - return _objectIDMap[imhd->v8.name]; -} - -int ScummEngine_v7::getObjectIdFromOBIM(const byte *obim) { - const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); - return READ_LE_UINT16(&imhd->v7.obj_id); -} - -int ScummEngine::getObjectIdFromOBIM(const byte *obim) { - if (_features & GF_SMALL_HEADER) - return READ_LE_UINT16(obim + 6); - - const ImageHeader *imhd = (const ImageHeader *)findResourceData(MKID('IMHD'), obim); - return READ_LE_UINT16(&imhd->old.obj_id); -} - - int ScummEngine::getInventorySlot() { int i; for (i = 0; i < _numInventory; i++) { -- cgit v1.2.3