@embroider/core 3.4.9-unstable.efd6c9a → 3.4.10-unstable.14b84ff
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +6 -5
- package/src/app-files.d.ts +1 -1
- package/src/app-files.js +9 -2
- package/src/app-files.js.map +1 -1
- package/src/asset.d.ts +0 -6
- package/src/asset.js.map +1 -1
- package/src/ember-html.d.ts +1 -6
- package/src/ember-html.js +7 -18
- package/src/ember-html.js.map +1 -1
- package/src/index.d.ts +1 -1
- package/src/index.js.map +1 -1
- package/src/module-resolver.d.ts +5 -0
- package/src/module-resolver.js +50 -2
- package/src/module-resolver.js.map +1 -1
- package/src/virtual-content.js +10 -0
- package/src/virtual-content.js.map +1 -1
- package/src/virtual-entrypoint.d.ts +19 -0
- package/src/virtual-entrypoint.js +316 -0
- package/src/virtual-entrypoint.js.map +1 -0
- package/src/virtual-route-entrypoint.d.ts +15 -0
- package/src/virtual-route-entrypoint.js +102 -0
- package/src/virtual-route-entrypoint.js.map +1 -0
- package/src/virtual-vendor-styles.js +29 -18
- package/src/virtual-vendor-styles.js.map +1 -1
    
        package/package.json
    CHANGED
    
    | @@ -1,6 +1,6 @@ | |
| 1 1 | 
             
            {
         | 
| 2 2 | 
             
              "name": "@embroider/core",
         | 
| 3 | 
            -
              "version": "3.4. | 
| 3 | 
            +
              "version": "3.4.10-unstable.14b84ff",
         | 
| 4 4 | 
             
              "private": false,
         | 
| 5 5 | 
             
              "description": "A build system for EmberJS applications.",
         | 
| 6 6 | 
             
              "repository": {
         | 
| @@ -23,8 +23,9 @@ | |
| 23 23 | 
             
                "@babel/core": "^7.14.5",
         | 
| 24 24 | 
             
                "@babel/parser": "^7.14.5",
         | 
| 25 25 | 
             
                "@babel/traverse": "^7.14.5",
         | 
| 26 | 
            -
                "@embroider/macros": "1.16. | 
| 27 | 
            -
                "@embroider/ | 
| 26 | 
            +
                "@embroider/macros": "1.16.2-unstable.14b84ff",
         | 
| 27 | 
            +
                "@embroider/reverse-exports": "0.1.1-unstable.14b84ff",
         | 
| 28 | 
            +
                "@embroider/shared-internals": "2.6.1-unstable.14b84ff",
         | 
| 28 29 | 
             
                "assert-never": "^1.2.1",
         | 
| 29 30 | 
             
                "babel-plugin-ember-template-compilation": "^2.1.1",
         | 
| 30 31 | 
             
                "broccoli-node-api": "^1.7.0",
         | 
| @@ -32,6 +33,7 @@ | |
| 32 33 | 
             
                "broccoli-plugin": "^4.0.7",
         | 
| 33 34 | 
             
                "broccoli-source": "^3.0.1",
         | 
| 34 35 | 
             
                "debug": "^4.3.2",
         | 
| 36 | 
            +
                "escape-string-regexp": "^4.0.0",
         | 
| 35 37 | 
             
                "fast-sourcemap-concat": "^1.4.0",
         | 
| 36 38 | 
             
                "filesize": "^10.0.7",
         | 
| 37 39 | 
             
                "fs-extra": "^9.1.0",
         | 
| @@ -43,7 +45,6 @@ | |
| 43 45 | 
             
                "resolve": "^1.20.0",
         | 
| 44 46 | 
             
                "resolve-package-path": "^4.0.1",
         | 
| 45 47 | 
             
                "resolve.exports": "^2.0.2",
         | 
| 46 | 
            -
                "@embroider/reverse-exports": "0.1.1-unstable.efd6c9a",
         | 
| 47 48 | 
             
                "typescript-memoize": "^1.0.1",
         | 
| 48 49 | 
             
                "walk-sync": "^3.0.0"
         | 
| 49 50 | 
             
              },
         | 
| @@ -56,8 +57,8 @@ | |
| 56 57 | 
             
                "@types/babel__traverse": "^7.18.5",
         | 
| 57 58 | 
             
                "@types/debug": "^4.1.5",
         | 
| 58 59 | 
             
                "@types/fs-extra": "^9.0.12",
         | 
| 59 | 
            -
                "@types/jsdom": "^16.2.11",
         | 
| 60 60 | 
             
                "@types/js-string-escape": "^1.0.0",
         | 
| 61 | 
            +
                "@types/jsdom": "^16.2.11",
         | 
| 61 62 | 
             
                "@types/lodash": "^4.14.170",
         | 
| 62 63 | 
             
                "@types/node": "^15.12.2",
         | 
| 63 64 | 
             
                "@types/resolve": "^1.20.0",
         | 
    
        package/src/app-files.d.ts
    CHANGED
    
    | @@ -20,7 +20,7 @@ export declare class AppFiles { | |
| 20 20 | 
             
                        shadowedFilename: string | undefined;
         | 
| 21 21 | 
             
                    };
         | 
| 22 22 | 
             
                };
         | 
| 23 | 
            -
                constructor(engine: Engine, appFiles: Set<string>, fastbootFiles: Set<string>, resolvableExtensions: RegExp, podModulePrefix?: string);
         | 
| 23 | 
            +
                constructor(engine: Engine, appFiles: Set<string>, fastbootFiles: Set<string>, resolvableExtensions: RegExp, staticAppPathsPattern: RegExp | undefined, podModulePrefix?: string);
         | 
| 24 24 | 
             
                private handleClassicRouteFile;
         | 
| 25 25 | 
             
                private handlePodsRouteFile;
         | 
| 26 26 | 
             
                get routeFiles(): Readonly<RouteFiles>;
         | 
    
        package/src/app-files.js
    CHANGED
    
    | @@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | |
| 3 3 | 
             
            exports.AppFiles = void 0;
         | 
| 4 4 | 
             
            const path_1 = require("path");
         | 
