diff options
Diffstat (limited to 'engines/lastexpress/entities/hadija.cpp')
-rw-r--r-- | engines/lastexpress/entities/hadija.cpp | 532 |
1 files changed, 532 insertions, 0 deletions
diff --git a/engines/lastexpress/entities/hadija.cpp b/engines/lastexpress/entities/hadija.cpp new file mode 100644 index 0000000000..5590c1b6fe --- /dev/null +++ b/engines/lastexpress/entities/hadija.cpp @@ -0,0 +1,532 @@ +/* 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/hadija.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 { + +Hadija::Hadija(LastExpressEngine *engine) : Entity(engine, kEntityHadija) { + ADD_CALLBACK_FUNCTION(Hadija, reset); + ADD_CALLBACK_FUNCTION(Hadija, enterExitCompartment); + ADD_CALLBACK_FUNCTION(Hadija, playSound); + ADD_CALLBACK_FUNCTION(Hadija, updateFromTime); + ADD_CALLBACK_FUNCTION(Hadija, updateEntity); + ADD_CALLBACK_FUNCTION(Hadija, compartment6); + ADD_CALLBACK_FUNCTION(Hadija, compartment8); + ADD_CALLBACK_FUNCTION(Hadija, compartment6to8); + ADD_CALLBACK_FUNCTION(Hadija, compartment8to6); + ADD_CALLBACK_FUNCTION(Hadija, chapter1); + ADD_CALLBACK_FUNCTION(Hadija, chapter1Handler); + ADD_CALLBACK_FUNCTION(Hadija, function12); + ADD_CALLBACK_FUNCTION(Hadija, chapter2); + ADD_CALLBACK_FUNCTION(Hadija, chapter2Handler); + ADD_CALLBACK_FUNCTION(Hadija, chapter3); + ADD_CALLBACK_FUNCTION(Hadija, chapter3Handler); + ADD_CALLBACK_FUNCTION(Hadija, chapter4); + ADD_CALLBACK_FUNCTION(Hadija, chapter4Handler); + ADD_CALLBACK_FUNCTION(Hadija, function19); + ADD_CALLBACK_FUNCTION(Hadija, chapter5); + ADD_CALLBACK_FUNCTION(Hadija, chapter5Handler); + ADD_CALLBACK_FUNCTION(Hadija, function22); + ADD_CALLBACK_FUNCTION(Hadija, function23); + ADD_NULL_FUNCTION(); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(1, Hadija, reset) + Entity::reset(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_SI(2, Hadija, enterExitCompartment, ObjectIndex) + Entity::enterExitCompartment(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_S(3, Hadija, playSound) + Entity::playSound(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_NOSETUP(4, Hadija, updateFromTime) + Entity::updateFromTime(savepoint); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_II(5, Hadija, updateEntity, CarIndex, EntityPosition) + Entity::updateEntity(savepoint, true); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(6, Hadija, compartment6) + COMPARTMENT_TO(Hadija, kObjectCompartment6, kPosition_4070, "619Cf", "619Df"); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(7, Hadija, compartment8) + COMPARTMENT_TO(Hadija, kObjectCompartment8, kPosition_2740, "619Ch", "619Dh"); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(8, Hadija, compartment6to8) + COMPARTMENT_FROM_TO(Hadija, kObjectCompartment6, kPosition_4070, "619Bf", kObjectCompartment8, kPosition_2740, "619Ah"); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(9, Hadija, compartment8to6) + COMPARTMENT_FROM_TO(Hadija, kObjectCompartment8, kPosition_2740, "619Bh", kObjectCompartment6, kPosition_4070, "619Af"); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(10, Hadija, chapter1) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK(kTimeChapter1, params->param1, setup_chapter1Handler); + break; + + case kActionDefault: + getData()->entityPosition = kPosition_4070; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(11, Hadija, chapter1Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK_PLAYSOUND_UPDATEPOSITION(kTimeParisEpernay, params->param1, 1, "Har1100", kPosition_4840); + +label_callback1: + TIME_CHECK_CALLBACK(kTime1084500, params->param2, 2, setup_compartment6to8); + +label_callback2: + if (params->param3 != kTimeInvalid && getState()->time > kTime1093500) { + + if (getState()->time <= kTime1134000) { + + if (!getEntities()->isPlayerInCar(kCarGreenSleeping) || !getEntities()->isInsideCompartment(kEntityMahmud, kCarGreenSleeping, kPosition_5790) || !params->param3) { + params->param3 = (uint)getState()->time + 75; + + if (!params->param3) { + setCallback(3); + setup_compartment8(); + return; + } + } + + if (params->param3 >= getState()->time) + return; + } + + params->param3 = kTimeInvalid; + + setCallback(3); + setup_compartment8(); + } + +label_callback3: + TIME_CHECK_CALLBACK(kTime1156500, params->param4, 4, setup_compartment8to6); + +label_callback4: + if (params->param5 != kTimeInvalid && getState()->time > kTime1165500) { + if (getState()->time <= kTime1188000) { + + if (!getEntities()->isPlayerInCar(kCarGreenSleeping) || !getEntities()->isInsideCompartment(kEntityMahmud, kCarGreenSleeping, kPosition_5790) || !params->param5) { + params->param5 = (uint)getState()->time + 75; + + if (!params->param5) { + setCallback(5); + setup_compartment6(); + return; + } + } + + if (params->param5 >= getState()->time) + return; + } + + params->param5 = kTimeInvalid; + + setCallback(5); + setup_compartment6(); + } + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + goto label_callback1; + + case 2: + goto label_callback2; + + case 3: + goto label_callback3; + + case 4: + goto label_callback4; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(12, Hadija, function12) + if (savepoint.action == kActionDefault) { + getObjects()->update(kObjectCompartment8, kEntityPlayer, kObjectLocation3, kCursorHandKnock, kCursorHand); + + getData()->entityPosition = kPosition_2740; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + + getEntities()->clearSequences(kEntityHadija); + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(13, Hadija, chapter2) + if (savepoint.action == kActionDefault) { + + getEntities()->clearSequences(kEntityHadija); + + getData()->entityPosition = kPosition_3050; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + getData()->clothes = kClothesDefault; + getData()->inventoryItem = kItemNone; + + setup_chapter2Handler(); + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(14, Hadija, chapter2Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (getState()->time > kTime1782000 && !params->param1) { + params->param1 = 1; + getData()->entityPosition = kPosition_2740; + } + + if (params->param2 == kTimeInvalid || getState()->time <= kTime1786500) { + TIME_CHECK_CALLBACK(kTime1822500, params->param3, 2, setup_compartment8to6); + break; + } + + if (getState()->time <= kTime1818000) { + + if (!getEntities()->isPlayerInCar(kCarGreenSleeping) || !params->param2) + params->param2 = (uint)getState()->time + 75; + + if (params->param2 >= getState()->time) { + TIME_CHECK_CALLBACK(kTime1822500, params->param3, 2, setup_compartment8to6); + break; + } + } + + params->param2 = kTimeInvalid; + + setCallback(1); + setup_compartment8(); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + TIME_CHECK_CALLBACK(kTime1822500, params->param3, 2, setup_compartment8to6); + break; + + case 2: + setCallback(3); + setup_playSound("Har2012"); + break; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(15, Hadija, chapter3) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter3Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityHadija); + + getData()->entityPosition = kPosition_4070; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(16, Hadija, chapter3Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + TIME_CHECK_CALLBACK(kTime1998000, params->param1, 1, setup_compartment6to8); + +label_callback1: + TIME_CHECK_CALLBACK(kTime2020500, params->param2, 2, setup_compartment8to6); + +label_callback2: + TIME_CHECK_CALLBACK(kTime2079000, params->param3, 3, setup_compartment6to8); + +label_callback3: + TIME_CHECK_CALLBACK(kTime2187000, params->param4, 4, setup_compartment8to6); + +label_callback4: + if (params->param5 != kTimeInvalid && getState()->time > kTime2196000) + TIME_CHECK_CAR(kTime2254500, params->param5, 5, setup_compartment6); + break; + + case kActionDefault: + getSavePoints()->push(kEntityAlouan, kEntityTrain, kAction191070912, kPosition_4840); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + goto label_callback1; + + case 2: + goto label_callback2; + + case 3: + goto label_callback3; + + case 4: + goto label_callback4; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(17, Hadija, chapter4) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter4Handler(); + break; + + case kActionDefault: + getData()->entityPosition = kPosition_4070; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(18, Hadija, chapter4Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (params->param1 != kTimeInvalid) + TIME_CHECK_CAR(kTime1714500, params->param1, 1, setup_compartment6); + +label_callback1: + TIME_CHECK_CALLBACK(kTime2367000, params->param2, 2, setup_compartment6to8); + +label_callback2: + TIME_CHECK_CALLBACK(kTime2421000, params->param3, 3, setup_compartment8to6); + +label_callback3: + if (params->param4 != kTimeInvalid && getState()->time > kTime2425500) + TIME_CHECK_CAR(kTime2484000, params->param4, 4, setup_compartment6); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + goto label_callback1; + + case 2: + goto label_callback2; + + case 3: + goto label_callback3; + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(19, Hadija, function19) + if (savepoint.action == kActionDefault) { + getObjects()->update(kObjectCompartment8, kEntityPlayer, kObjectLocation3, kCursorHandKnock, kCursorHand); + + getData()->entityPosition = kPosition_4070; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarGreenSleeping; + + getEntities()->clearSequences(kEntityHadija); + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(20, Hadija, chapter5) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter5Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityHadija); + + getData()->entityPosition = kPosition_3969; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarRestaurant; + getData()->clothes = kClothesDefault; + getData()->inventoryItem = kItemNone; + + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(21, Hadija, chapter5Handler) + if (savepoint.action == kActionProceedChapter5) + setup_function22(); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(22, Hadija, function22) + switch (savepoint.action) { + default: + break; + + case kActionNone: + UPDATE_PARAM(params->param1, getState()->time, 2700); + setup_function23(); + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5000; + getData()->location = kLocationOutsideCompartment; + getData()->car = kCarGreenSleeping; + break; + + case kActionDrawScene: + if (getEntities()->isInsideTrainCar(kEntityPlayer, kCarGreenSleeping)) { + setup_function23(); + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(23, Hadija, function23) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + setCallback(1); + setup_updateEntity(kCarGreenSleeping, kPosition_4070); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + setCallback(2); + setup_enterExitCompartment("619AF", kObjectCompartment6); + break; + + case 2: + getEntities()->clearSequences(kEntityHadija); + + getData()->entityPosition = kPosition_4840; + getData()->location = kLocationInsideCompartment; + + getObjects()->update(kObjectCompartment5, kEntityPlayer, kObjectLocation1, kCursorHandKnock, kCursorHand); + break; + } + break; + + case kAction135800432: + setup_nullfunction(); + break; + } +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_NULL_FUNCTION(24, Hadija) + +} // End of namespace LastExpress |