Merge pull request #633 from RudenkoArts/master
Wren eval, and TIC.spr fix
This commit is contained in:
commit
dbb762d8a9
4
Makefile
4
Makefile
|
@ -14,7 +14,7 @@ RM= rm -f
|
||||||
|
|
||||||
INCLUDES= \
|
INCLUDES= \
|
||||||
-I$(3RD_PARTY)/lua-5.3.1/src \
|
-I$(3RD_PARTY)/lua-5.3.1/src \
|
||||||
-I$(3RD_PARTY)/zlib-1.2.8 \
|
-I$(3RD_PARTY)/zlib-1.2.11 \
|
||||||
-I$(3RD_PARTY)/giflib-5.1.4/lib \
|
-I$(3RD_PARTY)/giflib-5.1.4/lib \
|
||||||
-I$(3RD_PARTY)/SDL2-2.0.7/include \
|
-I$(3RD_PARTY)/SDL2-2.0.7/include \
|
||||||
-I$(3RD_PARTY)/sdl-gpu/include \
|
-I$(3RD_PARTY)/sdl-gpu/include \
|
||||||
|
@ -330,7 +330,7 @@ $(STUDIO_DLL): $(DEMO_ASSETS) $(TIC80_DLL) $(TIC_O) bin/html.o
|
||||||
$(CC) $(TIC_O) bin/html.o $(TIC80_A) $(OPT) -shared $(INCLUDES) -L$(PRE_BUILT)/mingw -llua -lz -lgif -Wl,--out-implib,$(STUDIO_A) -o $@
|
$(CC) $(TIC_O) bin/html.o $(TIC80_A) $(OPT) -shared $(INCLUDES) -L$(PRE_BUILT)/mingw -llua -lz -lgif -Wl,--out-implib,$(STUDIO_A) -o $@
|
||||||
|
|
||||||
emscripten:
|
emscripten:
|
||||||
$(EMS_CC) $(SOURCES) $(SYSTEM) $(TIC80_SRC) $(OPT) $(INCLUDES) $(EMS_OPT) $(EMS_LINKER_FLAGS) -o build/html/tic.js
|
$(EMS_CC) $(SOURCES) $(SYSTEM) $(TIC80_SRC) $(OPT) $(INCLUDES) $(EMS_OPT) -s WASM=0 $(EMS_LINKER_FLAGS) -o build/html/tic.js
|
||||||
|
|
||||||
wasm:
|
wasm:
|
||||||
$(EMS_CC) $(SOURCES) $(SYSTEM) $(TIC80_SRC) $(OPT) $(INCLUDES) $(EMS_OPT) -s WASM=1 $(EMS_LINKER_FLAGS) -o build/html/tic.js
|
$(EMS_CC) $(SOURCES) $(SYSTEM) $(TIC80_SRC) $(OPT) $(INCLUDES) $(EMS_OPT) -s WASM=1 $(EMS_LINKER_FLAGS) -o build/html/tic.js
|
||||||
|
|
|
@ -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 =
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
OPT=-O3 -Wall -std=c99
|
OPT=-O3 -Wall -std=c99
|
||||||
SRC=bin2txt.c
|
SRC=bin2txt.c
|
||||||
3RD_PARTY = ../../3rd-party
|
3RD_PARTY = ../../3rd-party
|
||||||
INCLUDE=-I$(3RD_PARTY)/zlib-1.2.8
|
INCLUDE=-I$(3RD_PARTY)/zlib-1.2.11
|
||||||
PRE_BUILT = $(3RD_PARTY)/pre-built
|
PRE_BUILT = $(3RD_PARTY)/pre-built
|
||||||
LIB=-lz
|
LIB=-lz
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue