From 1f3c45bfe872b90c1eaef740e4acf9ca3a68e711 Mon Sep 17 00:00:00 2001 From: Ju / smwhr Date: Sat, 16 Nov 2024 21:54:12 +0100 Subject: [PATCH 1/2] Add -s flag to inkjs-compiler --- script/inkjs-compiler.ts | 25 ++++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/script/inkjs-compiler.ts b/script/inkjs-compiler.ts index c26659d2..7a1c3492 100644 --- a/script/inkjs-compiler.ts +++ b/script/inkjs-compiler.ts @@ -4,6 +4,7 @@ import { Compiler } from '../src/compiler/Compiler'; import { CompilerOptions } from '../src/compiler/CompilerOptions'; import { Story } from '../src/engine/Story'; import { PosixFileHandler } from '../src/compiler/FileHandler/PosixFileHandler'; +import { Stats } from '../src/compiler/Stats'; var readline = require('readline'); var path = require('path'); @@ -20,11 +21,16 @@ Usage: inkjs-compiler -c: Count all visits to knots, stitches and weave points, not just those referenced by TURNS_SINCE and read counts. -p: Play mode (automatic if a json file is passed as argument) + -s: Print stats about story including word count in JSON format + -k: Keep inklecate running in play mode even after story is complete `); process.exit(0); } const countAllVisit = process.argv.includes("-c"); +let printStats = process.argv.includes("-s"); +let statsResults: Stats|null = null + let play = process.argv.includes("-p") || process.argv.includes("-k"); const write = !process.argv.includes("-k") && !process.argv.includes("-p"); const explicitOutput = process.argv.includes("-o"); @@ -33,7 +39,7 @@ if(explicitOutput){ const opos = process.argv.indexOf("-o") + 1; outputfile = process.argv.splice(opos, 1)[0]; } -process.argv = process.argv.filter(p => !['-c', '-o', '-p', '-k'].includes(p)); +process.argv = process.argv.filter(p => !['-c', '-o', '-p', '-k', '-s'].includes(p)); const inputFile = process.argv[2] || null; if(!inputFile){ @@ -62,6 +68,11 @@ if(!inputFile.endsWith(".json")){ process.stderr.write("*** Compilation failed ***\n"); process.exit(1); } + + if(printStats){ + statsResults = c.GenerateStats() + } + let jsonified: string | void; if((jsonified = rstory.ToJson())){ @@ -72,10 +83,22 @@ if(!inputFile.endsWith(".json")){ fs.writeFileSync(outputfile, BOM+jsonStory); } }else{ + if(printStats){ + process.stderr.write("warning: Could not generate stats for an already compiled story. Try it on a .ink file instead." + "\n"); + printStats = false; + } + jsonStory = fs.readFileSync(inputFile,"utf-8").replace(BOM, "") play = true; } +if(jsonStory && !play && printStats && statsResults){ + Object.entries(statsResults).forEach(([w, n]) => { + const capitalizedW = w.charAt(0).toUpperCase() + w.slice(1) + process.stdout.write(`${capitalizedW}: ${n}\n`) + }); +} + if(jsonStory && play){ const rl = readline.createInterface({ input: process.stdin, //or fileStream From ba1ae45e5435242ba70ef377aa92450699655d2b Mon Sep 17 00:00:00 2001 From: Ju / smwhr Date: Sat, 16 Nov 2024 22:12:03 +0100 Subject: [PATCH 2/2] catch js Error on failed compilation --- script/inkjs-compiler.ts | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/script/inkjs-compiler.ts b/script/inkjs-compiler.ts index 7a1c3492..f788791b 100644 --- a/script/inkjs-compiler.ts +++ b/script/inkjs-compiler.ts @@ -63,9 +63,14 @@ if(!inputFile.endsWith(".json")){ ) const c = new Compiler(mainInk, options); - const rstory = c.Compile(); + let rstory:Story|null = null; + try { + rstory = c.Compile(); + } catch (error: unknown) { + if((error as Error).message != "Compilation failed.") throw error; //re-throw if an illegitimate js error + } + if (!rstory) { - process.stderr.write("*** Compilation failed ***\n"); process.exit(1); } @@ -84,7 +89,7 @@ if(!inputFile.endsWith(".json")){ } }else{ if(printStats){ - process.stderr.write("warning: Could not generate stats for an already compiled story. Try it on a .ink file instead." + "\n"); + process.stderr.write("WARNING: Could not generate stats for an already compiled story. Try it on a .ink file instead." + "\n"); printStats = false; }