From a6078d1d4852a4c70e49840eebc5f1fdeca0fe0e Mon Sep 17 00:00:00 2001 From: Thomas Dvornik Date: Mon, 18 Jun 2018 13:09:38 -0600 Subject: [PATCH] fix: add rootDir from tsconfig for plugins that use it (#39) * fix: add rootDir from tsconfig for plugins that use it * fix: use better conditional format which defaults to rootDir --- src/ts_node.ts | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/ts_node.ts b/src/ts_node.ts index b07cdf7c..64570cde 100644 --- a/src/ts_node.ts +++ b/src/ts_node.ts @@ -13,6 +13,7 @@ const debug = Debug() export interface TSConfig { compilerOptions: { + rootDir?: string rootDirs?: string[] outDir?: string target?: string @@ -82,12 +83,12 @@ export function tsPath(root: string, orig: string | undefined): string | undefin registerTSNode(root) const tsconfig = tsconfigs[root] if (!tsconfig) return orig - const {rootDirs, outDir} = tsconfig.compilerOptions - const rootDir = (rootDirs || [])[0] - if (!rootDir || !outDir) return orig + const {rootDir, rootDirs, outDir} = tsconfig.compilerOptions + const rootDirPath = rootDir || (rootDirs || [])[0] + if (!rootDirPath || !outDir) return orig // rewrite path from ./lib/foo to ./src/foo const lib = path.join(root, outDir) // ./lib - const src = path.join(root, rootDir) // ./src + const src = path.join(root, rootDirPath) // ./src const relative = path.relative(lib, orig) // ./commands const out = path.join(src, relative) // ./src/commands // this can be a directory of commands or point to a hook file