From 84784add6811aa1b285b70e139d0bdf9738c858c Mon Sep 17 00:00:00 2001 From: Kamil Zbróg Date: Mon, 28 Oct 2013 00:06:21 +0000 Subject: PRINCE: midi music player added. mob and object lists added --- engines/prince/mob.cpp | 63 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 engines/prince/mob.cpp (limited to 'engines/prince/mob.cpp') diff --git a/engines/prince/mob.cpp b/engines/prince/mob.cpp new file mode 100644 index 0000000000..caf44fef12 --- /dev/null +++ b/engines/prince/mob.cpp @@ -0,0 +1,63 @@ +/* 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 "prince/mob.h" + +#include "common/stream.h" + +namespace Prince { + +bool Mob::loadFromStream(Common::SeekableReadStream &stream) { + int32 pos = stream.pos(); + + uint16 visible = stream.readUint16LE(); + + if (visible == 0xFFFF) + return false; + + _visible = visible; + _type = stream.readUint16LE(); + _rect.left = stream.readUint16LE(); + _rect.top = stream.readUint16LE(); + _rect.right = stream.readUint16LE(); + _rect.bottom = stream.readUint16LE(); + + stream.skip(6 * sizeof(uint16)); + uint32 nameOffset = stream.readUint32LE(); + uint32 examTextOffset = stream.readUint32LE(); + + byte c; + stream.seek(nameOffset); + _name.clear(); + while ((c = stream.readByte())) + _name += c; + + stream.seek(examTextOffset); + _examText.clear(); + while ((c = stream.readByte())) + _examText += c; + stream.seek(pos + 32); + + return true; +} + +} -- cgit v1.2.3 From 8c85eff622e3bcec7685b6daf44aef094b6bdb09 Mon Sep 17 00:00:00 2001 From: Kamil Zbróg Date: Mon, 4 Nov 2013 11:28:10 +0000 Subject: PRINCE: code formating fixed --- engines/prince/mob.cpp | 50 ++++++++++++++++++++++++++------------------------ 1 file changed, 26 insertions(+), 24 deletions(-) (limited to 'engines/prince/mob.cpp') diff --git a/engines/prince/mob.cpp b/engines/prince/mob.cpp index caf44fef12..3df7235d2d 100644 --- a/engines/prince/mob.cpp +++ b/engines/prince/mob.cpp @@ -27,37 +27,39 @@ namespace Prince { bool Mob::loadFromStream(Common::SeekableReadStream &stream) { - int32 pos = stream.pos(); + int32 pos = stream.pos(); - uint16 visible = stream.readUint16LE(); + uint16 visible = stream.readUint16LE(); - if (visible == 0xFFFF) - return false; + if (visible == 0xFFFF) + return false; - _visible = visible; - _type = stream.readUint16LE(); - _rect.left = stream.readUint16LE(); - _rect.top = stream.readUint16LE(); - _rect.right = stream.readUint16LE(); - _rect.bottom = stream.readUint16LE(); + _visible = visible; + _type = stream.readUint16LE(); + _rect.left = stream.readUint16LE(); + _rect.top = stream.readUint16LE(); + _rect.right = stream.readUint16LE(); + _rect.bottom = stream.readUint16LE(); - stream.skip(6 * sizeof(uint16)); - uint32 nameOffset = stream.readUint32LE(); - uint32 examTextOffset = stream.readUint32LE(); + stream.skip(6 * sizeof(uint16)); + uint32 nameOffset = stream.readUint32LE(); + uint32 examTextOffset = stream.readUint32LE(); - byte c; - stream.seek(nameOffset); - _name.clear(); - while ((c = stream.readByte())) - _name += c; + byte c; + stream.seek(nameOffset); + _name.clear(); + while ((c = stream.readByte())) + _name += c; - stream.seek(examTextOffset); - _examText.clear(); - while ((c = stream.readByte())) - _examText += c; - stream.seek(pos + 32); + stream.seek(examTextOffset); + _examText.clear(); + while ((c = stream.readByte())) + _examText += c; + stream.seek(pos + 32); - return true; + return true; } } + +/* vim: set tabstop=4 noexpandtab: */ -- cgit v1.2.3