Descent3/scripts/myPowerHouse.cpp

649 lines
17 KiB
C++
Raw Permalink Normal View History

/*
* Descent 3
* Copyright (C) 2024 Parallax Software
*
* 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 3 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, see <http://www.gnu.org/licenses/>.
*/
2024-04-16 03:43:29 +00:00
/////////////////////////////////////////////////////////////////////
// D.A.L.L.A.S. Generated Level Script - DLL Source File
2024-04-16 18:56:40 +00:00
//
2024-04-16 03:43:29 +00:00
// Filename: myPowerHouse.cpp
// Version: 3
/////////////////////////////////////////////////////////////////////
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include "osiris_import.h"
#include "osiris_common.h"
#include "DallasFuncs.h"
2024-04-16 03:43:29 +00:00
#include "module.h"
2024-04-16 03:43:29 +00:00
#ifdef __cplusplus
2024-04-16 18:56:40 +00:00
extern "C" {
2024-04-16 03:43:29 +00:00
#endif
DLLEXPORT char STDCALL InitializeDLL(tOSIRISModuleInit *func_list);
DLLEXPORT void STDCALL ShutdownDLL(void);
2024-05-24 03:07:26 +00:00
DLLEXPORT int STDCALL GetGOScriptID(const char *name, uint8_t is_door);
DLLEXPORT void STDCALLPTR CreateInstance(int id);
DLLEXPORT void STDCALL DestroyInstance(int id, void *ptr);
DLLEXPORT int16_t STDCALL CallInstanceEvent(int id, void *ptr, int event, tOSIRISEventInfo *data);
DLLEXPORT int STDCALL GetTriggerScriptID(int trigger_room, int trigger_face);
DLLEXPORT int STDCALL GetCOScriptList(int **list, int **id_list);
2024-05-24 03:07:26 +00:00
DLLEXPORT int STDCALL SaveRestoreState(void *file_ptr, uint8_t saving_state);
2024-04-16 03:43:29 +00:00
#ifdef __cplusplus
}
#endif
// =================
// Script ID Numbers
// =================
2024-04-16 18:56:40 +00:00
#define ID_LEVEL_0000 0x000
2024-04-16 03:43:29 +00:00
2024-04-16 18:56:40 +00:00
#define ID_CUSTOM_OBJECT_0827 0x001
2024-04-16 03:43:29 +00:00
// ========================
// Script Class Definitions
// ========================
class BaseScript {
public:
2024-11-03 10:07:31 +00:00
virtual ~BaseScript() = default;
virtual int16_t CallEvent(int event, tOSIRISEventInfo *data);
2024-04-16 03:43:29 +00:00
};
class LevelScript_0000 final : public BaseScript {
2024-04-16 03:43:29 +00:00
public:
int16_t CallEvent(int event, tOSIRISEventInfo *data);
2024-04-16 03:43:29 +00:00
};
class CustomObjectScript_0827 final : public BaseScript {
2024-04-16 03:43:29 +00:00
public:
int16_t CallEvent(int event, tOSIRISEventInfo *data);
2024-04-16 03:43:29 +00:00
};
// ======================
// Global Action Counters
// ======================
2024-04-16 18:56:40 +00:00
#define MAX_ACTION_CTR_VALUE 100000
2024-04-16 03:43:29 +00:00
int ScriptActionCtr_000 = 0;
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// ========================================
// Function to Clear Global Action Counters
// ========================================
2024-04-16 18:56:40 +00:00
void ClearGlobalActionCtrs(void) { ScriptActionCtr_000 = 0; }
2024-04-16 03:43:29 +00:00
// ========================================
// Function to Save Global Action Counters
// ========================================
2024-04-16 18:56:40 +00:00
void SaveGlobalActionCtrs(void *file_ptr) { File_WriteInt(ScriptActionCtr_000, file_ptr); }
2024-04-16 03:43:29 +00:00
// ===========================================
// Function to Restore Global Action Counters
// ===========================================
2024-04-16 18:56:40 +00:00
void RestoreGlobalActionCtrs(void *file_ptr) { ScriptActionCtr_000 = File_ReadInt(file_ptr); }
2024-04-16 03:43:29 +00:00
// ===============================================================
// Start of Custom Script Block - DO NOT EDIT ANYTHING BEFORE THIS
// ===============================================================
/**{CUSTOM_SCRIPT_BLOCK_START}** DO NOT EDIT! **/
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Enter your custom script code here
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
/**{CUSTOM_SCRIPT_BLOCK_END}**** DO NOT EDIT! **/
// ============================================================
// End of Custom Script Block - DO NOT EDIT ANYTHING AFTER THIS
// ============================================================
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// =================
// Message File Data
// =================
2024-04-16 18:56:40 +00:00
#define MAX_SCRIPT_MESSAGES 256
#define MAX_MSG_FILEBUF_LEN 1024
#define NO_MESSAGE_STRING "*Message Not Found*"
#define INV_MSGNAME_STRING "*Message Name Invalid*"
#define WHITESPACE_CHARS " \t\r\n"
2024-04-16 03:43:29 +00:00
// Structure for storing a script message
struct tScriptMessage {
2024-04-16 18:56:40 +00:00
char *name; // the name of the message
char *message; // the actual message text
};
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Global storage for level script messages
tScriptMessage *message_list[MAX_SCRIPT_MESSAGES];
int num_messages;
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// ======================
// Message File Functions
// ======================
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Initializes the Message List
2024-04-16 18:56:40 +00:00
void InitMessageList(void) {
for (int j = 0; j < MAX_SCRIPT_MESSAGES; j++)
message_list[j] = NULL;
num_messages = 0;
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Clear the Message List
2024-04-16 18:56:40 +00:00
void ClearMessageList(void) {
for (int j = 0; j < num_messages; j++) {
free(message_list[j]->name);
free(message_list[j]->message);
free(message_list[j]);
message_list[j] = NULL;
}
num_messages = 0;
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Adds a message to the list
2024-04-16 18:56:40 +00:00
int AddMessageToList(char *name, char *msg) {
int pos;
// Make sure there is room in the list
if (num_messages >= MAX_SCRIPT_MESSAGES)
return false;
// Allocate memory for this message entry
pos = num_messages;
message_list[pos] = (tScriptMessage *)malloc(sizeof(tScriptMessage));
if (message_list[pos] == NULL)
return false;
// Allocate memory for the message name
message_list[pos]->name = (char *)malloc(strlen(name) + 1);
if (message_list[pos]->name == NULL) {
free(message_list[pos]);
return false;
}
strcpy(message_list[pos]->name, name);
// Allocate memory for the message name
message_list[pos]->message = (char *)malloc(strlen(msg) + 1);
if (message_list[pos]->message == NULL) {
free(message_list[pos]->name);
free(message_list[pos]);
return false;
}
strcpy(message_list[pos]->message, msg);
num_messages++;
return true;
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Removes any whitespace padding from the end of a string
2024-04-16 18:56:40 +00:00
void RemoveTrailingWhitespace(char *s) {
int last_char_pos;
last_char_pos = strlen(s) - 1;
while (last_char_pos >= 0 && isspace(s[last_char_pos])) {
s[last_char_pos] = '\0';
last_char_pos--;
}
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Returns a pointer to the first non-whitespace char in given string
2024-04-16 18:56:40 +00:00
char *SkipInitialWhitespace(char *s) {
while ((*s) != '\0' && isspace(*s))
s++;
return (s);
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Read in the Messages
int ReadMessageFile(const char *filename) {
2024-04-16 18:56:40 +00:00
void *infile;
char filebuffer[MAX_MSG_FILEBUF_LEN + 1];
char *line, *msg_start;
int line_num;
bool next_msgid_found;
// Try to open the file for loading
infile = File_Open(filename, "rt");
if (!infile)
return false;
line_num = 0;
next_msgid_found = true;
// Clear the message list
ClearMessageList();
// Read in and parse each line of the file
while (!File_eof(infile)) {
// Clear the buffer
strcpy(filebuffer, "");
// Read in a line from the file
File_ReadString(filebuffer, MAX_MSG_FILEBUF_LEN, infile);
line_num++;
// Remove whitespace padding at start and end of line
RemoveTrailingWhitespace(filebuffer);
line = SkipInitialWhitespace(filebuffer);
// If line is a comment, or empty, discard it
if (strlen(line) == 0 || strncmp(line, "//", 2) == 0)
continue;
if (!next_msgid_found) { // Parse out the last message ID number
// Grab the first keyword, make sure it's valid
line = strtok(line, WHITESPACE_CHARS);
if (line == NULL)
continue;
// Grab the second keyword, and assign it as the next message ID
line = strtok(NULL, WHITESPACE_CHARS);
if (line == NULL)
continue;
next_msgid_found = true;
} else { // Parse line as a message line
// Find the start of message, and mark it
msg_start = strchr(line, '=');
if (msg_start == NULL)
continue;
msg_start[0] = '\0';
msg_start++;
// Add the message to the list
AddMessageToList(line, msg_start);
}
}
File_Close(infile);
return true;
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Find a message
const char *GetMessage(const char *name) {
2024-04-16 18:56:40 +00:00
// Make sure given name is valid
if (name == NULL)
return INV_MSGNAME_STRING;
// Search message list for name
for (int j = 0; j < num_messages; j++)
if (strcmp(message_list[j]->name, name) == 0)
return (message_list[j]->message);
// Couldn't find it
return NO_MESSAGE_STRING;
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
//======================
2024-04-16 18:56:40 +00:00
// Name List Arrays
2024-04-16 03:43:29 +00:00
//======================
2024-04-16 18:56:40 +00:00
#define NUM_DOOR_NAMES 0
const char **Door_names = NULL;
2024-04-16 18:56:40 +00:00
int *Door_handles = NULL;
#define NUM_OBJECT_NAMES 1
const char *Object_names[NUM_OBJECT_NAMES] = {"Finish Level"};
2024-04-16 03:43:29 +00:00
int Object_handles[NUM_OBJECT_NAMES];
2024-04-16 18:56:40 +00:00
#define NUM_ROOM_NAMES 0
const char **Room_names = NULL;
2024-04-16 18:56:40 +00:00
int *Room_indexes = NULL;
#define NUM_TRIGGER_NAMES 0
const char **Trigger_names = NULL;
2024-04-16 18:56:40 +00:00
int *Trigger_indexes = NULL;
int *Trigger_faces = NULL;
int *Trigger_rooms = NULL;
#define NUM_SOUND_NAMES 0
const char **Sound_names = NULL;
2024-04-16 18:56:40 +00:00
int *Sound_indexes = NULL;
#define NUM_TEXTURE_NAMES 0
const char **Texture_names = NULL;
2024-04-16 18:56:40 +00:00
int *Texture_indexes = NULL;
#define NUM_PATH_NAMES 0
const char **Path_names = NULL;
2024-04-16 18:56:40 +00:00
int *Path_indexes = NULL;
#define NUM_MATCEN_NAMES 0
const char **Matcen_names = NULL;
2024-04-16 18:56:40 +00:00
int *Matcen_indexes = NULL;
#define NUM_GOAL_NAMES 0
const char **Goal_names = NULL;
2024-04-16 18:56:40 +00:00
int *Goal_indexes = NULL;
#define NUM_MESSAGE_NAMES 0
const char **Message_names = NULL;
const char **Message_strings = NULL;
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// ===============
// InitializeDLL()
// ===============
2024-04-16 18:56:40 +00:00
char STDCALL InitializeDLL(tOSIRISModuleInit *func_list) {
osicommon_Initialize((tOSIRISModuleInit *)func_list);
if (func_list->game_checksum != CHECKSUM) {
mprintf(0, "Game-Checksum FAIL!!! (%ul!=%ul)\n", func_list->game_checksum, CHECKSUM);
mprintf(0, "RECOMPILE YOUR SCRIPTS!!!\n");
return 0;
}
ClearGlobalActionCtrs();
dfInit();
InitMessageList();
// Build the filename of the message file
char filename[_MAX_PATH + 32];
2024-04-16 18:56:40 +00:00
int lang_type;
if (func_list->script_identifier != NULL) {
_splitpath(func_list->script_identifier, NULL, NULL, filename, NULL);
lang_type = Game_GetLanguage();
if (lang_type == LANGUAGE_FRENCH)
strcat(filename, "_FRN");
else if (lang_type == LANGUAGE_GERMAN)
strcat(filename, "_GER");
else if (lang_type == LANGUAGE_ITALIAN)
strcat(filename, "_ITN");
else if (lang_type == LANGUAGE_SPANISH)
strcat(filename, "_SPN");
strcat(filename, ".msg");
} else {
strcpy(filename, "myPowerHouse.msg");
lang_type = LANGUAGE_ENGLISH;
}
if (!ReadMessageFile(filename)) {
mprintf(0, "ERROR: Could not load message file - %s\n", filename);
}
int j;
// Do Door Index lookups
for (j = 0; j < NUM_DOOR_NAMES; j++)
Door_handles[j] = Scrpt_FindDoorName(Door_names[j]);
// Do Object Index lookups
for (j = 0; j < NUM_OBJECT_NAMES; j++)
Object_handles[j] = Scrpt_FindObjectName(Object_names[j]);
// Do Room Index lookups
for (j = 0; j < NUM_ROOM_NAMES; j++)
Room_indexes[j] = Scrpt_FindRoomName(Room_names[j]);
// Do Trigger Index lookups
for (j = 0; j < NUM_TRIGGER_NAMES; j++) {
Trigger_indexes[j] = Scrpt_FindTriggerName(Trigger_names[j]);
Trigger_faces[j] = Scrpt_GetTriggerFace(Trigger_indexes[j]);
Trigger_rooms[j] = Scrpt_GetTriggerRoom(Trigger_indexes[j]);
}
// Do Sound Index lookups
for (j = 0; j < NUM_SOUND_NAMES; j++)
Sound_indexes[j] = Scrpt_FindSoundName(Sound_names[j]);
// Do Texture Index lookups
for (j = 0; j < NUM_TEXTURE_NAMES; j++)
Texture_indexes[j] = Scrpt_FindTextureName(Texture_names[j]);
// Do Path Index lookups
for (j = 0; j < NUM_PATH_NAMES; j++)
Path_indexes[j] = Scrpt_FindPathName(Path_names[j]);
// Do Matcen Index lookups
for (j = 0; j < NUM_MATCEN_NAMES; j++)
Matcen_indexes[j] = Scrpt_FindMatcenName(Matcen_names[j]);
// Do Goal Index lookups
for (j = 0; j < NUM_GOAL_NAMES; j++)
Goal_indexes[j] = Scrpt_FindLevelGoalName(Goal_names[j]);
// Do Message Name lookups
for (j = 0; j < NUM_MESSAGE_NAMES; j++)
Message_strings[j] = GetMessage(Message_names[j]);
return 1;
2024-04-16 03:43:29 +00:00
}
// =============
// ShutdownDLL()
// =============
2024-04-16 18:56:40 +00:00
void STDCALL ShutdownDLL(void) { ClearMessageList(); }
2024-04-16 03:43:29 +00:00
// ===============
// GetGOScriptID()
// ===============
2024-05-24 03:07:26 +00:00
int STDCALL GetGOScriptID(const char *name, uint8_t isdoor) { return -1; }
2024-04-16 03:43:29 +00:00
// ================
// CreateInstance()
// ================
2024-04-16 18:56:40 +00:00
void STDCALLPTR CreateInstance(int id) {
switch (id) {
case ID_LEVEL_0000:
return new LevelScript_0000;
break;
case ID_CUSTOM_OBJECT_0827:
return new CustomObjectScript_0827;
break;
default:
mprintf(0, "SCRIPT: Illegal ID (%d)\n", id);
break;
}
return NULL;
2024-04-16 03:43:29 +00:00
}
// =================
// DestroyInstance()
// =================
2024-04-16 18:56:40 +00:00
void STDCALL DestroyInstance(int id, void *ptr) {
switch (id) {
case ID_LEVEL_0000:
delete ((LevelScript_0000 *)ptr);
break;
2024-04-16 18:56:40 +00:00
case ID_CUSTOM_OBJECT_0827:
delete ((CustomObjectScript_0827 *)ptr);
break;
default:
mprintf(0, "SCRIPT: Illegal ID (%d)\n", id);
break;
}
2024-04-16 03:43:29 +00:00
}
// ===================
// CallInstanceEvent()
// ===================
int16_t STDCALL CallInstanceEvent(int id, void *ptr, int event, tOSIRISEventInfo *data) {
2024-04-16 18:56:40 +00:00
switch (id) {
case ID_LEVEL_0000:
case ID_CUSTOM_OBJECT_0827:
return ((BaseScript *)ptr)->CallEvent(event, data);
break;
default:
mprintf(0, "SCRIPT: Illegal ID (%d)\n", id);
break;
}
return CONTINUE_CHAIN | CONTINUE_DEFAULT;
2024-04-16 03:43:29 +00:00
}
// ==================
// SaveRestoreState()
// ==================
2024-05-24 03:07:26 +00:00
int STDCALL SaveRestoreState(void *file_ptr, uint8_t saving_state) { return 0; }
2024-04-16 03:43:29 +00:00
// ====================
// GetTriggerScriptID()
// ====================
2024-04-16 18:56:40 +00:00
int STDCALL GetTriggerScriptID(int trigger_room, int trigger_face) { return -1; }
2024-04-16 03:43:29 +00:00
// =================
// GetCOScriptList()
// =================
2024-04-16 18:56:40 +00:00
int STDCALL GetCOScriptList(int **list, int **id_list) {
static int cust_handle_list[1];
static int cust_id_list[1] = {ID_CUSTOM_OBJECT_0827};
// Fill in the custom handle list
cust_handle_list[0] = Object_handles[0];
*list = cust_handle_list;
*id_list = cust_id_list;
return 1;
2024-04-16 03:43:29 +00:00
}
//=======================
2024-04-16 18:56:40 +00:00
// Script Implementation
2024-04-16 03:43:29 +00:00
//=======================
int16_t BaseScript::CallEvent(int event, tOSIRISEventInfo *data) {
2024-04-16 18:56:40 +00:00
mprintf(0, "BaseScript::CallEvent()\n");
return CONTINUE_CHAIN | CONTINUE_DEFAULT;
2024-04-16 03:43:29 +00:00
}
int16_t LevelScript_0000::CallEvent(int event, tOSIRISEventInfo *data) {
2024-04-16 18:56:40 +00:00
switch (event) {
case EVT_SAVESTATE: {
tOSIRISEVTSAVESTATE *event_data = &data->evt_savestate;
SaveGlobalActionCtrs(event_data->fileptr);
dfSave(event_data->fileptr);
} break;
case EVT_RESTORESTATE: {
tOSIRISEVTRESTORESTATE *event_data = &data->evt_restorestate;
RestoreGlobalActionCtrs(event_data->fileptr);
dfRestore(event_data->fileptr);
} break;
case EVT_LEVELSTART: {
ClearGlobalActionCtrs();
dfInit();
} break;
}
return CONTINUE_CHAIN | CONTINUE_DEFAULT;
2024-04-16 03:43:29 +00:00
}
int16_t CustomObjectScript_0827::CallEvent(int event, tOSIRISEventInfo *data) {
2024-04-16 18:56:40 +00:00
switch (event) {
case EVT_COLLIDE: {
tOSIRISEVTCOLLIDE *event_data = &data->evt_collide;
// Script 000: Script Description Goes Here
if (qObjIsPlayer(event_data->it_handle) == 1) {
aEndLevel();
// Increment the script action counter
if (ScriptActionCtr_000 < MAX_ACTION_CTR_VALUE)
ScriptActionCtr_000++;
}
} break;
}
return CONTINUE_CHAIN | CONTINUE_DEFAULT;
2024-04-16 03:43:29 +00:00
}
/*********************************************************
2024-04-16 18:56:40 +00:00
Script Save Block: DO NOT TOUCH ANYTHING IN THIS BLOCK!!!
2024-04-16 03:43:29 +00:00
**********************************************************
$$SCRIPT_BLOCK_START
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
VERSION 3
NEXT_ID 1
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// UserType value blocks
$$UTYPE_VALS_START UserVar
$$UTYPE_VALS_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$UTYPE_VALS_START UserFlag
$$UTYPE_VALS_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$UTYPE_VALS_START SpewHandle
$$UTYPE_VALS_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$UTYPE_VALS_START TimerID
$$UTYPE_VALS_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$UTYPE_VALS_START SavedObjectSlot
$$UTYPE_VALS_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$UTYPE_VALS_START GoalID
$$UTYPE_VALS_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Name Lists
$$DOOR_LIST_START
$$DOOR_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$OBJECT_LIST_START
Finish Level
$$OBJECT_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$ROOM_LIST_START
$$ROOM_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$TRIGGER_LIST_START
$$TRIGGER_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$SOUND_LIST_START
$$SOUND_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$TEXTURE_LIST_START
$$TEXTURE_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$SPECNAME_LIST_START
$$SPECNAME_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$PATH_LIST_START
$$PATH_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$MATCEN_LIST_START
$$MATCEN_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$GOAL_LIST_START
$$GOAL_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
$$STRM_AUDIO_LIST_START
$$STRM_AUDIO_LIST_END
2024-04-16 18:56:40 +00:00
2024-04-16 03:43:29 +00:00
// Script Tree Dump
2024-04-16 18:56:40 +00:00
00:0:Script Description Goes Here
$$CHILD_BLOCK_START
01:1:0
02:0
03:0
$$CHILD_BLOCK_START
05:2
$$CHILD_BLOCK_START
06:qObjIsPlayer:Bool
$$CHILD_BLOCK_START
10:1:1:-1:Object
$$CHILD_BLOCK_END
07:1:0
10:5:1:Bool
$$CHILD_BLOCK_END
$$CHILD_BLOCK_END
04:0:0:0
$$CHILD_BLOCK_START
08:aEndLevel
$$CHILD_BLOCK_END
$$CHILD_BLOCK_END
2024-04-16 03:43:29 +00:00
$$SCRIPT_BLOCK_END
*********************************************************/