diff --git a/src/config/plugin.ts b/src/config/plugin.ts index e6ba4e9a3..7d68a7674 100644 --- a/src/config/plugin.ts +++ b/src/config/plugin.ts @@ -343,7 +343,7 @@ export class Plugin implements IPlugin { } private addErrorScope(err: any, scope?: string) { - err.name = `${err.name} Plugin: ${this.name}` + err.name = err.name ?? inspect(err).trim() err.detail = compact([ err.detail, `module: ${this._base}`, @@ -431,6 +431,7 @@ export class Plugin implements IPlugin { private warn(err: CLIError | Error | string, scope?: string): void { if (typeof err === 'string') err = new Error(err) - process.emitWarning(this.addErrorScope(err, scope)) + const warning = this.addErrorScope(err, scope) + process.emitWarning(warning.name, warning) } } diff --git a/src/config/ts-path.ts b/src/config/ts-path.ts index fe1a153fc..a37a094ff 100644 --- a/src/config/ts-path.ts +++ b/src/config/ts-path.ts @@ -1,3 +1,4 @@ +import {access} from 'node:fs/promises' import {join, relative as pathRelative, sep} from 'node:path' import * as TSNode from 'ts-node' @@ -212,8 +213,23 @@ async function determinePath(root: string, orig: string): Promise { debug(`lib dir: ${lib}`) debug(`src dir: ${src}`) - debug(`src commands dir: ${out}`) - if (existsSync(out) || existsSync(out + '.ts')) { + debug(`src directory to find: ${out}`) + + if (existsSync(out)) { + debug(`Found source directory for ${orig} at ${out}`) + return out + } + + const sourceFiles = await Promise.all([ + access(`${out}.ts`) + .then(() => `${out}.ts`) + .catch(() => false), + access(`${out}.tsx`) + .then(() => `${out}.tsx`) + .catch(() => false), + ]) + + if (sourceFiles.some(Boolean)) { debug(`Found source file for ${orig} at ${out}`) return out }