temporary disabled html export

This commit is contained in:
nesbox 2018-09-05 00:37:32 +03:00
parent e55b2a2f9a
commit 2bfe213f61
5 changed files with 27 additions and 222 deletions

@ -1 +1 @@
Subproject commit b2e59affe6cb68b403d3b3d2f0f83b794a37c318 Subproject commit ad41cab4620ac249ea8414ebd83b6e636cc024a5

View File

@ -335,8 +335,6 @@ if(NOT EMSCRIPTEN)
list(APPEND DEMO_CARTS list(APPEND DEMO_CARTS
${CMAKE_SOURCE_DIR}/config.tic ${CMAKE_SOURCE_DIR}/config.tic
${CMAKE_SOURCE_DIR}/build/html/index.html
${CMAKE_SOURCE_DIR}/build/html/tic.js
) )
set(DEMO_CARTS_OUT) set(DEMO_CARTS_OUT)
@ -383,7 +381,6 @@ set(TIC80LIB_SRC
${TIC80LIB_DIR}/dialog.c ${TIC80LIB_DIR}/dialog.c
${TIC80LIB_DIR}/menu.c ${TIC80LIB_DIR}/menu.c
${TIC80LIB_DIR}/surf.c ${TIC80LIB_DIR}/surf.c
${TIC80LIB_DIR}/html.c
) )
set(TIC80_OUTPUTS tic80 tic80pro) set(TIC80_OUTPUTS tic80 tic80pro)

File diff suppressed because one or more lines are too long

View File

