From 644b4dcd0b3a01751ed525370a9c6bc4ccc4bbc6 Mon Sep 17 00:00:00 2001 From: Eugene Sandulenko Date: Tue, 5 Apr 2016 18:35:36 +0200 Subject: WAGE: Fixed moving objects to random scene --- engines/wage/wage.cpp | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) (limited to 'engines/wage/wage.cpp') diff --git a/engines/wage/wage.cpp b/engines/wage/wage.cpp index e0299c8da2..a6f5bb7990 100644 --- a/engines/wage/wage.cpp +++ b/engines/wage/wage.cpp @@ -284,8 +284,9 @@ void WageEngine::performInitialSetup() { if (!obj->_sceneOrOwner.equalsIgnoreCase(STORAGESCENE)) { Common::String location = obj->_sceneOrOwner; location.toLowercase(); - if (_world->_scenes.contains(location)) { - _world->move(obj, _world->_scenes[location]); + Scene *scene = getSceneByName(location); + if (scene != NULL) { + _world->move(obj, scene); } else { if (!_world->_chrs.contains(location)) { // Note: PLAYER@ is not a valid target here. @@ -328,13 +329,14 @@ void WageEngine::doClose() { } Scene *WageEngine::getSceneByName(Common::String &location) { - Scene *scene; if (location.equals("random@")) { - scene = _world->getRandomScene(); + return _world->getRandomScene(); } else { - scene = _world->_scenes[location]; + if (_world->_scenes.contains(location)) + return _world->_scenes[location]; + else + return NULL; } - return scene; } void WageEngine::onMove(Designed *what, Designed *from, Designed *to) { -- cgit v1.2.3