From b93722045982a03b571bd3ae10c14b15bd661932 Mon Sep 17 00:00:00 2001 From: Ben Tea Date: Thu, 2 Dec 2021 17:26:40 -0800 Subject: [PATCH 1/2] push @oclif/config dependency resolution changes upstream --- src/config/plugin.ts | 51 +++++++++++++++++++++++++++++++------------- src/config/util.ts | 4 ++++ 2 files changed, 40 insertions(+), 15 deletions(-) diff --git a/src/config/plugin.ts b/src/config/plugin.ts index 73b582877..ac1ad302e 100644 --- a/src/config/plugin.ts +++ b/src/config/plugin.ts @@ -11,7 +11,7 @@ import {Manifest} from '../interfaces/manifest' import {PJSON} from '../interfaces/pjson' import {Topic} from '../interfaces/topic' import {tsPath} from './ts-node' -import {compact, exists, flatMap, loadJSON, mapValues} from './util' +import {compact, exists, resolvePackage, flatMap, loadJSON, mapValues} from './util' import {isProd} from '../util' import ModuleLoader from '../module-loader' @@ -30,25 +30,35 @@ function topicsToArray(input: any, base?: string): Topic[] { }) } -// eslint-disable-next-line valid-jsdoc +// essentially just "cd .." +function * up(from: string) { + while (path.dirname(from) !== from) { + yield from + from = path.dirname(from) + } + yield from +} + +async function findSourcesRoot(root: string) { + for (const next of up(root)) { + const cur = path.join(next, 'package.json') + // eslint-disable-next-line no-await-in-loop + if (await exists(cur)) return path.dirname(cur) + } +} + /** + * @returns string + * @param name string + * @param root string * find package root * for packages installed into node_modules this will go up directories until * it finds a node_modules directory with the plugin installed into it * - * This is needed because of the deduping npm does + * This is needed because some oclif plugins do not declare the `main` field in their package.json + * https://github.com/oclif/config/pull/289#issuecomment-983904051 */ -async function findRoot(name: string | undefined, root: string) { - // essentially just "cd .." - function * up(from: string) { - while (path.dirname(from) !== from) { - yield from - from = path.dirname(from) - } - - yield from - } - +async function findRootLegacy(name: string | undefined, root: string): Promise { for (const next of up(root)) { let cur if (name) { @@ -59,7 +69,7 @@ async function findRoot(name: string | undefined, root: string) { // eslint-disable-next-line no-await-in-loop const pkg = await loadJSON(path.join(next, 'package.json')) if (pkg.name === name) return next - } catch {} + } catch { } } else { cur = path.join(next, 'package.json') // eslint-disable-next-line no-await-in-loop @@ -68,6 +78,17 @@ async function findRoot(name: string | undefined, root: string) { } } +async function findRoot(name: string | undefined, root: string) { + if (name) { + let pkgPath + try { + pkgPath = resolvePackage(name, {paths: [__dirname, root]}) + } catch (error) {} + return pkgPath ? findSourcesRoot(path.dirname(pkgPath)) : findRootLegacy(name, root) + } + return findSourcesRoot(root) +} + export class Plugin implements IPlugin { // static loadedPlugins: {[name: string]: Plugin} = {} _base = `${_pjson.name}@${_pjson.version}` diff --git a/src/config/util.ts b/src/config/util.ts index 0ce2cf78e..a622e03a8 100644 --- a/src/config/util.ts +++ b/src/config/util.ts @@ -19,6 +19,10 @@ export function exists(path: string): Promise { return new Promise(resolve => resolve(fs.existsSync(path))) } +export function resolvePackage(id: string, paths: { paths: string[] }): string { + return require.resolve(id, paths) +} + export function loadJSON(path: string): Promise { debug('config')('loadJSON %s', path) return new Promise((resolve, reject) => { From 7c26ae9ef307eeb58acee7fed355ee772634498c Mon Sep 17 00:00:00 2001 From: Ben Tea Date: Mon, 6 Dec 2021 09:33:19 -0800 Subject: [PATCH 2/2] fix lint --- src/config/plugin.ts | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/config/plugin.ts b/src/config/plugin.ts index ac1ad302e..62387036f 100644 --- a/src/config/plugin.ts +++ b/src/config/plugin.ts @@ -36,6 +36,7 @@ function * up(from: string) { yield from from = path.dirname(from) } + yield from } @@ -69,7 +70,7 @@ async function findRootLegacy(name: string | undefined, root: string): Promise