diff options
Diffstat (limited to 'src/uqm/comm/supox/supoxc.c')
-rw-r--r-- | src/uqm/comm/supox/supoxc.c | 708 |
1 files changed, 708 insertions, 0 deletions
diff --git a/src/uqm/comm/supox/supoxc.c b/src/uqm/comm/supox/supoxc.c new file mode 100644 index 0000000..e169cba --- /dev/null +++ b/src/uqm/comm/supox/supoxc.c @@ -0,0 +1,708 @@ +//Copyright Paul Reiche, Fred Ford. 1992-2002 + +/* + * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +#include "../commall.h" +#include "resinst.h" +#include "strings.h" + +#include "uqm/build.h" + + +static LOCDATA supox_desc = +{ + NULL, /* init_encounter_func */ + NULL, /* post_encounter_func */ + NULL, /* uninit_encounter_func */ + SUPOX_PMAP_ANIM, /* AlienFrame */ + SUPOX_FONT, /* AlienFont */ + WHITE_COLOR_INIT, /* AlienTextFColor */ + BLACK_COLOR_INIT, /* AlienTextBColor */ + {0, 0}, /* AlienTextBaseline */ + 0, /* SIS_TEXT_WIDTH - 16, */ /* AlienTextWidth */ + ALIGN_CENTER, /* AlienTextAlign */ + VALIGN_TOP, /* AlienTextValign */ + SUPOX_COLOR_MAP, /* AlienColorMap */ + SUPOX_MUSIC, /* AlienSong */ + NULL_RESOURCE, /* AlienAltSong */ + 0, /* AlienSongFlags */ + SUPOX_CONVERSATION_PHRASES, /* PlayerPhrases */ + 4, /* NumAnimations */ + { /* AlienAmbientArray (ambient animations) */ + { + 4, /* StartIndex */ + 5, /* NumFrames */ + YOYO_ANIM + | WAIT_TALKING, /* AnimFlags */ + ONE_SECOND / 10, ONE_SECOND / 10, /* FrameRate */ + ONE_SECOND, ONE_SECOND * 3, /* RestartRate */ + 0, /* BlockMask */ + }, + { + 9, /* StartIndex */ + 10, /* NumFrames */ + CIRCULAR_ANIM, /* AnimFlags */ + ONE_SECOND / 15, 0, /* FrameRate */ + ONE_SECOND, ONE_SECOND * 3, /* RestartRate */ + 0, /* BlockMask */ + }, + { + 19, /* StartIndex */ + 10, /* NumFrames */ + CIRCULAR_ANIM, /* AnimFlags */ + ONE_SECOND / 15, 0, /* FrameRate */ + ONE_SECOND, ONE_SECOND * 3, /* RestartRate */ + 0, /* BlockMask */ + }, + { + 29, /* StartIndex */ + 13, /* NumFrames */ + CIRCULAR_ANIM, /* AnimFlags */ + ONE_SECOND / 15, 0, /* FrameRate */ + ONE_SECOND, ONE_SECOND * 3, /* RestartRate */ + 0, /* BlockMask */ + }, + }, + { /* AlienTransitionDesc */ + 0, /* StartIndex */ + 0, /* NumFrames */ + 0, /* AnimFlags */ + 0, 0, /* FrameRate */ + 0, 0, /* RestartRate */ + 0, /* BlockMask */ + }, + { /* AlienTalkDesc */ + 1, /* StartIndex */ + 3, /* NumFrames */ + 0, /* AnimFlags */ + ONE_SECOND / 15, 0, /* FrameRate */ + ONE_SECOND / 12, 0, /* RestartRate */ + 0, /* BlockMask */ + }, + NULL, /* AlienNumberSpeech - none */ + /* Filler for loaded resources */ + NULL, NULL, NULL, + NULL, + NULL, +}; + +static void +ExitConversation (RESPONSE_REF R) +{ + setSegue (Segue_peace); + + if (PLAYER_SAID (R, bye_neutral)) + NPCPhrase (GOODBYE_NEUTRAL); + else if (PLAYER_SAID (R, what_do_i_do_now)) + NPCPhrase (FIX_IT); + else if (PLAYER_SAID (R, thanks_now_we_eat_you)) + { + NPCPhrase (HIDEOUS_MONSTERS); + + SET_GAME_STATE (SUPOX_HOSTILE, 1); + SET_GAME_STATE (SUPOX_HOME_VISITS, 0); + SET_GAME_STATE (SUPOX_VISITS, 0); + } + else if (PLAYER_SAID (R, bye_after_space)) + NPCPhrase (GOODBYE_AFTER_SPACE); + else if (PLAYER_SAID (R, bye_before_space)) + NPCPhrase (GOODBYE_BEFORE_SPACE); + else if (PLAYER_SAID (R, bye_allied_homeworld)) + NPCPhrase (GOODBYE_ALLIED_HOMEWORLD); + else if (PLAYER_SAID (R, can_you_help)) + { + NPCPhrase (HOW_HELP); + if (EscortFeasibilityStudy (SUPOX_SHIP) == 0) + NPCPhrase (DONT_NEED); + else + { + NPCPhrase (HAVE_4_SHIPS); + + AlienTalkSegue ((COUNT)~0); + AddEscortShips (SUPOX_SHIP, 4); + } + } +} + +static void AlliedHome (RESPONSE_REF R); + +static void +AlliedHome (RESPONSE_REF R) +{ + BYTE NumVisits, News; + + News = GET_GAME_STATE (SUPOX_WAR_NEWS); + NumVisits = GET_GAME_STATE (UTWIG_SUPOX_MISSION); + if (PLAYER_SAID (R, how_went_war)) + { + NPCPhrase (ABOUT_BATTLE); + + News |= (1 << 0); + } + else if (PLAYER_SAID (R, how_goes_war)) + { + if (NumVisits == 1) + { + NPCPhrase (FLEET_ON_WAY); + + SET_GAME_STATE (SUPOX_WAR_NEWS, 1); + } + else switch (GET_GAME_STATE (SUPOX_WAR_NEWS)) + { + case 0: + NPCPhrase (BATTLE_HAPPENS_1); + News = 1; + break; + case 1: + NPCPhrase (BATTLE_HAPPENS_2); + News = 2; + break; + } + + DISABLE_PHRASE (how_goes_war); + } + else if (PLAYER_SAID (R, learn_new_info)) + { + if (NumVisits < 5) + NPCPhrase (NO_NEW_INFO); + else + { + NPCPhrase (SAMATRA); + + News |= (1 << 1); + } + + DISABLE_PHRASE (learn_new_info); + } + else if (PLAYER_SAID (R, what_now_homeworld)) + { + if (NumVisits < 5) + NPCPhrase (UP_TO_YOU); + else + NPCPhrase (HOPE_KILL_EACH_OTHER); + + DISABLE_PHRASE (what_now_homeworld); + } + else if (PLAYER_SAID (R, how_is_ultron)) + { + NPCPhrase (ULTRON_IS_GREAT); + + DISABLE_PHRASE (how_is_ultron); + } + SET_GAME_STATE (SUPOX_WAR_NEWS, News); + + if (NumVisits >= 5) + { + if (!(News & (1 << 0))) + Response (how_went_war, AlliedHome); + } + else if (PHRASE_ENABLED (how_goes_war) + && ((NumVisits == 1 && News == 0) + || (NumVisits && News < 2))) + Response (how_goes_war, AlliedHome); + if (PHRASE_ENABLED (learn_new_info)) + Response (learn_new_info, AlliedHome); + if (PHRASE_ENABLED (what_now_homeworld)) + Response (what_now_homeworld, AlliedHome); + if (PHRASE_ENABLED (how_is_ultron)) + Response (how_is_ultron, AlliedHome); + if (NumVisits == 0) + Response (can_you_help, ExitConversation); + Response (bye_allied_homeworld, ExitConversation); +} + +static void +BeforeKohrAh (RESPONSE_REF R) +{ + BYTE NumVisits; + + if (PLAYER_SAID (R, whats_up_before_space)) + { + NumVisits = GET_GAME_STATE (SUPOX_INFO); + switch (NumVisits++) + { + case 0: + NPCPhrase (GENERAL_INFO_BEFORE_SPACE_1); + break; + case 1: + NPCPhrase (GENERAL_INFO_BEFORE_SPACE_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_INFO, NumVisits); + + DISABLE_PHRASE (whats_up_before_space); + } + else if (PLAYER_SAID (R, what_now_before_space)) + { + NPCPhrase (DO_THIS_BEFORE_SPACE); + + DISABLE_PHRASE (what_now_before_space); + } + + if (PHRASE_ENABLED (whats_up_before_space)) + Response (whats_up_before_space, BeforeKohrAh); + if (PHRASE_ENABLED (what_now_before_space)) + Response (what_now_before_space, BeforeKohrAh); + Response (bye_before_space, ExitConversation); +} + +static void +AfterKohrAh (RESPONSE_REF R) +{ + BYTE NumVisits; + + if (PLAYER_SAID (R, whats_up_after_space)) + { + NumVisits = GET_GAME_STATE (SUPOX_INFO); + switch (NumVisits++) + { + case 0: + NPCPhrase (GENERAL_INFO_AFTER_SPACE_1); + break; + case 1: + NPCPhrase (GENERAL_INFO_AFTER_SPACE_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_INFO, NumVisits); + + DISABLE_PHRASE (whats_up_after_space); + } + else if (PLAYER_SAID (R, what_now_after_space)) + { + NPCPhrase (DO_THIS_AFTER_SPACE); + + DISABLE_PHRASE (what_now_after_space); + } + + if (PHRASE_ENABLED (whats_up_after_space)) + Response (whats_up_after_space, AfterKohrAh); + if (PHRASE_ENABLED (what_now_after_space)) + Response (what_now_after_space, AfterKohrAh); + Response (bye_after_space, ExitConversation); +} + +static void +NeutralSupox (RESPONSE_REF R) +{ + BYTE i, LastStack, NumVisits; + RESPONSE_REF pStr[3]; + + LastStack = 0; + pStr[0] = pStr[1] = pStr[2] = 0; + if (PLAYER_SAID (R, i_am0)) + { + NPCPhrase (WE_ARE_SUPOX); + + SET_GAME_STATE (SUPOX_STACK1, 1); + DISABLE_PHRASE (i_am0); + } + else if (PLAYER_SAID (R, my_ship0)) + { + NPCPhrase (OUR_SHIP); + + SET_GAME_STATE (SUPOX_STACK1, 2); + DISABLE_PHRASE (my_ship0); + } + else if (PLAYER_SAID (R, from_alliance0)) + { + NPCPhrase (FROM_SUPOX); + + SET_GAME_STATE (SUPOX_STACK1, 3); + DISABLE_PHRASE (from_alliance0); + } + else if (PLAYER_SAID (R, are_you_copying)) + { + NPCPhrase (YEAH_SORRY); + + SET_GAME_STATE (SUPOX_STACK1, 4); + } + else if (PLAYER_SAID (R, why_copy)) + { + NPCPhrase (SYMBIOTS); + + SET_GAME_STATE (SUPOX_STACK1, 5); + } + else if (PLAYER_SAID (R, tell_us_of_your_species)) + { + NPCPhrase (OUR_SPECIES); + + LastStack = 1; + SET_GAME_STATE (SUPOX_STACK2, 1); + } + else if (PLAYER_SAID (R, plants_arent_intelligent)) + { + NPCPhrase (PROVES_WERE_SPECIAL); + + SET_GAME_STATE (SUPOX_STACK2, 2); + } + else if (PLAYER_SAID (R, anyone_around_here)) + { + NPCPhrase (UTWIG_NEARBY); + + LastStack = 2; + SET_GAME_STATE (SUPOX_WAR_NEWS, 1); + StartSphereTracking (UTWIG_SHIP); + } + else if (PLAYER_SAID (R, what_relation_to_utwig)) + { + NPCPhrase (UTWIG_ALLIES); + + LastStack = 2; + SET_GAME_STATE (SUPOX_WAR_NEWS, 1); + } + else if (PLAYER_SAID (R, whats_wrong_with_utwig)) + { + NPCPhrase (BROKE_ULTRON); + + LastStack = 2; + SET_GAME_STATE (SUPOX_WAR_NEWS, 2); + } + else if (PLAYER_SAID (R, whats_ultron)) + { + NPCPhrase (TAKE_ULTRON); + + SET_GAME_STATE (SUPOX_WAR_NEWS, 0); + SET_GAME_STATE (ULTRON_CONDITION, 1); + + Response (what_do_i_do_now, ExitConversation); + Response (thanks_now_we_eat_you, ExitConversation); + + return; + } + else if (PLAYER_SAID (R, got_fixed_ultron)) + { + NPCPhrase (GOOD_GIVE_TO_UTWIG); + + SET_GAME_STATE (SUPOX_ULTRON_HELP, 1); + } + else if (PLAYER_SAID (R, look_i_repaired_lots)) + { + NPCPhrase (ALMOST_THERE); + + SET_GAME_STATE (SUPOX_ULTRON_HELP, 1); + } + else if (PLAYER_SAID (R, look_i_slightly_repaired)) + { + NPCPhrase (GREAT_DO_MORE); + + SET_GAME_STATE (SUPOX_ULTRON_HELP, 1); + } + else if (PLAYER_SAID (R, where_get_repairs)) + { + NPCPhrase (ANCIENT_RHYME); + + SET_GAME_STATE (SUPOX_ULTRON_HELP, 1); + } + + switch (GET_GAME_STATE (SUPOX_STACK2)) + { + case 0: + pStr[1] = tell_us_of_your_species; + break; + case 1: + pStr[1] = plants_arent_intelligent; + break; + } + switch (GET_GAME_STATE (SUPOX_STACK1)) + { + case 0: + construct_response (shared_phrase_buf, + i_am0, + GLOBAL_SIS (CommanderName), + i_am1, + (UNICODE*)NULL); + pStr[0] = i_am0; + pStr[1] = 0; + break; + case 1: + construct_response (shared_phrase_buf, + my_ship0, + GLOBAL_SIS (ShipName), + my_ship1, + (UNICODE*)NULL); + pStr[0] = my_ship0; + pStr[1] = 0; + break; + case 2: + { + UNICODE buf[ALLIANCE_NAME_BUFSIZE]; + + GetAllianceName (buf, name_1); + construct_response ( + shared_phrase_buf, + from_alliance0, + buf, + from_alliance1, + (UNICODE*)NULL); + } + pStr[0] = from_alliance0; + pStr[1] = 0; + break; + case 3: + pStr[0] = are_you_copying; + pStr[1] = 0; + break; + case 4: + pStr[0] = why_copy; + pStr[1] = 0; + break; + } + NumVisits = GET_GAME_STATE (ULTRON_CONDITION); + if (NumVisits == 0) + { + switch (GET_GAME_STATE (SUPOX_WAR_NEWS)) + { + case 0: + if (GET_GAME_STATE (UTWIG_VISITS) + || GET_GAME_STATE (UTWIG_HOME_VISITS) + || GET_GAME_STATE (BOMB_VISITS)) + pStr[2] = what_relation_to_utwig; + else + pStr[2] = anyone_around_here; + break; + case 1: + pStr[2] = whats_wrong_with_utwig; + break; + case 2: + pStr[2] = whats_ultron; + break; + } + } + if (pStr[LastStack]) + { + if (LastStack != 0 || GET_GAME_STATE (SUPOX_STACK1) > 2) + Response (pStr[LastStack], NeutralSupox); + else + DoResponsePhrase (pStr[LastStack], NeutralSupox, shared_phrase_buf); + } + for (i = 0; i < 3; ++i) + { + if (i != LastStack && pStr[i]) + { + if (i != 0 || GET_GAME_STATE (SUPOX_STACK1) > 2) + Response (pStr[i], NeutralSupox); + else + DoResponsePhrase (pStr[i], NeutralSupox, shared_phrase_buf); + } + } + if (!GET_GAME_STATE (SUPOX_ULTRON_HELP)) + { + switch (NumVisits) + { + case 1: + Response (where_get_repairs, NeutralSupox); + break; + case 2: + Response (look_i_slightly_repaired, NeutralSupox); + break; + case 3: + Response (look_i_repaired_lots, NeutralSupox); + break; + case 4: + Response (got_fixed_ultron, NeutralSupox); + break; + } + } + Response (bye_neutral, ExitConversation); +} + +static void +Intro (void) +{ + BYTE NumVisits; + + if (LOBYTE (GLOBAL (CurrentActivity)) == WON_LAST_BATTLE) + { + NPCPhrase (OUT_TAKES); + + setSegue (Segue_peace); + return; + } + + if (GET_GAME_STATE (SUPOX_HOSTILE)) + { + NumVisits = GET_GAME_STATE (SUPOX_VISITS); + switch (NumVisits++) + { + case 0: + NPCPhrase (HOSTILE_SPACE_HELLO_1); + break; + case 1: + NPCPhrase (HOSTILE_SPACE_HELLO_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_VISITS, NumVisits); + + setSegue (Segue_peace); + } + else if (CheckAlliance (SUPOX_SHIP) == GOOD_GUY) + { + if (GET_GAME_STATE (GLOBAL_FLAGS_AND_DATA) & (1 << 7)) + { + NumVisits = GET_GAME_STATE (SUPOX_HOME_VISITS); + switch (NumVisits++) + { + case 0: + NPCPhrase (ALLIED_HOMEWORLD_HELLO_1); + break; + case 1: + NPCPhrase (ALLIED_HOMEWORLD_HELLO_2); + break; + case 2: + NPCPhrase (ALLIED_HOMEWORLD_HELLO_3); + break; + case 3: + NPCPhrase (ALLIED_HOMEWORLD_HELLO_4); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_HOME_VISITS, NumVisits); + + AlliedHome ((RESPONSE_REF)0); + } + else + { + NumVisits = GET_GAME_STATE (UTWIG_SUPOX_MISSION); + if (NumVisits == 1) + { + NumVisits = GET_GAME_STATE (SUPOX_VISITS); + switch (NumVisits++) + { + case 0: + NPCPhrase (HELLO_BEFORE_KOHRAH_SPACE_1); + break; + case 1: + NPCPhrase (HELLO_BEFORE_KOHRAH_SPACE_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_VISITS, NumVisits); + + BeforeKohrAh ((RESPONSE_REF)0); + } + else if (NumVisits < 5) + { + NumVisits = GET_GAME_STATE (SUPOX_VISITS); + switch (NumVisits++) + { + case 0: + NPCPhrase (HELLO_DURING_KOHRAH_SPACE_1); + break; + case 1: + NPCPhrase (HELLO_DURING_KOHRAH_SPACE_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_VISITS, NumVisits); + } + else + { + NumVisits = GET_GAME_STATE (SUPOX_VISITS); + switch (NumVisits++) + { + case 0: + NPCPhrase (HELLO_AFTER_KOHRAH_SPACE_1); + break; + case 1: + NPCPhrase (HELLO_AFTER_KOHRAH_SPACE_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_VISITS, NumVisits); + + AfterKohrAh ((RESPONSE_REF)0); + } + } + } + else + { + if (GET_GAME_STATE (GLOBAL_FLAGS_AND_DATA) & (1 << 7)) + { + NumVisits = GET_GAME_STATE (SUPOX_HOME_VISITS); + switch (NumVisits++) + { + case 0: + NPCPhrase (NEUTRAL_HOMEWORLD_HELLO_1); + break; + case 1: + NPCPhrase (NEUTRAL_HOMEWORLD_HELLO_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_HOME_VISITS, NumVisits); + } + else + { + NumVisits = GET_GAME_STATE (SUPOX_VISITS); + switch (NumVisits++) + { + case 0: + NPCPhrase (NEUTRAL_SPACE_HELLO_1); + break; + case 1: + NPCPhrase (NEUTRAL_SPACE_HELLO_2); + --NumVisits; + break; + } + SET_GAME_STATE (SUPOX_VISITS, NumVisits); + } + + NeutralSupox ((RESPONSE_REF)0); + } +} + +static COUNT +uninit_supox (void) +{ + return (0); +} + +static void +post_supox_enc (void) +{ + // nothing defined so far +} + +LOCDATA* +init_supox_comm (void) +{ + LOCDATA *retval; + + supox_desc.init_encounter_func = Intro; + supox_desc.post_encounter_func = post_supox_enc; + supox_desc.uninit_encounter_func = uninit_supox; + + supox_desc.AlienTextBaseline.x = TEXT_X_OFFS + (SIS_TEXT_WIDTH >> 1); + supox_desc.AlienTextBaseline.y = 0; + supox_desc.AlienTextWidth = SIS_TEXT_WIDTH - 16; + + if (!GET_GAME_STATE (SUPOX_HOSTILE) + || LOBYTE (GLOBAL (CurrentActivity)) == WON_LAST_BATTLE) + { + setSegue (Segue_peace); + } + else + { + setSegue (Segue_hostile); + } + retval = &supox_desc; + + return (retval); +} |