mirror of
https://github.com/suchmememanyskill/TegraExplorer.git
synced 2024-11-22 20:06:43 +00:00
optimize arrayClass.c
This commit is contained in:
parent
2ddc7ae2a9
commit
623634b515
1 changed files with 47 additions and 71 deletions
|
@ -11,6 +11,7 @@
|
||||||
|
|
||||||
u8 anotherOneIntArg[] = { IntClass };
|
u8 anotherOneIntArg[] = { IntClass };
|
||||||
u8 oneStringoneFunction[] = { StringClass, FunctionClass };
|
u8 oneStringoneFunction[] = { StringClass, FunctionClass };
|
||||||
|
u8 doubleInt[] = {IntClass, IntClass};
|
||||||
u8 oneIntOneAny[] = { IntClass, VARARGCOUNT };
|
u8 oneIntOneAny[] = { IntClass, VARARGCOUNT };
|
||||||
u8 anotherAnotherOneVarArg[] = { VARARGCOUNT };
|
u8 anotherAnotherOneVarArg[] = { VARARGCOUNT };
|
||||||
u8 oneByteArrayClass[] = {ByteArrayClass};
|
u8 oneByteArrayClass[] = {ByteArrayClass};
|
||||||
|
@ -36,6 +37,34 @@ Variable_t arrayClassGetIdx(Variable_t *caller, s64 idx) {
|
||||||
return (Variable_t) { 0 };
|
return (Variable_t) { 0 };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int arrayClassAdd(Variable_t *caller, Variable_t *add){
|
||||||
|
if (caller->variableType == IntArrayClass) {
|
||||||
|
if (add->variableType != IntClass) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
vecAdd(&caller->solvedArray.vector, add->integer.value);
|
||||||
|
}
|
||||||
|
else if (caller->variableType == StringArrayClass) {
|
||||||
|
if (add->variableType != StringClass) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
char* str = CpyStr(add->string.value);
|
||||||
|
vecAdd(&caller->solvedArray.vector, str);
|
||||||
|
}
|
||||||
|
else if (caller->variableType == ByteArrayClass) {
|
||||||
|
if (add->variableType != IntClass) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 val = (u8)(add->integer.value & 0xFF);
|
||||||
|
vecAdd(&caller->solvedArray.vector, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
ClassFunction(getArrayIdx) {
|
ClassFunction(getArrayIdx) {
|
||||||
s64 getVal = (*args)->integer.value;
|
s64 getVal = (*args)->integer.value;
|
||||||
// Out of bounds
|
// Out of bounds
|
||||||
|
@ -53,35 +82,22 @@ ClassFunction(getArrayLen) {
|
||||||
return newIntVariablePtr(caller->solvedArray.vector.count);
|
return newIntVariablePtr(caller->solvedArray.vector.count);
|
||||||
}
|
}
|
||||||
|
|
||||||
ClassFunction(createRefSkip) {
|
ClassFunction(arraySlice) {
|
||||||
s64 skipAmount = getIntValue(*args);
|
s64 skipAmount = getIntValue(*args);
|
||||||
if (caller->solvedArray.vector.count < skipAmount || skipAmount <= 0) {
|
s64 takeAmount = getIntValue(args[1]);
|
||||||
SCRIPT_FATAL_ERR("Accessing index %d while array is %d long", (int)skipAmount, (int)caller->solvedArray.vector.count);
|
|
||||||
|
if (caller->solvedArray.vector.count < (skipAmount + takeAmount) || skipAmount <= 0 || takeAmount <= 0) {
|
||||||
|
SCRIPT_FATAL_ERR("Slicing out of range of array with len %d", (int)caller->solvedArray.vector.count);
|
||||||
}
|
}
|
||||||
|
|
||||||
Variable_t refSkip = { .variableType = SolvedArrayReferenceClass };
|
Variable_t refSkip = { .variableType = SolvedArrayReferenceClass };
|
||||||
refSkip.solvedArray.arrayClassReference = caller;
|
refSkip.solvedArray.arrayClassReference = caller;
|
||||||
refSkip.solvedArray.offset = skipAmount;
|
refSkip.solvedArray.offset = skipAmount;
|
||||||
refSkip.solvedArray.len = caller->solvedArray.vector.count - skipAmount;
|
refSkip.solvedArray.len = takeAmount;
|
||||||
addPendingReference(caller);
|
addPendingReference(caller);
|
||||||
return copyVariableToPtr(refSkip);
|
return copyVariableToPtr(refSkip);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
ClassFunction(takeArray) {
|
|
||||||
s64 skipAmount = getIntValue(*args);
|
|
||||||
if (caller->solvedArray.vector.count < skipAmount || skipAmount <= 0) {
|
|
||||||
SCRIPT_FATAL_ERR("Accessing index %d while array is %d long", (int)skipAmount, (int)caller->solvedArray.vector.count);
|
|
||||||
}
|
|
||||||
|
|
||||||
Variable_t refSkip = { .variableType = SolvedArrayReferenceClass };
|
|
||||||
refSkip.solvedArray.arrayClassReference = caller;
|
|
||||||
refSkip.solvedArray.len = skipAmount;
|
|
||||||
addPendingReference(caller);
|
|
||||||
return copyVariableToPtr(refSkip);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
ClassFunction(arrayForEach) {
|
ClassFunction(arrayForEach) {
|
||||||
Vector_t* v = &caller->solvedArray.vector;
|
Vector_t* v = &caller->solvedArray.vector;
|
||||||
|
|
||||||
|
@ -112,39 +128,16 @@ ClassFunction(arrayCopy) {
|
||||||
ClassFunction(arraySet) {
|
ClassFunction(arraySet) {
|
||||||
s64 idx = getIntValue(*args);
|
s64 idx = getIntValue(*args);
|
||||||
Vector_t* v = &caller->solvedArray.vector;
|
Vector_t* v = &caller->solvedArray.vector;
|
||||||
if (v->count < idx || idx <= 0) {
|
if (v->count < idx || idx < 0) {
|
||||||
SCRIPT_FATAL_ERR("Accessing index %d while array is %d long", (int)idx, (int)caller->solvedArray.vector.count);
|
SCRIPT_FATAL_ERR("Accessing index %d while array is %d long", (int)idx, (int)caller->solvedArray.vector.count);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (caller->readOnly) {
|
u32 oldCount = caller->solvedArray.vector.count;
|
||||||
SCRIPT_FATAL_ERR("Array is read-only");
|
caller->solvedArray.vector.count = idx;
|
||||||
}
|
if (arrayClassAdd(caller, args[1])){
|
||||||
|
SCRIPT_FATAL_ERR("Adding the wrong type to a typed array");
|
||||||
if (caller->variableType == IntArrayClass) {
|
|
||||||
if (args[1]->variableType != IntClass) {
|
|
||||||
return NULL; // TODO: add proper error handling
|
|
||||||
}
|
|
||||||
|
|
||||||
s64* a = v->data;
|
|
||||||
a[idx] = getIntValue(args[1]);
|
|
||||||
}
|
|
||||||
else if (caller->variableType == StringArrayClass) {
|
|
||||||
if (args[1]->variableType != StringClass) {
|
|
||||||
return NULL; // TODO: add proper error handling
|
|
||||||
}
|
|
||||||
|
|
||||||
char** a = v->data;
|
|
||||||
FREE(a[idx]);
|
|
||||||
a[idx] = CpyStr(args[1]->string.value);
|
|
||||||
}
|
|
||||||
else if (caller->variableType == ByteArrayClass) {
|
|
||||||
if (args[1]->variableType != IntClass) {
|
|
||||||
return NULL; // TODO: add proper error handling
|
|
||||||
}
|
|
||||||
|
|
||||||
u8* a = v->data;
|
|
||||||
a[idx] = (u8)(getIntValue(args[1]) & 0xFF);
|
|
||||||
}
|
}
|
||||||
|
caller->solvedArray.vector.count = oldCount;
|
||||||
|
|
||||||
return &emptyClass;
|
return &emptyClass;
|
||||||
}
|
}
|
||||||
|
@ -152,28 +145,12 @@ ClassFunction(arraySet) {
|
||||||
ClassFunction(arrayAdd) {
|
ClassFunction(arrayAdd) {
|
||||||
Variable_t* arg = *args;
|
Variable_t* arg = *args;
|
||||||
|
|
||||||
if (caller->variableType == IntArrayClass) {
|
if (caller->readOnly) {
|
||||||
if (arg->variableType != IntClass) {
|
SCRIPT_FATAL_ERR("Array is read-only");
|
||||||
return NULL; // TODO: add proper error handling
|
|
||||||
}
|
}
|
||||||
|
|
||||||
vecAdd(&caller->solvedArray.vector, arg->integer.value);
|
if (arrayClassAdd(caller, arg)){
|
||||||
}
|
SCRIPT_FATAL_ERR("Adding the wrong type to a typed array");
|
||||||
else if (caller->variableType == StringArrayClass) {
|
|
||||||
if (arg->variableType != StringClass) {
|
|
||||||
return NULL; // TODO: add proper error handling
|
|
||||||
}
|
|
||||||
|
|
||||||
char* str = CpyStr(arg->string.value);
|
|
||||||
vecAdd(&caller->solvedArray.vector, str);
|
|
||||||
}
|
|
||||||
else if (caller->variableType == ByteArrayClass) {
|
|
||||||
if (arg->variableType != IntClass) {
|
|
||||||
return NULL; // TODO: add proper error handling
|
|
||||||
}
|
|
||||||
|
|
||||||
u8 val = (u8)(arg->integer.value & 0xFF);
|
|
||||||
vecAdd(&caller->solvedArray.vector, val);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return &emptyClass;
|
return &emptyClass;
|
||||||
|
@ -219,7 +196,7 @@ ClassFunction(arrayMinus) {
|
||||||
|
|
||||||
ClassFunction(bytesToStr) {
|
ClassFunction(bytesToStr) {
|
||||||
if (caller->variableType != ByteArrayClass) {
|
if (caller->variableType != ByteArrayClass) {
|
||||||
SCRIPT_FATAL_ERR("Nedd a bytearray to convert to str");
|
SCRIPT_FATAL_ERR("Need a bytearray to convert to str");
|
||||||
}
|
}
|
||||||
|
|
||||||
char* buff = malloc(caller->solvedArray.vector.count + 1);
|
char* buff = malloc(caller->solvedArray.vector.count + 1);
|
||||||
|
@ -241,13 +218,12 @@ ClassFunction(eqArray){
|
||||||
ClassFunctionTableEntry_t arrayFunctions[] = {
|
ClassFunctionTableEntry_t arrayFunctions[] = {
|
||||||
{"get", getArrayIdx, 1, anotherOneIntArg },
|
{"get", getArrayIdx, 1, anotherOneIntArg },
|
||||||
{"len", getArrayLen, 0, 0},
|
{"len", getArrayLen, 0, 0},
|
||||||
{"skip", createRefSkip, 1, anotherOneIntArg},
|
{"slice", arraySlice, 2, doubleInt},
|
||||||
{"foreach", arrayForEach, 2, oneStringoneFunction},
|
{"foreach", arrayForEach, 2, oneStringoneFunction},
|
||||||
{"copy", arrayCopy, 0, 0},
|
{"copy", arrayCopy, 0, 0},
|
||||||
{"set", arraySet, 2, oneIntOneAny},
|
{"set", arraySet, 2, oneIntOneAny},
|
||||||
{"+", arrayAdd, 1, anotherAnotherOneVarArg},
|
{"+", arrayAdd, 1, anotherAnotherOneVarArg},
|
||||||
{"-", arrayMinus, 1, anotherOneIntArg},
|
{"-", arrayMinus, 1, anotherOneIntArg},
|
||||||
{"take", takeArray, 1, anotherOneIntArg},
|
|
||||||
{"contains", arrayContains, 1, anotherAnotherOneVarArg},
|
{"contains", arrayContains, 1, anotherAnotherOneVarArg},
|
||||||
{"bytestostr", bytesToStr, 0, 0},
|
{"bytestostr", bytesToStr, 0, 0},
|
||||||
{"==", eqArray, 1, oneByteArrayClass},
|
{"==", eqArray, 1, oneByteArrayClass},
|
||||||
|
|
Loading…
Reference in a new issue