fix wren TIC.spr array of colors bug, and implement eval script

This commit is contained in:
RudenkoArts 2018-07-11 13:05:51 +03:00
parent 3032dd0816
commit c41b254fd7
1 changed files with 60 additions and 39 deletions

View File

@ -200,7 +200,8 @@ static void closeWren(tic_mem* tic)
wrenReleaseHandle(machine->wren, update_handle); wrenReleaseHandle(machine->wren, update_handle);
wrenReleaseHandle(machine->wren, scanline_handle); wrenReleaseHandle(machine->wren, scanline_handle);
wrenReleaseHandle(machine->wren, overline_handle); wrenReleaseHandle(machine->wren, overline_handle);
if (game_class != NULL) { if (game_class != NULL)
{
wrenReleaseHandle(machine->wren, game_class); wrenReleaseHandle(machine->wren, game_class);
} }
} }
@ -231,10 +232,10 @@ static void wren_map_height(WrenVM* vm)
static void wren_mgeti(WrenVM* vm) static void wren_mgeti(WrenVM* vm)
{ {
s32 index = getWrenNumber(vm, 1); s32 index = getWrenNumber(vm, 1);
if(index < 0 || index >= TIC_MAP_WIDTH * TIC_MAP_HEIGHT) { if(index < 0 || index >= TIC_MAP_WIDTH * TIC_MAP_HEIGHT)
{
wrenSetSlotDouble(vm, 0, 0); wrenSetSlotDouble(vm, 0, 0);
return; return;
} }
@ -498,12 +499,14 @@ static void wren_spr(WrenVM* vm)
{ {
if(isList(vm, 4)) if(isList(vm, 4))
{ {
wrenEnsureSlots(vm, top+1);
int list_count = wrenGetListCount(vm, 4);
for(s32 i = 0; i < TIC_PALETTE_SIZE; i++) for(s32 i = 0; i < TIC_PALETTE_SIZE; i++)
{ {
wrenGetListElement(vm, 4, i, 0); // todo, can be bug cause in slot 0 is object? wrenGetListElement(vm, 4, i, top);
if(isNumber(vm, 0)) if(i < list_count && isNumber(vm, top))
{ {
colors[i] = getWrenNumber(vm, 0); colors[i] = getWrenNumber(vm, top);
count++; count++;
} }
else else
@ -549,24 +552,33 @@ static void wren_spr(WrenVM* vm)
static void wren_spr_internal(WrenVM* vm) static void wren_spr_internal(WrenVM* vm)
{ {
s32 top = wrenGetSlotCount(vm);
s32 index = getWrenNumber(vm, 1); s32 index = getWrenNumber(vm, 1);
s32 x = getWrenNumber(vm, 2); s32 x = getWrenNumber(vm, 2);
s32 y = getWrenNumber(vm, 3); s32 y = getWrenNumber(vm, 3);
static u8 colors[TIC_PALETTE_SIZE]; static u8 colors[TIC_PALETTE_SIZE];
s32 count = 0; s32 count = 0;
if(isList(vm, 4)) { if(isList(vm, 4))
for(s32 i = 0; i < TIC_PALETTE_SIZE; i++) { {
wrenGetListElement(vm, 4, i, 0); // todo, can be bug cause in slot 0 is object? wrenEnsureSlots(vm, top+1);
if(isNumber(vm, 0)) { int list_count = wrenGetListCount(vm, 4);
colors[i] = getWrenNumber(vm, 0); for(s32 i = 0; i < TIC_PALETTE_SIZE; i++)
{
wrenGetListElement(vm, 4, i, top);
if(i < list_count && isNumber(vm, top))
{
colors[i] = getWrenNumber(vm, top);
count++; count++;
} else { }
else
{
break; break;
} }
} }
} }
else else
{ {
colors[0] = getWrenNumber(vm, 4); colors[0] = getWrenNumber(vm, 4);
@ -630,7 +642,6 @@ static void wren_map(WrenVM* vm)
static void wren_mset(WrenVM* vm) static void wren_mset(WrenVM* vm)
{ {
s32 x = getWrenNumber(vm, 1); s32 x = getWrenNumber(vm, 1);
s32 y = getWrenNumber(vm, 2); s32 y = getWrenNumber(vm, 2);
u8 value = getWrenNumber(vm, 3); u8 value = getWrenNumber(vm, 3);
@ -657,7 +668,8 @@ static void wren_textri(WrenVM* vm)
float pt[12]; float pt[12];
for (s32 i = 0; i < COUNT_OF(pt); i++){ for (s32 i = 0; i < COUNT_OF(pt); i++)
{
pt[i] = (float)getWrenNumber(vm, i + 1); pt[i] = (float)getWrenNumber(vm, i + 1);
} }
@ -666,12 +678,14 @@ static void wren_textri(WrenVM* vm)
bool use_map = false; bool use_map = false;
// check for use map // check for use map
if (top > 13){ if (top > 13)
{
use_map = wrenGetSlotBool(vm, 13); use_map = wrenGetSlotBool(vm, 13);
} }
// check for chroma // check for chroma
if (top > 14){ if (top > 14)
{
chroma = (u8)getWrenNumber(vm, 14); chroma = (u8)getWrenNumber(vm, 14);
} }
@ -721,7 +735,8 @@ static void wren_line(WrenVM* vm)
static void wren_circ(WrenVM* vm) static void wren_circ(WrenVM* vm)
{ {
s32 radius = getWrenNumber(vm, 3); s32 radius = getWrenNumber(vm, 3);
if(radius < 0) { if(radius < 0)
{
return; return;
} }
@ -737,7 +752,10 @@ static void wren_circ(WrenVM* vm)
static void wren_circb(WrenVM* vm) static void wren_circb(WrenVM* vm)
{ {
s32 radius = getWrenNumber(vm, 3); s32 radius = getWrenNumber(vm, 3);
if(radius < 0) return; if(radius < 0)
{
return;
}
s32 x = getWrenNumber(vm, 1); s32 x = getWrenNumber(vm, 1);
s32 y = getWrenNumber(vm, 2); s32 y = getWrenNumber(vm, 2);
@ -778,7 +796,8 @@ static void wren_tri(WrenVM* vm)
{ {
s32 pt[6]; s32 pt[6];
for(s32 i = 0; i < COUNT_OF(pt); i++){ for(s32 i = 0; i < COUNT_OF(pt); i++)
{
pt[i] = getWrenNumber(vm, i+1); pt[i] = getWrenNumber(vm, i+1);
} }
@ -1082,7 +1101,6 @@ static const char* const ApiKeywords[] = API_KEYWORDS;
static WrenForeignMethodFn foreignTicMethods(const char* signature) static WrenForeignMethodFn foreignTicMethods(const char* signature)
{ {
if (strcmp(signature, "static TIC.btn(_)" ) == 0) return wren_btn; if (strcmp(signature, "static TIC.btn(_)" ) == 0) return wren_btn;
if (strcmp(signature, "static TIC.btnp(_)" ) == 0) return wren_btnp; if (strcmp(signature, "static TIC.btnp(_)" ) == 0) return wren_btnp;
if (strcmp(signature, "static TIC.btnp(_,_,_)" ) == 0) return wren_btnp; if (strcmp(signature, "static TIC.btnp(_,_,_)" ) == 0) return wren_btnp;
@ -1177,14 +1195,13 @@ static WrenForeignMethodFn bindForeignMethod(
WrenVM* vm, const char* module, const char* className, WrenVM* vm, const char* module, const char* className,
bool isStatic, const char* signature) bool isStatic, const char* signature)
{ {
if (strcmp(module, "main") != 0) return NULL; if (strcmp(module, "main") != 0) return NULL;
// For convenience, concatenate all of the method qualifiers into a single // For convenience, concatenate all of the method qualifiers into a single signature string.
// signature string.
char fullName[256]; char fullName[256];
fullName[0] = '\0'; fullName[0] = '\0';
if (isStatic) { if (isStatic)
{
strcat(fullName, "static "); strcat(fullName, "static ");
} }
@ -1205,7 +1222,7 @@ static void initAPI(tic_machine* machine)
if (wrenInterpret(machine->wren, tic_wren_api) != WREN_RESULT_SUCCESS) if (wrenInterpret(machine->wren, tic_wren_api) != WREN_RESULT_SUCCESS)
{ {
machine->data->error(machine->data->data, "can't load Tic wren api"); machine->data->error(machine->data->data, "can't load TIC wren api");
} }
} }
@ -1232,10 +1249,10 @@ static void writeFn(WrenVM* vm, const char* text)
machine->data->trace(machine->data->data, text ? text : "null", color); machine->data->trace(machine->data->data, text ? text : "null", color);
} }
static bool initWren(tic_mem* tic, const char* code) static bool initWren(tic_mem* memory, const char* code)
{ {
tic_machine* machine = (tic_machine*)tic; tic_machine* machine = (tic_machine*)memory;
closeWren(tic); closeWren(memory);
WrenConfiguration config; WrenConfiguration config;
wrenInitConfiguration(&config); wrenInitConfiguration(&config);
@ -1249,7 +1266,8 @@ static bool initWren(tic_mem* tic, const char* code)
initAPI(machine); initAPI(machine);
if (wrenInterpret(machine->wren, code) != WREN_RESULT_SUCCESS){ if (wrenInterpret(machine->wren, code) != WREN_RESULT_SUCCESS)
{
return false; return false;
} }
@ -1273,7 +1291,8 @@ static bool initWren(tic_mem* tic, const char* code)
wrenCall(vm, new_handle); wrenCall(vm, new_handle);
wrenReleaseHandle(machine->wren, game_class); // release game class handle wrenReleaseHandle(machine->wren, game_class); // release game class handle
game_class = NULL; game_class = NULL;
if (wrenGetSlotCount(vm) == 0) { if (wrenGetSlotCount(vm) == 0)
{
machine->data->error(machine->data->data, "Error in game class :("); machine->data->error(machine->data->data, "Error in game class :(");
return false; return false;
} }
@ -1286,9 +1305,9 @@ static bool initWren(tic_mem* tic, const char* code)
return true; return true;
} }
static void callWrenTick(tic_mem* tic) static void callWrenTick(tic_mem* memory)
{ {
tic_machine* machine = (tic_machine*)tic; tic_machine* machine = (tic_machine*)memory;
WrenVM* vm = machine->wren; WrenVM* vm = machine->wren;
if(vm && game_class) if(vm && game_class)
@ -1328,9 +1347,9 @@ static void callWrenOverline(tic_mem* memory, void* data)
static const char* const WrenKeywords [] = static const char* const WrenKeywords [] =
{ {
"false", "true", "null", "break", "class", "construct", "break", "class", "construct", "else", "false", "for",
"else", "for", "foreign", "if", "import", "in", "is", "foreign", "if", "import", "in", "is", "null", "return",
"return", "static", "super", "var", "while", "this" "static", "super", "this", "true", "var", "while"
}; };
static const tic_outline_item* getWrenOutline(const char* code, s32* size) static const tic_outline_item* getWrenOutline(const char* code, s32* size)
@ -1344,8 +1363,10 @@ static const tic_outline_item* getWrenOutline(const char* code, s32* size)
return items; return items;
} }
void evalWren(tic_mem* tic, const char* code) { void evalWren(tic_mem* memory, const char* code)
printf("TODO: Wren eval not yet implemented\n."); {
tic_machine* machine = (tic_machine*)memory;
wrenInterpret(machine->wren, code);
} }
static const tic_script_config WrenSyntaxConfig = static const tic_script_config WrenSyntaxConfig =