Implemented APE support.
h3rald h3rald@h3rald.com
Mon, 02 Dec 2024 15:59:18 +0100
5 files changed,
57 insertions(+),
49 deletions(-)
M
.gitignore
→
.gitignore
@@ -58,3 +58,4 @@ example.hex
web/out/ web/assets/hex.js web/assets/hex.wasm +*.com.dbg
M
hex.c
→
hex.c
@@ -3,27 +3,31 @@
#ifdef EMSCRIPTEN #include <emscripten.h> -EM_ASYNC_JS(char *, em_fgets, (const char* buf, size_t bufsize), { - return await new Promise((resolve, reject) => { - if (Module.pending_lines.length > 0) { - resolve(Module.pending_lines.shift()); - } else { - Module.pending_fgets.push(resolve); - } - }).then((s) => { - // convert JS string to WASM string - let l = s.length + 1; - if (l >= bufsize) { - // truncate - l = bufsize - 1; - } - Module.stringToUTF8(s.slice(0, l), buf, l); - return buf; - }); +EM_ASYNC_JS(char *, em_fgets, (const char *buf, size_t bufsize), { + return await new Promise((resolve, reject) = > { + if (Module.pending_lines.length > 0) + { + resolve(Module.pending_lines.shift()); + } + else + { + Module.pending_fgets.push(resolve); + } + }) + .then((s) = > { + // convert JS string to WASM string + let l = s.length + 1; + if (l >= bufsize) + { + // truncate + l = bufsize - 1; + } + Module.stringToUTF8(s.slice(0, l), buf, l); + return buf; + }); }); #endif - // Common operations #define POP(ctx, x) hex_item_t x = hex_pop(ctx)@@ -3845,40 +3849,39 @@ fclose(file);
return content; } -static void do_repl(void *v_ctx) +static void do_repl(void *v_ctx) { - hex_context_t *ctx = (hex_context_t *)v_ctx; - char line[1024]; + hex_context_t *ctx = (hex_context_t *)v_ctx; + char line[1024]; #ifdef EMSCRIPTEN - char *p = line; - p = em_fgets(line, 1024); - if (!p) - { - printf("Error reading output"); - } + char *p = line; + p = em_fgets(line, 1024); + if (!p) + { + printf("Error reading output"); + } #else - printf("> "); // Prompt - if (fgets(line, sizeof(line), stdin) == NULL) - { - printf("\n"); // Handle EOF (Ctrl+D) - return; - } + printf("> "); // Prompt + fflush(stdout); + if (fgets(line, sizeof(line), stdin) == NULL) + { + printf("\n"); // Handle EOF (Ctrl+D) + return; + } #endif - // Normalize line endings (remove trailing \r\n or \n) - line[strcspn(line, "\r\n")] = '\0'; + // Normalize line endings (remove trailing \r\n or \n) + line[strcspn(line, "\r\n")] = '\0'; - // Tokenize and process the input - hex_interpret(ctx, line, "<repl>", 1, 1); - // Print the top item of the stack - if (ctx->stack.top >= 0) - { - hex_print_item(stdout, ctx->stack.entries[ctx->stack.top]); - // hex_print_item(stdout, HEX_STACK[HEX_TOP]); - printf("\n"); - } - return; - - + // Tokenize and process the input + hex_interpret(ctx, line, "<repl>", 1, 1); + // Print the top item of the stack + if (ctx->stack.top >= 0) + { + hex_print_item(stdout, ctx->stack.entries[ctx->stack.top]); + // hex_print_item(stdout, HEX_STACK[HEX_TOP]); + printf("\n"); + } + return; } // REPL implementation@@ -3902,7 +3905,7 @@ printf(" *\n");
while (1) { - do_repl(ctx); + do_repl(ctx); } #endif }
M
web/assets/styles.css
→
web/assets/styles.css
@@ -55,7 +55,8 @@ color: limegreen;
} a[href^=http] { - text-decoration-style: dashed; + text-decoration-style: dotted; + text-decoration-thickness: from-font; } strong {