@ -1858,124 +1858,6 @@ static void *ticMemmem(const void* haystack, size_t hlen, const void* needle, si
return NULL; return NULL;
} }
typedef struct
{
Console* console;
const char* cartName;
} AppFileReadParam;
typedef struct
{
u8* data;
size_t size;
} MemoryBuffer;
static void writeMemoryData(MemoryBuffer* memory, const u8* src, size_t size)
{
memcpy(memory->data + memory->size, src, size);
memory->size += size;
}
static void writeMemoryString(MemoryBuffer* memory, const char* str)
{
size_t size = strlen(str);
memcpy(memory->data + memory->size, str, size);
memory->size += size;
}
static void onConsoleExportHtmlCommand(Console* console, const char* name)
{
tic_mem* tic = console->tic;
char cartName[FILENAME_MAX];
strcpy(cartName, name);
{
static const char HtmlExt[] = ".html";
const char* pos = NULL;
if((pos = strstr(name, HtmlExt)) && strcmp(pos, HtmlExt) == 0);
else strcat(cartName, HtmlExt);
}
extern const u8 EmbedIndexZip[];
extern const s32 EmbedIndexZipSize;
extern const u8 EmbedTicJsZip[];
extern const s32 EmbedTicJsZipSize;
static const char Placeholder[] = "<script async type=\"text/javascript\" src=\"tic.js\"></script>";
u8* EmbedIndex = NULL;
u32 EmbedIndexSize = unzip(&EmbedIndex, EmbedIndexZip, EmbedIndexZipSize);
u8* EmbedTicJs = NULL;
u32 EmbedTicJsSize = unzip(&EmbedTicJs, EmbedTicJsZip, EmbedTicJsZipSize);
u8* ptr = ticMemmem(EmbedIndex, EmbedIndexSize, Placeholder, sizeof(Placeholder)-1);
if(ptr)
{
MemoryBuffer output = {(u8*)malloc(EmbedTicJsSize * 2), 0};
if(output.data)
{
writeMemoryData(&output, EmbedIndex, ptr - EmbedIndex);
writeMemoryString(&output, "<script type='text/javascript'>\n");
u8* buffer = (u8*)malloc(sizeof(tic_cartridge));
if(buffer)
{
writeMemoryString(&output, "var cartridge = [");
s32 size = tic->api.save(&tic->cart, buffer);
if(size)
{
// zip buffer
{
unsigned long outSize = sizeof(tic_cartridge);
u8* output = (u8*)malloc(outSize);
compress2(output, &outSize, buffer, size, Z_BEST_COMPRESSION);
free(buffer);
buffer = output;
size = outSize;
}
{
u8* ptr = buffer;
u8* end = ptr + size;
char value[] = "999,";
while(ptr != end)
{
sprintf(value, "%i,", *ptr++);
writeMemoryString(&output, value);
}
}
free(buffer);
writeMemoryString(&output, "];\n");
writeMemoryData(&output, EmbedTicJs, EmbedTicJsSize);
writeMemoryString(&output, "</script>\n");
ptr += sizeof(Placeholder)-1;
writeMemoryData(&output, ptr, EmbedIndexSize - (ptr - EmbedIndex));
fsGetFileData(onFileDownloaded, cartName, output.data, output.size, DEFAULT_CHMOD, console);
}
}
}
}
free(EmbedIndex);
free(EmbedTicJs);
}
#if defined(CAN_EXPORT) #if defined(CAN_EXPORT)
static void* embedCart(Console* console, s32* size) static void* embedCart(Console* console, s32* size)
@ -2054,20 +1936,15 @@ static void onConsoleExportNativeCommand(Console* console, const char* cartName)
#endif #endif
static const char* getExportName(Console* console, bool html) static const char* getExportName(Console* console)
{ {
static char name[FILENAME_MAX]; static char name[FILENAME_MAX];
strcpy(name, strlen(console->romName) ? console->romName : "game"); strcpy(name, strlen(console->romName) ? console->romName : "game");
if(html)
strcat(name, ".html");
else
{
#if defined(__TIC_WINDOWS__) #if defined(__TIC_WINDOWS__)
strcat(name, ExeExt); strcat(name, ExeExt);
#endif #endif
}
return name; return name;
} }
@ -2075,14 +1952,11 @@ static const char* getExportName(Console* console, bool html)
static void onConsoleExportCommand(Console* console, const char* param) static void onConsoleExportCommand(Console* console, const char* param)
{ {
if(param) if(param)
{
if(strcmp(param, "html") == 0) onConsoleExportHtmlCommand(console, getExportName(console, true));
else
{ {
if(strcmp(param, "native") == 0) if(strcmp(param, "native") == 0)
{ {
#if defined(CAN_EXPORT) #if defined(CAN_EXPORT)
onConsoleExportNativeCommand(console, getExportName(console, false)); onConsoleExportNativeCommand(console, getExportName(console));
#else #else
printBack(console, "\nnative export isn't supported on this platform\n"); printBack(console, "\nnative export isn't supported on this platform\n");
@ -2108,10 +1982,9 @@ static void onConsoleExportCommand(Console* console, const char* param)
commandDone(console); commandDone(console);
} }
} }
}
else else
{ {
onConsoleExportHtmlCommand(console, getExportName(console, true)); onConsoleExportNativeCommand(console, getExportName(console));
} }
} }
@ -2465,7 +2338,7 @@ static const struct
#endif #endif
{"add", NULL, "add file", onConsoleAddCommand}, {"add", NULL, "add file", onConsoleAddCommand},
{"get", NULL, "download file", onConsoleGetCommand}, {"get", NULL, "download file", onConsoleGetCommand},
{"export", NULL, "export html or native game", onConsoleExportCommand}, {"export", NULL, "export native game", onConsoleExportCommand},
{"import", NULL, "import sprites from .gif", onConsoleImportCommand}, {"import", NULL, "import sprites from .gif", onConsoleImportCommand},
{"del", NULL, "delete file or dir", onConsoleDelCommand}, {"del", NULL, "delete file or dir", onConsoleDelCommand},
{"cls", NULL, "clear screen", onConsoleClsCommand}, {"cls", NULL, "clear screen", onConsoleClsCommand},

View File

@ -1,37 +0,0 @@
// MIT License
// Copyright (c) 2017 Vadim Grigoruk @nesbox // grigoruk@gmail.com
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
#include <tic80_types.h>
const u8 EmbedIndexZip[] =
{
#include "../bin/assets/index.html.dat"
};
const s32 EmbedIndexZipSize = sizeof EmbedIndexZip;
const u8 EmbedTicJsZip[] =
{
#include "../bin/assets/tic.js.dat"
};
const s32 EmbedTicJsZipSize = sizeof EmbedTicJsZip;