@embroider/vite 0.2.1-unstable.f7656a3 → 0.2.1

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/index.d.ts CHANGED
@@ -1,9 +1,6 @@
1
1
  export * from './src/resolver.js';
2
- export * from './src/esbuild-resolver.js';
3
2
  export * from './src/hbs.js';
4
3
  export * from './src/scripts.js';
5
4
  export * from './src/template-tag.js';
5
+ export * from './src/addons.js';
6
6
  export * from './src/optimize-deps.js';
7
- export * from './src/assets.js';
8
- export * from './src/build.js';
9
- export * from './src/content-for.js';
package/index.mjs CHANGED
@@ -1,9 +1,6 @@
1
1
  export * from './src/resolver.js';
2
- export * from './src/esbuild-resolver.js';
3
2
  export * from './src/hbs.js';
4
3
  export * from './src/scripts.js';
5
4
  export * from './src/template-tag.js';
5
+ export * from './src/addons.js';
6
6
  export * from './src/optimize-deps.js';
7
- export * from './src/build.js';
8
- export * from './src/assets.js';
9
- export * from './src/content-for.js';
package/package.json CHANGED
@@ -1,36 +1,28 @@
1
1
  {
2
2
  "name": "@embroider/vite",
3
- "version": "0.2.1-unstable.f7656a3",
3
+ "version": "0.2.1",
4
4
  "main": "index.mjs",
5
5
  "peerDependencies": {
6
- "vite": "^5.2.0",
7
- "@embroider/core": "^3.4.16-unstable.f7656a3"
6
+ "vite": "^4.3.9",
7
+ "@embroider/core": "^3.4.17"
8
8
  },
9
9
  "dependencies": {
10
- "@babel/core": "^7.22.9",
11
10
  "@rollup/pluginutils": "^4.1.1",
12
11
  "assert-never": "^1.2.1",
13
12
  "content-tag": "^2.0.1",
14
13
  "debug": "^4.3.2",
15
- "esbuild": "^0.17.19",
16
- "fast-glob": "^3.3.2",
17
14
  "fs-extra": "^10.0.0",
18
- "jsdom": "^16.6.0",
19
- "send": "^0.18.0",
15
+ "jsdom": "^25.0.0",
20
16
  "source-map-url": "^0.4.1",
21
- "terser": "^5.7.0",
22
- "@embroider/reverse-exports": "0.1.1-unstable.f7656a3",
23
- "@embroider/macros": "1.16.7-unstable.f7656a3"
17
+ "terser": "^5.7.0"
24
18
  },
25
19
  "devDependencies": {
26
- "@types/babel__core": "^7.20.1",
27
20
  "@types/debug": "^4.1.5",
28
- "@types/fs-extra": "^9.0.12",
29
21
  "@types/jsdom": "^16.2.11",
30
- "@types/send": "^0.17.4",
31
- "rollup": "^4.18.0",
32
- "vite": "^5.3.3",
33
- "@embroider/core": "^3.4.16-unstable.f7656a3"
22
+ "@types/fs-extra": "^9.0.12",
23
+ "rollup": "^3.23.0",
24
+ "vite": "^4.3.9",
25
+ "@embroider/core": "^3.4.17"
34
26
  },
35
27
  "files": [
36
28
  "index.mjs",
@@ -0,0 +1 @@
1
+ export declare function addons(root: string): string[];
package/src/addons.js ADDED
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.addons = addons;
4
+ const core_1 = require("@embroider/core");
5
+ function addons(root) {
6
+ let rloader = new core_1.ResolverLoader(root);
7
+ let { options } = rloader.resolver;
8
+ let names = new Set();
9
+ for (let from of Object.keys(options.renameModules)) {
10
+ let pName = (0, core_1.packageName)(from);
11
+ if (pName) {
12
+ names.add(pName);
13
+ }
14
+ }
15
+ for (let from of Object.keys(options.renamePackages)) {
16
+ names.add(from);
17
+ }
18
+ for (let name of Object.keys(options.activeAddons)) {
19
+ names.add(name);
20
+ }
21
+ return [...names];
22
+ }
23
+ //# sourceMappingURL=addons.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addons.js","sourceRoot":"","sources":["addons.ts"],"names":[],"mappings":";;AAEA,wBAiBC;AAnBD,0CAA8D;AAE9D,SAAgB,MAAM,CAAC,IAAY;IACjC,IAAI,OAAO,GAAG,IAAI,qBAAc,CAAC,IAAI,CAAC,CAAC;IACvC,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,QAAQ,CAAC;IACnC,IAAI,KAAK,GAAG,IAAI,GAAG,EAAU,CAAC;IAC9B,KAAK,IAAI,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;QACpD,IAAI,KAAK,GAAG,IAAA,kBAAW,EAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IACD,KAAK,IAAI,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,CAAC;QACrD,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IACD,KAAK,IAAI,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC;QACnD,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IACD,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC;AACpB,CAAC","sourcesContent":["import { ResolverLoader, packageName } from '@embroider/core';\n\nexport function addons(root: string): string[] {\n let rloader = new ResolverLoader(root);\n let { options } = rloader.resolver;\n let names = new Set<string>();\n for (let from of Object.keys(options.renameModules)) {\n let pName = packageName(from);\n if (pName) {\n names.add(pName);\n }\n }\n for (let from of Object.keys(options.renamePackages)) {\n names.add(from);\n }\n for (let name of Object.keys(options.activeAddons)) {\n names.add(name);\n }\n return [...names];\n}\n"]}
package/src/hbs.js CHANGED
@@ -1,80 +1,56 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  exports.hbs = hbs;
7
+ // TODO: I copied this from @embroider/addon-dev, it needs to be its own package
8
+ // (or be in shared-internals or core)
4
9
  const pluginutils_1 = require("@rollup/pluginutils");
10
+ const fs_1 = require("fs");
5
11
  const core_1 = require("@embroider/core");
6
- const resolverLoader = new core_1.ResolverLoader(process.cwd());
7
- const hbsFilter = (0, pluginutils_1.createFilter)('**/*.hbs?([?]*)');
12
+ const assert_never_1 = __importDefault(require("assert-never"));
13
+ const path_1 = require("path");
14
+ const debug_1 = __importDefault(require("debug"));
15
+ const debug = (0, debug_1.default)('embroider:hbs-plugin');
8
16
  function hbs() {
9
17
  return {
10
18
  name: 'rollup-hbs-plugin',
11
19
  enforce: 'pre',
12
- async resolveId(source, importer, options) {
13
- var _a, _b, _c;
14
- if ((_a = options.custom) === null || _a === void 0 ? void 0 : _a.depScan) {
15
- // during depscan we have a corresponding esbuild plugin that is
16
- // responsible for this stuff instead. We don't want to fight with it.
17
- return null;
18
- }
19
- if ((_c = (_b = options.custom) === null || _b === void 0 ? void 0 : _b.embroider) === null || _c === void 0 ? void 0 : _c.isExtensionSearch) {
20
- return null;
21
- }
20
+ async resolveId(source, importer) {
22
21
  let resolution = await this.resolve(source, importer, {
23
22
  skipSelf: true,
24
23
  });
25
24
  if (!resolution) {
26
- let hbsSource = (0, core_1.syntheticJStoHBS)(source);
27
- if (hbsSource) {
28
- resolution = await this.resolve(hbsSource, importer, {
29
- skipSelf: true,
30
- custom: {
31
- embroider: {
32
- // we don't want to recurse into the whole embroider compatbility
33
- // resolver here. It has presumably already steered our request to the
34
- // correct place. All we want to do is slightly modify the request we
35
- // were given (changing the extension) and check if that would resolve
36
- // instead.
37
- //
38
- // Currently this guard is only actually exercised in rollup, not in
39
- // vite, due to https://github.com/vitejs/vite/issues/13852
40
- enableCustomResolver: false,
41
- isExtensionSearch: true,
42
- },
43
- },
44
- });
45
- }
46
- if (!resolution) {
47
- return null;
48
- }
25
+ return maybeSynthesizeComponentJS(this, source, importer);
49
26
  }
50
- let syntheticId = (0, core_1.needsSyntheticComponentJS)(source, resolution.id, resolverLoader.resolver.packageCache);
51
- if (syntheticId) {
52
- return {
53
- id: syntheticId,
54
- meta: {
55
- 'rollup-hbs-plugin': {
56
- type: 'template-only-component-js',
57
- },
58
- },
59
- };
27
+ else {
28
+ return maybeRewriteHBS(resolution);
60
29
  }
61
30
  },
62
31
  load(id) {
63
- var _a;
64
- if (((_a = getMeta(this, id)) === null || _a === void 0 ? void 0 : _a.type) === 'template-only-component-js') {
65
- return {
66
- code: (0, core_1.templateOnlyComponentSource)(),
67
- };
32
+ const meta = getMeta(this, id);
33
+ if (!meta) {
34
+ return;
68
35
  }
69
- },
70
- transform(code, id) {
71
- if (!hbsFilter(id)) {
72
- return null;
36
+ switch (meta.type) {
37
+ case 'template':
38
+ let input = (0, fs_1.readFileSync)(id, 'utf8');
39
+ let code = (0, core_1.hbsToJS)(input);
40
+ return {
41
+ code,
42
+ };
43
+ case 'template-only-component-js':
44
+ return {
45
+ code: templateOnlyComponent,
46
+ };
47
+ default:
48
+ (0, assert_never_1.default)(meta);
73
49
  }
74
- return (0, core_1.hbsToJS)(code);
75
50
  },
76
51
  };
77
52
  }
53
+ const templateOnlyComponent = `import templateOnly from '@ember/component/template-only';\n` + `export default templateOnly();\n`;
78
54
  function getMeta(context, id) {
79
55
  var _a, _b;
80
56
  const meta = (_b = (_a = context.getModuleInfo(id)) === null || _a === void 0 ? void 0 : _a.meta) === null || _b === void 0 ? void 0 : _b['rollup-hbs-plugin'];
@@ -85,4 +61,56 @@ function getMeta(context, id) {
85
61
  return null;
86
62
  }
87
63
  }
64
+ function correspondingTemplate(filename) {
65
+ let { ext } = (0, path_1.parse)(filename);
66
+ return filename.slice(0, filename.length - ext.length) + '.hbs';
67
+ }
68
+ async function maybeSynthesizeComponentJS(context, source, importer) {
69
+ debug(`checking for template-only component: %s`, source);
70
+ let templateResolution = await context.resolve(correspondingTemplate(source), importer, {
71
+ skipSelf: true,
72
+ custom: {
73
+ embroider: {
74
+ // we don't want to recurse into the whole embroider compatbility
75
+ // resolver here. It has presumably already steered our request to the
76
+ // correct place. All we want to do is slightly modify the request we
77
+ // were given (changing the extension) and check if that would resolve
78
+ // instead.
79
+ //
80
+ // Currently this guard is only actually exercised in rollup, not in
81
+ // vite, due to https://github.com/vitejs/vite/issues/13852
82
+ enableCustomResolver: false,
83
+ },
84
+ },
85
+ });
86
+ if (!templateResolution) {
87
+ return null;
88
+ }
89
+ debug(`emitting template only component: %s`, templateResolution.id);
90
+ // we're trying to resolve a JS module but only the corresponding HBS
91
+ // file exists. Synthesize the template-only component JS.
92
+ return {
93
+ id: templateResolution.id.replace(/\.hbs$/, '.js'),
94
+ meta: {
95
+ 'rollup-hbs-plugin': {
96
+ type: 'template-only-component-js',
97
+ },
98
+ },
99
+ };
100
+ }
101
+ const hbsFilter = (0, pluginutils_1.createFilter)('**/*.hbs');
102
+ function maybeRewriteHBS(resolution) {
103
+ if (!hbsFilter(resolution.id)) {
104
+ return null;
105
+ }
106
+ debug('emitting hbs rewrite: %s', resolution.id);
107
+ return {
108
+ ...resolution,
109
+ meta: {
110
+ 'rollup-hbs-plugin': {
111
+ type: 'template',
112
+ },
113
+ },
114
+ };
115
+ }
88
116
  //# sourceMappingURL=hbs.js.map
package/src/hbs.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"hbs.js","sourceRoot":"","sources":["hbs.ts"],"names":[],"mappings":";;AAcA,kBA0EC;AAxFD,qDAAmD;AAGnD,0CAMyB;AAEzB,MAAM,cAAc,GAAG,IAAI,qBAAc,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;AACzD,MAAM,SAAS,GAAG,IAAA,0BAAY,EAAC,iBAAiB,CAAC,CAAC;AAElD,SAAgB,GAAG;IACjB,OAAO;QACL,IAAI,EAAE,mBAAmB;QACzB,OAAO,EAAE,KAAK;QACd,KAAK,CAAC,SAAS,CAAC,MAAc,EAAE,QAA4B,EAAE,OAAO;;YACnE,IAAI,MAAA,OAAO,CAAC,MAAM,0CAAE,OAAO,EAAE,CAAC;gBAC5B,gEAAgE;gBAChE,sEAAsE;gBACtE,OAAO,IAAI,CAAC;YACd,CAAC;YAED,IAAI,MAAA,MAAA,OAAO,CAAC,MAAM,0CAAE,SAAS,0CAAE,iBAAiB,EAAE,CAAC;gBACjD,OAAO,IAAI,CAAC;YACd,CAAC;YAED,IAAI,UAAU,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,EAAE;gBACpD,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;YAEH,IAAI,CAAC,UAAU,EAAE,CAAC;gBAChB,IAAI,SAAS,GAAG,IAAA,uBAAgB,EAAC,MAAM,CAAC,CAAC;gBACzC,IAAI,SAAS,EAAE,CAAC;oBACd,UAAU,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,QAAQ,EAAE;wBACnD,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE;4BACN,SAAS,EAAE;gCACT,iEAAiE;gCACjE,sEAAsE;gCACtE,qEAAqE;gCACrE,sEAAsE;gCACtE,WAAW;gCACX,EAAE;gCACF,oEAAoE;gCACpE,2DAA2D;gCAC3D,oBAAoB,EAAE,KAAK;gCAC3B,iBAAiB,EAAE,IAAI;6BACxB;yBACF;qBACF,CAAC,CAAC;gBACL,CAAC;gBAED,IAAI,CAAC,UAAU,EAAE,CAAC;oBAChB,OAAO,IAAI,CAAC;gBACd,CAAC;YACH,CAAC;YAED,IAAI,WAAW,GAAG,IAAA,gCAAyB,EAAC,MAAM,EAAE,UAAU,CAAC,EAAE,EAAE,cAAc,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YACzG,IAAI,WAAW,EAAE,CAAC;gBAChB,OAAO;oBACL,EAAE,EAAE,WAAW;oBACf,IAAI,EAAE;wBACJ,mBAAmB,EAAE;4BACnB,IAAI,EAAE,4BAA4B;yBACnC;qBACF;iBACF,CAAC;YACJ,CAAC;QACH,CAAC;QAED,IAAI,CAAC,EAAU;;YACb,IAAI,CAAA,MAAA,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,0CAAE,IAAI,MAAK,4BAA4B,EAAE,CAAC;gBAC7D,OAAO;oBACL,IAAI,EAAE,IAAA,kCAA2B,GAAE;iBACpC,CAAC;YACJ,CAAC;QACH,CAAC;QAED,SAAS,CAAC,IAAY,EAAE,EAAU;YAChC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC;gBACnB,OAAO,IAAI,CAAC;YACd,CAAC;YACD,OAAO,IAAA,cAAO,EAAC,IAAI,CAAC,CAAC;QACvB,CAAC;KACF,CAAC;AACJ,CAAC;AAMD,SAAS,OAAO,CAAC,OAAsB,EAAE,EAAU;;IACjD,MAAM,IAAI,GAAG,MAAA,MAAA,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC,0CAAE,IAAI,0CAAG,mBAAmB,CAAC,CAAC;IACpE,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,IAAY,CAAC;IACtB,CAAC;SAAM,CAAC;QACN,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC","sourcesContent":["import { createFilter } from '@rollup/pluginutils';\nimport type { PluginContext } from 'rollup';\nimport type { Plugin } from 'vite';\nimport {\n hbsToJS,\n ResolverLoader,\n needsSyntheticComponentJS,\n templateOnlyComponentSource,\n syntheticJStoHBS,\n} from '@embroider/core';\n\nconst resolverLoader = new ResolverLoader(process.cwd());\nconst hbsFilter = createFilter('**/*.hbs?([?]*)');\n\nexport function hbs(): Plugin {\n return {\n name: 'rollup-hbs-plugin',\n enforce: 'pre',\n async resolveId(source: string, importer: string | undefined, options) {\n if (options.custom?.depScan) {\n // during depscan we have a corresponding esbuild plugin that is\n // responsible for this stuff instead. We don't want to fight with it.\n return null;\n }\n\n if (options.custom?.embroider?.isExtensionSearch) {\n return null;\n }\n\n let resolution = await this.resolve(source, importer, {\n skipSelf: true,\n });\n\n if (!resolution) {\n let hbsSource = syntheticJStoHBS(source);\n if (hbsSource) {\n resolution = await this.resolve(hbsSource, importer, {\n skipSelf: true,\n custom: {\n embroider: {\n // we don't want to recurse into the whole embroider compatbility\n // resolver here. It has presumably already steered our request to the\n // correct place. All we want to do is slightly modify the request we\n // were given (changing the extension) and check if that would resolve\n // instead.\n //\n // Currently this guard is only actually exercised in rollup, not in\n // vite, due to https://github.com/vitejs/vite/issues/13852\n enableCustomResolver: false,\n isExtensionSearch: true,\n },\n },\n });\n }\n\n if (!resolution) {\n return null;\n }\n }\n\n let syntheticId = needsSyntheticComponentJS(source, resolution.id, resolverLoader.resolver.packageCache);\n if (syntheticId) {\n return {\n id: syntheticId,\n meta: {\n 'rollup-hbs-plugin': {\n type: 'template-only-component-js',\n },\n },\n };\n }\n },\n\n load(id: string) {\n if (getMeta(this, id)?.type === 'template-only-component-js') {\n return {\n code: templateOnlyComponentSource(),\n };\n }\n },\n\n transform(code: string, id: string) {\n if (!hbsFilter(id)) {\n return null;\n }\n return hbsToJS(code);\n },\n };\n}\n\ntype Meta = {\n type: 'template-only-component-js';\n};\n\nfunction getMeta(context: PluginContext, id: string): Meta | null {\n const meta = context.getModuleInfo(id)?.meta?.['rollup-hbs-plugin'];\n if (meta) {\n return meta as Meta;\n } else {\n return null;\n }\n}\n"]}
1
+ {"version":3,"file":"hbs.js","sourceRoot":"","sources":["hbs.ts"],"names":[],"mappings":"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","sourcesContent":["// TODO: I copied this from @embroider/addon-dev, it needs to be its own package\n// (or be in shared-internals or core)\nimport { createFilter } from '@rollup/pluginutils';\nimport type { PluginContext, ResolvedId } from 'rollup';\nimport type { Plugin } from 'vite';\nimport { readFileSync } from 'fs';\nimport { hbsToJS } from '@embroider/core';\nimport assertNever from 'assert-never';\nimport { parse as pathParse } from 'path';\nimport makeDebug from 'debug';\n\nconst debug = makeDebug('embroider:hbs-plugin');\n\nexport function hbs(): Plugin {\n return {\n name: 'rollup-hbs-plugin',\n enforce: 'pre',\n async resolveId(source: string, importer: string | undefined) {\n let resolution = await this.resolve(source, importer, {\n skipSelf: true,\n });\n\n if (!resolution) {\n return maybeSynthesizeComponentJS(this, source, importer);\n } else {\n return maybeRewriteHBS(resolution);\n }\n },\n\n load(id: string) {\n const meta = getMeta(this, id);\n if (!meta) {\n return;\n }\n\n switch (meta.type) {\n case 'template':\n let input = readFileSync(id, 'utf8');\n let code = hbsToJS(input);\n return {\n code,\n };\n case 'template-only-component-js':\n return {\n code: templateOnlyComponent,\n };\n default:\n assertNever(meta);\n }\n },\n };\n}\n\nconst templateOnlyComponent =\n `import templateOnly from '@ember/component/template-only';\\n` + `export default templateOnly();\\n`;\n\ntype Meta =\n | {\n type: 'template';\n }\n | {\n type: 'template-only-component-js';\n };\n\nfunction getMeta(context: PluginContext, id: string): Meta | null {\n const meta = context.getModuleInfo(id)?.meta?.['rollup-hbs-plugin'];\n if (meta) {\n return meta as Meta;\n } else {\n return null;\n }\n}\n\nfunction correspondingTemplate(filename: string): string {\n let { ext } = pathParse(filename);\n return filename.slice(0, filename.length - ext.length) + '.hbs';\n}\n\nasync function maybeSynthesizeComponentJS(context: PluginContext, source: string, importer: string | undefined) {\n debug(`checking for template-only component: %s`, source);\n let templateResolution = await context.resolve(correspondingTemplate(source), importer, {\n skipSelf: true,\n custom: {\n embroider: {\n // we don't want to recurse into the whole embroider compatbility\n // resolver here. It has presumably already steered our request to the\n // correct place. All we want to do is slightly modify the request we\n // were given (changing the extension) and check if that would resolve\n // instead.\n //\n // Currently this guard is only actually exercised in rollup, not in\n // vite, due to https://github.com/vitejs/vite/issues/13852\n enableCustomResolver: false,\n },\n },\n });\n if (!templateResolution) {\n return null;\n }\n debug(`emitting template only component: %s`, templateResolution.id);\n\n // we're trying to resolve a JS module but only the corresponding HBS\n // file exists. Synthesize the template-only component JS.\n return {\n id: templateResolution.id.replace(/\\.hbs$/, '.js'),\n meta: {\n 'rollup-hbs-plugin': {\n type: 'template-only-component-js',\n },\n },\n };\n}\n\nconst hbsFilter = createFilter('**/*.hbs');\n\nfunction maybeRewriteHBS(resolution: ResolvedId) {\n if (!hbsFilter(resolution.id)) {\n return null;\n }\n debug('emitting hbs rewrite: %s', resolution.id);\n return {\n ...resolution,\n meta: {\n 'rollup-hbs-plugin': {\n type: 'template',\n },\n },\n };\n}\n"]}
@@ -1,14 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.optimizeDeps = optimizeDeps;
4
- const esbuild_resolver_1 = require("./esbuild-resolver");
5
4
  function optimizeDeps() {
6
5
  return {
7
6
  exclude: ['@embroider/macros'],
8
- extensions: ['.hbs', '.gjs', '.gts'],
9
- esbuildOptions: {
10
- plugins: [(0, esbuild_resolver_1.esBuildResolver)()],
11
- },
12
7
  };
13
8
  }
14
9
  //# sourceMappingURL=optimize-deps.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"optimize-deps.js","sourceRoot":"","sources":["optimize-deps.ts"],"names":[],"mappings":";;AAOA,oCAQC;AAfD,yDAAqD;AAOrD,SAAgB,YAAY;IAC1B,OAAO;QACL,OAAO,EAAE,CAAC,mBAAmB,CAAC;QAC9B,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC;QACpC,cAAc,EAAE;YACd,OAAO,EAAE,CAAC,IAAA,kCAAe,GAAE,CAAC;SAC7B;KACF,CAAC;AACJ,CAAC","sourcesContent":["import { esBuildResolver } from './esbuild-resolver';\n\nexport interface OptimizeDeps {\n exclude?: string[];\n [key: string]: unknown;\n}\n\nexport function optimizeDeps(): OptimizeDeps {\n return {\n exclude: ['@embroider/macros'],\n extensions: ['.hbs', '.gjs', '.gts'],\n esbuildOptions: {\n plugins: [esBuildResolver()],\n },\n };\n}\n"]}
1
+ {"version":3,"file":"optimize-deps.js","sourceRoot":"","sources":["optimize-deps.ts"],"names":[],"mappings":";;AAKA,oCAIC;AAJD,SAAgB,YAAY;IAC1B,OAAO;QACL,OAAO,EAAE,CAAC,mBAAmB,CAAC;KAC/B,CAAC;AACJ,CAAC","sourcesContent":["export interface OptimizeDeps {\n exclude?: string[];\n [key: string]: unknown;\n}\n\nexport function optimizeDeps(): OptimizeDeps {\n return {\n exclude: ['@embroider/macros'],\n };\n}\n"]}
package/src/request.d.ts CHANGED
@@ -1,26 +1,14 @@
1
- import type { ModuleRequest, Resolution } from '@embroider/core';
2
- import type { PluginContext, ResolveIdResult } from 'rollup';
1
+ import type { ModuleRequest } from '@embroider/core';
3
2
  export declare const virtualPrefix = "embroider_virtual:";
4
3
  export declare class RollupModuleRequest implements ModuleRequest {
5
- private context;
6
4
  readonly specifier: string;
7
5
  readonly fromFile: string;
8
6
  readonly meta: Record<string, any> | undefined;
9
- readonly isNotFound: boolean;
10
- readonly resolvedTo: Resolution<ResolveIdResult> | undefined;
11
- private queryParams;
12
- private importerQueryParams;
13
- static from(context: PluginContext, source: string, importer: string | undefined, custom: Record<string, any> | undefined): RollupModuleRequest | undefined;
7
+ static from(source: string, importer: string | undefined, custom: Record<string, any> | undefined): RollupModuleRequest | undefined;
14
8
  private constructor();
15
- get debugType(): string;
16
9
  get isVirtual(): boolean;
17
- private get specifierWithQueryParams();
18
- private get fromFileWithQueryParams();
19
10
  alias(newSpecifier: string): this;
20
11
  rehome(newFromFile: string): this;
21
12
  virtualize(filename: string): this;
22
13
  withMeta(meta: Record<string, any> | undefined): this;
23
- notFound(): this;
24
- defaultResolve(): Promise<Resolution<ResolveIdResult>>;
25
- resolveTo(resolution: Resolution<ResolveIdResult>): this;
26
14
  }
package/src/request.js CHANGED
@@ -4,7 +4,7 @@ exports.RollupModuleRequest = exports.virtualPrefix = void 0;
4
4
  const core_1 = require("@embroider/core");
5
5
  exports.virtualPrefix = 'embroider_virtual:';
6
6
  class RollupModuleRequest {
7
- static from(context, source, importer, custom) {
7
+ static from(source, importer, custom) {
8
8
  var _a, _b, _c;
9
9
  if (!((_b = (_a = custom === null || custom === void 0 ? void 0 : custom.embroider) === null || _a === void 0 ? void 0 : _a.enableCustomResolver) !== null && _b !== void 0 ? _b : true)) {
10
10
  return;
@@ -19,92 +19,33 @@ class RollupModuleRequest {
19
19
  }
20
20
  // strip query params off the importer
21
21
  let fromFile = (0, core_1.cleanUrl)(nonVirtual);
22
- let importerQueryParams = (0, core_1.getUrlQueryParams)(nonVirtual);
23
- // strip query params off the source but keep track of them
24
- // we use regexp-based methods over a URL object because the
25
- // source can be a relative path.
26
- let cleanSource = (0, core_1.cleanUrl)(source);
27
- let queryParams = (0, core_1.getUrlQueryParams)(source);
28
- return new RollupModuleRequest(context, cleanSource, fromFile, (_c = custom === null || custom === void 0 ? void 0 : custom.embroider) === null || _c === void 0 ? void 0 : _c.meta, false, undefined, queryParams, importerQueryParams);
22
+ return new RollupModuleRequest(source, fromFile, (_c = custom === null || custom === void 0 ? void 0 : custom.embroider) === null || _c === void 0 ? void 0 : _c.meta);
29
23
  }
30
24
  }
31
- constructor(context, specifier, fromFile, meta, isNotFound, resolvedTo, queryParams, importerQueryParams) {
32
- this.context = context;
25
+ constructor(specifier, fromFile, meta) {
33
26
  this.specifier = specifier;
34
27
  this.fromFile = fromFile;
35
28
  this.meta = meta;
36
- this.isNotFound = isNotFound;
37
- this.resolvedTo = resolvedTo;
38
- this.queryParams = queryParams;
39
- this.importerQueryParams = importerQueryParams;
40
- }
41
- get debugType() {
42
- return 'rollup';
43
29
  }
44
30
  get isVirtual() {
45
31
  return this.specifier.startsWith(exports.virtualPrefix);
46
32
  }
47
- get specifierWithQueryParams() {
48
- return `${this.specifier}${this.queryParams}`;
49
- }
50
- get fromFileWithQueryParams() {
51
- return `${this.fromFile}${this.importerQueryParams}`;
52
- }
53
33
  alias(newSpecifier) {
54
- return new RollupModuleRequest(this.context, newSpecifier, this.fromFile, this.meta, false, undefined, this.queryParams, this.importerQueryParams);
34
+ return new RollupModuleRequest(newSpecifier, this.fromFile, this.meta);
55
35
  }
56
36
  rehome(newFromFile) {
57
37
  if (this.fromFile === newFromFile) {
58
38
  return this;
59
39
  }
60
40
  else {
61
- return new RollupModuleRequest(this.context, this.specifier, newFromFile, this.meta, false, undefined, this.queryParams, this.importerQueryParams);
41
+ return new RollupModuleRequest(this.specifier, newFromFile, this.meta);
62
42
  }
63
43
  }
64
44
  virtualize(filename) {
65
- return new RollupModuleRequest(this.context, exports.virtualPrefix + filename, this.fromFile, this.meta, false, undefined, this.queryParams, this.importerQueryParams);
45
+ return new RollupModuleRequest(exports.virtualPrefix + filename, this.fromFile, this.meta);
66
46
  }
67
47
  withMeta(meta) {
68
- return new RollupModuleRequest(this.context, this.specifier, this.fromFile, meta, this.isNotFound, this.resolvedTo, this.queryParams, this.importerQueryParams);
69
- }
70
- notFound() {
71
- return new RollupModuleRequest(this.context, this.specifier, this.fromFile, this.meta, true, undefined, this.queryParams, this.importerQueryParams);
72
- }
73
- async defaultResolve() {
74
- if (this.isVirtual) {
75
- return {
76
- type: 'found',
77
- filename: this.specifier,
78
- result: { id: this.specifierWithQueryParams, resolvedBy: this.fromFileWithQueryParams },
79
- isVirtual: this.isVirtual,
80
- };
81
- }
82
- if (this.isNotFound) {
83
- // TODO: we can make sure this looks correct in rollup & vite output when a
84
- // user encounters it
85
- let err = new Error(`module not found ${this.specifierWithQueryParams}`);
86
- err.code = 'MODULE_NOT_FOUND';
87
- return { type: 'not_found', err };
88
- }
89
- let result = await this.context.resolve(this.specifierWithQueryParams, this.fromFileWithQueryParams, {
90
- skipSelf: true,
91
- custom: {
92
- embroider: {
93
- enableCustomResolver: false,
94
- meta: this.meta,
95
- },
96
- },
97
- });
98
- if (result) {
99
- let { pathname } = new URL(result.id, 'http://example.com');
100
- return { type: 'found', filename: pathname, result, isVirtual: this.isVirtual };
101
- }
102
- else {
103
- return { type: 'not_found', err: undefined };
104
- }
105
- }
106
- resolveTo(resolution) {
107
- return new RollupModuleRequest(this.context, this.specifier, this.fromFile, this.meta, this.isNotFound, resolution, this.queryParams, this.importerQueryParams);
48
+ return new RollupModuleRequest(this.specifier, this.fromFile, meta);
108
49
  }
109
50
  }
110
51
  exports.RollupModuleRequest = RollupModuleRequest;
@@ -1 +1 @@
1
- {"version":3,"file":"request.js","sourceRoot":"","sources":["request.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ModuleRequest, Resolution } from '@embroider/core';\nimport { cleanUrl, getUrlQueryParams } from '@embroider/core';\nimport type { PluginContext, ResolveIdResult } from 'rollup';\n\nexport const virtualPrefix = 'embroider_virtual:';\n\nexport class RollupModuleRequest implements ModuleRequest {\n static from(\n context: PluginContext,\n source: string,\n importer: string | undefined,\n custom: Record<string, any> | undefined\n ): RollupModuleRequest | undefined {\n if (!(custom?.embroider?.enableCustomResolver ?? true)) {\n return;\n }\n if (source && importer && source[0] !== '\\0') {\n let nonVirtual: string;\n if (importer.startsWith(virtualPrefix)) {\n nonVirtual = importer.slice(virtualPrefix.length);\n } else {\n nonVirtual = importer;\n }\n\n // strip query params off the importer\n let fromFile = cleanUrl(nonVirtual);\n let importerQueryParams = getUrlQueryParams(nonVirtual);\n\n // strip query params off the source but keep track of them\n // we use regexp-based methods over a URL object because the\n // source can be a relative path.\n let cleanSource = cleanUrl(source);\n let queryParams = getUrlQueryParams(source);\n\n return new RollupModuleRequest(\n context,\n cleanSource,\n fromFile,\n custom?.embroider?.meta,\n false,\n undefined,\n queryParams,\n importerQueryParams\n );\n }\n }\n\n private constructor(\n private context: PluginContext,\n readonly specifier: string,\n readonly fromFile: string,\n readonly meta: Record<string, any> | undefined,\n readonly isNotFound: boolean,\n readonly resolvedTo: Resolution<ResolveIdResult> | undefined,\n private queryParams: string,\n private importerQueryParams: string\n ) {}\n\n get debugType() {\n return 'rollup';\n }\n\n get isVirtual(): boolean {\n return this.specifier.startsWith(virtualPrefix);\n }\n\n private get specifierWithQueryParams(): string {\n return `${this.specifier}${this.queryParams}`;\n }\n\n private get fromFileWithQueryParams(): string {\n return `${this.fromFile}${this.importerQueryParams}`;\n }\n\n alias(newSpecifier: string) {\n return new RollupModuleRequest(\n this.context,\n newSpecifier,\n this.fromFile,\n this.meta,\n false,\n undefined,\n this.queryParams,\n this.importerQueryParams\n ) as this;\n }\n rehome(newFromFile: string) {\n if (this.fromFile === newFromFile) {\n return this;\n } else {\n return new RollupModuleRequest(\n this.context,\n this.specifier,\n newFromFile,\n this.meta,\n false,\n undefined,\n this.queryParams,\n this.importerQueryParams\n ) as this;\n }\n }\n virtualize(filename: string) {\n return new RollupModuleRequest(\n this.context,\n virtualPrefix + filename,\n this.fromFile,\n this.meta,\n false,\n undefined,\n this.queryParams,\n this.importerQueryParams\n ) as this;\n }\n withMeta(meta: Record<string, any> | undefined): this {\n return new RollupModuleRequest(\n this.context,\n this.specifier,\n this.fromFile,\n meta,\n this.isNotFound,\n this.resolvedTo,\n this.queryParams,\n this.importerQueryParams\n ) as this;\n }\n notFound(): this {\n return new RollupModuleRequest(\n this.context,\n this.specifier,\n this.fromFile,\n this.meta,\n true,\n undefined,\n this.queryParams,\n this.importerQueryParams\n ) as this;\n }\n async defaultResolve(): Promise<Resolution<ResolveIdResult>> {\n if (this.isVirtual) {\n return {\n type: 'found',\n filename: this.specifier,\n result: { id: this.specifierWithQueryParams, resolvedBy: this.fromFileWithQueryParams },\n isVirtual: this.isVirtual,\n };\n }\n if (this.isNotFound) {\n // TODO: we can make sure this looks correct in rollup & vite output when a\n // user encounters it\n let err = new Error(`module not found ${this.specifierWithQueryParams}`);\n (err as any).code = 'MODULE_NOT_FOUND';\n return { type: 'not_found', err };\n }\n let result = await this.context.resolve(this.specifierWithQueryParams, this.fromFileWithQueryParams, {\n skipSelf: true,\n custom: {\n embroider: {\n enableCustomResolver: false,\n meta: this.meta,\n },\n },\n });\n if (result) {\n let { pathname } = new URL(result.id, 'http://example.com');\n return { type: 'found', filename: pathname, result, isVirtual: this.isVirtual };\n } else {\n return { type: 'not_found', err: undefined };\n }\n }\n\n resolveTo(resolution: Resolution<ResolveIdResult>): this {\n return new RollupModuleRequest(\n this.context,\n this.specifier,\n this.fromFile,\n this.meta,\n this.isNotFound,\n resolution,\n this.queryParams,\n this.importerQueryParams\n ) as this;\n }\n}\n"]}
1
+ {"version":3,"file":"request.js","sourceRoot":"","sources":["request.ts"],"names":[],"mappings":";;;AACA,0CAA2C;AAE9B,QAAA,aAAa,GAAG,oBAAoB,CAAC;AAElD,MAAa,mBAAmB;IAC9B,MAAM,CAAC,IAAI,CACT,MAAc,EACd,QAA4B,EAC5B,MAAuC;;QAEvC,IAAI,CAAC,CAAC,MAAA,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,0CAAE,oBAAoB,mCAAI,IAAI,CAAC,EAAE,CAAC;YACvD,OAAO;QACT,CAAC;QAED,IAAI,MAAM,IAAI,QAAQ,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;YAC7C,IAAI,UAAkB,CAAC;YACvB,IAAI,QAAQ,CAAC,UAAU,CAAC,qBAAa,CAAC,EAAE,CAAC;gBACvC,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,qBAAa,CAAC,MAAM,CAAC,CAAC;YACpD,CAAC;iBAAM,CAAC;gBACN,UAAU,GAAG,QAAQ,CAAC;YACxB,CAAC;YAED,sCAAsC;YACtC,IAAI,QAAQ,GAAG,IAAA,eAAQ,EAAC,UAAU,CAAC,CAAC;YACpC,OAAO,IAAI,mBAAmB,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,0CAAE,IAAI,CAAC,CAAC;QAC5E,CAAC;IACH,CAAC;IAED,YACW,SAAiB,EACjB,QAAgB,EAChB,IAAqC;QAFrC,cAAS,GAAT,SAAS,CAAQ;QACjB,aAAQ,GAAR,QAAQ,CAAQ;QAChB,SAAI,GAAJ,IAAI,CAAiC;IAC7C,CAAC;IAEJ,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,qBAAa,CAAC,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,YAAoB;QACxB,OAAO,IAAI,mBAAmB,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAS,CAAC;IACjF,CAAC;IACD,MAAM,CAAC,WAAmB;QACxB,IAAI,IAAI,CAAC,QAAQ,KAAK,WAAW,EAAE,CAAC;YAClC,OAAO,IAAI,CAAC;QACd,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,EAAE,IAAI,CAAC,IAAI,CAAS,CAAC;QACjF,CAAC;IACH,CAAC;IACD,UAAU,CAAC,QAAgB;QACzB,OAAO,IAAI,mBAAmB,CAAC,qBAAa,GAAG,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAS,CAAC;IAC7F,CAAC;IACD,QAAQ,CAAC,IAAqC;QAC5C,OAAO,IAAI,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAS,CAAC;IAC9E,CAAC;CACF;AAlDD,kDAkDC","sourcesContent":["import type { ModuleRequest } from '@embroider/core';\nimport { cleanUrl } from '@embroider/core';\n\nexport const virtualPrefix = 'embroider_virtual:';\n\nexport class RollupModuleRequest implements ModuleRequest {\n static from(\n source: string,\n importer: string | undefined,\n custom: Record<string, any> | undefined\n ): RollupModuleRequest | undefined {\n if (!(custom?.embroider?.enableCustomResolver ?? true)) {\n return;\n }\n\n if (source && importer && source[0] !== '\\0') {\n let nonVirtual: string;\n if (importer.startsWith(virtualPrefix)) {\n nonVirtual = importer.slice(virtualPrefix.length);\n } else {\n nonVirtual = importer;\n }\n\n // strip query params off the importer\n let fromFile = cleanUrl(nonVirtual);\n return new RollupModuleRequest(source, fromFile, custom?.embroider?.meta);\n }\n }\n\n private constructor(\n readonly specifier: string,\n readonly fromFile: string,\n readonly meta: Record<string, any> | undefined\n ) {}\n\n get isVirtual(): boolean {\n return this.specifier.startsWith(virtualPrefix);\n }\n\n alias(newSpecifier: string) {\n return new RollupModuleRequest(newSpecifier, this.fromFile, this.meta) as this;\n }\n rehome(newFromFile: string) {\n if (this.fromFile === newFromFile) {\n return this;\n } else {\n return new RollupModuleRequest(this.specifier, newFromFile, this.meta) as this;\n }\n }\n virtualize(filename: string) {\n return new RollupModuleRequest(virtualPrefix + filename, this.fromFile, this.meta) as this;\n }\n withMeta(meta: Record<string, any> | undefined): this {\n return new RollupModuleRequest(this.specifier, this.fromFile, meta) as this;\n }\n}\n"]}
package/src/resolver.js CHANGED
@@ -4,51 +4,26 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.resolver = resolver;
7
+ const path_1 = require("path");
7
8
  const core_1 = require("@embroider/core");
9
+ const fs_extra_1 = require("fs-extra");
8
10
  const request_1 = require("./request");
9
11
  const assert_never_1 = __importDefault(require("assert-never"));
10
- const debug_1 = __importDefault(require("debug"));
11
- const path_1 = require("path");
12
- const esbuild_request_1 = require("./esbuild-request");
13
- const debug = (0, debug_1.default)('embroider:vite');
14
12
  function resolver() {
15
- let resolverLoader = new core_1.ResolverLoader(process.cwd());
16
- let server;
17
- let virtualDeps = new Map();
13
+ let resolverOptions = (0, fs_extra_1.readJSONSync)((0, path_1.join)((0, core_1.locateEmbroiderWorkingDir)(process.cwd()), 'resolver.json'));
14
+ let resolver = new core_1.Resolver(resolverOptions);
18
15
  return {
19
16
  name: 'embroider-resolver',
20
17
  enforce: 'pre',
21
- configureServer(s) {
22
- server = s;
23
- server.watcher.on('all', (_eventName, path) => {
24
- for (let [id, watches] of virtualDeps) {
25
- for (let watch of watches) {
26
- if (path.startsWith(watch)) {
27
- debug('Invalidate %s because %s', id, path);
28
- server.moduleGraph.onFileChange(id);
29
- let m = server.moduleGraph.getModuleById(id);
30
- if (m) {
31
- server.reloadModule(m);
32
- }
33
- }
34
- }
35
- }
36
- });
37
- },
38
18
  async resolveId(source, importer, options) {
39
- var _a;
40
- if ((_a = options.custom) === null || _a === void 0 ? void 0 : _a.depScan) {
41
- return await observeDepScan(this, source, importer, options);
42
- }
43
- let request = request_1.RollupModuleRequest.from(this, source, importer, options.custom);
19
+ let request = request_1.RollupModuleRequest.from(source, importer, options.custom);
44
20
  if (!request) {
45
21
  // fallthrough to other rollup plugins
46
22
  return null;
47
23
  }
48
- let resolution = await resolverLoader.resolver.resolve(request);
24
+ let resolution = await resolver.resolve(request, defaultResolve(this));
49
25
  switch (resolution.type) {
50
26
  case 'found':
51
- case 'ignored':
52
27
  return resolution.result;
53
28
  case 'not_found':
54
29
  return null;
@@ -58,45 +33,33 @@ function resolver() {
58
33
  },
59
34
  load(id) {
60
35
  if (id.startsWith(request_1.virtualPrefix)) {
61
- let { pathname } = new URL(id, 'http://example.com');
62
- let { src, watches } = (0, core_1.virtualContent)(pathname.slice(request_1.virtualPrefix.length + 1), resolverLoader.resolver);
63
- virtualDeps.set(id, watches);
64
- server === null || server === void 0 ? void 0 : server.watcher.add(watches);
65
- return src;
36
+ return (0, core_1.virtualContent)(id.slice(request_1.virtualPrefix.length), resolver);
66
37
  }
67
38
  },
68
- buildEnd() {
69
- this.emitFile({
70
- type: 'asset',
71
- fileName: '@embroider/core/vendor.js',
72
- source: (0, core_1.virtualContent)((0, path_1.resolve)(resolverLoader.resolver.options.engines[0].root, '-embroider-vendor.js'), resolverLoader.resolver).src,
73
- });
74
- this.emitFile({
75
- type: 'asset',
76
- fileName: '@embroider/core/test-support.js',
77
- source: (0, core_1.virtualContent)((0, path_1.resolve)(resolverLoader.resolver.options.engines[0].root, '-embroider-test-support.js'), resolverLoader.resolver).src,
78
- });
79
- },
80
39
  };
81
40
  }
82
- // During depscan, we have a wildly different job than during normal
83
- // usage. Embroider's esbuild resolver plugin replaces this rollup
84
- // resolver plugin for actually doing resolving, so we don't do any of
85
- // that. But we are still well-positioned to observe what vite's rollup
86
- // resolver plugin is doing, and that is important because vite's
87
- // esbuild depscan plugin will always obscure the results before
88
- // embroider's esbuild resolver plugin can see them. It obscures the
89
- // results by marking *both* "not found" and "this is a third-party
90
- // package" as "external: true". We really care about the difference
91
- // between the two, since we have fallback behaviors that should apply
92
- // to "not found" that should not apply to successfully discovered
93
- // third-party packages.
94
- async function observeDepScan(context, source, importer, options) {
95
- let result = await context.resolve(source, importer, {
96
- ...options,
97
- skipSelf: true,
98
- });
99
- (0, esbuild_request_1.writeStatus)(source, result ? 'found' : 'not_found');
100
- return result;
41
+ function defaultResolve(context) {
42
+ return async (request) => {
43
+ if (request.isVirtual) {
44
+ return {
45
+ type: 'found',
46
+ result: { id: request.specifier, resolvedBy: request.fromFile },
47
+ };
48
+ }
49
+ let result = await context.resolve(request.specifier, request.fromFile, {
50
+ skipSelf: true,
51
+ custom: {
52
+ embroider: {
53
+ meta: request.meta,
54
+ },
55
+ },
56
+ });
57
+ if (result) {
58
+ return { type: 'found', result };
59
+ }
60
+ else {
61
+ return { type: 'not_found', err: undefined };
62
+ }
63
+ };
101
64
  }
102
65
  //# sourceMappingURL=resolver.js.map