From f7b181d4f1c47cc8f5568ef328c61df9b02d4684 Mon Sep 17 00:00:00 2001 From: Federico Ponzi Date: Thu, 31 Oct 2024 20:09:21 +0000 Subject: [PATCH] PDF Generation: feature parity with the toolbox Signed-off-by: Federico Ponzi --- package.json | 26 +++++++++++++++ src/tla2tools.ts | 32 ++++++++++++++++++- .../checkResultView/headerSection/index.tsx | 3 +- 3 files changed, 59 insertions(+), 2 deletions(-) diff --git a/package.json b/package.json index 5ed2b3e..0b1179a 100644 --- a/package.json +++ b/package.json @@ -382,6 +382,31 @@ "maxLength": 1000, "description": "Command to produce PDFs from .tex files." }, + "tlaplus.pdf.commentsShade": { + "default": true, + "type": "boolean", + "scope": "application", + "description": "If enabled, comments will have a gray background." + }, + "tlaplus.pdf.commentsShadeColor": { + "default": 0.85, + "type": "number", + "scope": "application", + "maxLength": 10, + "description": "If comments are shaded in gray, this config changes the darkness of the shading. This must be a number between 0.0 (completely black) and 1.0 (no shading)." + }, + "tlaplus.pdf.numberLines": { + "default": false, + "type": "boolean", + "scope": "application", + "description": "Show line numbers in PDFs." + }, + "tlaplus.pdf.noPcalShade": { + "default": false, + "type": "boolean", + "scope": "application", + "description": "Causes a PlusCal algorithm (which appear in a comment) not to be shaded. (The algorithm's comments will be shaded.)" + }, "tlaplus.tlaps.enabled": { "type": "boolean", "default": false, @@ -504,6 +529,7 @@ "vscode:prepublish": "npm run compile -- --production", "compile": "node ./esbuild.js", "lint": "eslint --ext .ts,.tsx src/ tests/", + "lint:fix": "eslint --fix --ext .ts,.tsx src/ tests/", "watch": "npm run compile -- --watch", "pretest": "tsc -p ./", "test": "node ./out/tests/runTest.js", diff --git a/src/tla2tools.ts b/src/tla2tools.ts index 36571a6..fe65ca4 100644 --- a/src/tla2tools.ts +++ b/src/tla2tools.ts @@ -17,6 +17,10 @@ const CFG_JAVA_OPTIONS = 'tlaplus.java.options'; const CFG_TLC_OPTIONS = 'tlaplus.tlc.modelChecker.options'; const CFG_PLUSCAL_OPTIONS = 'tlaplus.pluscal.options'; const CFG_TLC_OPTIONS_PROMPT = 'tlaplus.tlc.modelChecker.optionsPrompt'; +const CFG_TLA_PDF_NUMBER_LINES = 'tlaplus.pdf.numberLines'; +const CFG_TLA_PDF_NO_PCAL_SHADE = 'tlaplus.pdf.noPcalShade'; +const CFG_TLA_PDF_COMMENTS_SHADE = 'tlaplus.pdf.commentsShade'; +const CFG_TLA_PDF_COMMENTS_SHADE_COLOR = 'tlaplus.pdf.commentsShadeColor'; const VAR_TLC_SPEC_NAME = /\$\{specName\}/g; const VAR_TLC_MODEL_NAME = /\$\{modelName\}/g; @@ -102,10 +106,34 @@ export async function runSany(tlaFilePath: string): Promise { } export async function runTex(tlaFilePath: string): Promise { + const shadeComments = vscode.workspace.getConfiguration().get(CFG_TLA_PDF_COMMENTS_SHADE, true); + const commentColor = vscode.workspace.getConfiguration().get(CFG_TLA_PDF_COMMENTS_SHADE_COLOR, 0.85); + const numberLines = vscode.workspace.getConfiguration().get(CFG_TLA_PDF_NUMBER_LINES, false); + const noPcalShade = vscode.workspace.getConfiguration().get(CFG_TLA_PDF_NO_PCAL_SHADE, false); + + const toolArgs = ['-metadir', + path.dirname(tlaFilePath), + path.basename(tlaFilePath)]; + + if (shadeComments) { + toolArgs.unshift('-nops', + '-shade', + '-grayLevel', + commentColor.toString()); + } + + if (numberLines) { + toolArgs.unshift('-number'); + } + + if (noPcalShade) { + toolArgs.unshift('-noPcalShade'); + } + return runTool( TlaTool.TEX, tlaFilePath, - [ path.basename(tlaFilePath) ], + toolArgs, [] ); } @@ -148,6 +176,8 @@ async function runTool( toolOptions: string[], javaOptions: string[] ): Promise { + // log the arugments: + //console.log(toolName + ': ' + filePath + ' ' + toolOptions.join(' ') + ' ' + javaOptions.join(' ')); const javaPath = await obtainJavaPath(); // TODO: Merge cfgOptions with javaOptions to avoid complete overrides. const cfgOptions = getConfigOptions(CFG_JAVA_OPTIONS); diff --git a/src/webview/checkResultView/headerSection/index.tsx b/src/webview/checkResultView/headerSection/index.tsx index 1e56e75..79a9c21 100644 --- a/src/webview/checkResultView/headerSection/index.tsx +++ b/src/webview/checkResultView/headerSection/index.tsx @@ -34,7 +34,8 @@ export const HeaderSection = React.memo(({checkResult}: HeaderSectionI) => { - +
Start: {checkResult.startDateTimeStr}, end: {checkResult.endDateTimeStr}