diff --git a/src/console.c b/src/console.c index 9345ead..57adc4f 100644 --- a/src/console.c +++ b/src/console.c @@ -509,55 +509,6 @@ static void onCartLoaded(Console* console, const char* name) } -#if defined(TIC80_PRO) - -static void loadProjectCode(Console* console, const void* data, s32 size) -{ - tic_mem* tic = console->tic; - - SDL_memcpy(tic->cart.code.data, data, SDL_min(size, sizeof(tic_code))); -} - -static void loadProject(Console* console, const char* name) -{ - tic_mem* tic = console->tic; - - SDL_memset(&tic->cart, 0, sizeof(tic_cartridge)); - - static struct{const char* name; void(*func)(Console* console, const void* data, s32 size);} ProjectFiles[] = - { - {"code.lua", loadProjectCode}, - {"sprites.gif", NULL}, - {"tiles.gif", NULL}, - {"palette.dat", NULL}, - {"map.dat", NULL}, - {"waves.dat", NULL}, - {"sfx.dat", NULL}, - {"music.dat", NULL}, - {"cover.gif", NULL}, - }; - - for(s32 i = 0; i < COUNT_OF(ProjectFiles); i++) - { - char path[FILENAME_MAX]; - sprintf(path, "%s/%s", name, ProjectFiles[i].name); - - s32 size = 0; - void* data = fsLoadFile(console->fs, path, &size); - - if(data) - { - ProjectFiles[i].func(console, data, size); - SDL_free(data); - } - } - - onCartLoaded(console, name); - - commandDone(console); -} -#endif - static void onConsoleLoadCommandConfirmed(Console* console, const char* param) { if(onConsoleLoadSectionCommand(console, param)) return; @@ -567,14 +518,6 @@ static void onConsoleLoadCommandConfirmed(Console* console, const char* param) s32 size = 0; const char* name = getCartName(param); -#if defined(TIC80_PRO) - if(fsIsDir(console->fs, name)) - { - loadProject(console, name); - return; - } -#endif - void* data = strcmp(name, CONFIG_TIC_PATH) == 0 ? fsLoadRootFile(console->fs, name, &size) : fsLoadFile(console->fs, name, &size); @@ -753,11 +696,6 @@ static bool printFilename(const char* name, const char* info, s32 id, void* data printLine(console); -#if defined(TIC80_PRO) - if(dir && SDL_strstr(name, CartExt) == (name + SDL_strlen(name) - SDL_strlen(CartExt))) - dir = false; -#endif - if(dir) { @@ -1657,6 +1595,17 @@ static bool bufferEmpty(const u8* data, s32 size) return true; } +static char* printText(char* ptr, const char* tag, const char* data) +{ + if(strlen(data) == 0) + return ptr; + + sprintf(ptr, "-- <%s>\n%s\n-- \n", tag, data, tag); + ptr += strlen(ptr); + + return ptr; +} + static char* printBuf(char* ptr, const void* data, s32 size, s32 row) { if(bufferEmpty(data, size)) @@ -1674,17 +1623,20 @@ static char* printBuf(char* ptr, const void* data, s32 size, s32 row) return ptr; } -static char* printSection(char* ptr, const char* tag, s32 count, const u8* data, s32 size) +static char* printBinary(char* ptr, const char* tag, s32 count, const u8* data, s32 size) { if(bufferEmpty(data, size * count)) return ptr; - sprintf(ptr, "\n-- ### %s:\n", tag); + sprintf(ptr, "\n-- <%s>\n", tag); ptr += strlen(ptr); for(s32 i = 0; i < count; i++, data += size) ptr = printBuf(ptr, data, size, i); + sprintf(ptr, "-- \n", tag); + ptr += strlen(ptr); + return ptr; } @@ -1700,17 +1652,19 @@ static CartSaveResult saveProject(Console* console, const char* name) if(stream) { - strcpy(stream, tic->cart.code.data); - char* ptr = stream + strlen(stream); + char* ptr = printText(stream, "CODE", tic->cart.code.data); - ptr = printSection(ptr, "PALETTE", 1, tic->cart.palette.data, sizeof(tic_palette)); - ptr = printSection(ptr, "TILES", TIC_BANK_SPRITES, tic->cart.gfx.tiles[0].data, sizeof(tic_tile)); - ptr = printSection(ptr, "SPRITES", TIC_BANK_SPRITES, tic->cart.gfx.sprites[0].data, sizeof(tic_tile)); - ptr = printSection(ptr, "MAP", TIC_MAP_HEIGHT, tic->cart.gfx.map.data, TIC_MAP_WIDTH); - ptr = printSection(ptr, "WAVES", ENVELOPES_COUNT, tic->cart.sound.sfx.waveform.envelopes[0].data, sizeof(tic_waveform)); - ptr = printSection(ptr, "SFX", SFX_COUNT, (const u8*)&tic->cart.sound.sfx.data, sizeof(tic_sound_effect)); - ptr = printSection(ptr, "PATTERNS", MUSIC_PATTERNS, (const u8*)&tic->cart.sound.music.patterns.data, sizeof(tic_track_pattern)); - ptr = printSection(ptr, "TRACKS", MUSIC_TRACKS, (const u8*)&tic->cart.sound.music.tracks.data, sizeof(tic_track)); + // TODO: flip data for palette + ptr = printBinary(ptr, "PALETTE", 1, tic->cart.palette.data, sizeof(tic_palette)); + ptr = printBinary(ptr, "TILES", TIC_BANK_SPRITES, tic->cart.gfx.tiles[0].data, sizeof(tic_tile)); + ptr = printBinary(ptr, "SPRITES", TIC_BANK_SPRITES, tic->cart.gfx.sprites[0].data, sizeof(tic_tile)); + ptr = printBinary(ptr, "MAP", TIC_MAP_HEIGHT, tic->cart.gfx.map.data, TIC_MAP_WIDTH); + ptr = printBinary(ptr, "WAVES", ENVELOPES_COUNT, tic->cart.sound.sfx.waveform.envelopes[0].data, sizeof(tic_waveform)); + ptr = printBinary(ptr, "SFX", SFX_COUNT, (const u8*)&tic->cart.sound.sfx.data, sizeof(tic_sound_effect)); + ptr = printBinary(ptr, "PATTERNS", MUSIC_PATTERNS, (const u8*)&tic->cart.sound.music.patterns.data, sizeof(tic_track_pattern)); + ptr = printBinary(ptr, "TRACKS", MUSIC_TRACKS, (const u8*)&tic->cart.sound.music.tracks.data, sizeof(tic_track)); + + // TODO: add cover name = getProjectName(name); @@ -1773,6 +1727,174 @@ static void onConsoleSaveProjectCommand(Console* console, const char* param) } } +static bool loadProject(Console* console, const char* data, s32 size) +{ + tic_mem* tic = console->tic; + + char* project = (char*)SDL_malloc(size+1); + + bool done = false; + + if(project) + { + SDL_memcpy(project, data, size); + project[size] = '\0'; + + tic_cartridge* cart = (tic_cartridge*)SDL_malloc(sizeof(tic_cartridge)); + + if(cart) + { + SDL_memset(cart, 0, sizeof(tic_cartridge)); + + // TODO: init default palette here + { + memcpy(&cart->palette, &tic->cart.palette, sizeof(tic_palette)); + } + + const char* projectEnd = project + strlen(project); + + { + const char* tag = "CODE"; + char tagbuf[64]; + sprintf(tagbuf, "-- <%s>\n", tag); + + const char* start = SDL_strstr(project, tagbuf); + + if(start) + { + start += strlen(tagbuf); + + if(start < projectEnd) + { + sprintf(tagbuf, "\n-- ", tag); + const char* end = SDL_strstr(start, tagbuf); + + s32 size = end - start; + if(size > 0) + { + SDL_memcpy(cart->code.data, start, end - start); + done = true; + } + } + } + } + + { + const char* tag = "TILES"; + char tagbuf[64]; + sprintf(tagbuf, "-- <%s>\n", tag); + + const char* start = SDL_strstr(project, tagbuf); + + if(start) + { + start += strlen(tagbuf); + + if(start < projectEnd) + { + sprintf(tagbuf, "\n-- ", tag); + const char* end = SDL_strstr(start, tagbuf); + + s32 size = end - start; + if(size > 0) + { + s32 count = 256; + s32 size = sizeof(tic_tile) * 2; + + const char* ptr = start; + + while(ptr < end) + { + char lineStr[] = "999"; + memcpy(lineStr, ptr + strlen("-- "), strlen(lineStr)); + + s32 index = SDL_atoi(lineStr); + + if(index < count) + { + ptr += strlen("-- 999:"); + str2buf(ptr, size, cart->gfx.tiles[index].data, true); + ptr += size + 1; + } + } + + done = true; + } + } + } + } + + if(done) + { + SDL_memcpy(&tic->cart, cart, sizeof(tic_cartridge)); + } + + SDL_free(cart); + } + + + SDL_free(project); + } + + return done; +} + +static void onConsoleLoadProjectCommandConfirmed(Console* console, const char* param) +{ + // if(onConsoleLoadProjectSectionCommand(console, param)) return; + + if(param) + { + s32 size = 0; + const char* name = getProjectName(param); + + void* data = fsLoadFile(console->fs, name, &size); + + if(data && loadProject(console, data, size)) + { + strcpy(console->romName, name); + + studioRomLoaded(); + + printBack(console, "\nproject "); + printFront(console, console->romName); + printBack(console, " loaded!\nuse "); + printFront(console, "RUN"); + printBack(console, " command to run it\n"); + + SDL_free(data); + } + else + { + printBack(console, "\nproject loading error"); + } + } + else printBack(console, "\nproject name is missing"); + + commandDone(console); +} + +static void onConsoleLoadProjectCommand(Console* console, const char* param) +{ + if(studioCartChanged()) + { + static const char* Rows[] = + { + "YOU HAVE", + "UNSAVED CHANGES", + "", + "DO YOU REALLY WANT", + "TO LOAD PROJECT?", + }; + + confirmCommand(console, Rows, COUNT_OF(Rows), param, onConsoleLoadProjectCommandConfirmed); + } + else + { + onConsoleLoadProjectCommandConfirmed(console, param); + } +} + #endif static CartSaveResult saveCartName(Console* console, const char* name) @@ -2083,6 +2205,7 @@ static const struct {"load", NULL, "load cart", onConsoleLoadCommand}, {"save", NULL, "save cart", onConsoleSaveCommand}, #if defined(TIC80_PRO) + {"loadp", NULL, "load project", onConsoleLoadProjectCommand}, {"savep", NULL, "save project", onConsoleSaveProjectCommand}, #endif {"run", NULL, "run loaded cart", onConsoleRunCommand}, diff --git a/src/map.c b/src/map.c index 3efc8e0..4c4538d 100644 --- a/src/map.c +++ b/src/map.c @@ -999,7 +999,7 @@ static void copyFromClipboard(Map* map) { u8* data = SDL_malloc(size); - str2buf(clipboard, data, true); + str2buf(clipboard, strlen(clipboard), data, true); if(data[0] * data[1] == size - 2) { diff --git a/src/music.c b/src/music.c index 2cf74e5..5ca4ba8 100644 --- a/src/music.c +++ b/src/music.c @@ -598,7 +598,7 @@ static void copyFromClipboard(Music* music) { u8* data = SDL_malloc(size); - str2buf(clipboard, data, true); + str2buf(clipboard, strlen(clipboard), data, true); ClipboardHeader header = {0}; diff --git a/src/studio.c b/src/studio.c index 3a0f8ac..4824673 100644 --- a/src/studio.c +++ b/src/studio.c @@ -342,13 +342,11 @@ void toClipboard(const void* data, s32 size, bool flip) } } -void str2buf(const char* str, void* buf, bool flip) +void str2buf(const char* str, s32 size, void* buf, bool flip) { char val[] = "0x00"; const char* ptr = str; - s32 size = (s32)strlen(str); - for(s32 i = 0; i < size/2; i++) { if(flip) @@ -378,7 +376,7 @@ bool fromClipboard(void* data, s32 size, bool flip) { bool valid = strlen(clipboard) == size * 2; - if(valid) str2buf(clipboard, data, flip); + if(valid) str2buf(clipboard, strlen(clipboard), data, flip); SDL_free(clipboard); diff --git a/src/studio.h b/src/studio.h index 17eb748..2163eec 100644 --- a/src/studio.h +++ b/src/studio.h @@ -146,7 +146,7 @@ EditorMode getStudioMode(); void exitStudio(); u32 unzip(u8** dest, const u8* source, size_t size); -void str2buf(const char* str, void* buf, bool flip); +void str2buf(const char* str, s32 size, void* buf, bool flip); void toClipboard(const void* data, s32 size, bool flip); bool fromClipboard(void* data, s32 size, bool flip); diff --git a/src/tic.h b/src/tic.h index afce57f..d788dbe 100644 --- a/src/tic.h +++ b/src/tic.h @@ -29,6 +29,8 @@ #define TIC_VERSION_MAJOR 0 #define TIC_VERSION_MINOR 47 #define TIC_VERSION_PATCH 0 + +// TODO: add PRO postfix to title #define TIC_VERSION_STATUS "" #define TIC_MAKE_VERSION(major, minor, patch) ((major) * 10000 + (minor) * 100 + (patch))