diff options
Diffstat (limited to 'engines/lastexpress/entities/waiter1.cpp')
-rw-r--r-- | engines/lastexpress/entities/waiter1.cpp | 1034 |
1 files changed, 1034 insertions, 0 deletions
diff --git a/engines/lastexpress/entities/waiter1.cpp b/engines/lastexpress/entities/waiter1.cpp new file mode 100644 index 0000000000..21e40d326d --- /dev/null +++ b/engines/lastexpress/entities/waiter1.cpp @@ -0,0 +1,1034 @@ +/* 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 "lastexpress/entities/waiter1.h" + +#include "lastexpress/game/entities.h" +#include "lastexpress/game/logic.h" +#include "lastexpress/game/object.h" +#include "lastexpress/game/savepoint.h" +#include "lastexpress/game/state.h" + +#include "lastexpress/lastexpress.h" + +namespace LastExpress { + +#define HANDLE_TABLE(index, param, callback, function) \ + if (ENTITY_PARAM(index, param)) { \ + setCallback(callback); \ + function(); \ + break; \ + } + +Waiter1::Waiter1(LastExpressEngine *engine) : Entity(engine, kEntityWaiter1) { + ADD_CALLBACK_FUNCTION(Waiter1, callSavepoint); + ADD_CALLBACK_FUNCTION(Waiter1, updateFromTime); + ADD_CALLBACK_FUNCTION(Waiter1, draw); + ADD_CALLBACK_FUNCTION(Waiter1, updatePosition); + ADD_CALLBACK_FUNCTION(Waiter1, callbackActionOnDirection); + ADD_CALLBACK_FUNCTION(Waiter1, playSound); + ADD_CALLBACK_FUNCTION(Waiter1, function7); + ADD_CALLBACK_FUNCTION(Waiter1, function8); + ADD_CALLBACK_FUNCTION(Waiter1, function9); + ADD_CALLBACK_FUNCTION(Waiter1, function10); + ADD_CALLBACK_FUNCTION(Waiter1, chapter1); + ADD_CALLBACK_FUNCTION(Waiter1, function12); + ADD_CALLBACK_FUNCTION(Waiter1, function13); + ADD_CALLBACK_FUNCTION(Waiter1, function14); + ADD_CALLBACK_FUNCTION(Waiter1, function15); + ADD_CALLBACK_FUNCTION(Waiter1, function16); + ADD_CALLBACK_FUNCTION(Waiter1, function17); + ADD_CALLBACK_FUNCTION(Waiter1, function18); + ADD_CALLBACK_FUNCTION(Waiter1, function19); + ADD_CALLBACK_FUNCTION(Waiter1, chapter1Handler); + ADD_CALLBACK_FUNCTION(Waiter1, function21); + ADD_CALLBACK_FUNCTION(Waiter1, function22); + ADD_CALLBACK_FUNCTION(Waiter1, chapter2); + ADD_CALLBACK_FUNCTION(Waiter1, chapter2Handler); + ADD_CALLBACK_FUNCTION(Waiter1, function25); + ADD_CALLBACK_FUNCTION(Waiter1, function26); + ADD_CALLBACK_FUNCTION(Waiter1, chapter3); + ADD_CALLBACK_FUNCTION(Waiter1, chapter3Handler); + ADD_CALLBACK_FUNCTION(Waiter1, augustAnnaDateOrder); + ADD_CALLBACK_FUNCTION(Waiter1, function30); + ADD_CALLBACK_FUNCTION(Waiter1, chapter4); + ADD_CALLBACK_FUNCTION(Waiter1, chapter4Handler); + ADD_CALLBACK_FUNCTION(Waiter1, augustOrderSteak); + ADD_CALLBACK_FUNCTION(Waiter1, augustServeDuck); + ADD_CALLBACK_FUNCTION(Waiter1, function35); + ADD_CALLBACK_FUNCTION(Waiter1, chapter5); + ADD_CALLBACK_FUNCTION(Waiter1, chapter5Handler); + ADD_NULL_FUNCTION(); +} + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_SIIS(1, Waiter1, callSavepoint, EntityIndex, ActionIndex) + Entity::callSavepoint(savepoint, true); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_NOSETUP(2, Waiter1, updateFromTime) + Entity::updateFromTime(savepoint); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_S(3, Waiter1, draw) + Entity::draw(savepoint, true); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_NOSETUP(4, Waiter1, updatePosition) + Entity::updatePosition(savepoint, true); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_NOSETUP(5, Waiter1, callbackActionOnDirection) + EXPOSE_PARAMS(EntityData::EntityParametersIIII); + + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (getData()->direction != kDirectionRight) + callbackAction(); + break; + + case kActionExitCompartment: + callbackAction(); + break; + + case kActionExcuseMeCath: + if (!params->param1) { + getSound()->excuseMe(kEntityWaiter1); + params->param1 = 1; + } + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION_S(6, Waiter1, playSound) + Entity::playSound(savepoint); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(7, Waiter1, function7) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5800; + getData()->location = kLocationOutsideCompartment; + + ENTITY_PARAM(0, 3) = 0; + + setCallback(1); + setup_draw("911"); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getEntities()->clearSequences(kEntityWaiter1); + getSavePoints()->push(kEntityWaiter1, kEntityRebecca, kAction123712592); + break; + + case 2: + getEntities()->clearSequences(kEntityWaiter1); + getData()->entityPosition = kPosition_5900; + callbackAction(); + break; + } + break; + + case kAction136702400: + setCallback(2); + setup_draw("913"); + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(8, Waiter1, function8) + serveTable(savepoint, "911", kEntityTables3, "010L", "010M", "913", &ENTITY_PARAM(1, 2)); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(9, Waiter1, function9) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5800; + getData()->location = kLocationOutsideCompartment; + + setCallback(1); + setup_draw("915"); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getSavePoints()->push(kEntityWaiter1, kEntityAbbot, kAction122358304); + getEntities()->drawSequenceLeft(kEntityWaiter1, "029D"); + + setCallback(2); + setup_playSound(getProgress().chapter == kChapter3 ? "Abb3016" : "Abb4001"); + break; + + case 2: + getSavePoints()->push(kEntityWaiter1, kEntityAbbot, kAction122288808); + + setCallback(3); + setup_draw("917"); + break; + + case 3: + getData()->entityPosition = kPosition_5900; + getEntities()->clearSequences(kEntityWaiter1); + ENTITY_PARAM(2, 2) = 0; + ENTITY_PARAM(1, 6) = 0; + + callbackAction(); + break; + } + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(10, Waiter1, function10) + serveTable(savepoint, "916", kEntityTables4, "014E", "014F", "918", &ENTITY_PARAM(2, 3), false); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(11, Waiter1, chapter1) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter1Handler(); + break; + + case kActionDefault: + getSavePoints()->addData(kEntityWaiter1, kAction270410280, 0); + getSavePoints()->addData(kEntityWaiter1, kAction304061224, 1); + getSavePoints()->addData(kEntityWaiter1, kAction252568704, 10); + getSavePoints()->addData(kEntityWaiter1, kAction286534136, 11); + getSavePoints()->addData(kEntityWaiter1, kAction218983616, 12); + getSavePoints()->addData(kEntityWaiter1, kAction218586752, 13); + getSavePoints()->addData(kEntityWaiter1, kAction207330561, 14); + getSavePoints()->addData(kEntityWaiter1, kAction286403504, 16); + getSavePoints()->addData(kEntityWaiter1, kAction218128129, 17); + getSavePoints()->addData(kEntityWaiter1, kAction270068760, 18); + getSavePoints()->addData(kEntityWaiter1, kAction223712416, 2); + getSavePoints()->addData(kEntityWaiter1, kAction237485916, 5); + getSavePoints()->addData(kEntityWaiter1, kAction188893625, 8); + getSavePoints()->addData(kEntityWaiter1, kAction204704037, 6); + getSavePoints()->addData(kEntityWaiter1, kAction292758554, 7); + getSavePoints()->addData(kEntityWaiter1, kAction337548856, 9); + + getData()->entityPosition = kPosition_5900; + getData()->location = kLocationOutsideCompartment; + getData()->car = kCarRestaurant; + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(12, Waiter1, function12) + handleServer(savepoint, "907", kEntityAnna, kAction268773672, &ENTITY_PARAM(0, 1)); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(13, Waiter1, function13) + handleServer(savepoint, "911", kEntityAugust, kAction268773672, &ENTITY_PARAM(0, 2), "010F"); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(14, Waiter1, function14) + handleServer(savepoint, "908", kEntityAnna, kAction170016384, &ENTITY_PARAM(0, 4)); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(15, Waiter1, function15) + handleServer(savepoint, "912", kEntityAugust, kAction170016384, &ENTITY_PARAM(0, 5)); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(16, Waiter1, function16) + serveTable(savepoint, "907", kEntityTables0, "001N", "001P", "909", &ENTITY_PARAM(0, 6)); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(17, Waiter1, function17) + serveTable(savepoint, "915", kEntityTables4, "014E", "014F", "917", &ENTITY_PARAM(1, 1), true, false, 67); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(18, Waiter1, function18) + serveTable(savepoint, "911", kEntityTables3, "010L", "010H", "913", &ENTITY_PARAM(0, 7)); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(19, Waiter1, function19) + serveTable(savepoint, "911", kEntityTables3, "010L", "010M", "913", &ENTITY_PARAM(0, 8), true, true); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(20, Waiter1, chapter1Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (params->param2) { + if (Entity::updateParameter(params->param3, getState()->time, 2700)) { + ENTITY_PARAM(0, 4) = 1; + params->param2 = 0; + } + } + + if (params->param1) { + if (Entity::updateParameter(params->param4, getState()->time, 4500)) { + ENTITY_PARAM(0, 5) = 1; + params->param1 = 0; + } + } + + if (!getEntities()->isInKitchen(kEntityWaiter1) && !getEntities()->isSomebodyInsideRestaurantOrSalon()) + break; + + HANDLE_TABLE(0, 1, 1, setup_function12); + HANDLE_TABLE(0, 2, 2, setup_function13); + HANDLE_TABLE(0, 3, 3, setup_function7); + HANDLE_TABLE(0, 4, 4, setup_function14); + HANDLE_TABLE(0, 5, 5, setup_function15); + HANDLE_TABLE(0, 6, 6, setup_function16); + HANDLE_TABLE(1, 1, 7, setup_function17); + HANDLE_TABLE(0, 7, 8, setup_function18); + HANDLE_TABLE(0, 8, 9, setup_function19); + HANDLE_TABLE(1, 2, 10, setup_function8); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 10: + getSavePoints()->push(kEntityWaiter1, kEntityPascale, kAction352703104); + setup_function21(); + break; + + case 11: + case 12: + getEntities()->clearSequences(kEntityWaiter1); + getData()->entityPosition = kPosition_5900; + + if (getCallback() == 11) + params->param2 = 1; + else + params->param1 = 1; + break; + + case 13: + case 14: + getEntities()->clearSequences(kEntityWaiter1); + getData()->entityPosition = kPosition_5900; + break; + } + break; + + case kAction136702400: + setCallback(savepoint.entity2 == kEntityAnna ? 13 : 14); + setup_draw(savepoint.entity2 == kEntityAnna ? "909" : "913"); + break; + + case kAction203859488: + setCallback(savepoint.entity2 == kEntityAnna ? 11 : 12); + setup_draw(savepoint.entity2 == kEntityAnna ? "910" : "913"); + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(21, Waiter1, function21) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5900; + break; + + case kAction101632192: + setup_function22(); + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(22, Waiter1, function22) + if (savepoint.action == kActionDefault) { + getData()->entityPosition = kPosition_5900; + getData()->location = kLocationOutsideCompartment; + getData()->car = kCarRestaurant; + + getEntities()->clearSequences(kEntityWaiter1); + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(23, Waiter1, chapter2) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter2Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityWaiter1); + + getData()->entityPosition = kPosition_5900; + getData()->location = kLocationOutsideCompartment; + getData()->car = kCarRestaurant; + getData()->clothes = kClothes1; + getData()->inventoryItem = kItemNone; + + ENTITY_PARAM(1, 3) = 0; + ENTITY_PARAM(1, 4) = 0; + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(24, Waiter1, chapter2Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (!getEntities()->isInKitchen(kEntityWaiter1) || !getEntities()->isSomebodyInsideRestaurantOrSalon()) + break; + + HANDLE_TABLE(1, 3, 1, setup_function25); + HANDLE_TABLE(1, 4, 2, setup_function26); + break; + + case kActionCallback: + if (getCallback() == 1) + HANDLE_TABLE(1, 4, 2, setup_function26); + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(25, Waiter1, function25) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5800; + getData()->location = kLocationOutsideCompartment; + + setCallback(1); + setup_draw("957"); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getSavePoints()->push(kEntityWaiter1, kEntityAugust, kAction123712592); + getEntities()->drawSequenceLeft(kEntityWaiter1, "BLANK"); + break; + + case 2: + getData()->entityPosition = kPosition_5900; + getEntities()->clearSequences(kEntityWaiter1); + ENTITY_PARAM(1, 3) = 0; + + callbackAction(); + break; + } + break; + + case kAction219522616: + setCallback(2); + setup_draw("959"); + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(26, Waiter1, function26) + serveTable(savepoint, "957", kEntityTables0, "016E", "016D", "959", &ENTITY_PARAM(1, 4)); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(27, Waiter1, chapter3) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter3Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityWaiter1); + + getData()->entityPosition = kPosition_5900; + getData()->location = kLocationOutsideCompartment; + getData()->car = kCarRestaurant; + getData()->clothes = kClothes1; + getData()->inventoryItem = kItemNone; + + ENTITY_PARAM(0, 3) = 0; + ENTITY_PARAM(1, 2) = 0; + ENTITY_PARAM(1, 5) = 0; + ENTITY_PARAM(1, 6) = 0; + ENTITY_PARAM(2, 3) = 0; + ENTITY_PARAM(2, 4) = 0; + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(28, Waiter1, chapter3Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (!getEntities()->isInKitchen(kEntityWaiter2) || !getEntities()->isSomebodyInsideRestaurantOrSalon()) + break; + + if (ENTITY_PARAM(1, 5)) { + setCallback(1); + setup_augustAnnaDateOrder(); + break; + } + +label_callback_1: + if (ENTITY_PARAM(1, 6)) { + setCallback(2); + setup_function9(); + break; + } + +label_callback_2: + if (ENTITY_PARAM(2, 4)) { + setCallback(3); + setup_function30(); + break; + } + +label_callback_3: + if (ENTITY_PARAM(2, 3)) { + setCallback(4); + setup_function10(); + break; + } + +label_callback_4: + if (ENTITY_PARAM(0, 3)) { + setCallback(5); + setup_function7(); + break; + } + +label_callback_5: + if (ENTITY_PARAM(1, 2)) { + setCallback(6); + setup_function8(); + break; + } + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + goto label_callback_1; + + case 2: + goto label_callback_2; + + case 3: + goto label_callback_3; + + case 4: + goto label_callback_4; + + case 5: + goto label_callback_5; + } + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(29, Waiter1, augustAnnaDateOrder) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5800; + getData()->location = kLocationOutsideCompartment; + + setCallback(1); + setup_draw("911"); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getSavePoints()->push(kEntityWaiter1, kEntityAnna, kAction122358304); + getEntities()->drawSequenceLeft(kEntityWaiter1, "026D"); + + setCallback(2); + setup_playSound("Ann3138"); + break; + + case 2: + getSavePoints()->push(kEntityWaiter1, kEntityAnna, kAction122288808); + + setCallback(3); + setup_draw("913"); + break; + + case 3: + getData()->entityPosition = kPosition_5900; + getEntities()->clearSequences(kEntityWaiter1); + ENTITY_PARAM(1, 5) = 0; + + callbackAction(); + break; + } + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(30, Waiter1, function30) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5800; + getData()->location = kLocationOutsideCompartment; + + setCallback(1); + setup_draw("916"); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getSavePoints()->push(kEntityWaiter1, kEntityAbbot, kAction122358304); + getEntities()->drawSequenceLeft(kEntityWaiter1, "029D"); + + setCallback(2); + setup_playSound("Abb3016a"); + break; + + case 2: + getSavePoints()->push(kEntityWaiter1, kEntityAbbot, kAction122288808); + + setCallback(3); + setup_draw("918"); + break; + + case 3: + getData()->entityPosition = kPosition_5900; + getEntities()->clearSequences(kEntityWaiter1); + ENTITY_PARAM(2, 4) = 0; + + callbackAction(); + break; + } + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(31, Waiter1, chapter4) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter4Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityWaiter1); + + getData()->entityPosition = kPosition_5900; + getData()->location = kLocationOutsideCompartment; + getData()->car = kCarRestaurant; + getData()->clothes = kClothesDefault; + getData()->inventoryItem = kItemNone; + + ENTITY_PARAM(0, 3) = 0; + ENTITY_PARAM(1, 7) = 0; + ENTITY_PARAM(1, 8) = 0; + ENTITY_PARAM(2, 1) = 0; + ENTITY_PARAM(2, 2) = 0; + ENTITY_PARAM(2, 3) = 0; + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(32, Waiter1, chapter4Handler) + switch (savepoint.action) { + default: + break; + + case kActionNone: + if (Entity::updateParameter(params->param2, getState()->time, 3600)) { + ENTITY_PARAM(1, 8) = 1; + params->param1 = 0; + } + + if (!getEntities()->isInKitchen(kEntityWaiter2) || !getEntities()->isSomebodyInsideRestaurantOrSalon()) + break; + + if (ENTITY_PARAM(1, 7)) { + setCallback(1); + setup_augustOrderSteak(); + break; + } + +label_callback_1: + if (ENTITY_PARAM(1, 8)) { + setCallback(2); + setup_augustServeDuck(); + break; + } + +label_callback_2: + if (ENTITY_PARAM(2, 1)) { + setCallback(3); + setup_function35(); + break; + } + +label_callback_3: + if (ENTITY_PARAM(2, 2)) { + setCallback(4); + setup_function9(); + break; + } + +label_callback_4: + if (ENTITY_PARAM(2, 3)) { + setCallback(5); + setup_function10(); + break; + } + +label_callback_5: + if (ENTITY_PARAM(0, 3)) { + setCallback(6); + setup_function7(); + break; + } + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + params->param1 = 1; + goto label_callback_1; + + case 2: + goto label_callback_2; + + case 3: + goto label_callback_3; + + case 4: + goto label_callback_4; + + case 5: + goto label_callback_5; + } + break; + + case kAction201431954: + ENTITY_PARAM(0, 3) = 0; + ENTITY_PARAM(1, 7) = 0; + ENTITY_PARAM(1, 8) = 0; + ENTITY_PARAM(2, 1) = 0; + ENTITY_PARAM(2, 3) = 0; + params->param1 = 0; + + getData()->entityPosition = kPosition_5900; + getData()->location = kLocationOutsideCompartment; + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(33, Waiter1, augustOrderSteak) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + setCallback(1); + setup_draw("911"); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getEntities()->drawSequenceLeft(kEntityWaiter1, "010F3"); + getEntities()->drawSequenceLeft(kEntityAugust, "010D3"); + + setCallback(2); + setup_playSound("AUG4002"); + break; + + case 2: + getSavePoints()->push(kEntityWaiter1, kEntityAugust, kAction122288808); + + setCallback(3); + setup_draw("913"); + break; + + case 3: + getData()->entityPosition = kPosition_5900; + getEntities()->clearSequences(kEntityWaiter1); + ENTITY_PARAM(1, 7) = 0; + + callbackAction(); + break; + } + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(34, Waiter1, augustServeDuck) + switch (savepoint.action) { + default: + break; + + case kActionDefault: + setCallback(1); + setup_draw("912"); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + getSavePoints()->push(kEntityWaiter1, kEntityAugust, kAction122358304); + getSound()->playSound(kEntityWaiter1, "AUG1053"); + + setCallback(2); + setup_draw("010G3"); + break; + + case 2: + getSavePoints()->push(kEntityWaiter1, kEntityAugust, kAction201964801); + + setCallback(3); + setup_draw("914"); + break; + + case 3: + getData()->entityPosition = kPosition_5900; + getEntities()->clearSequences(kEntityWaiter1); + ENTITY_PARAM(1, 8) = 0; + + callbackAction(); + break; + } + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(35, Waiter1, function35) + serveTable(savepoint, "911", kEntityTables3, "010L", "010M", "914", &ENTITY_PARAM(2, 1), false, true); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(36, Waiter1, chapter5) + switch (savepoint.action) { + default: + break; + + case kActionNone: + setup_chapter5Handler(); + break; + + case kActionDefault: + getEntities()->clearSequences(kEntityWaiter1); + + getData()->entityPosition = kPosition_3969; + getData()->location = kLocationInsideCompartment; + getData()->car = kCarRestaurant; + getData()->inventoryItem = kItemNone; + break; + } +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_FUNCTION(37, Waiter1, chapter5Handler) + if (savepoint.action == kActionProceedChapter5) + setup_nullfunction(); +IMPLEMENT_FUNCTION_END + +////////////////////////////////////////////////////////////////////////// +IMPLEMENT_NULL_FUNCTION(38, Waiter1) + + +////////////////////////////////////////////////////////////////////////// +// Private functions +////////////////////////////////////////////////////////////////////////// +void Waiter1::handleServer(const SavePoint &savepoint, const char *name, EntityIndex entity, ActionIndex action, uint *parameter, const char *name2) { + switch (savepoint.action) { + default: + break; + + case kActionDefault: + getData()->entityPosition = kPosition_5800; + getData()->location = kLocationOutsideCompartment; + + setCallback(1); + setup_draw(name); + break; + + case kActionCallback: + if (getCallback() == 1) { + // Prepare or draw sequences depending of value of string + if (strcmp(name2, "")) + getEntities()->clearSequences(kEntityWaiter1); + else + getEntities()->drawSequenceLeft(kEntityWaiter1, name2); + + getSavePoints()->push(kEntityWaiter1, entity, action); + *parameter = 0; + + callbackAction(); + } + break; + } +} + +////////////////////////////////////////////////////////////////////////// +void Waiter1::serveTable(const SavePoint &savepoint, const char *seq1, EntityIndex entity, const char *seq2, const char *seq3, const char *seq4, uint *parameter, bool shouldUpdatePosition, bool pushSavepoint, Position position) { + switch (savepoint.action) { + default: + break; + + case kActionDefault: + if (shouldUpdatePosition) { + getData()->entityPosition = kPosition_5800; + getData()->location = kLocationOutsideCompartment; + } + + setCallback(1); + setup_draw(seq1); + break; + + case kActionCallback: + switch (getCallback()) { + default: + break; + + case 1: + if (position) + getEntities()->updatePositionEnter(kEntityWaiter1, kCarRestaurant, position); + + getSavePoints()->push(kEntityWaiter1, entity, kAction136455232); + + setCallback(2); + setup_callSavepoint(seq2, entity, kActionDrawTablesWithChairs, seq3); + break; + + case 2: + if (position) + getEntities()->updatePositionExit(kEntityWaiter1, kCarRestaurant, position); + + setCallback(3); + setup_draw(seq4); + break; + + case 3: + getData()->entityPosition = kPosition_5900; + + // Special case for functions 19 & 35 + if (pushSavepoint) + getSavePoints()->push(kEntityWaiter1, kEntityRebecca, kAction224253538); + + getEntities()->clearSequences(kEntityWaiter1); + *parameter = 0; + + callbackAction(); + break; + } + break; + } +} + +} // End of namespace LastExpress |