| 5 5 | 
             
            class AppFiles {
         | 
| 6 | 
            -
                constructor(engine, appFiles, fastbootFiles, resolvableExtensions, podModulePrefix) {
         | 
| 6 | 
            +
                constructor(engine, appFiles, fastbootFiles, resolvableExtensions, staticAppPathsPattern, podModulePrefix) {
         | 
| 7 7 | 
             
                    this.engine = engine;
         | 
| 8 8 | 
             
                    let tests = [];
         | 
| 9 9 | 
             
                    let components = [];
         | 
| @@ -79,7 +79,14 @@ class AppFiles { | |
| 79 79 | 
             
                            this.handleClassicRouteFile(relativePath)) {
         | 
| 80 80 | 
             
                            continue;
         | 
| 81 81 | 
             
                        }
         | 
| 82 | 
            -
                         | 
| 82 | 
            +
                        if (staticAppPathsPattern) {
         | 
| 83 | 
            +
                            if (!staticAppPathsPattern.test(relativePath)) {
         | 
| 84 | 
            +
                                otherAppFiles.push(relativePath);
         | 
| 85 | 
            +
                            }
         | 
| 86 | 
            +
                        }
         | 
| 87 | 
            +
                        else {
         | 
| 88 | 
            +
                            otherAppFiles.push(relativePath);
         | 
| 89 | 
            +
                        }
         | 
| 83 90 | 
             
                    }
         | 
| 84 91 | 
             
                    this.tests = tests;
         | 
| 85 92 | 
             
                    this.components = components;
         | 
    
        package/src/app-files.js.map
    CHANGED
    
    | @@ -1 +1 @@ | |
| 1 | 
            -
            {"version":3,"file":"app-files.js","sourceRoot":"","sources":["app-files.ts"],"names":[],"mappings":"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","sourcesContent":["import { sep } from 'path';\nimport type { Package, AddonPackage } from '@embroider/shared-internals';\n\nexport interface RouteFiles {\n  route?: string;\n  template?: string;\n  controller?: string;\n  children: Map<string, RouteFiles>;\n}\n\nexport class AppFiles {\n  readonly tests: ReadonlyArray<string>;\n  readonly components: ReadonlyArray<string>;\n  readonly helpers: ReadonlyArray<string>;\n  readonly modifiers: ReadonlyArray<string>;\n  private perRoute: RouteFiles;\n  readonly otherAppFiles: ReadonlyArray<string>;\n  readonly isFastbootOnly: Map<string, boolean>;\n  readonly fastbootFiles: { [appName: string]: { localFilename: string; shadowedFilename: string | undefined } };\n\n  constructor(\n    readonly engine: Engine,\n    appFiles: Set<string>,\n    fastbootFiles: Set<string>,\n    resolvableExtensions: RegExp,\n    podModulePrefix?: string\n  ) {\n    let tests: string[] = [];\n    let components: string[] = [];\n    let helpers: string[] = [];\n    let modifiers: string[] = [];\n    let otherAppFiles: string[] = [];\n    this.perRoute = { children: new Map() };\n\n    let combinedFiles = new Set<string>();\n    let combinedNonFastbootFiles = new Set<string>();\n    let isFastbootOnly = new Map<string, boolean>();\n\n    for (let f of appFiles) {\n      combinedFiles.add(f);\n      combinedNonFastbootFiles.add(f);\n    }\n    for (let f of fastbootFiles) {\n      combinedFiles.add(f);\n    }\n\n    for (let addon of engine.addons.keys()) {\n      let appJS = addon.meta['app-js'];\n      if (appJS) {\n        for (let filename of Object.keys(appJS)) {\n          filename = filename.replace(/^\\.\\//, '');\n          combinedFiles.add(filename);\n          combinedNonFastbootFiles.add(filename);\n        }\n      }\n\n      let fastbootJS = addon.meta['fastboot-js'];\n      if (fastbootJS) {\n        for (let filename of Object.keys(fastbootJS)) {\n          filename = filename.replace(/^\\.\\//, '');\n          combinedFiles.add(filename);\n        }\n      }\n    }\n\n    for (let relativePath of combinedFiles) {\n      isFastbootOnly.set(relativePath, !combinedNonFastbootFiles.has(relativePath));\n      relativePath = relativePath.split(sep).join('/');\n      if (!resolvableExtensions.test(relativePath)) {\n        continue;\n      }\n\n      if (/\\.d\\.ts$/.test(relativePath)) {\n        // .d.ts files are technically \"*.ts\" files but aren't really and we\n        // don't want to include them when we crawl through the app.\n        continue;\n      }\n\n      if (relativePath.startsWith('tests/')) {\n        tests.push(relativePath);\n        continue;\n      }\n\n      if (relativePath.startsWith('components/')) {\n        // hbs files are resolvable, but not when they're used via co-location.\n        // An hbs file is used via colocation when it's inside the components\n        // directory, and also not named \"template.hbs\" (because that is an\n        // older pattern used with pods-like layouts).\n        if (!relativePath.endsWith('.hbs') || relativePath.endsWith('/template.hbs')) {\n          components.push(relativePath);\n        }\n        continue;\n      }\n\n      if (relativePath.startsWith('templates/components/')) {\n        components.push(relativePath);\n        continue;\n      }\n\n      if (relativePath.startsWith('helpers/')) {\n        helpers.push(relativePath);\n        continue;\n      }\n\n      if (relativePath.startsWith('modifiers/')) {\n        modifiers.push(relativePath);\n        continue;\n      }\n\n      if (\n        (podModulePrefix !== undefined && this.handlePodsRouteFile(relativePath, podModulePrefix)) ||\n        this.handleClassicRouteFile(relativePath)\n      ) {\n        continue;\n      }\n\n      otherAppFiles.push(relativePath);\n    }\n    this.tests = tests;\n    this.components = components;\n    this.helpers = helpers;\n    this.modifiers = modifiers;\n    this.otherAppFiles = otherAppFiles;\n    this.isFastbootOnly = isFastbootOnly;\n\n    // this deliberately only describes the app's fastboot files. Not the full\n    // merge from all the addons. This is because they need different handling\n    // in the module resolver -- addon fastboot files can always be a\n    // fallbackResolve, because if the app happens to define the same name\n    // (whether fastboot-specific or just browser) that wins over the addon.\n    // Whereas if the app itself defines a fastbot-specific version of a file,\n    // that must take precedence over the *normal* resolution, and must be\n    // implemented in beforeResolve.\n    this.fastbootFiles = Object.fromEntries(\n      [...fastbootFiles].map(name => [\n        `./${name}`,\n        {\n          localFilename: `./_fastboot_/${name}`,\n          shadowedFilename: appFiles.has(name) ? `./${name}` : undefined,\n        },\n      ])\n    );\n  }\n\n  private handleClassicRouteFile(relativePath: string): boolean {\n    let [prefix, ...rest] = relativePath.replace(/\\.\\w{1,3}$/, '').split('/');\n    if (!['controllers', 'templates', 'routes'].includes(prefix)) {\n      return false;\n    }\n    let type = prefix.slice(0, -1) as 'controller' | 'template' | 'route';\n    let cursor = this.perRoute;\n    for (let part of rest) {\n      let child = cursor.children.get(part);\n      if (child) {\n        cursor = child;\n      } else {\n        let newEntry = { children: new Map() };\n        cursor.children.set(part, newEntry);\n        cursor = newEntry;\n      }\n    }\n    cursor[type] = relativePath;\n    return true;\n  }\n\n  private handlePodsRouteFile(relativePath: string, podModulePrefix: string): boolean {\n    let parts = relativePath.replace(/\\.\\w{1,3}$/, '').split('/');\n    let type = parts.pop();\n    if (!type || !['controller', 'template', 'route'].includes(type)) {\n      return false;\n    }\n    let podParts = podModulePrefix.split('/');\n    // The first part of podModulePrefix is the app's package name\n    podParts.shift();\n\n    for (let podPart of podParts) {\n      if (parts.shift() !== podPart) {\n        return false;\n      }\n    }\n\n    let cursor = this.perRoute;\n    for (let part of parts) {\n      let child = cursor.children.get(part);\n      if (child) {\n        cursor = child;\n      } else {\n        let newEntry = { children: new Map() };\n        cursor.children.set(part, newEntry);\n        cursor = newEntry;\n      }\n    }\n    cursor[type as 'controller' | 'template' | 'route'] = relativePath;\n    return true;\n  }\n\n  get routeFiles(): Readonly<RouteFiles> {\n    return this.perRoute;\n  }\n}\n\nexport interface Engine {\n  // the engine's own package\n  package: Package;\n  // the set of active addons in the engine. For each one we keep track of a file that can resolve the addon, because we'll need that later.\n  addons: Map<AddonPackage, string>;\n  // is this the top-level engine?\n  isApp: boolean;\n  // runtime name for the engine's own module namespace\n  modulePrefix: string;\n  // TODO: remove this after we remove the stage2 entrypoint\n  appRelativePath: string;\n}\n"]}
         | 
| 1 | 
            +
            {"version":3,"file":"app-files.js","sourceRoot":"","sources":["app-files.ts"],"names":[],"mappings":"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","sourcesContent":["import { sep } from 'path';\nimport type { Package, AddonPackage } from '@embroider/shared-internals';\n\nexport interface RouteFiles {\n  route?: string;\n  template?: string;\n  controller?: string;\n  children: Map<string, RouteFiles>;\n}\n\nexport class AppFiles {\n  readonly tests: ReadonlyArray<string>;\n  readonly components: ReadonlyArray<string>;\n  readonly helpers: ReadonlyArray<string>;\n  readonly modifiers: ReadonlyArray<string>;\n  private perRoute: RouteFiles;\n  readonly otherAppFiles: ReadonlyArray<string>;\n  readonly isFastbootOnly: Map<string, boolean>;\n  readonly fastbootFiles: { [appName: string]: { localFilename: string; shadowedFilename: string | undefined } };\n\n  constructor(\n    readonly engine: Engine,\n    appFiles: Set<string>,\n    fastbootFiles: Set<string>,\n    resolvableExtensions: RegExp,\n    staticAppPathsPattern: RegExp | undefined,\n    podModulePrefix?: string\n  ) {\n    let tests: string[] = [];\n    let components: string[] = [];\n    let helpers: string[] = [];\n    let modifiers: string[] = [];\n    let otherAppFiles: string[] = [];\n    this.perRoute = { children: new Map() };\n\n    let combinedFiles = new Set<string>();\n    let combinedNonFastbootFiles = new Set<string>();\n    let isFastbootOnly = new Map<string, boolean>();\n\n    for (let f of appFiles) {\n      combinedFiles.add(f);\n      combinedNonFastbootFiles.add(f);\n    }\n    for (let f of fastbootFiles) {\n      combinedFiles.add(f);\n    }\n\n    for (let addon of engine.addons.keys()) {\n      let appJS = addon.meta['app-js'];\n      if (appJS) {\n        for (let filename of Object.keys(appJS)) {\n          filename = filename.replace(/^\\.\\//, '');\n          combinedFiles.add(filename);\n          combinedNonFastbootFiles.add(filename);\n        }\n      }\n\n      let fastbootJS = addon.meta['fastboot-js'];\n      if (fastbootJS) {\n        for (let filename of Object.keys(fastbootJS)) {\n          filename = filename.replace(/^\\.\\//, '');\n          combinedFiles.add(filename);\n        }\n      }\n    }\n\n    for (let relativePath of combinedFiles) {\n      isFastbootOnly.set(relativePath, !combinedNonFastbootFiles.has(relativePath));\n      relativePath = relativePath.split(sep).join('/');\n      if (!resolvableExtensions.test(relativePath)) {\n        continue;\n      }\n\n      if (/\\.d\\.ts$/.test(relativePath)) {\n        // .d.ts files are technically \"*.ts\" files but aren't really and we\n        // don't want to include them when we crawl through the app.\n        continue;\n      }\n\n      if (relativePath.startsWith('tests/')) {\n        tests.push(relativePath);\n        continue;\n      }\n\n      if (relativePath.startsWith('components/')) {\n        // hbs files are resolvable, but not when they're used via co-location.\n        // An hbs file is used via colocation when it's inside the components\n        // directory, and also not named \"template.hbs\" (because that is an\n        // older pattern used with pods-like layouts).\n        if (!relativePath.endsWith('.hbs') || relativePath.endsWith('/template.hbs')) {\n          components.push(relativePath);\n        }\n        continue;\n      }\n\n      if (relativePath.startsWith('templates/components/')) {\n        components.push(relativePath);\n        continue;\n      }\n\n      if (relativePath.startsWith('helpers/')) {\n        helpers.push(relativePath);\n        continue;\n      }\n\n      if (relativePath.startsWith('modifiers/')) {\n        modifiers.push(relativePath);\n        continue;\n      }\n\n      if (\n        (podModulePrefix !== undefined && this.handlePodsRouteFile(relativePath, podModulePrefix)) ||\n        this.handleClassicRouteFile(relativePath)\n      ) {\n        continue;\n      }\n\n      if (staticAppPathsPattern) {\n        if (!staticAppPathsPattern.test(relativePath)) {\n          otherAppFiles.push(relativePath);\n        }\n      } else {\n        otherAppFiles.push(relativePath);\n      }\n    }\n    this.tests = tests;\n    this.components = components;\n    this.helpers = helpers;\n    this.modifiers = modifiers;\n    this.otherAppFiles = otherAppFiles;\n    this.isFastbootOnly = isFastbootOnly;\n\n    // this deliberately only describes the app's fastboot files. Not the full\n    // merge from all the addons. This is because they need different handling\n    // in the module resolver -- addon fastboot files can always be a\n    // fallbackResolve, because if the app happens to define the same name\n    // (whether fastboot-specific or just browser) that wins over the addon.\n    // Whereas if the app itself defines a fastbot-specific version of a file,\n    // that must take precedence over the *normal* resolution, and must be\n    // implemented in beforeResolve.\n    this.fastbootFiles = Object.fromEntries(\n      [...fastbootFiles].map(name => [\n        `./${name}`,\n        {\n          localFilename: `./_fastboot_/${name}`,\n          shadowedFilename: appFiles.has(name) ? `./${name}` : undefined,\n        },\n      ])\n    );\n  }\n\n  private handleClassicRouteFile(relativePath: string): boolean {\n    let [prefix, ...rest] = relativePath.replace(/\\.\\w{1,3}$/, '').split('/');\n    if (!['controllers', 'templates', 'routes'].includes(prefix)) {\n      return false;\n    }\n    let type = prefix.slice(0, -1) as 'controller' | 'template' | 'route';\n    let cursor = this.perRoute;\n    for (let part of rest) {\n      let child = cursor.children.get(part);\n      if (child) {\n        cursor = child;\n      } else {\n        let newEntry = { children: new Map() };\n        cursor.children.set(part, newEntry);\n        cursor = newEntry;\n      }\n    }\n    cursor[type] = relativePath;\n    return true;\n  }\n\n  private handlePodsRouteFile(relativePath: string, podModulePrefix: string): boolean {\n    let parts = relativePath.replace(/\\.\\w{1,3}$/, '').split('/');\n    let type = parts.pop();\n    if (!type || !['controller', 'template', 'route'].includes(type)) {\n      return false;\n    }\n    let podParts = podModulePrefix.split('/');\n    // The first part of podModulePrefix is the app's package name\n    podParts.shift();\n\n    for (let podPart of podParts) {\n      if (parts.shift() !== podPart) {\n        return false;\n      }\n    }\n\n    let cursor = this.perRoute;\n    for (let part of parts) {\n      let child = cursor.children.get(part);\n      if (child) {\n        cursor = child;\n      } else {\n        let newEntry = { children: new Map() };\n        cursor.children.set(part, newEntry);\n        cursor = newEntry;\n      }\n    }\n    cursor[type as 'controller' | 'template' | 'route'] = relativePath;\n    return true;\n  }\n\n  get routeFiles(): Readonly<RouteFiles> {\n    return this.perRoute;\n  }\n}\n\nexport interface Engine {\n  // the engine's own package\n  package: Package;\n  // the set of active addons in the engine. For each one we keep track of a file that can resolve the addon, because we'll need that later.\n  addons: Map<AddonPackage, string>;\n  // is this the top-level engine?\n  isApp: boolean;\n  // runtime name for the engine's own module namespace\n  modulePrefix: string;\n  // TODO: remove this after we remove the stage2 entrypoint\n  appRelativePath: string;\n}\n"]}
         | 
    
        package/src/asset.d.ts
    CHANGED
    
    | @@ -3,12 +3,6 @@ | |
| 3 3 | 
             
            /// <reference types="jsdom/base" />
         | 
| 4 4 | 
             
            import type { JSDOM } from 'jsdom';
         | 
| 5 5 | 
             
            import type { EmberHTML } from './ember-html';
         | 
| 6 | 
            -
            export interface ImplicitAssetPaths {
         | 
| 7 | 
            -
                'implicit-scripts': string[];
         | 
| 8 | 
            -
                'implicit-test-scripts': string[];
         | 
| 9 | 
            -
                'implicit-styles': string[];
         | 
| 10 | 
            -
                'implicit-test-styles': string[];
         | 
| 11 | 
            -
            }
         | 
| 12 6 | 
             
            interface BaseAsset {
         | 
| 13 7 | 
             
                relativePath: string;
         | 
| 14 8 | 
             
            }
         | 
    
        package/src/asset.js.map
    CHANGED
    
    | @@ -1 +1 @@ | |
| 1 | 
            -
            {"version":3,"file":"asset.js","sourceRoot":"","sources":["asset.ts"],"names":[],"mappings":"","sourcesContent":["import type { JSDOM } from 'jsdom';\nimport type { EmberHTML } from './ember-html';\n\ | 
| 1 | 
            +
            {"version":3,"file":"asset.js","sourceRoot":"","sources":["asset.ts"],"names":[],"mappings":"","sourcesContent":["import type { JSDOM } from 'jsdom';\nimport type { EmberHTML } from './ember-html';\n\ninterface BaseAsset {\n  // where this asset should be placed, relative to the app's root\n  relativePath: string;\n}\n\nexport interface OnDiskAsset extends BaseAsset {\n  kind: 'on-disk';\n\n  // absolute path to where we will find it\n  sourcePath: string;\n  mtime: number;\n  size: number;\n}\n\nexport interface InMemoryAsset extends BaseAsset {\n  kind: 'in-memory';\n\n  // the actual bits\n  source: string | Buffer;\n}\n\n// This represents an HTML entrypoint to the Ember app\nexport interface EmberAsset extends BaseAsset {\n  kind: 'ember';\n\n  // absolute path to where we will find the html file\n  sourcePath: string;\n\n  // these describe the file at sourcePath so we can avoid rebuilding when it\n  // hasn't changed\n  mtime: number;\n  size: number;\n\n  // whether we should include the test suite (in addition to the ember app)\n  includeTests: boolean;\n\n  // the rootURL at which this Ember app expects to be hosted.\n  rootURL: string;\n\n  // This will receive the parsed document. It may optionally modify the\n  // document. And it must return a description of the locations where we're\n  // supposed to insert the parts of the Ember app.\n  prepare(dom: JSDOM): EmberHTML;\n}\n\nexport type Asset = OnDiskAsset | InMemoryAsset | EmberAsset;\n"]}
         | 
    
        package/src/ember-html.d.ts
    CHANGED
    
    | @@ -6,15 +6,13 @@ export interface EmberHTML { | |
| 6 6 | 
             
                javascript: Node;
         | 
| 7 7 | 
             
                styles: Node;
         | 
| 8 8 | 
             
                implicitScripts: Node;
         | 
| 9 | 
            -
                implicitStyles: Node;
         | 
| 10 9 | 
             
                testJavascript?: Node;
         | 
| 11 | 
            -
                implicitTestScripts?: Node;
         | 
| 12 | 
            -
                implicitTestStyles?: Node;
         | 
| 13 10 | 
             
            }
         | 
| 14 11 | 
             
            declare class Placeholder {
         | 
| 15 12 | 
             
                readonly start: Node;
         | 
| 16 13 | 
             
                readonly end: Node;
         | 
| 17 14 | 
             
                readonly reference: Node;
         | 
| 15 | 
            +
                static find(node: Node): Placeholder;
         | 
| 18 16 | 
             
                static replacing(node: Node): Placeholder;
         | 
| 19 17 | 
             
                static immediatelyAfter(node: Node): Placeholder;
         | 
| 20 18 | 
             
                readonly parent: HTMLElement;
         | 
| @@ -28,10 +26,7 @@ export declare class PreparedEmberHTML { | |
| 28 26 | 
             
                javascript: Placeholder;
         | 
| 29 27 | 
             
                styles: Placeholder;
         | 
| 30 28 | 
             
                implicitScripts: Placeholder;
         | 
| 31 | 
            -
                implicitStyles: Placeholder;
         | 
| 32 29 | 
             
                testJavascript: Placeholder;
         | 
| 33 | 
            -
                implicitTestScripts: Placeholder;
         | 
| 34 | 
            -
                implicitTestStyles: Placeholder;
         | 
| 35 30 | 
             
                constructor(asset: EmberAsset);
         | 
| 36 31 | 
             
                private placeholders;
         | 
| 37 32 | 
             
                clear(): void;
         | 
    
        package/src/ember-html.js
    CHANGED
    
    | @@ -5,6 +5,10 @@ const jsdom_1 = require("jsdom"); | |
| 5 5 | 
             
            const fs_1 = require("fs");
         | 
| 6 6 | 
             
            const html_placeholder_1 = require("./html-placeholder");
         | 
| 7 7 | 
             
            class Placeholder {
         | 
| 8 | 
            +
                static find(node) {
         | 
| 9 | 
            +
                    let placeholder = this.immediatelyAfter(node);
         | 
| 10 | 
            +
                    return placeholder;
         | 
| 11 | 
            +
                }
         | 
| 8 12 | 
             
                static replacing(node) {
         | 
| 9 13 | 
             
                    let placeholder = this.immediatelyAfter(node);
         | 
| 10 14 | 
             
                    node.parentElement.removeChild(node);
         | 
| @@ -49,30 +53,15 @@ class PreparedEmberHTML { | |
| 49 53 | 
             
                    this.asset = asset;
         | 
| 50 54 | 
             
                    this.dom = new jsdom_1.JSDOM((0, fs_1.readFileSync)(asset.sourcePath, 'utf8'));
         | 
| 51 55 | 
             
                    let html = asset.prepare(this.dom);
         | 
| 52 | 
            -
                    this.javascript = Placeholder. | 
| 56 | 
            +
                    this.javascript = Placeholder.find(html.javascript);
         | 
| 53 57 | 
             
                    this.styles = Placeholder.replacing(html.styles);
         | 
| 54 | 
            -
                    this.implicitScripts = Placeholder. | 
| 55 | 
            -
                    this.implicitStyles = Placeholder.replacing(html.implicitStyles);
         | 
| 58 | 
            +
                    this.implicitScripts = Placeholder.find(html.implicitScripts);
         | 
| 56 59 | 
             
                    this.testJavascript = html.testJavascript
         | 
| 57 60 | 
             
                        ? Placeholder.replacing(html.testJavascript)
         | 
| 58 61 | 
             
                        : Placeholder.immediatelyAfter(this.javascript.end);
         | 
| 59 | 
            -
                    this.implicitTestScripts = html.implicitTestScripts
         | 
| 60 | 
            -
                        ? Placeholder.replacing(html.implicitTestScripts)
         | 
| 61 | 
            -
                        : Placeholder.immediatelyAfter(this.implicitScripts.end);
         | 
| 62 | 
            -
                    this.implicitTestStyles = html.implicitTestStyles
         | 
| 63 | 
            -
                        ? Placeholder.replacing(html.implicitTestStyles)
         | 
| 64 | 
            -
                        : Placeholder.immediatelyAfter(this.implicitStyles.end);
         | 
| 65 62 | 
             
                }
         | 
| 66 63 | 
             
                placeholders() {
         | 
| 67 | 
            -
                    return [
         | 
| 68 | 
            -
                        this.javascript,
         | 
| 69 | 
            -
                        this.styles,
         | 
| 70 | 
            -
                        this.implicitScripts,
         | 
| 71 | 
            -
                        this.implicitStyles,
         | 
| 72 | 
            -
                        this.implicitTestScripts,
         | 
| 73 | 
            -
                        this.implicitTestStyles,
         | 
| 74 | 
            -
                        this.testJavascript,
         | 
| 75 | 
            -
                    ];
         | 
| 64 | 
            +
                    return [this.javascript, this.styles, this.implicitScripts, this.testJavascript];
         | 
| 76 65 | 
             
                }
         | 
| 77 66 | 
             
                clear() {
         | 
| 78 67 | 
             
                    for (let range of this.placeholders()) {
         | 
    
        package/src/ember-html.js.map
    CHANGED
    
    | @@ -1 +1 @@ | |
| 1 | 
            -
            {"version":3,"file":"ember-html.js","sourceRoot":"","sources":["ember-html.ts"],"names":[],"mappings":";;;AAAA,iCAA8B;AAC9B,2BAAkC;AAElC,yDAAiE; | 
| 1 | 
            +
            {"version":3,"file":"ember-html.js","sourceRoot":"","sources":["ember-html.ts"],"names":[],"mappings":"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","sourcesContent":["import { JSDOM } from 'jsdom';\nimport { readFileSync } from 'fs';\nimport type { EmberAsset } from './asset';\nimport { makeTag, normalizeStyleLink } from './html-placeholder';\n\nexport interface EmberHTML {\n  // each of the Nodes in here points at where we should insert the\n  // corresponding parts of the ember app. The Nodes themselves will be\n  // replaced, so provide placeholders.\n\n  // these are mandatory, the Ember app may need to put things into them.\n  javascript: Node;\n  styles: Node;\n  implicitScripts: Node;\n\n  // these are optional because you *may* choose to stick your implicit test\n  // things into specific locations (which we need for backward-compat). But you\n  // can leave these off and we will simply put them in the same places as the\n  // non-test things.\n  //\n  // Do not confuse these with controlling whether or not we will insert tests.\n  // That is separately controlled via `includeTests`.\n  testJavascript?: Node;\n}\n\nclass Placeholder {\n  static find(node: Node): Placeholder {\n    let placeholder = this.immediatelyAfter(node);\n    return placeholder;\n  }\n\n  static replacing(node: Node): Placeholder {\n    let placeholder = this.immediatelyAfter(node);\n    node.parentElement!.removeChild(node);\n    return placeholder;\n  }\n\n  static immediatelyAfter(node: Node): Placeholder {\n    let document = node.ownerDocument;\n    let parent = node.parentElement;\n\n    if (!document || !parent) {\n      throw new Error('Cannot make Placeholder out of detached node');\n    }\n\n    let nextSibling = node.nextSibling;\n    let start = document.createTextNode('');\n    let end = document.createTextNode('');\n\n    parent.insertBefore(start, nextSibling);\n    parent.insertBefore(end, nextSibling);\n    return new Placeholder(start, end, node);\n  }\n\n  readonly parent: HTMLElement;\n\n  constructor(readonly start: Node, readonly end: Node, readonly reference: Node) {\n    if (start.parentElement && start.parentElement === end.parentElement) {\n      this.parent = start.parentElement;\n    } else {\n      throw new Error('Cannot make Placeholder out of detached node');\n    }\n  }\n\n  clear() {\n    let { start, end, parent } = this;\n    while (start.nextSibling && start.nextSibling !== end) {\n      parent.removeChild(start.nextSibling);\n    }\n  }\n\n  insert(node: Node) {\n    this.parent.insertBefore(node, this.end);\n  }\n}\n\nexport class PreparedEmberHTML {\n  dom: JSDOM;\n  javascript: Placeholder;\n  styles: Placeholder;\n  implicitScripts: Placeholder;\n  testJavascript: Placeholder;\n\n  constructor(private asset: EmberAsset) {\n    this.dom = new JSDOM(readFileSync(asset.sourcePath, 'utf8'));\n    let html = asset.prepare(this.dom);\n    this.javascript = Placeholder.find(html.javascript);\n    this.styles = Placeholder.replacing(html.styles);\n    this.implicitScripts = Placeholder.find(html.implicitScripts);\n    this.testJavascript = html.testJavascript\n      ? Placeholder.replacing(html.testJavascript)\n      : Placeholder.immediatelyAfter(this.javascript.end);\n  }\n\n  private placeholders(): Placeholder[] {\n    return [this.javascript, this.styles, this.implicitScripts, this.testJavascript];\n  }\n\n  clear() {\n    for (let range of this.placeholders()) {\n      range.clear();\n    }\n  }\n\n  // this takes the src relative to the application root, we adjust it so it's\n  // root-relative via the configured rootURL\n  insertScriptTag(\n    placeholder: Placeholder,\n    relativeSrc: string,\n    { type, tag = 'script' }: { type?: string; tag?: string } = {}\n  ) {\n    let document = this.dom.window.document;\n    let from = placeholder.reference.nodeType === 1 ? (placeholder.reference as HTMLElement) : undefined;\n    let src = this.asset.rootURL + relativeSrc;\n    let attributes: Record<string, string> = type ? { src, type } : { src };\n    let newTag = makeTag(document, { from, tag, attributes });\n    placeholder.insert(this.dom.window.document.createTextNode('\\n'));\n    placeholder.insert(newTag);\n  }\n\n  // this takes the href relative to the application root, we adjust it so it's\n  // root-relative via the configured rootURL\n  insertStyleLink(placeholder: Placeholder, relativeHref: string) {\n    let document = this.dom.window.document;\n    let from = placeholder.reference.nodeType === 1 ? (placeholder.reference as HTMLElement) : undefined;\n    let href = this.asset.rootURL + relativeHref;\n    let newTag = makeTag(document, { from, tag: 'link', attributes: { href } });\n    normalizeStyleLink(newTag);\n    placeholder.insert(this.dom.window.document.createTextNode('\\n'));\n    placeholder.insert(newTag);\n  }\n}\n\nexport function insertNewline(at: Node) {\n  at.parentElement!.insertBefore(at.ownerDocument!.createTextNode('\\n'), at);\n}\n"]}
         | 
    
        package/src/index.d.ts
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            export { Packager, PackagerConstructor, Variant, applyVariantToBabelConfig, getAppMeta, getPackagerCacheDir, } from './packager';
         | 
| 2 2 | 
             
            export { HTMLEntrypoint, BundleSummary } from './html-entrypoint';
         | 
| 3 3 | 
             
            export { default as Stage } from './stage';
         | 
| 4 | 
            -
            export { Asset, EmberAsset | 
| 4 | 
            +
            export { Asset, EmberAsset } from './asset';
         | 
| 5 5 | 
             
            export { default as Options, optionsWithDefaults } from './options';
         | 
| 6 6 | 
             
            export { default as toBroccoliPlugin } from './to-broccoli-plugin';
         | 
| 7 7 | 
             
            export { default as WaitForTrees, OutputPaths } from './wait-for-trees';
         | 
    
        package/src/index.js.map
    CHANGED
    
    | @@ -1 +1 @@ | |
| 1 | 
            -
            {"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,uCAOoB;AAHlB,qHAAA,yBAAyB,OAAA;AACzB,sGAAA,UAAU,OAAA;AACV,+GAAA,mBAAmB,OAAA;AAErB,qDAAkE;AAAzD,iHAAA,cAAc,OAAA;AAGvB,qCAAoE;AAAvC,8GAAA,mBAAmB,OAAA;AAChD,2DAAmE;AAA1D,uIAAA,OAAO,OAAoB;AACpC,mDAAwE;AAA/D,+HAAA,OAAO,OAAgB;AAChC,iDAAiE;AAAxD,oHAAA,OAAO,OAAuB;AACvC,uCAA4F;AAAnF,gGAAA,IAAI,OAAA;AAAE,uGAAA,WAAW,OAAA;AAAE,gGAAA,IAAI,OAAA;AAAE,iGAAA,KAAK,OAAA;AAAE,yGAAA,aAAa,OAAA;AAAE,2GAAA,eAAe,OAAA;AACvE,qDAAoG;AAA3F,2GAAA,QAAQ,OAAA;AACjB,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AACvB,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AAGvB,8EAA8E;AAC9E,+DAA+D;AAC/D,8DAA4C","sourcesContent":["export {\n  Packager,\n  PackagerConstructor,\n  Variant,\n  applyVariantToBabelConfig,\n  getAppMeta,\n  getPackagerCacheDir,\n} from './packager';\nexport { HTMLEntrypoint, BundleSummary } from './html-entrypoint';\nexport { default as Stage } from './stage';\nexport { Asset, EmberAsset | 
| 1 | 
            +
            {"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,uCAOoB;AAHlB,qHAAA,yBAAyB,OAAA;AACzB,sGAAA,UAAU,OAAA;AACV,+GAAA,mBAAmB,OAAA;AAErB,qDAAkE;AAAzD,iHAAA,cAAc,OAAA;AAGvB,qCAAoE;AAAvC,8GAAA,mBAAmB,OAAA;AAChD,2DAAmE;AAA1D,uIAAA,OAAO,OAAoB;AACpC,mDAAwE;AAA/D,+HAAA,OAAO,OAAgB;AAChC,iDAAiE;AAAxD,oHAAA,OAAO,OAAuB;AACvC,uCAA4F;AAAnF,gGAAA,IAAI,OAAA;AAAE,uGAAA,WAAW,OAAA;AAAE,gGAAA,IAAI,OAAA;AAAE,iGAAA,KAAK,OAAA;AAAE,yGAAA,aAAa,OAAA;AAAE,2GAAA,eAAe,OAAA;AACvE,qDAAoG;AAA3F,2GAAA,QAAQ,OAAA;AACjB,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AACvB,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AAGvB,8EAA8E;AAC9E,+DAA+D;AAC/D,8DAA4C","sourcesContent":["export {\n  Packager,\n  PackagerConstructor,\n  Variant,\n  applyVariantToBabelConfig,\n  getAppMeta,\n  getPackagerCacheDir,\n} from './packager';\nexport { HTMLEntrypoint, BundleSummary } from './html-entrypoint';\nexport { default as Stage } from './stage';\nexport { Asset, EmberAsset } from './asset';\nexport { default as Options, optionsWithDefaults } from './options';\nexport { default as toBroccoliPlugin } from './to-broccoli-plugin';\nexport { default as WaitForTrees, OutputPaths } from './wait-for-trees';\nexport { compile as jsHandlebarsCompile } from './js-handlebars';\nexport { todo, unsupported, warn, debug, expectWarning, throwOnWarnings } from './messages';\nexport { Resolver, Options as ResolverOptions, ModuleRequest, Resolution } from './module-resolver';\nexport { ResolverLoader } from './resolver-loader';\nexport { virtualContent } from './virtual-content';\nexport type { Engine } from './app-files';\n\n// this is reexported because we already make users manage a peerDep from some\n// other packages (like embroider/webpack and @embroider/compat\nexport * from '@embroider/shared-internals';\n"]}
         | 
    
        package/src/module-resolver.d.ts
    CHANGED
    
    | @@ -12,8 +12,11 @@ export interface Options { | |
| 12 12 | 
             
                appRoot: string;
         | 
| 13 13 | 
             
                engines: EngineConfig[];
         | 
| 14 14 | 
             
                modulePrefix: string;
         | 
| 15 | 
            +
                splitAtRoutes?: (RegExp | string)[];
         | 
| 15 16 | 
             
                podModulePrefix?: string;
         | 
| 16 17 | 
             
                amdCompatibility: Required<UserOptions['amdCompatibility']>;
         | 
| 18 | 
            +
                autoRun: boolean;
         | 
| 19 | 
            +
                staticAppPaths: string[];
         | 
| 17 20 | 
             
            }
         | 
| 18 21 | 
             
            export interface EngineConfig {
         | 
| 19 22 | 
             
                packageName: string;
         | 
| @@ -80,6 +83,8 @@ export declare class Resolver { | |
| 80 83 | 
             
                private generateFastbootSwitch;
         | 
| 81 84 | 
             
                private handleFastbootSwitch;
         | 
| 82 85 | 
             
                private handleImplicitModules;
         | 
| 86 | 
            +
                private handleEntrypoint;
         | 
| 87 | 
            +
                private handleRouteEntrypoint;
         | 
| 83 88 | 
             
                private handleImplicitTestScripts;
         | 
| 84 89 | 
             
                private handleTestSupportStyles;
         | 
| 85 90 | 
             
                private handleGlobalsCompat;
         | 
    
        package/src/module-resolver.js
    CHANGED
    
    | @@ -22,6 +22,7 @@ const typescript_memoize_1 = require("typescript-memoize"); | |
| 22 22 | 
             
            const describe_exports_1 = require("./describe-exports");
         | 
| 23 23 | 
             
            const fs_1 = require("fs");
         | 
| 24 24 | 
             
            const node_resolve_1 = require("./node-resolve");
         | 
| 25 | 
            +
            const virtual_route_entrypoint_1 = require("./virtual-route-entrypoint");
         | 
| 25 26 | 
             
            const debug = (0, debug_1.default)('embroider:resolver');
         | 
| 26 27 | 
             
            // Using a formatter makes this work lazy so nothing happens when we aren't
         | 
| 27 28 | 
             
            // logging. It is unfortunate that formatters are a globally mutable config and
         | 
| @@ -84,6 +85,8 @@ class Resolver { | |
| 84 85 | 
             
                    request = this.handleImplicitTestScripts(request);
         | 
| 85 86 | 
             
                    request = this.handleVendorStyles(request);
         | 
| 86 87 | 
             
                    request = this.handleTestSupportStyles(request);
         | 
| 88 | 
            +
                    request = this.handleEntrypoint(request);
         | 
| 89 | 
            +
                    request = this.handleRouteEntrypoint(request);
         | 
| 87 90 | 
             
                    request = this.handleRenaming(request);
         | 
| 88 91 | 
             
                    request = this.handleVendor(request);
         | 
| 89 92 | 
             
                    // we expect the specifier to be app relative at this point - must be after handleRenaming
         | 
| @@ -262,6 +265,51 @@ class Resolver { | |
| 262 265 | 
             
                        return logTransition(`own implicit modules`, request, request.virtualize((0, path_1.resolve)(pkg.root, `-embroider-${im.type}.js`)));
         | 
| 263 266 | 
             
                    }
         | 
| 264 267 | 
             
                }
         | 
| 268 | 
            +
                handleEntrypoint(request) {
         | 
| 269 | 
            +
                    if (isTerminal(request)) {
         | 
| 270 | 
            +
                        return request;
         | 
| 271 | 
            +
                    }
         | 
| 272 | 
            +
                    // TODO: also handle targeting from the outside (for engines) like:
         | 
| 273 | 
            +
                    // request.specifier === 'my-package-name/-embroider-entrypoint.js'
         | 
| 274 | 
            +
                    // just like implicit-modules does.
         | 
| 275 | 
            +
                    //TODO move the extra forwardslash handling out into the vite plugin
         | 
| 276 | 
            +
                    const candidates = ['@embroider/core/entrypoint', '/@embroider/core/entrypoint', './@embroider/core/entrypoint'];
         | 
| 277 | 
            +
                    if (!candidates.some(c => request.specifier.startsWith(c + '/') || request.specifier === c)) {
         | 
| 278 | 
            +
                        return request;
         | 
| 279 | 
            +
                    }
         | 
| 280 | 
            +
                    const result = /\.?\/?@embroider\/core\/entrypoint(?:\/(?<packageName>.*))?/.exec(request.specifier);
         | 
| 281 | 
            +
                    if (!result) {
         | 
| 282 | 
            +
                        // TODO make a better error
         | 
| 283 | 
            +
                        throw new Error('entrypoint does not match pattern' + request.specifier);
         | 
| 284 | 
            +
                    }
         | 
| 285 | 
            +
                    const { packageName } = result.groups;
         | 
| 286 | 
            +
                    const requestingPkg = this.packageCache.ownerOfFile(request.fromFile);
         | 
| 287 | 
            +
                    if (!(requestingPkg === null || requestingPkg === void 0 ? void 0 : requestingPkg.isV2Ember())) {
         | 
| 288 | 
            +
                        throw new Error(`bug: found entrypoint import in non-ember package at ${request.fromFile}`);
         | 
| 289 | 
            +
                    }
         | 
| 290 | 
            +
                    let pkg;
         | 
| 291 | 
            +
                    if (packageName) {
         | 
| 292 | 
            +
                        pkg = this.packageCache.resolve(packageName, requestingPkg);
         | 
| 293 | 
            +
                    }
         | 
| 294 | 
            +
                    else {
         | 
| 295 | 
            +
                        pkg = requestingPkg;
         | 
| 296 | 
            +
                    }
         | 
| 297 | 
            +
                    return logTransition('entrypoint', request, request.virtualize((0, path_1.resolve)(pkg.root, '-embroider-entrypoint.js')));
         | 
| 298 | 
            +
                }
         | 
| 299 | 
            +
                handleRouteEntrypoint(request) {
         | 
| 300 | 
            +
                    if (isTerminal(request)) {
         | 
| 301 | 
            +
                        return request;
         | 
| 302 | 
            +
                    }
         | 
| 303 | 
            +
                    let routeName = (0, virtual_route_entrypoint_1.decodePublicRouteEntrypoint)(request.specifier);
         | 
| 304 | 
            +
                    if (!routeName) {
         | 
| 305 | 
            +
                        return request;
         | 
| 306 | 
            +
                    }
         | 
| 307 | 
            +
                    let pkg = this.packageCache.ownerOfFile(request.fromFile);
         | 
| 308 | 
            +
                    if (!(pkg === null || pkg === void 0 ? void 0 : pkg.isV2Ember())) {
         | 
| 309 | 
            +
                        throw new Error(`bug: found entrypoint import in non-ember package at ${request.fromFile}`);
         | 
| 310 | 
            +
                    }
         | 
| 311 | 
            +
                    return logTransition('route entrypoint', request, request.virtualize((0, virtual_route_entrypoint_1.encodeRouteEntrypoint)(pkg.root, routeName)));
         | 
| 312 | 
            +
                }
         | 
| 265 313 | 
             
                handleImplicitTestScripts(request) {
         | 
| 266 314 | 
             
                    //TODO move the extra forwardslash handling out into the vite plugin
         | 
| 267 315 | 
             
                    const candidates = [
         | 
| @@ -328,8 +376,8 @@ class Resolver { | |
| 328 376 | 
             
                        return request;
         | 
| 329 377 | 
             
                    }
         | 
| 330 378 | 
             
                    let pkg = this.packageCache.ownerOfFile(request.fromFile);
         | 
| 331 | 
            -
                    if ((pkg === null || pkg === void 0 ? void 0 : pkg.root) | 
| 332 | 
            -
                        throw new Error(`bug: found an import of ${request.specifier} in ${request.fromFile}, but this is not the top-level Ember app. The top-level Ember app is the only one that has support for @embroider/core/vendor.css. If you think something should be fixed in Embroider, please open an issue on https://github.com/embroider-build/embroider/issues.`);
         | 
| 379 | 
            +
                    if (!pkg || !this.options.engines.some(e => e.root === (pkg === null || pkg === void 0 ? void 0 : pkg.root))) {
         | 
| 380 | 
            +
                        throw new Error(`bug: found an import of ${request.specifier} in ${request.fromFile}, but this is not the top-level Ember app or Engine. The top-level Ember app is the only one that has support for @embroider/core/vendor.css. If you think something should be fixed in Embroider, please open an issue on https://github.com/embroider-build/embroider/issues.`);
         | 
| 333 381 | 
             
                    }
         | 
| 334 382 | 
             
                    return logTransition('vendor-styles', request, request.virtualize((0, path_1.resolve)(pkg.root, '-embroider-vendor-styles.css')));
         | 
| 335 383 | 
             
                }
         |