ember-scoped-css 1.1.0 → 2.0.0
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/README.md +203 -47
- package/dist/cjs/all-Du43cBa9.cjs +1308 -0
- package/dist/cjs/all.cjs +3 -0
- package/dist/cjs/babel.cjs +9 -0
- package/dist/cjs/rollup.cjs +8 -0
- package/dist/cjs/vite.cjs +8 -0
- package/dist/runtime/index.d.ts +11 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +12 -8
- package/dist/runtime/index.js.map +1 -7
- package/{declarations → dist}/runtime/test-support.d.ts +5 -2
- package/dist/runtime/test-support.d.ts.map +1 -0
- package/dist/runtime/test-support.js +357 -182
- package/dist/runtime/test-support.js.map +1 -7
- package/package.json +21 -24
- package/src/build/babel-plugin.js +4 -1
- package/src/build/public-exports/all.js +10 -0
- package/src/build/public-exports/babel.js +5 -0
- package/src/build/public-exports/rollup.js +3 -0
- package/src/build/public-exports/vite.js +3 -0
- package/src/build/scoped-css-unplugin.js +10 -33
- package/src/build/template-plugin.js +9 -19
- package/src/build/template-plugin.test.ts +108 -19
- package/src/build/unplugin-colocated.js +103 -0
- package/src/build/unplugin-inline.js +71 -0
- package/src/lib/css/rewrite.js +8 -8
- package/src/lib/css/rewrite.test.ts +69 -128
- package/src/lib/path/const.js +19 -0
- package/src/lib/path/hash-from-absolute-path.js +3 -2
- package/src/lib/path/template-transform-paths.js +3 -2
- package/src/lib/path/utils.appPath.test.ts +2 -2
- package/src/lib/path/utils.hashFrom.test.ts +2 -2
- package/src/lib/path/utils.js +63 -20
- package/src/lib/request.js +58 -33
- package/src/runtime/index.ts +1 -1
- package/declarations/build/template-plugin.d.ts +0 -7
- package/declarations/build/template-plugin.d.ts.map +0 -1
- package/declarations/build/template-plugin.test.d.ts +0 -2
- package/declarations/build/template-plugin.test.d.ts.map +0 -1
- package/declarations/lib/css/rewrite.d.ts +0 -2
- package/declarations/lib/css/rewrite.d.ts.map +0 -1
- package/declarations/lib/css/rewrite.test.d.ts +0 -2
- package/declarations/lib/css/rewrite.test.d.ts.map +0 -1
- package/declarations/lib/css/utils.d.ts +0 -29
- package/declarations/lib/css/utils.d.ts.map +0 -1
- package/declarations/lib/path/hash-from-absolute-path.d.ts +0 -3
- package/declarations/lib/path/hash-from-absolute-path.d.ts.map +0 -1
- package/declarations/lib/path/hash-from-absolute-path.test.d.ts +0 -2
- package/declarations/lib/path/hash-from-absolute-path.test.d.ts.map +0 -1
- package/declarations/lib/path/hash-from-module-path.d.ts +0 -31
- package/declarations/lib/path/hash-from-module-path.d.ts.map +0 -1
- package/declarations/lib/path/md5.d.ts +0 -12
- package/declarations/lib/path/md5.d.ts.map +0 -1
- package/declarations/lib/path/template-transform-paths.d.ts +0 -11
- package/declarations/lib/path/template-transform-paths.d.ts.map +0 -1
- package/declarations/lib/path/template-transform-paths.test.d.ts +0 -2
- package/declarations/lib/path/template-transform-paths.test.d.ts.map +0 -1
- package/declarations/lib/path/utils.appPath.test.d.ts +0 -2
- package/declarations/lib/path/utils.appPath.test.d.ts.map +0 -1
- package/declarations/lib/path/utils.d.ts +0 -94
- package/declarations/lib/path/utils.d.ts.map +0 -1
- package/declarations/lib/path/utils.findWorkspacePath.test.d.ts +0 -2
- package/declarations/lib/path/utils.findWorkspacePath.test.d.ts.map +0 -1
- package/declarations/lib/path/utils.hashFrom.test.d.ts +0 -2
- package/declarations/lib/path/utils.hashFrom.test.d.ts.map +0 -1
- package/declarations/lib/path/utils.isRelevantFile.test.d.ts +0 -2
- package/declarations/lib/path/utils.isRelevantFile.test.d.ts.map +0 -1
- package/declarations/lib/path/utils.paths.test.d.ts +0 -5
- package/declarations/lib/path/utils.paths.test.d.ts.map +0 -1
- package/declarations/lib/renameClass.d.ts +0 -9
- package/declarations/lib/renameClass.d.ts.map +0 -1
- package/declarations/lib/request.d.ts +0 -8
- package/declarations/lib/request.d.ts.map +0 -1
- package/declarations/lib/rewriteHbs.d.ts +0 -17
- package/declarations/lib/rewriteHbs.d.ts.map +0 -1
- package/declarations/runtime/index.d.ts +0 -8
- package/declarations/runtime/index.d.ts.map +0 -1
- package/declarations/runtime/test-support.d.ts.map +0 -1
- package/dist/cjs/babel-plugin.cjs +0 -176
- package/dist/cjs/index.cjs +0 -968
- package/dist/cjs/template-plugin.cjs +0 -856
- package/src/build/index.js +0 -7
- package/src/build/vite.js +0 -3
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Appends a suffix to a class name during build time.
|
|
3
|
-
* This function is not available at runtime and is removed.
|
|
4
|
-
*
|
|
5
|
-
* @param {string} className the class, defined within the co-located CSS to have a suffix appended to it during build time.
|
|
6
|
-
*/
|
|
7
|
-
export declare function scopedClass(className: string): string;
|
|
8
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/runtime/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAIrD"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-support.d.ts","sourceRoot":"","sources":["../../src/runtime/test-support.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,WAAW,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAAC;AAExD;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,wBAAgB,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,CAAC"}
|
|
@@ -1,176 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
|
|
30
|
-
// src/build/babel-plugin.js
|
|
31
|
-
var babel_plugin_exports = {};
|
|
32
|
-
__export(babel_plugin_exports, {
|
|
33
|
-
default: () => babel_plugin_default
|
|
34
|
-
});
|
|
35
|
-
module.exports = __toCommonJS(babel_plugin_exports);
|
|
36
|
-
|
|
37
|
-
// src/lib/path/utils.js
|
|
38
|
-
var import_node_assert = __toESM(require("node:assert"), 1);
|
|
39
|
-
var import_node_fs = __toESM(require("node:fs"), 1);
|
|
40
|
-
var import_node_module = require("node:module");
|
|
41
|
-
var import_node_path = __toESM(require("node:path"), 1);
|
|
42
|
-
var import_meta = {};
|
|
43
|
-
var here = import_meta.url;
|
|
44
|
-
var ourRequire = globalThis.require ? globalThis.require : here && (0, import_node_module.createRequire)(here);
|
|
45
|
-
if (!ourRequire) {
|
|
46
|
-
ourRequire = require;
|
|
47
|
-
}
|
|
48
|
-
var IRRELEVANT_PATHS = ["node_modules/.pnpm", "__vite-"];
|
|
49
|
-
var UNSUPPORTED_DIRECTORIES = /* @__PURE__ */ new Set(["tests"]);
|
|
50
|
-
var CWD = process.cwd();
|
|
51
|
-
function isRelevantFile(fileName, { additionalRoots, cwd }) {
|
|
52
|
-
if (fileName.startsWith("/testem")) return false;
|
|
53
|
-
if (fileName.startsWith("\0")) return false;
|
|
54
|
-
if (fileName.match(/^[a-zA-Z]/)) return false;
|
|
55
|
-
if (fileName.startsWith("/@embroider")) return false;
|
|
56
|
-
if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;
|
|
57
|
-
let workspace = findWorkspacePath(fileName);
|
|
58
|
-
(0, import_node_assert.default)(cwd, `cwd was not passed to isRelevantFile`);
|
|
59
|
-
let ourWorkspace = findWorkspacePath(cwd);
|
|
60
|
-
if (workspace !== ourWorkspace) {
|
|
61
|
-
return false;
|
|
62
|
-
}
|
|
63
|
-
let local = fileName.replace(workspace, "");
|
|
64
|
-
let [, ...parts] = local.split("/").filter(Boolean);
|
|
65
|
-
if (UNSUPPORTED_DIRECTORIES.has(parts[0])) {
|
|
66
|
-
return false;
|
|
67
|
-
}
|
|
68
|
-
let roots = ["/components/", "/templates/", ...additionalRoots || []];
|
|
69
|
-
if (!roots.some((root) => fileName.includes(root))) {
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
return true;
|
|
73
|
-
}
|
|
74
|
-
var SEEN = /* @__PURE__ */ new Set();
|
|
75
|
-
function getSeen(sourcePath) {
|
|
76
|
-
if (SEEN.has(sourcePath)) return sourcePath;
|
|
77
|
-
let parts = sourcePath.split("/");
|
|
78
|
-
for (let i = parts.length - 1; i > 1; i--) {
|
|
79
|
-
let toCheck = parts.slice(0, i).join("/");
|
|
80
|
-
let seen = SEEN.has(toCheck);
|
|
81
|
-
if (seen) {
|
|
82
|
-
return toCheck;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
function findWorkspacePath(sourcePath, options) {
|
|
87
|
-
let cwd = options?.cwd ?? CWD;
|
|
88
|
-
if (sourcePath.endsWith("/")) {
|
|
89
|
-
sourcePath = sourcePath.replace(/\/$/, "");
|
|
90
|
-
}
|
|
91
|
-
let seen = getSeen(sourcePath);
|
|
92
|
-
if (seen) {
|
|
93
|
-
return seen;
|
|
94
|
-
}
|
|
95
|
-
let candidatePath = import_node_path.default.join(sourcePath, "package.json");
|
|
96
|
-
const isWorkspace = import_node_fs.default.existsSync(candidatePath);
|
|
97
|
-
if (isWorkspace) {
|
|
98
|
-
return sourcePath;
|
|
99
|
-
}
|
|
100
|
-
const packageJsonPath = findPackageJsonUp(sourcePath, { cwd });
|
|
101
|
-
if (!packageJsonPath) {
|
|
102
|
-
throw new Error(`Could not determine project for ${sourcePath}`);
|
|
103
|
-
}
|
|
104
|
-
const workspacePath = import_node_path.default.dirname(packageJsonPath);
|
|
105
|
-
SEEN.add(workspacePath);
|
|
106
|
-
return workspacePath;
|
|
107
|
-
}
|
|
108
|
-
function findPackageJsonUp(startPath, options) {
|
|
109
|
-
let cwd = options?.cwd ?? CWD;
|
|
110
|
-
let parts = startPath.split("/");
|
|
111
|
-
for (let i = parts.length - 1; i > 1; i--) {
|
|
112
|
-
let toCheck = parts.slice(0, i).join("/");
|
|
113
|
-
let packageJson = import_node_path.default.join(toCheck, "package.json");
|
|
114
|
-
let exists = import_node_fs.default.existsSync(packageJson);
|
|
115
|
-
if (exists) {
|
|
116
|
-
return packageJson;
|
|
117
|
-
}
|
|
118
|
-
if (toCheck === cwd) {
|
|
119
|
-
break;
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
return null;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
// src/build/babel-plugin.js
|
|
126
|
-
function _isRelevantFile(state, cwd) {
|
|
127
|
-
let fileName = state.file.opts.filename;
|
|
128
|
-
let additionalRoots = state.opts?.additionalRoots;
|
|
129
|
-
return isRelevantFile(fileName, {
|
|
130
|
-
additionalRoots,
|
|
131
|
-
cwd
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
var babel_plugin_default = (env, options, workingDirectory) => {
|
|
135
|
-
return {
|
|
136
|
-
visitor: {
|
|
137
|
-
Program: {
|
|
138
|
-
enter(path2, state) {
|
|
139
|
-
if (!_isRelevantFile(state, workingDirectory)) {
|
|
140
|
-
state.canSkip = true;
|
|
141
|
-
return;
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
},
|
|
145
|
-
ImportDeclaration(path2, state) {
|
|
146
|
-
if (state.canSkip) {
|
|
147
|
-
return;
|
|
148
|
-
}
|
|
149
|
-
if (path2.node.source.value === "ember-scoped-css") {
|
|
150
|
-
let specifier = path2.node.specifiers.find(
|
|
151
|
-
(x) => x.imported.name === "scopedClass"
|
|
152
|
-
);
|
|
153
|
-
if (specifier) {
|
|
154
|
-
state.file.opts.importedScopedClass = specifier.local.name;
|
|
155
|
-
}
|
|
156
|
-
if (specifier.local.name !== "scopedClass") {
|
|
157
|
-
throw new Error(
|
|
158
|
-
`The scopedClass import is a psuedo-helper, and may not be renamed as it is removed at build time.`
|
|
159
|
-
);
|
|
160
|
-
}
|
|
161
|
-
path2.remove();
|
|
162
|
-
}
|
|
163
|
-
},
|
|
164
|
-
/**
|
|
165
|
-
* Only in strict mode, do we care about remoning the scope bag reference
|
|
166
|
-
*/
|
|
167
|
-
ObjectProperty(path2, state) {
|
|
168
|
-
if (!state.file.opts?.importedScopedClass) return;
|
|
169
|
-
if (path2.node.value.type === "Identifier" && path2.node.value.name === state.file.opts?.importedScopedClass) {
|
|
170
|
-
path2.remove();
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
};
|
|
175
|
-
};
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/build/babel-plugin.js", "../../src/lib/path/utils.js"],
  "sourcesContent": ["import { isRelevantFile } from '../lib/path/utils.js';\n\nfunction _isRelevantFile(state, cwd) {\n  let fileName = state.file.opts.filename;\n  let additionalRoots = state.opts?.additionalRoots;\n\n  return isRelevantFile(fileName, {\n    additionalRoots,\n    cwd,\n  });\n}\n\n/**\n * @param {any} env - babel plugin env, env.types is most commonly used (esp in TS)\n * @param {object} options - the options for scoped-css -- this is also available in each visitor's state.opts\n * @param {string} workingDirectory\n */\nexport default (env, options, workingDirectory) => {\n  /**\n   * This babel plugin does two things:\n   * - removes the import of scopedClass, if it exists\n   *   - if scopedClass was imported, it is removed from any component's \"scope bag\"\n   *     (the scope bag being a low-level object used for passing what is \"in scope\" for a component)\n   */\n  return {\n    visitor: {\n      Program: {\n        enter(path, state) {\n          if (!_isRelevantFile(state, workingDirectory)) {\n            state.canSkip = true;\n\n            return;\n          }\n        },\n      },\n      ImportDeclaration(path, state) {\n        if (state.canSkip) {\n          return;\n        }\n\n        if (path.node.source.value === 'ember-scoped-css') {\n          let specifier = path.node.specifiers.find(\n            (x) => x.imported.name === 'scopedClass',\n          );\n\n          if (specifier) {\n            state.file.opts.importedScopedClass = specifier.local.name;\n          }\n\n          if (specifier.local.name !== 'scopedClass') {\n            throw new Error(\n              `The scopedClass import is a psuedo-helper, and may not be renamed as it is removed at build time.`,\n            );\n          }\n\n          path.remove();\n        }\n      },\n      /**\n       * Only in strict mode, do we care about remoning the scope bag reference\n       */\n      ObjectProperty(path, state) {\n        if (!state.file.opts?.importedScopedClass) return;\n\n        if (\n          path.node.value.type === 'Identifier' &&\n          path.node.value.name === state.file.opts?.importedScopedClass\n        ) {\n          path.remove();\n        }\n      },\n    },\n  };\n};\n", "import assert from 'node:assert';\nimport fsSync, { existsSync } from 'node:fs';\nimport { createRequire } from 'node:module';\nimport path from 'node:path';\n\nimport { hashFromAbsolutePath } from './hash-from-absolute-path.js';\nimport { hashFromModulePath } from './hash-from-module-path.js';\n\nexport { hashFromAbsolutePath } from './hash-from-absolute-path.js';\nexport { hashFromModulePath } from './hash-from-module-path.js';\n\nconst COMPONENT_EXTENSIONS = ['.gts', '.gjs', '.ts', '.js', '.hbs'];\n\n// CJS / ESM?\nlet here = import.meta.url;\nlet ourRequire = globalThis.require\n  ? globalThis.require\n  : here && createRequire(here);\n\nif (!ourRequire) {\n  ourRequire = require;\n}\n\nconst IRRELEVANT_PATHS = ['node_modules/.pnpm', '__vite-'];\nconst UNSUPPORTED_DIRECTORIES = new Set(['tests']);\n\nconst CWD = process.cwd();\n\n/**\n * Regardless of what the filePath format is,\n * this will try to return the correct postfix.\n *\n * @param {string} filePath\n * @returns\n */\nexport function hashFrom(filePath) {\n  if (filePath.startsWith('/')) {\n    return hashFromAbsolutePath(filePath);\n  }\n\n  return hashFromModulePath(filePath);\n}\n\n/**\n *\n */\nexport function cssHasAssociatedComponent(cssPath) {\n  return cssHasStandardFile(cssPath) || cssHasPodsFile(cssPath);\n}\n\nfunction cssHasStandardFile(id) {\n  /**\n   * Normally we don't need to check a JS path here, but when using\n   * embroider@3, we have a \"rewritten app\", which has all our source\n   * preprocessed a bit before scoped-css transformations.\n   *\n   * (In Vite, we operate more directly with the source)\n   */\n  for (let ext of COMPONENT_EXTENSIONS) {\n    let candidatePath = id.replace(/\\.css$/, ext);\n\n    if (existsSync(candidatePath)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction cssHasPodsFile(id) {\n  if (!id.endsWith('styles.css')) {\n    return;\n  }\n\n  /**\n   * Normally we don't need to check a JS path here, but when using\n   * embroider@3, we have a \"rewritten app\", which has all our source\n   * preprocessed a bit before scoped-css transformations.\n   *\n   * (In Vite, we operate more directly with the source)\n   */\n  for (let ext of COMPONENT_EXTENSIONS) {\n    let candidatePath = id.replace(/styles\\.css$/, `template${ext}`);\n\n    if (existsSync(candidatePath)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Based on ember's component location conventions,\n * this function will provide a path for where we\n * expect the CSS to live.\n *\n * For co-located structure:\n *   - components/my-component.hbs\n *   - components/my-component.css\n *\n * For nested co-located structure\n *   - components/my-component/foo.hbs\n *   - components/my-component/foo.css\n *\n * For Pods routes structure\n *   - routes/my-route/template.{hbs,js}\n *   - routes/my-route/styles.css\n *\n * Deliberately not supported:\n *   - components w/ pods -- this is deprecated in 5.10\n *\n * @param {string} fileName - the hbs, js, gjs, gts or whatever co-located path.\n * @returns {string} - expected css path\n */\nexport function cssPathFor(fileName) {\n  let withoutExt = withoutExtension(fileName);\n  let cssPath = withoutExt + '.css';\n\n  if (isPod(fileName)) {\n    cssPath = fileName\n      .replace(/template\\.js$/, 'styles.css')\n      .replace(/template\\.hbs/, 'styles.css');\n  }\n\n  return cssPath;\n}\n\n/**\n * Note that components in the \"pods\" convention will\n * never be supported.\n *\n * @param {string} filePath\n */\nexport function isPodTemplate(filePath) {\n  if (filePath.includes('/components/')) {\n    return false;\n  }\n\n  return filePath.endsWith('template.js') || filePath.endsWith('template.hbs');\n}\n\n/**\n * Note that components in the \"pods\" convention will\n * never be supported.\n *\n * Checks if a file ends with\n * - template.js\n * - template.hbs\n * - styles.css\n *\n * @param {string} filePath\n */\nexport function isPod(filePath) {\n  if (filePath.includes('/components/')) {\n    return false;\n  }\n\n  if (isPodTemplate(filePath)) {\n    return true;\n  }\n\n  return filePath.endsWith('styles.css');\n}\n\n/**\n *\n * @param {string} filePath\n * @returns the same path, but without the extension\n */\nexport function withoutExtension(filePath) {\n  let parsed = path.parse(filePath);\n\n  return path.join(parsed.dir, parsed.name);\n}\n\n/**\n * Examples for fileName\n * - absolute on-disk path\n * - in webpack\n *   - URL-absolute path, starting with /\n *\n * @param {string} fileName\n * @param {{ additionalRoots?: string[]; cwd: string }} options\n * @returns\n */\nexport function isRelevantFile(fileName, { additionalRoots, cwd }) {\n  // Fake file handled by testem server when it runs\n  if (fileName.startsWith('/testem')) return false;\n  // Private Virtual Modules\n  if (fileName.startsWith('\\0')) return false;\n  // These are not valid userland names (or are from libraries)\n  if (fileName.match(/^[a-zA-Z]/)) return false;\n  // External to us\n  if (fileName.startsWith('/@embroider')) return false;\n  if (IRRELEVANT_PATHS.some((i) => fileName.includes(i))) return false;\n\n  let workspace = findWorkspacePath(fileName);\n\n  assert(cwd, `cwd was not passed to isRelevantFile`);\n\n  let ourWorkspace = findWorkspacePath(cwd);\n\n  if (workspace !== ourWorkspace) {\n    return false;\n  }\n\n  let local = fileName.replace(workspace, '');\n  let [, ...parts] = local.split('/').filter(Boolean);\n\n  if (UNSUPPORTED_DIRECTORIES.has(parts[0])) {\n    return false;\n  }\n\n  /**\n   * Mostly pods support.\n   * folks need to opt in to pods (routes), because every pods app can be configured differently\n   */\n  let roots = ['/components/', '/templates/', ...(additionalRoots || [])];\n\n  if (!roots.some((root) => fileName.includes(root))) {\n    return;\n  }\n\n  return true;\n}\n\nexport function packageScopedPathToModulePath(packageScopedPath) {\n  /**\n   * *By convention*, `src` is omitted from component paths.\n   * We can reflect the same behavior by replacing src/\n   * with an empty string.\n   *\n   * CSS isn't emitted as a co-located module, but\n   * to keep conventions consistent across languages,\n   * we can pretend it is.\n   *\n   * Any customization beyond removing `src` and `app` is potentially confusing.\n   * If we need further customizations, we'll want to match on `exports` in the\n   * corresponding package.json\n   */\n  let packageRelative = packageScopedPath.replace(/^\\/src\\//, '/');\n\n  let parsed = path.parse(packageRelative);\n\n  if (isPod(packageRelative)) {\n    /**\n     * For pods, we chop off the whole file, and use the dir name as the \"modulePath\"\n     */\n    return parsed.dir;\n  }\n\n  /**\n   * If an extension is passed, remove it.\n   * When using packagers, folks are used to not having to specify extensions for files.\n   * Since we don't even emit css files co-located to each module,\n   * this helps us not convey a lie that a file may exist in at runtime.\n   *\n   * For example `<module-name>/components/button`.\n   * It doesn't matter what the extension is, because you can only have one css file\n   * for the button module anyway.\n   */\n  let localPackagerStylePath = path.join(parsed.dir, parsed.name);\n\n  return localPackagerStylePath;\n}\n\n/**\n * returns the app-module path of the source file\n *\n * This assumes normal ember app conventions\n *\n * which is `<package.json#name>/path-to-file`\n */\nexport function appPath(sourcePath) {\n  let workspacePath = findWorkspacePath(sourcePath);\n  let name = moduleName(sourcePath);\n\n  /**\n   *  Under embroider builds, the spec-compliant version of the app\n   * has all the files under a folder which represents the package name,\n   * rather than \"app\".\n   */\n  let packageRelative = sourcePath.replace(workspacePath, '');\n\n  /**\n   * But we also don't want 'app' -- which is present in the v1 addon pipeline\n   */\n  packageRelative = packageRelative.replace(`/app/`, `/`);\n\n  // Any of the above relpacements could accidentally give us an extra / (depending on our build environment)\n  packageRelative = packageRelative.replace('//', '/');\n\n  let localPackagerStylePath = packageScopedPathToModulePath(packageRelative);\n\n  return `${name}${localPackagerStylePath}`;\n}\n\n/**\n * To avoid hitting the filesysetm, we'll store all found\n * project paths bere, so we can, in memory,\n * get the folder where a package.json exists, rather than\n * hit the file system every time.\n */\nconst SEEN = new Set();\n\nfunction getSeen(sourcePath) {\n  if (SEEN.has(sourcePath)) return sourcePath;\n\n  let parts = sourcePath.split('/');\n\n  for (let i = parts.length - 1; i > 1; i--) {\n    let toCheck = parts.slice(0, i).join('/');\n\n    let seen = SEEN.has(toCheck);\n\n    if (seen) {\n      return toCheck;\n    }\n  }\n}\n\nexport function findWorkspacePath(sourcePath, options) {\n  let cwd = options?.cwd ?? CWD;\n\n  if (sourcePath.endsWith('/')) {\n    sourcePath = sourcePath.replace(/\\/$/, '');\n  }\n\n  let seen = getSeen(sourcePath);\n\n  if (seen) {\n    return seen;\n  }\n\n  let candidatePath = path.join(sourcePath, 'package.json');\n\n  const isWorkspace = fsSync.existsSync(candidatePath);\n\n  if (isWorkspace) {\n    return sourcePath;\n  }\n\n  const packageJsonPath = findPackageJsonUp(sourcePath, { cwd });\n\n  if (!packageJsonPath) {\n    throw new Error(`Could not determine project for ${sourcePath}`);\n  }\n\n  const workspacePath = path.dirname(packageJsonPath);\n\n  SEEN.add(workspacePath);\n\n  return workspacePath;\n}\n\nfunction findPackageJsonUp(startPath, options) {\n  let cwd = options?.cwd ?? CWD;\n  let parts = startPath.split('/');\n\n  for (let i = parts.length - 1; i > 1; i--) {\n    let toCheck = parts.slice(0, i).join('/');\n\n    let packageJson = path.join(toCheck, 'package.json');\n    let exists = fsSync.existsSync(packageJson);\n\n    if (exists) {\n      return packageJson;\n    }\n\n    // Don't traverse all the way to the root of the file system.\n    if (toCheck === cwd) {\n      break;\n    }\n  }\n\n  return null;\n}\n\nconst MANIFEST_CACHE = new Map();\n\n/**\n * Will return the package.json#name, or config/environment#moudlePrefix (if v1 app)\n *\n * @param {string} sourcePath\n */\nexport function moduleName(sourcePath) {\n  const workspace = findWorkspacePath(sourcePath);\n  const manifest = getManifest(workspace);\n\n  return manifest.name;\n}\n\n/**\n * @param {string} workspace\n */\nfunction getManifest(workspace) {\n  let existing = MANIFEST_CACHE.get(workspace);\n\n  if (existing) {\n    return existing;\n  }\n\n  let buffer = fsSync.readFileSync(path.join(workspace, 'package.json'));\n  let content = buffer.toString();\n  let json = JSON.parse(content);\n\n  MANIFEST_CACHE.set(workspace, json);\n\n  return json;\n}\n"],
  "mappings": "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",
  "names": ["assert", "path", "fsSync", "path"]
}

|