diff options
Diffstat (limited to 'engines/lastexpress/entities/yasmin.cpp')
-rw-r--r-- | engines/lastexpress/entities/yasmin.cpp | 490 |
1 files changed, 490 insertions, 0 deletions
diff --git a/engines/lastexpress/entities/yasmin.cpp b/engines/lastexpress/entities/yasmin.cpp new file mode 100644 index 0000000000..7dc46f9690 --- /dev/null +++ b/engines/lastexpress/entities/yasmin.cpp @@ -0,0 +1,490 @@ +/* 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. + * + * $URL$ + * $Id$ + * + */ + +#include "lastexpress/entities/yasmin.h" + +#include "lastexpress/game/entities.h" +#include "lastexpress/game/logic.h" +#include "lastexpress/game/object.h" +#include "lastexpress/game/savepoint.h" +#include "lastexpress/game/sound.h" +#include "lastexpress/game/state.h" + +#include "lastexpress/lastexpress.h" +#include "lastexpress/helpers.h" + +namespace LastExpress { + +Yasmin::Yasmin(LastExpressEngine *engine) : Entity(engine, kEntityYasmin) { + ADD_CALLBACK_FUNCTION(Yasmin, reset); + ADD_CALLBACK_FUNCTION(Yasmin, enterExitCompartment); + ADD_CALLBACK_FUNCTION(Yasmin, playSound); + ADD_CALLBACK_FUNCTION(Yasmin, updateFromTime); + ADD_CALLBACK_FUNCTION(Yasmin, updateEntity); + ADD_CALLBACK_FUNCTION(Yasmin, function6); + ADD_CALLBACK_FUNCTION(Yasmin, function7); + ADD_CALLBACK_FUNCTION(Yasmin, chapter1); + ADD_CALLBACK_FUNCTION(Yasmin, chapter1Handler); + ADD_CALLBACK_FUNCTION(Yasmin, function10); + ADD_CALLBACK_FUNCTION(Yasmin, chapter2); + ADD_CALLBACK_FUNCTION(Yasmin, chapter2Handler); + ADD_CALLBACK_FUNCTION(Yasmin, chapter3); + ADD_CALLBACK_FUNCTION(Yasmin, chapter3Handler); + ADD_CALLBACK_FUNCTION(Yasmin, chapter4); + ADD_CALLBACK_FUNCTION(Yasmin, chapter4Handler); + ADD_CALLBACK_FUNCTION(Yasmin, function17); + ADD_CALLBACK_FUNCTION(Yasmin, chapter5); + ADD_CALLBACK_FUNCTION(Yasmin, chapter5Handler); + ADD_CALLBACK_FUNCTION(Yasmin, function20); + ADD_CALLBACK_FUNCTION(Yasmin, function21); + ADD_NULL_FUNCTION(); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(1, Yasmin, reset) + switch (savepoint.action) { + default: + break; + + case kActionExcuseMeCath: + getSound()->excuseMeCath(); + break; + + case kActionExcuseMe: + getSound()->excuseMe(kEntityYasmin); + break; + } + + // Process default actions + Entity::reset(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_SI(2, Yasmin, enterExitCompartment, ObjectIndex) + Entity::enterExitCompartment(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_S(3, Yasmin, playSound) + Entity::playSound(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_NOSETUP(4, Yasmin, updateFromTime) + Entity::updateFromTime(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_II(5, Yasmin, updateEntity, CarIndex, EntityPosition) + Entity::updateEntity(savepoint, true); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(6, Yasmin, function6) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_4840; + getData()->location = kLocationOutsideCompartment; + + setCallback(1); + setup_enterExitCompartment("615Be", kObjectCompartment5); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + setCallback(2); + setup_updateEntity(kCarGreenSleeping, kPosition_3050); + break; + + case 2: + setCallback(3); + setup_enterExitCompartment("615Ag", kObjectCompartment7); + break; + + case 3: + getData()->location = kLocationInsideCompartment; + getEntities()->clearSequences(kEntityYasmin); + + CALLBACK_ACTION(); + break; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(7, Yasmin, function7) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_3050; + getData()->location = kLocationOutsideCompartment; + + setCallback(1); + setup_enterExitCompartment("615Bg", kObjectCompartment7); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + setCallback(2); + setup_updateEntity(kCarGreenSleeping, kPosition_4840); + break; + + case 2: + setCallback(3); + setup_enterExitCompartment("615Ae", kObjectCompartment5); + break; + + case 3: + getData()->location = kLocationInsideCompartment; + getEntities()->clearSequences(kEntityYasmin); + + CALLBACK_ACTION(); + break; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(8, Yasmin, chapter1) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK(kTimeChapter1, params->param1, setup_chapter1Handler); + break; + + case kActionDefault: + getData()->entityPosition = kPosition_4840; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(9, Yasmin, chapter1Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK_CALLBACK(kTime1093500, params->param1, 1, setup_function6); + TIME_CHECK_CALLBACK(kTime1161000, params->param2, 3, setup_function7); + TIME_CHECK_PLAYSOUND_UPDATEPOSITION(kTime1162800, params->param3, 4, "Har1102", kPosition_4070); + TIME_CHECK_CALLBACK_1(kTime1165500, params->param4, 5, setup_playSound, "Har1104"); + TIME_CHECK_CALLBACK_1(kTime1174500, params->param5, 6, setup_playSound, "Har1106"); + TIME_CHECK_CALLBACK(kTime1183500, params->param6, 7, setup_function6); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getData()->entityPosition = kPosition_2740; + setCallback(2); + setup_playSound("Har1102"); + break; + + case 2: + TIME_CHECK_CALLBACK(kTime1161000, params->param2, 3, setup_function7); + // Fallback to case 3 + + case 3: + TIME_CHECK_PLAYSOUND_UPDATEPOSITION(kTime1162800, params->param3, 4, "Har1102", kPosition_4070); + // Fallback to case 4 + + case 4: + TIME_CHECK_CALLBACK_1(kTime1165500, params->param4, 5, setup_playSound, "Har1104"); + // Fallback to case 5 + + case 5: + TIME_CHECK_CALLBACK_1(kTime1174500, params->param5, 6, setup_playSound, "Har1106"); + // Fallback to case 6 + + case 6: + TIME_CHECK_CALLBACK(kTime1183500, params->param6, 7, setup_function6); + break; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(10, Yasmin, function10) + if (savepoint.action == kActionDefault) { + getObjects()->update(kObjectCompartment7, kEntityPlayer, kObjectLocation3, kCursorHandKnock, kCursorHand); + getData()->entityPosition = kPosition_3050; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + + getEntities()->clearSequences(kEntityYasmin); + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(11, Yasmin, chapter2) + if (savepoint.action == kActionDefault) { + getEntities()->clearSequences(kEntityYasmin); + + getData()->entityPosition = kPosition_3050; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + getData()->clothes = kClothesDefault; + getData()->inventoryItem = kItemNone; + + setup_chapter2Handler(); + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(12, Yasmin, chapter2Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK_CALLBACK(kTime1759500, params->param1, 1, setup_function7); + + if (getState()->time > kTime1800000 && !params->param2) { + params->param2 = 1; + getData()->entityPosition = kPosition_4070; + + getSavePoints()->push(kEntityYasmin, kEntityTrain, kAction191070912, kPosition_4070); + } + break; + + case kActionCallback: + + if (getCallback() != 1) + break; + + if (getState()->time > kTime1800000 && !params->param2) { + params->param2 = 1; + getData()->entityPosition = kPosition_4070; + + getSavePoints()->push(kEntityYasmin, kEntityTrain, kAction191070912, kPosition_4070); + } + + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(13, Yasmin, chapter3) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter3Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityYasmin); + + getData()->entityPosition = kPosition_3050; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(14, Yasmin, chapter3Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK_CALLBACK(kTime2062800, params->param1, 1, setup_function6); + TIME_CHECK_CALLBACK(kTime2106000, params->param2, 2, setup_function7); + TIME_CHECK_CALLBACK(kTime2160000, params->param3, 3, setup_function6); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + TIME_CHECK_CALLBACK(kTime2106000, params->param2, 2, setup_function7); + // Fallback to case 2 + + case 2: + TIME_CHECK_CALLBACK(kTime2160000, params->param3, 3, setup_function6); + break; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(15, Yasmin, chapter4) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter4Handler(); + break; + + case kActionDefault: + getData()->entityPosition = kPosition_3050; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(16, Yasmin, chapter4Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK_CALLBACK(kTime2457000, params->param1, 1, setup_function7); + TIME_CHECK_CALLBACK(kTime2479500, params->param2, 3, setup_function6); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getData()->entityPosition = kPosition_4070; + setCallback(2); + setup_playSound("Har1110"); + break; + + case 2: + TIME_CHECK_CALLBACK(kTime2479500, params->param2, 3, setup_function6); + break; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(17, Yasmin, function17) + // Same as existing function 10 ? + function10(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(18, Yasmin, chapter5) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter5Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityYasmin); + + getData()->entityPosition = kPosition_3969; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarRestaurant; + getData()->clothes = kClothesDefault; + getData()->inventoryItem = kItemNone; + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(19, Yasmin, chapter5Handler) + if (savepoint.action == kActionProceedChapter5) + setup_function20(); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(20, Yasmin, function20) + switch (savepoint.action) { + default: + break; + + case kActionNone: + UPDATE_PARAM(params->param1, getState()->time, 2700); + setup_function21(); + break; + + case kActionDefault: + getData()->entityPosition = kPosition_2500; + getData()->location = kLocationOutsideCompartment; + getData()->car = kCarGreenSleeping; + break; + + case kActionDrawScene: + if (getEntities()->isInsideTrainCar(kEntityPlayer, kCarGreenSleeping)) { + setup_function21(); + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(21, Yasmin, function21) + switch (savepoint.action) { + default: + break; + + case kActionNone: + case kActionDefault: + if (getEntities()->updateEntity(kEntityYasmin, (CarIndex)params->param1, (EntityPosition)params->param2)) + CALLBACK_ACTION(); + break; + + case kActionExcuseMeCath: + getSound()->excuseMeCath(); + break; + + case kActionExcuseMe: + getSound()->excuseMe(kEntityYasmin); + break; + } +} + +} // End of namespace LastExpress |