1595 lines
48 KiB
C++
1595 lines
48 KiB
C++
/**
|
|
* @file lscript_readlso.cpp
|
|
* @brief classes to read lso file
|
|
*
|
|
* $LicenseInfo:firstyear=2002&license=viewergpl$
|
|
*
|
|
* Copyright (c) 2002-2009, Linden Research, Inc.
|
|
*
|
|
* Second Life Viewer Source Code
|
|
* The source code in this file ("Source Code") is provided by Linden Lab
|
|
* to you under the terms of the GNU General Public License, version 2.0
|
|
* ("GPL"), unless you have obtained a separate licensing agreement
|
|
* ("Other License"), formally executed by you and Linden Lab. Terms of
|
|
* the GPL can be found in doc/GPL-license.txt in this distribution, or
|
|
* online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
|
|
*
|
|
* There are special exceptions to the terms and conditions of the GPL as
|
|
* it is applied to this Source Code. View the full text of the exception
|
|
* in the file doc/FLOSS-exception.txt in this software distribution, or
|
|
* online at
|
|
* http://secondlifegrid.net/programs/open_source/licensing/flossexception
|
|
*
|
|
* By copying, modifying or distributing this software, you acknowledge
|
|
* that you have read and understood your obligations described above,
|
|
* and agree to abide by those obligations.
|
|
*
|
|
* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
|
|
* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
|
|
* COMPLETENESS OR PERFORMANCE.
|
|
* $/LicenseInfo$
|
|
*/
|
|
|
|
#include "linden_common.h"
|
|
|
|
#include "lscript_readlso.h"
|
|
#include "lscript_library.h"
|
|
#include "lscript_alloc.h"
|
|
|
|
LLScriptLSOParse::LLScriptLSOParse(LLFILE *fp)
|
|
{
|
|
U8 sizearray[4];
|
|
size_t filesize;
|
|
S32 pos = 0;
|
|
if (fread(&sizearray, 1, 4, fp) != 4)
|
|
{
|
|
llwarns << "Short read" << llendl;
|
|
filesize = 0;
|
|
} else {
|
|
filesize = bytestream2integer(sizearray, pos);
|
|
}
|
|
mRawData = new U8[filesize];
|
|
fseek(fp, 0, SEEK_SET);
|
|
if (fread(mRawData, 1, filesize, fp) != filesize)
|
|
{
|
|
llwarns << "Short read" << llendl;
|
|
}
|
|
|
|
initOpCodePrinting();
|
|
}
|
|
|
|
LLScriptLSOParse::LLScriptLSOParse(U8 *buffer)
|
|
{
|
|
mRawData = buffer;
|
|
initOpCodePrinting();
|
|
}
|
|
|
|
LLScriptLSOParse::~LLScriptLSOParse()
|
|
{
|
|
delete [] mRawData;
|
|
}
|
|
|
|
void LLScriptLSOParse::printData(LLFILE *fp)
|
|
{
|
|
|
|
|
|
|
|
printNameDesc(fp);
|
|
|
|
printRegisters(fp);
|
|
|
|
printGlobals(fp);
|
|
|
|
printGlobalFunctions(fp);
|
|
|
|
printStates(fp);
|
|
|
|
printHeap(fp);
|
|
}
|
|
|
|
void LLScriptLSOParse::printNameDesc(LLFILE *fp)
|
|
{
|
|
fprintf(fp, "=============================\n\n");
|
|
}
|
|
|
|
S32 gMajorVersion = 0;
|
|
|
|
void LLScriptLSOParse::printRegisters(LLFILE *fp)
|
|
{
|
|
// print out registers first
|
|
S32 i;
|
|
|
|
fprintf(fp, "=============================\n");
|
|
fprintf(fp, "Registers\n");
|
|
fprintf(fp, "=============================\n");
|
|
S32 version = get_register(mRawData, LREG_VN);
|
|
if (version == LSL2_VERSION1_END_NUMBER)
|
|
{
|
|
gMajorVersion = LSL2_MAJOR_VERSION_ONE;
|
|
}
|
|
else if (version == LSL2_VERSION_NUMBER)
|
|
{
|
|
gMajorVersion = LSL2_MAJOR_VERSION_TWO;
|
|
}
|
|
for (i = LREG_IP; i < LREG_EOF; i++)
|
|
{
|
|
if (i < LREG_NCE)
|
|
{
|
|
fprintf(fp, "%s: 0x%X\n", gLSCRIPTRegisterNames[i], get_register(mRawData, (LSCRIPTRegisters)i));
|
|
}
|
|
else if (gMajorVersion == LSL2_MAJOR_VERSION_TWO)
|
|
{
|
|
U64 data = get_register_u64(mRawData, (LSCRIPTRegisters)i);
|
|
fprintf(fp, "%s: 0x%X%X\n", gLSCRIPTRegisterNames[i], (U32)(data>>32), (U32)(data & 0xFFFFFFFF));
|
|
}
|
|
}
|
|
fprintf(fp, "=============================\n\n");
|
|
}
|
|
|
|
void LLScriptLSOParse::printGlobals(LLFILE *fp)
|
|
{
|
|
// print out registers first
|
|
S32 offset, varoffset;
|
|
S32 ivalue;
|
|
F32 fpvalue;
|
|
LLVector3 vvalue;
|
|
LLQuaternion qvalue;
|
|
char name[256]; /*Flawfinder: ignore*/
|
|
U8 type;
|
|
|
|
S32 global_v_offset = get_register(mRawData, LREG_GVR);
|
|
S32 global_f_offset = get_register(mRawData, LREG_GFR);
|
|
|
|
fprintf(fp, "=============================\n");
|
|
fprintf(fp, "[0x%X] Global Variables\n", global_v_offset);
|
|
fprintf(fp, "=============================\n");
|
|
|
|
|
|
while (global_v_offset < global_f_offset)
|
|
{
|
|
|
|
// get offset to skip past name
|
|
varoffset = global_v_offset;
|
|
offset = bytestream2integer(mRawData, global_v_offset);
|
|
|
|
// get typeexport
|
|
type = *(mRawData + global_v_offset++);
|
|
|
|
// set name
|
|
bytestream2char(name, mRawData, global_v_offset, sizeof(name));
|
|
|
|
switch(type)
|
|
{
|
|
case LST_INTEGER:
|
|
ivalue = bytestream2integer(mRawData, global_v_offset);
|
|
fprintf(fp, "[0x%X] integer %s = %d\n", varoffset, name, ivalue);
|
|
break;
|
|
case LST_FLOATINGPOINT:
|
|
fpvalue = bytestream2float(mRawData, global_v_offset);
|
|
fprintf(fp, "[0x%X] integer %s = %f\n", varoffset, name, fpvalue);
|
|
break;
|
|
case LST_STRING:
|
|
ivalue = bytestream2integer(mRawData, global_v_offset);
|
|
fprintf(fp, "[0x%X] string %s = 0x%X\n", varoffset, name, ivalue + get_register(mRawData, LREG_HR) - 1);
|
|
break;
|
|
case LST_KEY:
|
|
ivalue = bytestream2integer(mRawData, global_v_offset);
|
|
fprintf(fp, "[0x%X] key %s = 0x%X\n", varoffset, name, ivalue + get_register(mRawData, LREG_HR) - 1);
|
|
break;
|
|
case LST_VECTOR:
|
|
bytestream2vector(vvalue, mRawData, global_v_offset);
|
|
fprintf(fp, "[0x%X] vector %s = < %f, %f, %f >\n", varoffset, name, vvalue.mV[VX], vvalue.mV[VY], vvalue.mV[VZ]);
|
|
break;
|
|
case LST_QUATERNION:
|
|
bytestream2quaternion(qvalue, mRawData, global_v_offset);
|
|
fprintf(fp, "[0x%X] quaternion %s = < %f, %f, %f, %f >\n", varoffset, name, qvalue.mQ[VX], qvalue.mQ[VY], qvalue.mQ[VZ], qvalue.mQ[VS]);
|
|
break;
|
|
case LST_LIST:
|
|
ivalue = bytestream2integer(mRawData, global_v_offset);
|
|
fprintf(fp, "[0x%X] list %s = 0x%X\n", varoffset, name, ivalue + get_register(mRawData, LREG_HR) - 1);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
fprintf(fp, "=============================\n\n");
|
|
}
|
|
|
|
void LLScriptLSOParse::printGlobalFunctions(LLFILE *fp)
|
|
{
|
|
// print out registers first
|
|
S32 i, offset;
|
|
// LLVector3 vvalue; unused
|
|
// LLQuaternion qvalue; unused
|
|
char name[256]; /*Flawfinder: ignore*/
|
|
U8 type;
|
|
|
|
offset = get_register(mRawData, LREG_GFR);
|
|
S32 start_of_state = get_register(mRawData, LREG_SR);
|
|
if (start_of_state == offset)
|
|
return;
|
|
|
|
S32 global_f_offset = get_register(mRawData, LREG_GFR);
|
|
|
|
fprintf(fp, "=============================\n");
|
|
fprintf(fp, "[0x%X] Global Functions\n", global_f_offset);
|
|
fprintf(fp, "=============================\n");
|
|
|
|
|
|
S32 num_functions = bytestream2integer(mRawData, offset);
|
|
S32 orig_function_offset;
|
|
S32 function_offset;
|
|
S32 next_function_offset = 0;
|
|
S32 function_number = 0;
|
|
S32 opcode_start;
|
|
S32 opcode_end;
|
|
|
|
for (i = 0; i < num_functions; i++)
|
|
{
|
|
// jump to function
|
|
// if this is the first function
|
|
if (i == 0)
|
|
{
|
|
if (i < num_functions - 1)
|
|
{
|
|
function_offset = bytestream2integer(mRawData, offset);
|
|
next_function_offset = bytestream2integer(mRawData, offset);
|
|
function_offset += global_f_offset;
|
|
opcode_end = next_function_offset + global_f_offset;
|
|
}
|
|
else
|
|
{
|
|
function_offset = bytestream2integer(mRawData, offset);
|
|
function_offset += global_f_offset;
|
|
opcode_end = get_register(mRawData, LREG_SR);
|
|
}
|
|
}
|
|
else if (i < num_functions - 1)
|
|
{
|
|
function_offset = next_function_offset;
|
|
next_function_offset = bytestream2integer(mRawData, offset);
|
|
function_offset += global_f_offset;
|
|
opcode_end = next_function_offset + global_f_offset;
|
|
}
|
|
else
|
|
{
|
|
function_offset = next_function_offset;
|
|
function_offset += global_f_offset;
|
|
opcode_end = get_register(mRawData, LREG_SR);
|
|
}
|
|
orig_function_offset = function_offset;
|
|
// where do the opcodes start
|
|
opcode_start = bytestream2integer(mRawData, function_offset);
|
|
opcode_start += orig_function_offset;
|
|
bytestream2char(name, mRawData, function_offset, sizeof(name));
|
|
// get return type
|
|
type = *(mRawData + function_offset++);
|
|
fprintf(fp, "[Function #%d] [0x%X] %s\n", function_number, orig_function_offset, name);
|
|
fprintf(fp, "\tReturn Type: %s\n", LSCRIPTTypeNames[type]);
|
|
type = *(mRawData + function_offset++);
|
|
S32 params;
|
|
params = 0;
|
|
S32 pcount = 0;
|
|
while (type)
|
|
{
|
|
bytestream2char(name, mRawData, function_offset, sizeof(name));
|
|
fprintf(fp, "\tParameter #%d: %s %s\n", pcount++, LSCRIPTTypeNames[type], name);
|
|
type = *(mRawData + function_offset++);
|
|
}
|
|
fprintf(fp, "\t\tOpCodes: 0x%X - 0x%X\n", opcode_start, opcode_end);
|
|
printOpCodeRange(fp, opcode_start, opcode_end, 2);
|
|
function_number++;
|
|
}
|
|
|
|
fprintf(fp, "=============================\n\n");
|
|
}
|
|
|
|
void LLScriptLSOParse::printStates(LLFILE *fp)
|
|
{
|
|
// print out registers first
|
|
S32 i, offset;
|
|
U32 j, k;
|
|
// LLVector3 vvalue; unused
|
|
// LLQuaternion qvalue; unused
|
|
char name[256]; /*Flawfinder: ignore*/
|
|
|
|
S32 state_offset = get_register(mRawData, LREG_SR);
|
|
|
|
fprintf(fp, "=============================\n");
|
|
fprintf(fp, "[0x%X] States\n", state_offset);
|
|
fprintf(fp, "=============================\n");
|
|
|
|
offset = state_offset;
|
|
S32 num_states = bytestream2integer(mRawData, offset);
|
|
S32 state_info_offset;
|
|
S32 event_jump_table;
|
|
U64 event_handlers;
|
|
S32 event_offset;
|
|
S32 original_event_offset;
|
|
S32 opcode_start;
|
|
S32 worst_case_opcode_end;
|
|
S32 opcode_end;
|
|
S32 stack_size;
|
|
S32 read_ahead;
|
|
S32 first_jump = 0;
|
|
|
|
for (i = 0; i < num_states; i++)
|
|
{
|
|
state_info_offset = bytestream2integer(mRawData, offset);
|
|
if (gMajorVersion == LSL2_MAJOR_VERSION_TWO)
|
|
event_handlers = bytestream2u64(mRawData, offset);
|
|
else
|
|
event_handlers = bytestream2integer(mRawData, offset);
|
|
if (!first_jump)
|
|
{
|
|
first_jump = state_info_offset;
|
|
}
|
|
read_ahead = offset;
|
|
if (offset < first_jump + state_offset)
|
|
{
|
|
worst_case_opcode_end = bytestream2integer(mRawData, read_ahead) + state_offset;
|
|
}
|
|
else
|
|
{
|
|
worst_case_opcode_end = get_register(mRawData, LREG_HR);
|
|
}
|
|
state_info_offset += state_offset;
|
|
fprintf(fp, "[0x%X] ", state_info_offset);
|
|
state_info_offset += LSCRIPTDataSize[LST_INTEGER];
|
|
bytestream2char(name, mRawData, state_info_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
|
|
event_jump_table = state_info_offset;
|
|
|
|
// run run through the handlers
|
|
for (j = LSTT_STATE_BEGIN; j < LSTT_STATE_END; j++)
|
|
{
|
|
if (event_handlers & LSCRIPTStateBitField[j])
|
|
{
|
|
event_offset = bytestream2integer(mRawData, state_info_offset);
|
|
stack_size = bytestream2integer(mRawData, state_info_offset);
|
|
|
|
read_ahead = event_jump_table;
|
|
|
|
S32 temp_end;
|
|
S32 dummy;
|
|
|
|
opcode_end = worst_case_opcode_end;
|
|
|
|
for (k = LSTT_STATE_BEGIN; k < LSTT_STATE_END; k++)
|
|
{
|
|
if (event_handlers & LSCRIPTStateBitField[k])
|
|
{
|
|
temp_end = bytestream2integer(mRawData, read_ahead);
|
|
dummy = bytestream2integer(mRawData, read_ahead);
|
|
if ( (temp_end < opcode_end)
|
|
&&(temp_end > event_offset))
|
|
{
|
|
opcode_end = temp_end;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (event_offset)
|
|
{
|
|
event_offset += event_jump_table;
|
|
if (opcode_end < worst_case_opcode_end)
|
|
opcode_end += event_jump_table;
|
|
original_event_offset = event_offset;
|
|
|
|
fprintf(fp, "\t[0x%X] ", event_offset);
|
|
|
|
opcode_start = bytestream2integer(mRawData, event_offset);
|
|
opcode_start += original_event_offset;
|
|
|
|
switch(j)
|
|
{
|
|
case LSTT_STATE_ENTRY: // LSTT_STATE_ENTRY
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_STATE_EXIT: // LSTT_STATE_EXIT
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_TOUCH_START: // LSTT_TOUCH_START
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_TOUCH: // LSTT_TOUCH
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_TOUCH_END: // LSTT_TOUCH_END
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_COLLISION_START: // LSTT_COLLISION_START
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_COLLISION: // LSTT_COLLISION
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_COLLISION_END: // LSTT_COLLISION_END
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_LAND_COLLISION_START: // LSTT_LAND_COLLISION_START
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_LAND_COLLISION: // LSTT_LAND_COLLISION
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_LAND_COLLISION_END: // LSTT_LAND_COLLISION_END
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_INVENTORY: // LSTT_INVENTORY
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
break;
|
|
case LSTT_ATTACH: // LSTT_ATTACH
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
break;
|
|
case LSTT_DATASERVER: // LSTT_DATASERVER
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
break;
|
|
case LSTT_TIMER: // LSTT_TIMER
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_MOVING_START: // LSTT_MOVING_START
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_MOVING_END: // LSTT_MOVING_END
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_CHAT: // LSTT_CHAT
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
break;
|
|
case LSTT_OBJECT_REZ: // LSTT_OBJECT_REZ
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
break;
|
|
case LSTT_REMOTE_DATA: // LSTT_REMOTE_DATA
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
break;
|
|
case LSTT_REZ: // LSTT_REZ
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_SENSOR: // LSTT_SENSOR
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
break;
|
|
case LSTT_NO_SENSOR: // LSTT_NO_SENSOR
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_CONTROL: // LSTT_CONTROL
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
break;
|
|
case LSTT_LINK_MESSAGE: // LSTT_LINK_MESSAGE
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
break;
|
|
case LSTT_MONEY: // LSTT_MONEY
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
break;
|
|
case LSTT_EMAIL: // LSTT_EMAIL
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
break;
|
|
case LSTT_AT_TARGET: // LSTT_AT_TARGET
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tvector %s\n", name);
|
|
break;
|
|
case LSTT_NOT_AT_TARGET: // LSTT_NOT_AT_TARGET
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_AT_ROT_TARGET: // LSTT_AT_ROT_TARGET
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tquaternion %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tquaternion %s\n", name);
|
|
break;
|
|
case LSTT_NOT_AT_ROT_TARGET: // LSTT_NOT_AT_TARGET
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
break;
|
|
case LSTT_RTPERMISSIONS: // LSTT_RTPERMISSIONS
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
break;
|
|
case LSTT_HTTP_RESPONSE: // LSTT_REMOTE_DATA ?!?!?!
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tinteger %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tlist %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
break;
|
|
case LSTT_HTTP_REQUEST: // LSTT_HTTP_REQUEST
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "%s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tkey %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
bytestream2char(name, mRawData, event_offset, sizeof(name));
|
|
fprintf(fp, "\t\tstring %s\n", name);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
fprintf(fp, "\t\tStack Size: %d\n", stack_size);
|
|
fprintf(fp, "\t\t\tOpCodes: 0x%X - 0x%X\n", opcode_start, opcode_end);
|
|
printOpCodeRange(fp, opcode_start, opcode_end, 3);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
fprintf(fp, "=============================\n\n");
|
|
}
|
|
|
|
void LLScriptLSOParse::printHeap(LLFILE *fp)
|
|
{
|
|
// print out registers first
|
|
|
|
S32 heap_offset = get_register(mRawData, LREG_HR);
|
|
S32 heap_pointer = get_register(mRawData, LREG_HP);
|
|
fprintf(fp, "=============================\n");
|
|
fprintf(fp, "[0x%X - 0x%X] Heap\n", heap_offset, heap_pointer);
|
|
fprintf(fp, "=============================\n");
|
|
|
|
lsa_fprint_heap(mRawData, fp);
|
|
|
|
fprintf(fp, "=============================\n\n");
|
|
}
|
|
|
|
void lso_print_tabs(LLFILE *fp, S32 tabs)
|
|
{
|
|
S32 i;
|
|
for (i = 0; i < tabs; i++)
|
|
{
|
|
fprintf(fp, "\t");
|
|
}
|
|
}
|
|
|
|
void LLScriptLSOParse::printOpCodes(LLFILE *fp, S32 &offset, S32 tabs)
|
|
{
|
|
U8 opcode = *(mRawData + offset);
|
|
mPrintOpCodes[opcode](fp, mRawData, offset, tabs);
|
|
}
|
|
|
|
void LLScriptLSOParse::printOpCodeRange(LLFILE *fp, S32 start, S32 end, S32 tabs)
|
|
{
|
|
while (start < end)
|
|
{
|
|
printOpCodes(fp, start, tabs);
|
|
}
|
|
}
|
|
|
|
void LLScriptLSOParse::initOpCodePrinting()
|
|
{
|
|
S32 i;
|
|
for (i = 0; i < 256; i++)
|
|
{
|
|
mPrintOpCodes[i] = print_noop;
|
|
}
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_NOOP]] = print_noop;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POP]] = print_pop;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPS]] = print_pops;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPL]] = print_popl;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPV]] = print_popv;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPQ]] = print_popq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPARG]] = print_poparg;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPIP]] = print_popip;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPBP]] = print_popbp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPSP]] = print_popsp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_POPSLR]] = print_popslr;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_DUP]] = print_dup;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_DUPS]] = print_dups;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_DUPL]] = print_dupl;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_DUPV]] = print_dupv;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_DUPQ]] = print_dupq;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STORE]] = print_store;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STORES]] = print_stores;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREL]] = print_storel;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREV]] = print_storev;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREQ]] = print_storeq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREG]] = print_storeg;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREGS]] = print_storegs;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREGL]] = print_storegl;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREGV]] = print_storegv;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STOREGQ]] = print_storegq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADP]] = print_loadp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADSP]] = print_loadsp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADLP]] = print_loadlp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADVP]] = print_loadvp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADQP]] = print_loadqp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADGP]] = print_loadgp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADGSP]] = print_loadgsp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADGLP]] = print_loadglp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADGVP]] = print_loadgvp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LOADGQP]] = print_loadgqp;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSH]] = print_push;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHS]] = print_pushs;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHL]] = print_pushl;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHV]] = print_pushv;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHQ]] = print_pushq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHG]] = print_pushg;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHGS]] = print_pushgs;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHGL]] = print_pushgl;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHGV]] = print_pushgv;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHGQ]] = print_pushgq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHIP]] = print_puship;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHSP]] = print_pushsp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHBP]] = print_pushbp;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHARGB]] = print_pushargb;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHARGI]] = print_pushargi;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHARGF]] = print_pushargf;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHARGS]] = print_pushargs;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHARGV]] = print_pushargv;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHARGQ]] = print_pushargq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHE]] = print_pushe;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHEV]] = print_pushev;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHEQ]] = print_pusheq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PUSHARGE]] = print_pusharge;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_ADD]] = print_add;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_SUB]] = print_sub;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_MUL]] = print_mul;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_DIV]] = print_div;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_MOD]] = print_mod;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_EQ]] = print_eq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_NEQ]] = print_neq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LEQ]] = print_leq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_GEQ]] = print_geq;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_LESS]] = print_less;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_GREATER]] = print_greater;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_BITAND]] = print_bitand;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_BITOR]] = print_bitor;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_BITXOR]] = print_bitxor;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_BOOLAND]] = print_booland;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_BOOLOR]] = print_boolor;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_SHL]] = print_shl;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_SHR]] = print_shr;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_NEG]] = print_neg;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_BITNOT]] = print_bitnot;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_BOOLNOT]] = print_boolnot;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_JUMP]] = print_jump;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_JUMPIF]] = print_jumpif;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_JUMPNIF]] = print_jumpnif;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STATE]] = print_state;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_CALL]] = print_call;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_RETURN]] = print_return;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_CAST]] = print_cast;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STACKTOS]] = print_stacktos;
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_STACKTOL]] = print_stacktol;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_PRINT]] = print_print;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_CALLLIB]] = print_calllib;
|
|
|
|
mPrintOpCodes[LSCRIPTOpCodes[LOPC_CALLLIB_TWO_BYTE]] = print_calllib_two_byte;
|
|
}
|
|
|
|
void print_noop(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tNOOP\n", offset++);
|
|
}
|
|
|
|
void print_pop(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOP\n", offset++);
|
|
}
|
|
|
|
void print_pops(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPS\n", offset++);
|
|
}
|
|
|
|
void print_popl(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPL\n", offset++);
|
|
}
|
|
|
|
void print_popv(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPV\n", offset++);
|
|
}
|
|
|
|
void print_popq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPQ\n", offset++);
|
|
}
|
|
|
|
void print_poparg(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPARG ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_popip(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPIP\n", offset++);
|
|
}
|
|
|
|
void print_popbp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPBP\n", offset++);
|
|
}
|
|
|
|
void print_popsp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPSP\n", offset++);
|
|
}
|
|
|
|
void print_popslr(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPOPSLR\n", offset++);
|
|
}
|
|
|
|
void print_dup(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tDUP\n", offset++);
|
|
}
|
|
|
|
void print_dups(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tDUPS\n", offset++);
|
|
}
|
|
|
|
void print_dupl(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tDUPL\n", offset++);
|
|
}
|
|
|
|
void print_dupv(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tDUPV\n", offset++);
|
|
}
|
|
|
|
void print_dupq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tDUPQ\n", offset++);
|
|
}
|
|
|
|
void print_store(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTORE $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_stores(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTORES $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_storel(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREL $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_storev(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREV $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_storeq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREQ $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_storeg(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREG ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_storegs(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGS ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_storegl(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGL ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_storegv(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGV ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_storegq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGQ ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_loadp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREP $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_loadsp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREPS $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_loadlp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREPL $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_loadvp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREVP $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_loadqp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREQP $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_loadgp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGP ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_loadgsp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGSP ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_loadglp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGLP ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_loadgvp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGVP ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_loadgqp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTOREGQP ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_push(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSH $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_pushs(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHS $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_pushl(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHL $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_pushv(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHV $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_pushq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHQ $BP + ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_pushg(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHG ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "0x%X\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_pushgs(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHGS ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "0x%X\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_pushgl(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHGL ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "0x%X\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_pushgv(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHGV ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "0x%X\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_pushgq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHGQ ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "0x%X\n", arg + get_register(buffer, LREG_GVR));
|
|
}
|
|
|
|
void print_puship(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHIP\n", offset++);
|
|
}
|
|
|
|
void print_pushbp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHBP\n", offset++);
|
|
}
|
|
|
|
void print_pushsp(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHSP\n", offset++);
|
|
}
|
|
|
|
void print_pushargb(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHARGB ", offset++);
|
|
arg = *(buffer + offset++);
|
|
fprintf(fp, "%d\n", (U32)arg);
|
|
}
|
|
|
|
void print_pushargi(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHARGI ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_pushargf(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
F32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHARGF ", offset++);
|
|
arg = bytestream2float(buffer, offset);
|
|
fprintf(fp, "%f\n", arg);
|
|
}
|
|
|
|
void print_pushargs(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
char arg[1024]; /*Flawfinder: ignore*/
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHARGS ", offset++);
|
|
bytestream2char(arg, buffer, offset, sizeof(arg));
|
|
fprintf(fp, "%s\n", arg);
|
|
}
|
|
|
|
void print_pushargv(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
LLVector3 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHARGV ", offset++);
|
|
bytestream2vector(arg, buffer, offset);
|
|
fprintf(fp, "< %f, %f, %f >\n", arg.mV[VX], arg.mV[VY], arg.mV[VZ]);
|
|
}
|
|
|
|
void print_pushargq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
LLQuaternion arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHARGV ", offset++);
|
|
bytestream2quaternion(arg, buffer, offset);
|
|
fprintf(fp, "< %f, %f, %f, %f >\n", arg.mQ[VX], arg.mQ[VY], arg.mQ[VZ], arg.mQ[VS]);
|
|
}
|
|
|
|
void print_pushe(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHE\n", offset++);
|
|
}
|
|
|
|
void print_pushev(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHEV\n", offset++);
|
|
}
|
|
|
|
void print_pusheq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHEQ\n", offset++);
|
|
}
|
|
|
|
void print_pusharge(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPUSHARGE ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
|
|
void print_add(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tADD ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_sub(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSUB ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_mul(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tMUL ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_div(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tDIV ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_mod(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tMOD ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_eq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tEQ ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_neq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tNEQ ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_leq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tLEQ ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_geq(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tGEQ ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_less(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tLESS ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_greater(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tGREATER ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
|
|
void print_bitand(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tBITAND\n", offset++);
|
|
}
|
|
|
|
void print_bitor(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tBITOR\n", offset++);
|
|
}
|
|
|
|
void print_bitxor(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tBITXOR\n", offset++);
|
|
}
|
|
|
|
void print_booland(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tBOOLAND\n", offset++);
|
|
}
|
|
|
|
void print_boolor(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tBOOLOR\n", offset++);
|
|
}
|
|
|
|
void print_shl(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSHL\n", offset++);
|
|
}
|
|
|
|
void print_shr(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSHR\n", offset++);
|
|
}
|
|
|
|
|
|
void print_neg(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 type;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tNEG ", offset++);
|
|
type = *(buffer + offset++);
|
|
fprintf(fp, "%s\n", LSCRIPTTypeNames[type]);
|
|
}
|
|
|
|
void print_bitnot(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tBITNOT\n", offset++);
|
|
}
|
|
|
|
void print_boolnot(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tBOOLNOT\n", offset++);
|
|
}
|
|
|
|
void print_jump(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tJUMP ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_jumpif(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
U8 type;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tJUMPIF ", offset++);
|
|
type = *(buffer + offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%s, %d\n", LSCRIPTTypeNames[type], arg);
|
|
}
|
|
|
|
void print_jumpnif(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
U8 type;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tJUMPNIF ", offset++);
|
|
type = *(buffer + offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%s, %d\n", LSCRIPTTypeNames[type], arg);
|
|
}
|
|
|
|
void print_state(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTATE ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_call(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tCALL ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_return(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tRETURN\n", offset++);
|
|
}
|
|
|
|
void print_cast(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 types;
|
|
U8 type1;
|
|
U8 type2;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tCAST ", offset++);
|
|
types = *(buffer + offset++);
|
|
type1 = types >> 4;
|
|
type2 = types & 0xf;
|
|
fprintf(fp, "%s, %s\n", LSCRIPTTypeNames[type1], LSCRIPTTypeNames[type2]);
|
|
}
|
|
|
|
void print_stacktos(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTACKTOS ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_stacktol(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
S32 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tSTACKTOL ", offset++);
|
|
arg = bytestream2integer(buffer, offset);
|
|
fprintf(fp, "%d\n", arg);
|
|
}
|
|
|
|
void print_print(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tPRINT ", offset++);
|
|
U8 type = *(buffer + offset++);
|
|
fprintf(fp, "%s\n", LSCRIPTTypeNames[type]);
|
|
}
|
|
|
|
void print_calllib(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U8 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tCALLLIB ", offset++);
|
|
arg = *(buffer + offset++);
|
|
fprintf(fp, "%d (%s)\n", (U32)arg, gScriptLibrary.mFunctions[arg].mName);
|
|
}
|
|
|
|
|
|
void print_calllib_two_byte(LLFILE *fp, U8 *buffer, S32 &offset, S32 tabs)
|
|
{
|
|
U16 arg;
|
|
lso_print_tabs(fp, tabs);
|
|
fprintf(fp, "[0x%X]\tCALLLIB_TWO_BYTE ", offset++);
|
|
arg = bytestream2u16(buffer, offset);
|
|
fprintf(fp, "%d (%s)\n", (U32)arg, gScriptLibrary.mFunctions[arg].mName);
|
|
}
|
|
|