From faf2de3b09694f08f3e23162524759d8af108671 Mon Sep 17 00:00:00 2001 From: James Yu Date: Thu, 2 Nov 2023 19:20:40 +0000 Subject: [PATCH] Fix #4048 Gracefully fail mkdirSync --- src/components/builder.ts | 29 +++++++++++++++++------------ 1 file changed, 17 insertions(+), 12 deletions(-) diff --git a/src/components/builder.ts b/src/components/builder.ts index b82a20733..57f3fa60a 100644 --- a/src/components/builder.ts +++ b/src/components/builder.ts @@ -677,21 +677,26 @@ export class Builder { outDir = path.resolve(rootDir, outDir) } logger.log(`outDir: ${outDir} .`) - try { - lw.cacher.getIncludedTeX(rootFile).forEach(file => { - const relativePath = path.dirname(file.replace(rootDir, '.')) - const fullOutDir = path.resolve(outDir, relativePath) - // To avoid issues when fullOutDir is the root dir - // Using fs.mkdir() on the root directory even with recursion will result in an error + lw.cacher.getIncludedTeX(rootFile).forEach(file => { + const relativePath = path.dirname(file.replace(rootDir, '.')) + const fullOutDir = path.resolve(outDir, relativePath) + // To avoid issues when fullOutDir is the root dir + // Using fs.mkdir() on the root directory even with recursion will result in an error + try { if (! (fs.existsSync(fullOutDir) && fs.statSync(fullOutDir).isDirectory())) { fs.mkdirSync(fullOutDir, { recursive: true }) } - }) - } catch (e) { - logger.log('Unexpected Error: please see the console log of the Developer Tools of VS Code.') - logger.refreshStatus('x', 'errorForeground') - throw(e) - } + } catch (e) { + if (e instanceof Error) { + // #4048 + logger.log(`Unexpected Error: ${e.name}: ${e.message} .`) + } else { + logger.log('Unexpected Error: please see the console log of the Developer Tools of VS Code.') + logger.refreshStatus('x', 'errorForeground') + throw(e) + } + } + }) } }