From 3dc22c7f0dd185bf853b1f9b3b5b45f431587827 Mon Sep 17 00:00:00 2001 From: Charles Pierce Date: Thu, 18 Mar 2021 16:38:19 -0700 Subject: [PATCH] Exclude peerDependencies from Engines 'app' directory --- packages/compat/src/compat-app.ts | 2 +- packages/compat/src/moved-package-cache.ts | 3 +++ packages/core/src/package.ts | 15 +++++++++++++-- 3 files changed, 17 insertions(+), 3 deletions(-) diff --git a/packages/compat/src/compat-app.ts b/packages/compat/src/compat-app.ts index ad91ff66b0..64eb0ddb88 100644 --- a/packages/compat/src/compat-app.ts +++ b/packages/compat/src/compat-app.ts @@ -175,7 +175,7 @@ class CompatAppAdapter implements AppAdapter { @Memoize() activeAddonChildren(pkg: Package = this.appPackage): AddonPackage[] { - let result = pkg.dependencies.filter(this.isActiveAddon) as AddonPackage[]; + let result = pkg.addonDependencies.filter(this.isActiveAddon) as AddonPackage[]; if (pkg === this.appPackage) { let extras = [this.synthVendor, this.synthStyles].filter(this.isActiveAddon) as AddonPackage[]; result = [...result, ...extras]; diff --git a/packages/compat/src/moved-package-cache.ts b/packages/compat/src/moved-package-cache.ts index 30619deeb0..b84908f9d2 100644 --- a/packages/compat/src/moved-package-cache.ts +++ b/packages/compat/src/moved-package-cache.ts @@ -314,6 +314,9 @@ function packageProxy(pkg: Package, getMovedPackage: (pkg: Package) => Package) if (prop === 'dependencies') { return pkg.dependencies.map(getMovedPackage); } + if (prop === 'addonDependencies') { + return pkg.addonDependencies.map(getMovedPackage); + } if (prop === 'nonResolvableDeps') { if (!pkg.nonResolvableDeps) { return pkg.nonResolvableDeps; diff --git a/packages/core/src/package.ts b/packages/core/src/package.ts index 13e907df52..9c2f24fb5c 100644 --- a/packages/core/src/package.ts +++ b/packages/core/src/package.ts @@ -167,11 +167,22 @@ export default class Package { @Memoize() get dependencies(): Package[] { - let names = flatMap(this.dependencyKeys, key => Object.keys(this.packageJSON[key] || {})); + return this.loadDependencies(this.dependencyKeys); + } + + @Memoize() + get addonDependencies(): Package[] { + // When looking for child addons, we want to ignore 'peerDependencies' of a given package, to + // align with how ember-cli resolves addons + return this.loadDependencies(this.dependencyKeys.filter(key => key !== 'peerDependencies')); + } + + loadDependencies(keys: ('dependencies' | 'devDependencies' | 'peerDependencies')[]): Package[] { + const names = flatMap(keys, key => Object.keys(this.packageJSON[key] || {})); return names .map(name => { if (this.nonResolvableDeps) { - let dep = this.nonResolvableDeps.get(name); + const dep = this.nonResolvableDeps.get(name); if (dep) { return dep; }