@angular-devkit/build-angular 16.2.0-next.1 → 16.2.0-next.3
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 +22 -21
- package/src/builders/app-shell/render-worker.js +6 -2
- package/src/builders/application/execute-build.js +40 -8
- package/src/builders/application/options.d.ts +14 -1
- package/src/builders/application/options.js +33 -3
- package/src/builders/application/schema.d.ts +62 -2
- package/src/builders/application/schema.js +1 -1
- package/src/builders/application/schema.json +62 -0
- package/src/builders/browser-esbuild/builder-status-warnings.d.ts +1 -1
- package/src/builders/browser-esbuild/builder-status-warnings.js +1 -1
- package/src/builders/browser-esbuild/schema.d.ts +17 -1
- package/src/builders/browser-esbuild/schema.js +1 -1
- package/src/builders/browser-esbuild/schema.json +1 -0
- package/src/builders/dev-server/builder.js +3 -2
- package/src/builders/dev-server/vite-server.d.ts +1 -1
- package/src/builders/dev-server/vite-server.js +82 -37
- package/src/builders/jest/index.js +2 -2
- package/src/tools/babel/plugins/adjust-typescript-enums.js +21 -31
- package/src/tools/babel/presets/application.d.ts +1 -0
- package/src/tools/babel/presets/application.js +43 -41
- package/src/tools/babel/webpack-loader.d.ts +0 -1
- package/src/tools/babel/webpack-loader.js +3 -23
- package/src/tools/esbuild/angular/angular-host.js +5 -2
- package/src/tools/esbuild/angular/compilation/angular-compilation.js +2 -1
- package/src/tools/esbuild/application-code-bundle.js +58 -24
- package/src/tools/esbuild/index-html-generator.d.ts +6 -2
- package/src/tools/esbuild/index-html-generator.js +41 -13
- package/src/tools/esbuild/javascript-transformer-worker.js +25 -6
- package/src/tools/esbuild/stylesheets/sass-language.js +58 -28
- package/src/tools/esbuild/stylesheets/stylesheet-plugin-factory.d.ts +10 -0
- package/src/tools/esbuild/stylesheets/stylesheet-plugin-factory.js +29 -14
- package/src/tools/sass/lexer.d.ts +29 -0
- package/src/tools/sass/lexer.js +248 -0
- package/src/tools/sass/rebasing-importer.d.ts +5 -2
- package/src/tools/sass/rebasing-importer.js +47 -153
- package/src/tools/sass/sass-service.d.ts +5 -0
- package/src/tools/sass/sass-service.js +1 -1
- package/src/utils/server-rendering/esm-in-memory-file-loader.d.ts +11 -0
- package/src/utils/server-rendering/esm-in-memory-file-loader.js +53 -0
- package/src/utils/server-rendering/prerender.d.ts +22 -0
- package/src/utils/server-rendering/prerender.js +127 -0
- package/src/utils/server-rendering/render-page.d.ts +38 -0
- package/src/utils/server-rendering/render-page.js +63 -0
- package/src/utils/server-rendering/render-worker.d.ts +18 -0
- package/src/utils/server-rendering/render-worker.js +20 -0
|
@@ -15,6 +15,32 @@ const magic_string_1 = __importDefault(require("magic-string"));
|
|
|
15
15
|
const node_fs_1 = require("node:fs");
|
|
16
16
|
const node_path_1 = require("node:path");
|
|
17
17
|
const node_url_1 = require("node:url");
|
|
18
|
+
const lexer_1 = require("./lexer");
|
|
19
|
+
/**
|
|
20
|
+
* A prefix that is added to import and use directive specifiers that should be resolved
|
|
21
|
+
* as modules and that will contain added resolve directory information.
|
|
22
|
+
*
|
|
23
|
+
* This functionality is used to workaround the Sass limitation that it does not provide the
|
|
24
|
+
* importer file to custom resolution plugins.
|
|
25
|
+
*/
|
|
26
|
+
const MODULE_RESOLUTION_PREFIX = '__NG_PACKAGE__';
|
|
27
|
+
function packModuleSpecifier(specifier, resolveDir) {
|
|
28
|
+
const packed = MODULE_RESOLUTION_PREFIX + ';' + resolveDir + ';' + specifier;
|
|
29
|
+
// Normalize path separators and escape characters
|
|
30
|
+
// https://developer.mozilla.org/en-US/docs/Web/CSS/url#syntax
|
|
31
|
+
const normalizedPacked = packed.replace(/\\/g, '/').replace(/[()\s'"]/g, '\\$&');
|
|
32
|
+
return normalizedPacked;
|
|
33
|
+
}
|
|
34
|
+
function unpackModuleSpecifier(specifier) {
|
|
35
|
+
if (!specifier.startsWith(`${MODULE_RESOLUTION_PREFIX};`)) {
|
|
36
|
+
return { specifier };
|
|
37
|
+
}
|
|
38
|
+
const values = specifier.split(';', 3);
|
|
39
|
+
return {
|
|
40
|
+
specifier: values[2],
|
|
41
|
+
resolveDir: values[1],
|
|
42
|
+
};
|
|
43
|
+
}
|
|
18
44
|
/**
|
|
19
45
|
* A Sass Importer base class that provides the load logic to rebase all `url()` functions
|
|
20
46
|
* within a stylesheet. The rebasing will ensure that the URLs in the output of the Sass compiler
|
|
@@ -42,7 +68,7 @@ class UrlRebasingImporter {
|
|
|
42
68
|
let contents = (0, node_fs_1.readFileSync)(stylesheetPath, 'utf-8');
|
|
43
69
|
// Rebase any URLs that are found
|
|
44
70
|
let updatedContents;
|
|
45
|
-
for (const { start, end, value } of findUrls(contents)) {
|
|
71
|
+
for (const { start, end, value } of (0, lexer_1.findUrls)(contents)) {
|
|
46
72
|
// Skip if value is empty or a Sass variable
|
|
47
73
|
if (value.length === 0 || value.startsWith('$')) {
|
|
48
74
|
continue;
|
|
@@ -58,6 +84,21 @@ class UrlRebasingImporter {
|
|
|
58
84
|
updatedContents ?? (updatedContents = new magic_string_1.default(contents));
|
|
59
85
|
updatedContents.update(start, end, rebasedUrl);
|
|
60
86
|
}
|
|
87
|
+
// Add resolution directory information to module specifiers to facilitate resolution
|
|
88
|
+
for (const { start, end, specifier } of (0, lexer_1.findImports)(contents)) {
|
|
89
|
+
// Currently only provide directory information for known/common packages:
|
|
90
|
+
// * `@material/`
|
|
91
|
+
// * `@angular/`
|
|
92
|
+
//
|
|
93
|
+
// Comprehensive pre-resolution support may be added in the future. This is complicated by CSS/Sass not
|
|
94
|
+
// requiring a `./` or `../` prefix to signify relative paths. A bare specifier could be either relative
|
|
95
|
+
// or a module specifier. To differentiate, a relative resolution would need to be attempted first.
|
|
96
|
+
if (!specifier.startsWith('@angular/') && !specifier.startsWith('@material/')) {
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
updatedContents ?? (updatedContents = new magic_string_1.default(contents));
|
|
100
|
+
updatedContents.update(start, end, `"${packModuleSpecifier(specifier, stylesheetDirectory)}"`);
|
|
101
|
+
}
|
|
61
102
|
if (updatedContents) {
|
|
62
103
|
contents = updatedContents.toString();
|
|
63
104
|
if (this.rebaseSourceMaps) {
|
|
@@ -89,155 +130,6 @@ class UrlRebasingImporter {
|
|
|
89
130
|
};
|
|
90
131
|
}
|
|
91
132
|
}
|
|
92
|
-
/**
|
|
93
|
-
* Determines if a unicode code point is a CSS whitespace character.
|
|
94
|
-
* @param code The unicode code point to test.
|
|
95
|
-
* @returns true, if the code point is CSS whitespace; false, otherwise.
|
|
96
|
-
*/
|
|
97
|
-
function isWhitespace(code) {
|
|
98
|
-
// Based on https://www.w3.org/TR/css-syntax-3/#whitespace
|
|
99
|
-
switch (code) {
|
|
100
|
-
case 0x0009: // tab
|
|
101
|
-
case 0x0020: // space
|
|
102
|
-
case 0x000a: // line feed
|
|
103
|
-
case 0x000c: // form feed
|
|
104
|
-
case 0x000d: // carriage return
|
|
105
|
-
return true;
|
|
106
|
-
default:
|
|
107
|
-
return false;
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Scans a CSS or Sass file and locates all valid url function values as defined by the CSS
|
|
112
|
-
* syntax specification.
|
|
113
|
-
* @param contents A string containing a CSS or Sass file to scan.
|
|
114
|
-
* @returns An iterable that yields each CSS url function value found.
|
|
115
|
-
*/
|
|
116
|
-
function* findUrls(contents) {
|
|
117
|
-
let pos = 0;
|
|
118
|
-
let width = 1;
|
|
119
|
-
let current = -1;
|
|
120
|
-
const next = () => {
|
|
121
|
-
pos += width;
|
|
122
|
-
current = contents.codePointAt(pos) ?? -1;
|
|
123
|
-
width = current > 0xffff ? 2 : 1;
|
|
124
|
-
return current;
|
|
125
|
-
};
|
|
126
|
-
// Based on https://www.w3.org/TR/css-syntax-3/#consume-ident-like-token
|
|
127
|
-
while ((pos = contents.indexOf('url(', pos)) !== -1) {
|
|
128
|
-
// Set to position of the (
|
|
129
|
-
pos += 3;
|
|
130
|
-
width = 1;
|
|
131
|
-
// Consume all leading whitespace
|
|
132
|
-
while (isWhitespace(next())) {
|
|
133
|
-
/* empty */
|
|
134
|
-
}
|
|
135
|
-
// Initialize URL state
|
|
136
|
-
const url = { start: pos, end: -1, value: '' };
|
|
137
|
-
let complete = false;
|
|
138
|
-
// If " or ', then consume the value as a string
|
|
139
|
-
if (current === 0x0022 || current === 0x0027) {
|
|
140
|
-
const ending = current;
|
|
141
|
-
// Based on https://www.w3.org/TR/css-syntax-3/#consume-string-token
|
|
142
|
-
while (!complete) {
|
|
143
|
-
switch (next()) {
|
|
144
|
-
case -1: // EOF
|
|
145
|
-
return;
|
|
146
|
-
case 0x000a: // line feed
|
|
147
|
-
case 0x000c: // form feed
|
|
148
|
-
case 0x000d: // carriage return
|
|
149
|
-
// Invalid
|
|
150
|
-
complete = true;
|
|
151
|
-
break;
|
|
152
|
-
case 0x005c: // \ -- character escape
|
|
153
|
-
// If not EOF or newline, add the character after the escape
|
|
154
|
-
switch (next()) {
|
|
155
|
-
case -1:
|
|
156
|
-
return;
|
|
157
|
-
case 0x000a: // line feed
|
|
158
|
-
case 0x000c: // form feed
|
|
159
|
-
case 0x000d: // carriage return
|
|
160
|
-
// Skip when inside a string
|
|
161
|
-
break;
|
|
162
|
-
default:
|
|
163
|
-
// TODO: Handle hex escape codes
|
|
164
|
-
url.value += String.fromCodePoint(current);
|
|
165
|
-
break;
|
|
166
|
-
}
|
|
167
|
-
break;
|
|
168
|
-
case ending:
|
|
169
|
-
// Full string position should include the quotes for replacement
|
|
170
|
-
url.end = pos + 1;
|
|
171
|
-
complete = true;
|
|
172
|
-
yield url;
|
|
173
|
-
break;
|
|
174
|
-
default:
|
|
175
|
-
url.value += String.fromCodePoint(current);
|
|
176
|
-
break;
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
next();
|
|
180
|
-
continue;
|
|
181
|
-
}
|
|
182
|
-
// Based on https://www.w3.org/TR/css-syntax-3/#consume-url-token
|
|
183
|
-
while (!complete) {
|
|
184
|
-
switch (current) {
|
|
185
|
-
case -1: // EOF
|
|
186
|
-
return;
|
|
187
|
-
case 0x0022: // "
|
|
188
|
-
case 0x0027: // '
|
|
189
|
-
case 0x0028: // (
|
|
190
|
-
// Invalid
|
|
191
|
-
complete = true;
|
|
192
|
-
break;
|
|
193
|
-
case 0x0029: // )
|
|
194
|
-
// URL is valid and complete
|
|
195
|
-
url.end = pos;
|
|
196
|
-
complete = true;
|
|
197
|
-
break;
|
|
198
|
-
case 0x005c: // \ -- character escape
|
|
199
|
-
// If not EOF or newline, add the character after the escape
|
|
200
|
-
switch (next()) {
|
|
201
|
-
case -1: // EOF
|
|
202
|
-
return;
|
|
203
|
-
case 0x000a: // line feed
|
|
204
|
-
case 0x000c: // form feed
|
|
205
|
-
case 0x000d: // carriage return
|
|
206
|
-
// Invalid
|
|
207
|
-
complete = true;
|
|
208
|
-
break;
|
|
209
|
-
default:
|
|
210
|
-
// TODO: Handle hex escape codes
|
|
211
|
-
url.value += String.fromCodePoint(current);
|
|
212
|
-
break;
|
|
213
|
-
}
|
|
214
|
-
break;
|
|
215
|
-
default:
|
|
216
|
-
if (isWhitespace(current)) {
|
|
217
|
-
while (isWhitespace(next())) {
|
|
218
|
-
/* empty */
|
|
219
|
-
}
|
|
220
|
-
// Unescaped whitespace is only valid before the closing )
|
|
221
|
-
if (current === 0x0029) {
|
|
222
|
-
// URL is valid
|
|
223
|
-
url.end = pos;
|
|
224
|
-
}
|
|
225
|
-
complete = true;
|
|
226
|
-
}
|
|
227
|
-
else {
|
|
228
|
-
// Add the character to the url value
|
|
229
|
-
url.value += String.fromCodePoint(current);
|
|
230
|
-
}
|
|
231
|
-
break;
|
|
232
|
-
}
|
|
233
|
-
next();
|
|
234
|
-
}
|
|
235
|
-
// An end position indicates a URL was found
|
|
236
|
-
if (url.end !== -1) {
|
|
237
|
-
yield url;
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
133
|
/**
|
|
242
134
|
* Provides the Sass importer logic to resolve relative stylesheet imports via both import and use rules
|
|
243
135
|
* and also rebase any `url()` function usage within those stylesheets. The rebasing will ensure that
|
|
@@ -400,8 +292,10 @@ class ModuleUrlRebasingImporter extends RelativeUrlRebasingImporter {
|
|
|
400
292
|
if (url.startsWith('file://')) {
|
|
401
293
|
return super.canonicalize(url, options);
|
|
402
294
|
}
|
|
403
|
-
const
|
|
404
|
-
|
|
295
|
+
const { specifier, resolveDir } = unpackModuleSpecifier(url);
|
|
296
|
+
let result = this.finder(specifier, { ...options, resolveDir });
|
|
297
|
+
result && (result = super.canonicalize(result.href, options));
|
|
298
|
+
return result;
|
|
405
299
|
}
|
|
406
300
|
}
|
|
407
301
|
exports.ModuleUrlRebasingImporter = ModuleUrlRebasingImporter;
|
|
@@ -442,4 +336,4 @@ function sassBindWorkaround(importer) {
|
|
|
442
336
|
return importer;
|
|
443
337
|
}
|
|
444
338
|
exports.sassBindWorkaround = sassBindWorkaround;
|
|
445
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rebasing-importer.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/sass/rebasing-importer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { RawSourceMap } from '@ampproject/remapping';\nimport MagicString from 'magic-string';\nimport { readFileSync, readdirSync } from 'node:fs';\nimport { basename, dirname, extname, join, relative } from 'node:path';\nimport { fileURLToPath, pathToFileURL } from 'node:url';\nimport type { FileImporter, Importer, ImporterResult, Syntax } from 'sass';\n\n/**\n * A preprocessed cache entry for the files and directories within a previously searched\n * directory when performing Sass import resolution.\n */\nexport interface DirectoryEntry {\n  files: Set<string>;\n  directories: Set<string>;\n}\n\n/**\n * A Sass Importer base class that provides the load logic to rebase all `url()` functions\n * within a stylesheet. The rebasing will ensure that the URLs in the output of the Sass compiler\n * reflect the final filesystem location of the output CSS file.\n *\n * This class provides the core of the rebasing functionality. To ensure that each file is processed\n * by this importer's load implementation, the Sass compiler requires the importer's canonicalize\n * function to return a non-null value with the resolved location of the requested stylesheet.\n * Concrete implementations of this class must provide this canonicalize functionality for rebasing\n * to be effective.\n */\nabstract class UrlRebasingImporter implements Importer<'sync'> {\n  /**\n   * @param entryDirectory The directory of the entry stylesheet that was passed to the Sass compiler.\n   * @param rebaseSourceMaps When provided, rebased files will have an intermediate sourcemap added to the Map\n   * which can be used to generate a final sourcemap that contains original sources.\n   */\n  constructor(\n    private entryDirectory: string,\n    private rebaseSourceMaps?: Map<string, RawSourceMap>,\n  ) {}\n\n  abstract canonicalize(url: string, options: { fromImport: boolean }): URL | null;\n\n  load(canonicalUrl: URL): ImporterResult | null {\n    const stylesheetPath = fileURLToPath(canonicalUrl);\n    const stylesheetDirectory = dirname(stylesheetPath);\n    let contents = readFileSync(stylesheetPath, 'utf-8');\n\n    // Rebase any URLs that are found\n    let updatedContents;\n    for (const { start, end, value } of findUrls(contents)) {\n      // Skip if value is empty or a Sass variable\n      if (value.length === 0 || value.startsWith('$')) {\n        continue;\n      }\n\n      // Skip if root-relative, absolute or protocol relative url\n      if (/^((?:\\w+:)?\\/\\/|data:|chrome:|#|\\/)/.test(value)) {\n        continue;\n      }\n\n      const rebasedPath = relative(this.entryDirectory, join(stylesheetDirectory, value));\n\n      // Normalize path separators and escape characters\n      // https://developer.mozilla.org/en-US/docs/Web/CSS/url#syntax\n      const rebasedUrl = './' + rebasedPath.replace(/\\\\/g, '/').replace(/[()\\s'\"]/g, '\\\\$&');\n\n      updatedContents ??= new MagicString(contents);\n      updatedContents.update(start, end, rebasedUrl);\n    }\n\n    if (updatedContents) {\n      contents = updatedContents.toString();\n      if (this.rebaseSourceMaps) {\n        // Generate an intermediate source map for the rebasing changes\n        const map = updatedContents.generateMap({\n          hires: true,\n          includeContent: true,\n          source: canonicalUrl.href,\n        });\n        this.rebaseSourceMaps.set(canonicalUrl.href, map as RawSourceMap);\n      }\n    }\n\n    let syntax: Syntax | undefined;\n    switch (extname(stylesheetPath).toLowerCase()) {\n      case '.css':\n        syntax = 'css';\n        break;\n      case '.sass':\n        syntax = 'indented';\n        break;\n      default:\n        syntax = 'scss';\n        break;\n    }\n\n    return {\n      contents,\n      syntax,\n      sourceMapUrl: canonicalUrl,\n    };\n  }\n}\n\n/**\n * Determines if a unicode code point is a CSS whitespace character.\n * @param code The unicode code point to test.\n * @returns true, if the code point is CSS whitespace; false, otherwise.\n */\nfunction isWhitespace(code: number): boolean {\n  // Based on https://www.w3.org/TR/css-syntax-3/#whitespace\n  switch (code) {\n    case 0x0009: // tab\n    case 0x0020: // space\n    case 0x000a: // line feed\n    case 0x000c: // form feed\n    case 0x000d: // carriage return\n      return true;\n    default:\n      return false;\n  }\n}\n\n/**\n * Scans a CSS or Sass file and locates all valid url function values as defined by the CSS\n * syntax specification.\n * @param contents A string containing a CSS or Sass file to scan.\n * @returns An iterable that yields each CSS url function value found.\n */\nfunction* findUrls(contents: string): Iterable<{ start: number; end: number; value: string }> {\n  let pos = 0;\n  let width = 1;\n  let current = -1;\n  const next = () => {\n    pos += width;\n    current = contents.codePointAt(pos) ?? -1;\n    width = current > 0xffff ? 2 : 1;\n\n    return current;\n  };\n\n  // Based on https://www.w3.org/TR/css-syntax-3/#consume-ident-like-token\n  while ((pos = contents.indexOf('url(', pos)) !== -1) {\n    // Set to position of the (\n    pos += 3;\n    width = 1;\n\n    // Consume all leading whitespace\n    while (isWhitespace(next())) {\n      /* empty */\n    }\n\n    // Initialize URL state\n    const url = { start: pos, end: -1, value: '' };\n    let complete = false;\n\n    // If \" or ', then consume the value as a string\n    if (current === 0x0022 || current === 0x0027) {\n      const ending = current;\n      // Based on https://www.w3.org/TR/css-syntax-3/#consume-string-token\n      while (!complete) {\n        switch (next()) {\n          case -1: // EOF\n            return;\n          case 0x000a: // line feed\n          case 0x000c: // form feed\n          case 0x000d: // carriage return\n            // Invalid\n            complete = true;\n            break;\n          case 0x005c: // \\ -- character escape\n            // If not EOF or newline, add the character after the escape\n            switch (next()) {\n              case -1:\n                return;\n              case 0x000a: // line feed\n              case 0x000c: // form feed\n              case 0x000d: // carriage return\n                // Skip when inside a string\n                break;\n              default:\n                // TODO: Handle hex escape codes\n                url.value += String.fromCodePoint(current);\n                break;\n            }\n            break;\n          case ending:\n            // Full string position should include the quotes for replacement\n            url.end = pos + 1;\n            complete = true;\n            yield url;\n            break;\n          default:\n            url.value += String.fromCodePoint(current);\n            break;\n        }\n      }\n\n      next();\n      continue;\n    }\n\n    // Based on https://www.w3.org/TR/css-syntax-3/#consume-url-token\n    while (!complete) {\n      switch (current) {\n        case -1: // EOF\n          return;\n        case 0x0022: // \"\n        case 0x0027: // '\n        case 0x0028: // (\n          // Invalid\n          complete = true;\n          break;\n        case 0x0029: // )\n          // URL is valid and complete\n          url.end = pos;\n          complete = true;\n          break;\n        case 0x005c: // \\ -- character escape\n          // If not EOF or newline, add the character after the escape\n          switch (next()) {\n            case -1: // EOF\n              return;\n            case 0x000a: // line feed\n            case 0x000c: // form feed\n            case 0x000d: // carriage return\n              // Invalid\n              complete = true;\n              break;\n            default:\n              // TODO: Handle hex escape codes\n              url.value += String.fromCodePoint(current);\n              break;\n          }\n          break;\n        default:\n          if (isWhitespace(current)) {\n            while (isWhitespace(next())) {\n              /* empty */\n            }\n            // Unescaped whitespace is only valid before the closing )\n            if (current === 0x0029) {\n              // URL is valid\n              url.end = pos;\n            }\n            complete = true;\n          } else {\n            // Add the character to the url value\n            url.value += String.fromCodePoint(current);\n          }\n          break;\n      }\n      next();\n    }\n\n    // An end position indicates a URL was found\n    if (url.end !== -1) {\n      yield url;\n    }\n  }\n}\n\n/**\n * Provides the Sass importer logic to resolve relative stylesheet imports via both import and use rules\n * and also rebase any `url()` function usage within those stylesheets. The rebasing will ensure that\n * the URLs in the output of the Sass compiler reflect the final filesystem location of the output CSS file.\n */\nexport class RelativeUrlRebasingImporter extends UrlRebasingImporter {\n  constructor(\n    entryDirectory: string,\n    private directoryCache = new Map<string, DirectoryEntry>(),\n    rebaseSourceMaps?: Map<string, RawSourceMap>,\n  ) {\n    super(entryDirectory, rebaseSourceMaps);\n  }\n\n  canonicalize(url: string, options: { fromImport: boolean }): URL | null {\n    return this.resolveImport(url, options.fromImport, true);\n  }\n\n  /**\n   * Attempts to resolve a provided URL to a stylesheet file using the Sass compiler's resolution algorithm.\n   * Based on https://github.com/sass/dart-sass/blob/44d6bb6ac72fe6b93f5bfec371a1fffb18e6b76d/lib/src/importer/utils.dart\n   * @param url The file protocol URL to resolve.\n   * @param fromImport If true, URL was from an import rule; otherwise from a use rule.\n   * @param checkDirectory If true, try checking for a directory with the base name containing an index file.\n   * @returns A full resolved URL of the stylesheet file or `null` if not found.\n   */\n  private resolveImport(url: string, fromImport: boolean, checkDirectory: boolean): URL | null {\n    let stylesheetPath;\n    try {\n      stylesheetPath = fileURLToPath(url);\n    } catch {\n      // Only file protocol URLs are supported by this importer\n      return null;\n    }\n\n    const directory = dirname(stylesheetPath);\n    const extension = extname(stylesheetPath);\n    const hasStyleExtension =\n      extension === '.scss' || extension === '.sass' || extension === '.css';\n    // Remove the style extension if present to allow adding the `.import` suffix\n    const filename = basename(stylesheetPath, hasStyleExtension ? extension : undefined);\n\n    const importPotentials = new Set<string>();\n    const defaultPotentials = new Set<string>();\n\n    if (hasStyleExtension) {\n      if (fromImport) {\n        importPotentials.add(filename + '.import' + extension);\n        importPotentials.add('_' + filename + '.import' + extension);\n      }\n      defaultPotentials.add(filename + extension);\n      defaultPotentials.add('_' + filename + extension);\n    } else {\n      if (fromImport) {\n        importPotentials.add(filename + '.import.scss');\n        importPotentials.add(filename + '.import.sass');\n        importPotentials.add(filename + '.import.css');\n        importPotentials.add('_' + filename + '.import.scss');\n        importPotentials.add('_' + filename + '.import.sass');\n        importPotentials.add('_' + filename + '.import.css');\n      }\n      defaultPotentials.add(filename + '.scss');\n      defaultPotentials.add(filename + '.sass');\n      defaultPotentials.add(filename + '.css');\n      defaultPotentials.add('_' + filename + '.scss');\n      defaultPotentials.add('_' + filename + '.sass');\n      defaultPotentials.add('_' + filename + '.css');\n    }\n\n    let foundDefaults;\n    let foundImports;\n    let hasPotentialIndex = false;\n\n    let cachedEntries = this.directoryCache.get(directory);\n    if (cachedEntries) {\n      // If there is a preprocessed cache of the directory, perform an intersection of the potentials\n      // and the directory files.\n      const { files, directories } = cachedEntries;\n      foundDefaults = [...defaultPotentials].filter((potential) => files.has(potential));\n      foundImports = [...importPotentials].filter((potential) => files.has(potential));\n      hasPotentialIndex = checkDirectory && !hasStyleExtension && directories.has(filename);\n    } else {\n      // If no preprocessed cache exists, get the entries from the file system and, while searching,\n      // generate the cache for later requests.\n      let entries;\n      try {\n        entries = readdirSync(directory, { withFileTypes: true });\n      } catch {\n        return null;\n      }\n\n      foundDefaults = [];\n      foundImports = [];\n      cachedEntries = { files: new Set<string>(), directories: new Set<string>() };\n      for (const entry of entries) {\n        const isDirectory = entry.isDirectory();\n        if (isDirectory) {\n          cachedEntries.directories.add(entry.name);\n        }\n\n        // Record if the name should be checked as a directory with an index file\n        if (checkDirectory && !hasStyleExtension && entry.name === filename && isDirectory) {\n          hasPotentialIndex = true;\n        }\n\n        if (!entry.isFile()) {\n          continue;\n        }\n\n        cachedEntries.files.add(entry.name);\n\n        if (importPotentials.has(entry.name)) {\n          foundImports.push(entry.name);\n        }\n\n        if (defaultPotentials.has(entry.name)) {\n          foundDefaults.push(entry.name);\n        }\n      }\n\n      this.directoryCache.set(directory, cachedEntries);\n    }\n\n    // `foundImports` will only contain elements if `options.fromImport` is true\n    const result = this.checkFound(foundImports) ?? this.checkFound(foundDefaults);\n    if (result !== null) {\n      return pathToFileURL(join(directory, result));\n    }\n\n    if (hasPotentialIndex) {\n      // Check for index files using filename as a directory\n      return this.resolveImport(url + '/index', fromImport, false);\n    }\n\n    return null;\n  }\n\n  /**\n   * Checks an array of potential stylesheet files to determine if there is a valid\n   * stylesheet file. More than one discovered file may indicate an error.\n   * @param found An array of discovered stylesheet files.\n   * @returns A fully resolved path for a stylesheet file or `null` if not found.\n   * @throws If there are ambiguous files discovered.\n   */\n  private checkFound(found: string[]): string | null {\n    if (found.length === 0) {\n      // Not found\n      return null;\n    }\n\n    // More than one found file may be an error\n    if (found.length > 1) {\n      // Presence of CSS files alongside a Sass file does not cause an error\n      const foundWithoutCss = found.filter((element) => extname(element) !== '.css');\n      // If the length is zero then there are two or more css files\n      // If the length is more than one than there are two or more sass/scss files\n      if (foundWithoutCss.length !== 1) {\n        throw new Error('Ambiguous import detected.');\n      }\n\n      // Return the non-CSS file (sass/scss files have priority)\n      // https://github.com/sass/dart-sass/blob/44d6bb6ac72fe6b93f5bfec371a1fffb18e6b76d/lib/src/importer/utils.dart#L44-L47\n      return foundWithoutCss[0];\n    }\n\n    return found[0];\n  }\n}\n\n/**\n * Provides the Sass importer logic to resolve module (npm package) stylesheet imports via both import and\n * use rules and also rebase any `url()` function usage within those stylesheets. The rebasing will ensure that\n * the URLs in the output of the Sass compiler reflect the final filesystem location of the output CSS file.\n */\nexport class ModuleUrlRebasingImporter extends RelativeUrlRebasingImporter {\n  constructor(\n    entryDirectory: string,\n    directoryCache: Map<string, DirectoryEntry>,\n    rebaseSourceMaps: Map<string, RawSourceMap> | undefined,\n    private finder: FileImporter<'sync'>['findFileUrl'],\n  ) {\n    super(entryDirectory, directoryCache, rebaseSourceMaps);\n  }\n\n  override canonicalize(url: string, options: { fromImport: boolean }): URL | null {\n    if (url.startsWith('file://')) {\n      return super.canonicalize(url, options);\n    }\n\n    const result = this.finder(url, options);\n\n    return result ? super.canonicalize(result.href, options) : null;\n  }\n}\n\n/**\n * Provides the Sass importer logic to resolve load paths located stylesheet imports via both import and\n * use rules and also rebase any `url()` function usage within those stylesheets. The rebasing will ensure that\n * the URLs in the output of the Sass compiler reflect the final filesystem location of the output CSS file.\n */\nexport class LoadPathsUrlRebasingImporter extends RelativeUrlRebasingImporter {\n  constructor(\n    entryDirectory: string,\n    directoryCache: Map<string, DirectoryEntry>,\n    rebaseSourceMaps: Map<string, RawSourceMap> | undefined,\n    private loadPaths: Iterable<string>,\n  ) {\n    super(entryDirectory, directoryCache, rebaseSourceMaps);\n  }\n\n  override canonicalize(url: string, options: { fromImport: boolean }): URL | null {\n    if (url.startsWith('file://')) {\n      return super.canonicalize(url, options);\n    }\n\n    let result = null;\n    for (const loadPath of this.loadPaths) {\n      result = super.canonicalize(pathToFileURL(join(loadPath, url)).href, options);\n      if (result !== null) {\n        break;\n      }\n    }\n\n    return result;\n  }\n}\n\n/**\n * Workaround for Sass not calling instance methods with `this`.\n * The `canonicalize` and `load` methods will be bound to the class instance.\n * @param importer A Sass importer to bind.\n * @returns The bound Sass importer.\n */\nexport function sassBindWorkaround<T extends Importer>(importer: T): T {\n  importer.canonicalize = importer.canonicalize.bind(importer);\n  importer.load = importer.load.bind(importer);\n\n  return importer;\n}\n"]}
|
|
339
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rebasing-importer.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/sass/rebasing-importer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { RawSourceMap } from '@ampproject/remapping';\nimport MagicString from 'magic-string';\nimport { readFileSync, readdirSync } from 'node:fs';\nimport { basename, dirname, extname, join, relative } from 'node:path';\nimport { fileURLToPath, pathToFileURL } from 'node:url';\nimport type { Importer, ImporterResult, Syntax } from 'sass';\nimport { findImports, findUrls } from './lexer';\n\n/**\n * A preprocessed cache entry for the files and directories within a previously searched\n * directory when performing Sass import resolution.\n */\nexport interface DirectoryEntry {\n  files: Set<string>;\n  directories: Set<string>;\n}\n\n/**\n * A prefix that is added to import and use directive specifiers that should be resolved\n * as modules and that will contain added resolve directory information.\n *\n * This functionality is used to workaround the Sass limitation that it does not provide the\n * importer file to custom resolution plugins.\n */\nconst MODULE_RESOLUTION_PREFIX = '__NG_PACKAGE__';\n\nfunction packModuleSpecifier(specifier: string, resolveDir: string): string {\n  const packed = MODULE_RESOLUTION_PREFIX + ';' + resolveDir + ';' + specifier;\n\n  // Normalize path separators and escape characters\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/url#syntax\n  const normalizedPacked = packed.replace(/\\\\/g, '/').replace(/[()\\s'\"]/g, '\\\\$&');\n\n  return normalizedPacked;\n}\n\nfunction unpackModuleSpecifier(specifier: string): { specifier: string; resolveDir?: string } {\n  if (!specifier.startsWith(`${MODULE_RESOLUTION_PREFIX};`)) {\n    return { specifier };\n  }\n\n  const values = specifier.split(';', 3);\n\n  return {\n    specifier: values[2],\n    resolveDir: values[1],\n  };\n}\n\n/**\n * A Sass Importer base class that provides the load logic to rebase all `url()` functions\n * within a stylesheet. The rebasing will ensure that the URLs in the output of the Sass compiler\n * reflect the final filesystem location of the output CSS file.\n *\n * This class provides the core of the rebasing functionality. To ensure that each file is processed\n * by this importer's load implementation, the Sass compiler requires the importer's canonicalize\n * function to return a non-null value with the resolved location of the requested stylesheet.\n * Concrete implementations of this class must provide this canonicalize functionality for rebasing\n * to be effective.\n */\nabstract class UrlRebasingImporter implements Importer<'sync'> {\n  /**\n   * @param entryDirectory The directory of the entry stylesheet that was passed to the Sass compiler.\n   * @param rebaseSourceMaps When provided, rebased files will have an intermediate sourcemap added to the Map\n   * which can be used to generate a final sourcemap that contains original sources.\n   */\n  constructor(\n    private entryDirectory: string,\n    private rebaseSourceMaps?: Map<string, RawSourceMap>,\n  ) {}\n\n  abstract canonicalize(url: string, options: { fromImport: boolean }): URL | null;\n\n  load(canonicalUrl: URL): ImporterResult | null {\n    const stylesheetPath = fileURLToPath(canonicalUrl);\n    const stylesheetDirectory = dirname(stylesheetPath);\n    let contents = readFileSync(stylesheetPath, 'utf-8');\n\n    // Rebase any URLs that are found\n    let updatedContents;\n    for (const { start, end, value } of findUrls(contents)) {\n      // Skip if value is empty or a Sass variable\n      if (value.length === 0 || value.startsWith('$')) {\n        continue;\n      }\n\n      // Skip if root-relative, absolute or protocol relative url\n      if (/^((?:\\w+:)?\\/\\/|data:|chrome:|#|\\/)/.test(value)) {\n        continue;\n      }\n\n      const rebasedPath = relative(this.entryDirectory, join(stylesheetDirectory, value));\n\n      // Normalize path separators and escape characters\n      // https://developer.mozilla.org/en-US/docs/Web/CSS/url#syntax\n      const rebasedUrl = './' + rebasedPath.replace(/\\\\/g, '/').replace(/[()\\s'\"]/g, '\\\\$&');\n\n      updatedContents ??= new MagicString(contents);\n      updatedContents.update(start, end, rebasedUrl);\n    }\n\n    // Add resolution directory information to module specifiers to facilitate resolution\n    for (const { start, end, specifier } of findImports(contents)) {\n      // Currently only provide directory information for known/common packages:\n      // * `@material/`\n      // * `@angular/`\n      //\n      // Comprehensive pre-resolution support may be added in the future. This is complicated by CSS/Sass not\n      // requiring a `./` or `../` prefix to signify relative paths. A bare specifier could be either relative\n      // or a module specifier. To differentiate, a relative resolution would need to be attempted first.\n      if (!specifier.startsWith('@angular/') && !specifier.startsWith('@material/')) {\n        continue;\n      }\n\n      updatedContents ??= new MagicString(contents);\n      updatedContents.update(\n        start,\n        end,\n        `\"${packModuleSpecifier(specifier, stylesheetDirectory)}\"`,\n      );\n    }\n\n    if (updatedContents) {\n      contents = updatedContents.toString();\n      if (this.rebaseSourceMaps) {\n        // Generate an intermediate source map for the rebasing changes\n        const map = updatedContents.generateMap({\n          hires: true,\n          includeContent: true,\n          source: canonicalUrl.href,\n        });\n        this.rebaseSourceMaps.set(canonicalUrl.href, map as RawSourceMap);\n      }\n    }\n\n    let syntax: Syntax | undefined;\n    switch (extname(stylesheetPath).toLowerCase()) {\n      case '.css':\n        syntax = 'css';\n        break;\n      case '.sass':\n        syntax = 'indented';\n        break;\n      default:\n        syntax = 'scss';\n        break;\n    }\n\n    return {\n      contents,\n      syntax,\n      sourceMapUrl: canonicalUrl,\n    };\n  }\n}\n\n/**\n * Provides the Sass importer logic to resolve relative stylesheet imports via both import and use rules\n * and also rebase any `url()` function usage within those stylesheets. The rebasing will ensure that\n * the URLs in the output of the Sass compiler reflect the final filesystem location of the output CSS file.\n */\nexport class RelativeUrlRebasingImporter extends UrlRebasingImporter {\n  constructor(\n    entryDirectory: string,\n    private directoryCache = new Map<string, DirectoryEntry>(),\n    rebaseSourceMaps?: Map<string, RawSourceMap>,\n  ) {\n    super(entryDirectory, rebaseSourceMaps);\n  }\n\n  canonicalize(url: string, options: { fromImport: boolean }): URL | null {\n    return this.resolveImport(url, options.fromImport, true);\n  }\n\n  /**\n   * Attempts to resolve a provided URL to a stylesheet file using the Sass compiler's resolution algorithm.\n   * Based on https://github.com/sass/dart-sass/blob/44d6bb6ac72fe6b93f5bfec371a1fffb18e6b76d/lib/src/importer/utils.dart\n   * @param url The file protocol URL to resolve.\n   * @param fromImport If true, URL was from an import rule; otherwise from a use rule.\n   * @param checkDirectory If true, try checking for a directory with the base name containing an index file.\n   * @returns A full resolved URL of the stylesheet file or `null` if not found.\n   */\n  private resolveImport(url: string, fromImport: boolean, checkDirectory: boolean): URL | null {\n    let stylesheetPath;\n    try {\n      stylesheetPath = fileURLToPath(url);\n    } catch {\n      // Only file protocol URLs are supported by this importer\n      return null;\n    }\n\n    const directory = dirname(stylesheetPath);\n    const extension = extname(stylesheetPath);\n    const hasStyleExtension =\n      extension === '.scss' || extension === '.sass' || extension === '.css';\n    // Remove the style extension if present to allow adding the `.import` suffix\n    const filename = basename(stylesheetPath, hasStyleExtension ? extension : undefined);\n\n    const importPotentials = new Set<string>();\n    const defaultPotentials = new Set<string>();\n\n    if (hasStyleExtension) {\n      if (fromImport) {\n        importPotentials.add(filename + '.import' + extension);\n        importPotentials.add('_' + filename + '.import' + extension);\n      }\n      defaultPotentials.add(filename + extension);\n      defaultPotentials.add('_' + filename + extension);\n    } else {\n      if (fromImport) {\n        importPotentials.add(filename + '.import.scss');\n        importPotentials.add(filename + '.import.sass');\n        importPotentials.add(filename + '.import.css');\n        importPotentials.add('_' + filename + '.import.scss');\n        importPotentials.add('_' + filename + '.import.sass');\n        importPotentials.add('_' + filename + '.import.css');\n      }\n      defaultPotentials.add(filename + '.scss');\n      defaultPotentials.add(filename + '.sass');\n      defaultPotentials.add(filename + '.css');\n      defaultPotentials.add('_' + filename + '.scss');\n      defaultPotentials.add('_' + filename + '.sass');\n      defaultPotentials.add('_' + filename + '.css');\n    }\n\n    let foundDefaults;\n    let foundImports;\n    let hasPotentialIndex = false;\n\n    let cachedEntries = this.directoryCache.get(directory);\n    if (cachedEntries) {\n      // If there is a preprocessed cache of the directory, perform an intersection of the potentials\n      // and the directory files.\n      const { files, directories } = cachedEntries;\n      foundDefaults = [...defaultPotentials].filter((potential) => files.has(potential));\n      foundImports = [...importPotentials].filter((potential) => files.has(potential));\n      hasPotentialIndex = checkDirectory && !hasStyleExtension && directories.has(filename);\n    } else {\n      // If no preprocessed cache exists, get the entries from the file system and, while searching,\n      // generate the cache for later requests.\n      let entries;\n      try {\n        entries = readdirSync(directory, { withFileTypes: true });\n      } catch {\n        return null;\n      }\n\n      foundDefaults = [];\n      foundImports = [];\n      cachedEntries = { files: new Set<string>(), directories: new Set<string>() };\n      for (const entry of entries) {\n        const isDirectory = entry.isDirectory();\n        if (isDirectory) {\n          cachedEntries.directories.add(entry.name);\n        }\n\n        // Record if the name should be checked as a directory with an index file\n        if (checkDirectory && !hasStyleExtension && entry.name === filename && isDirectory) {\n          hasPotentialIndex = true;\n        }\n\n        if (!entry.isFile()) {\n          continue;\n        }\n\n        cachedEntries.files.add(entry.name);\n\n        if (importPotentials.has(entry.name)) {\n          foundImports.push(entry.name);\n        }\n\n        if (defaultPotentials.has(entry.name)) {\n          foundDefaults.push(entry.name);\n        }\n      }\n\n      this.directoryCache.set(directory, cachedEntries);\n    }\n\n    // `foundImports` will only contain elements if `options.fromImport` is true\n    const result = this.checkFound(foundImports) ?? this.checkFound(foundDefaults);\n    if (result !== null) {\n      return pathToFileURL(join(directory, result));\n    }\n\n    if (hasPotentialIndex) {\n      // Check for index files using filename as a directory\n      return this.resolveImport(url + '/index', fromImport, false);\n    }\n\n    return null;\n  }\n\n  /**\n   * Checks an array of potential stylesheet files to determine if there is a valid\n   * stylesheet file. More than one discovered file may indicate an error.\n   * @param found An array of discovered stylesheet files.\n   * @returns A fully resolved path for a stylesheet file or `null` if not found.\n   * @throws If there are ambiguous files discovered.\n   */\n  private checkFound(found: string[]): string | null {\n    if (found.length === 0) {\n      // Not found\n      return null;\n    }\n\n    // More than one found file may be an error\n    if (found.length > 1) {\n      // Presence of CSS files alongside a Sass file does not cause an error\n      const foundWithoutCss = found.filter((element) => extname(element) !== '.css');\n      // If the length is zero then there are two or more css files\n      // If the length is more than one than there are two or more sass/scss files\n      if (foundWithoutCss.length !== 1) {\n        throw new Error('Ambiguous import detected.');\n      }\n\n      // Return the non-CSS file (sass/scss files have priority)\n      // https://github.com/sass/dart-sass/blob/44d6bb6ac72fe6b93f5bfec371a1fffb18e6b76d/lib/src/importer/utils.dart#L44-L47\n      return foundWithoutCss[0];\n    }\n\n    return found[0];\n  }\n}\n\n/**\n * Provides the Sass importer logic to resolve module (npm package) stylesheet imports via both import and\n * use rules and also rebase any `url()` function usage within those stylesheets. The rebasing will ensure that\n * the URLs in the output of the Sass compiler reflect the final filesystem location of the output CSS file.\n */\nexport class ModuleUrlRebasingImporter extends RelativeUrlRebasingImporter {\n  constructor(\n    entryDirectory: string,\n    directoryCache: Map<string, DirectoryEntry>,\n    rebaseSourceMaps: Map<string, RawSourceMap> | undefined,\n    private finder: (\n      specifier: string,\n      options: { fromImport: boolean; resolveDir?: string },\n    ) => URL | null,\n  ) {\n    super(entryDirectory, directoryCache, rebaseSourceMaps);\n  }\n\n  override canonicalize(url: string, options: { fromImport: boolean }): URL | null {\n    if (url.startsWith('file://')) {\n      return super.canonicalize(url, options);\n    }\n\n    const { specifier, resolveDir } = unpackModuleSpecifier(url);\n\n    let result = this.finder(specifier, { ...options, resolveDir });\n    result &&= super.canonicalize(result.href, options);\n\n    return result;\n  }\n}\n\n/**\n * Provides the Sass importer logic to resolve load paths located stylesheet imports via both import and\n * use rules and also rebase any `url()` function usage within those stylesheets. The rebasing will ensure that\n * the URLs in the output of the Sass compiler reflect the final filesystem location of the output CSS file.\n */\nexport class LoadPathsUrlRebasingImporter extends RelativeUrlRebasingImporter {\n  constructor(\n    entryDirectory: string,\n    directoryCache: Map<string, DirectoryEntry>,\n    rebaseSourceMaps: Map<string, RawSourceMap> | undefined,\n    private loadPaths: Iterable<string>,\n  ) {\n    super(entryDirectory, directoryCache, rebaseSourceMaps);\n  }\n\n  override canonicalize(url: string, options: { fromImport: boolean }): URL | null {\n    if (url.startsWith('file://')) {\n      return super.canonicalize(url, options);\n    }\n\n    let result = null;\n    for (const loadPath of this.loadPaths) {\n      result = super.canonicalize(pathToFileURL(join(loadPath, url)).href, options);\n      if (result !== null) {\n        break;\n      }\n    }\n\n    return result;\n  }\n}\n\n/**\n * Workaround for Sass not calling instance methods with `this`.\n * The `canonicalize` and `load` methods will be bound to the class instance.\n * @param importer A Sass importer to bind.\n * @returns The bound Sass importer.\n */\nexport function sassBindWorkaround<T extends Importer>(importer: T): T {\n  importer.canonicalize = importer.canonicalize.bind(importer);\n  importer.load = importer.load.bind(importer);\n\n  return importer;\n}\n"]}
|
|
@@ -15,6 +15,11 @@ export interface FileImporterWithRequestContextOptions extends FileImporterOptio
|
|
|
15
15
|
* Workaround until https://github.com/sass/sass/issues/3247 is addressed.
|
|
16
16
|
*/
|
|
17
17
|
previousResolvedModules?: Set<string>;
|
|
18
|
+
/**
|
|
19
|
+
* The base directory to use when resolving the request.
|
|
20
|
+
* This value is only set if using the rebasing importers.
|
|
21
|
+
*/
|
|
22
|
+
resolveDir?: string;
|
|
18
23
|
}
|
|
19
24
|
/**
|
|
20
25
|
* A Sass renderer implementation that provides an interface that can be used by Webpack's
|
|
@@ -211,4 +211,4 @@ class SassWorkerImplementation {
|
|
|
211
211
|
}
|
|
212
212
|
}
|
|
213
213
|
exports.SassWorkerImplementation = SassWorkerImplementation;
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sass-service.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/sass/sass-service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { dirname, join } from 'node:path';\nimport { fileURLToPath, pathToFileURL } from 'node:url';\nimport { MessageChannel, Worker } from 'node:worker_threads';\nimport {\n  CompileResult,\n  Exception,\n  FileImporter,\n  Importer,\n  Logger,\n  SourceSpan,\n  StringOptionsWithImporter,\n  StringOptionsWithoutImporter,\n} from 'sass';\nimport { maxWorkers } from '../../utils/environment-options';\n\n/**\n * The maximum number of Workers that will be created to execute render requests.\n */\nconst MAX_RENDER_WORKERS = maxWorkers;\n\n/**\n * The callback type for the `dart-sass` asynchronous render function.\n */\ntype RenderCallback = (error?: Exception, result?: CompileResult) => void;\n\ntype FileImporterOptions = Parameters<FileImporter['findFileUrl']>[1];\n\nexport interface FileImporterWithRequestContextOptions extends FileImporterOptions {\n  /**\n   * This is a custom option and is required as SASS does not provide context from which the file is being resolved.\n   * This breaks Yarn PNP as transitive deps cannot be resolved from the workspace root.\n   *\n   * Workaround until https://github.com/sass/sass/issues/3247 is addressed.\n   */\n  previousResolvedModules?: Set<string>;\n}\n\n/**\n * An object containing the contextual information for a specific render request.\n */\ninterface RenderRequest {\n  id: number;\n  workerIndex: number;\n  callback: RenderCallback;\n  logger?: Logger;\n  importers?: Importers[];\n  previousResolvedModules?: Set<string>;\n}\n\n/**\n * All available importer types.\n */\ntype Importers =\n  | Importer<'sync'>\n  | Importer<'async'>\n  | FileImporter<'sync'>\n  | FileImporter<'async'>;\n\n/**\n * A response from the Sass render Worker containing the result of the operation.\n */\ninterface RenderResponseMessage {\n  id: number;\n  error?: Exception;\n  result?: Omit<CompileResult, 'loadedUrls'> & { loadedUrls: string[] };\n  warnings?: {\n    message: string;\n    deprecation: boolean;\n    stack?: string;\n    span?: Omit<SourceSpan, 'url'> & { url?: string };\n  }[];\n}\n\n/**\n * A Sass renderer implementation that provides an interface that can be used by Webpack's\n * `sass-loader`. The implementation uses a Worker thread to perform the Sass rendering\n * with the `dart-sass` package.  The `dart-sass` synchronous render function is used within\n * the worker which can be up to two times faster than the asynchronous variant.\n */\nexport class SassWorkerImplementation {\n  private readonly workers: Worker[] = [];\n  private readonly availableWorkers: number[] = [];\n  private readonly requests = new Map<number, RenderRequest>();\n  private readonly workerPath = join(__dirname, './worker.js');\n  private idCounter = 1;\n  private nextWorkerIndex = 0;\n\n  constructor(private rebase = false) {}\n\n  /**\n   * Provides information about the Sass implementation.\n   * This mimics enough of the `dart-sass` value to be used with the `sass-loader`.\n   */\n  get info(): string {\n    return 'dart-sass\\tworker';\n  }\n\n  /**\n   * The synchronous render function is not used by the `sass-loader`.\n   */\n  compileString(): never {\n    throw new Error('Sass compileString is not supported.');\n  }\n\n  /**\n   * Asynchronously request a Sass stylesheet to be renderered.\n   *\n   * @param source The contents to compile.\n   * @param options The `dart-sass` options to use when rendering the stylesheet.\n   */\n  compileStringAsync(\n    source: string,\n    options: StringOptionsWithImporter<'async'> | StringOptionsWithoutImporter<'async'>,\n  ): Promise<CompileResult> {\n    // The `functions`, `logger` and `importer` options are JavaScript functions that cannot be transferred.\n    // If any additional function options are added in the future, they must be excluded as well.\n    const { functions, importers, url, logger, ...serializableOptions } = options;\n\n    // The CLI's configuration does not use or expose the ability to defined custom Sass functions\n    if (functions && Object.keys(functions).length > 0) {\n      throw new Error('Sass custom functions are not supported.');\n    }\n\n    return new Promise<CompileResult>((resolve, reject) => {\n      let workerIndex = this.availableWorkers.pop();\n      if (workerIndex === undefined) {\n        if (this.workers.length < MAX_RENDER_WORKERS) {\n          workerIndex = this.workers.length;\n          this.workers.push(this.createWorker());\n        } else {\n          workerIndex = this.nextWorkerIndex++;\n          if (this.nextWorkerIndex >= this.workers.length) {\n            this.nextWorkerIndex = 0;\n          }\n        }\n      }\n\n      const callback: RenderCallback = (error, result) => {\n        if (error) {\n          const url = error.span?.url as string | undefined;\n          if (url) {\n            error.span.url = pathToFileURL(url);\n          }\n\n          reject(error);\n\n          return;\n        }\n\n        if (!result) {\n          reject(new Error('No result.'));\n\n          return;\n        }\n\n        resolve(result);\n      };\n\n      const request = this.createRequest(workerIndex, callback, logger, importers);\n      this.requests.set(request.id, request);\n\n      this.workers[workerIndex].postMessage({\n        id: request.id,\n        source,\n        hasImporter: !!importers?.length,\n        hasLogger: !!logger,\n        rebase: this.rebase,\n        options: {\n          ...serializableOptions,\n          // URL is not serializable so to convert to string here and back to URL in the worker.\n          url: url ? fileURLToPath(url) : undefined,\n        },\n      });\n    });\n  }\n\n  /**\n   * Shutdown the Sass render worker.\n   * Executing this method will stop any pending render requests.\n   */\n  close(): void {\n    for (const worker of this.workers) {\n      try {\n        void worker.terminate();\n      } catch {}\n    }\n    this.requests.clear();\n  }\n\n  private createWorker(): Worker {\n    const { port1: mainImporterPort, port2: workerImporterPort } = new MessageChannel();\n    const importerSignal = new Int32Array(new SharedArrayBuffer(4));\n\n    const worker = new Worker(this.workerPath, {\n      workerData: { workerImporterPort, importerSignal },\n      transferList: [workerImporterPort],\n    });\n\n    worker.on('message', (response: RenderResponseMessage) => {\n      const request = this.requests.get(response.id);\n      if (!request) {\n        return;\n      }\n\n      this.requests.delete(response.id);\n      this.availableWorkers.push(request.workerIndex);\n\n      if (response.warnings && request.logger?.warn) {\n        for (const { message, span, ...options } of response.warnings) {\n          request.logger.warn(message, {\n            ...options,\n            span: span && {\n              ...span,\n              url: span.url ? pathToFileURL(span.url) : undefined,\n            },\n          });\n        }\n      }\n\n      if (response.result) {\n        request.callback(undefined, {\n          ...response.result,\n          // URL is not serializable so in the worker we convert to string and here back to URL.\n          loadedUrls: response.result.loadedUrls.map((p) => pathToFileURL(p)),\n        });\n      } else {\n        request.callback(response.error);\n      }\n    });\n\n    mainImporterPort.on(\n      'message',\n      ({ id, url, options }: { id: number; url: string; options: FileImporterOptions }) => {\n        const request = this.requests.get(id);\n        if (!request?.importers) {\n          mainImporterPort.postMessage(null);\n          Atomics.store(importerSignal, 0, 1);\n          Atomics.notify(importerSignal, 0);\n\n          return;\n        }\n\n        this.processImporters(request.importers, url, {\n          ...options,\n          previousResolvedModules: request.previousResolvedModules,\n        })\n          .then((result) => {\n            if (result) {\n              request.previousResolvedModules ??= new Set();\n              request.previousResolvedModules.add(dirname(result));\n            }\n\n            mainImporterPort.postMessage(result);\n          })\n          .catch((error) => {\n            mainImporterPort.postMessage(error);\n          })\n          .finally(() => {\n            Atomics.store(importerSignal, 0, 1);\n            Atomics.notify(importerSignal, 0);\n          });\n      },\n    );\n\n    mainImporterPort.unref();\n\n    return worker;\n  }\n\n  private async processImporters(\n    importers: Iterable<Importers>,\n    url: string,\n    options: FileImporterWithRequestContextOptions,\n  ): Promise<string | null> {\n    for (const importer of importers) {\n      if (this.isImporter(importer)) {\n        // Importer\n        throw new Error('Only File Importers are supported.');\n      }\n\n      // File importer (Can be sync or aync).\n      const result = await importer.findFileUrl(url, options);\n      if (result) {\n        return fileURLToPath(result);\n      }\n    }\n\n    return null;\n  }\n\n  private createRequest(\n    workerIndex: number,\n    callback: RenderCallback,\n    logger: Logger | undefined,\n    importers: Importers[] | undefined,\n  ): RenderRequest {\n    return {\n      id: this.idCounter++,\n      workerIndex,\n      callback,\n      logger,\n      importers,\n    };\n  }\n\n  private isImporter(value: Importers): value is Importer {\n    return 'canonicalize' in value && 'load' in value;\n  }\n}\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sass-service.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/sass/sass-service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { dirname, join } from 'node:path';\nimport { fileURLToPath, pathToFileURL } from 'node:url';\nimport { MessageChannel, Worker } from 'node:worker_threads';\nimport {\n  CompileResult,\n  Exception,\n  FileImporter,\n  Importer,\n  Logger,\n  SourceSpan,\n  StringOptionsWithImporter,\n  StringOptionsWithoutImporter,\n} from 'sass';\nimport { maxWorkers } from '../../utils/environment-options';\n\n/**\n * The maximum number of Workers that will be created to execute render requests.\n */\nconst MAX_RENDER_WORKERS = maxWorkers;\n\n/**\n * The callback type for the `dart-sass` asynchronous render function.\n */\ntype RenderCallback = (error?: Exception, result?: CompileResult) => void;\n\ntype FileImporterOptions = Parameters<FileImporter['findFileUrl']>[1];\n\nexport interface FileImporterWithRequestContextOptions extends FileImporterOptions {\n  /**\n   * This is a custom option and is required as SASS does not provide context from which the file is being resolved.\n   * This breaks Yarn PNP as transitive deps cannot be resolved from the workspace root.\n   *\n   * Workaround until https://github.com/sass/sass/issues/3247 is addressed.\n   */\n  previousResolvedModules?: Set<string>;\n\n  /**\n   * The base directory to use when resolving the request.\n   * This value is only set if using the rebasing importers.\n   */\n  resolveDir?: string;\n}\n\n/**\n * An object containing the contextual information for a specific render request.\n */\ninterface RenderRequest {\n  id: number;\n  workerIndex: number;\n  callback: RenderCallback;\n  logger?: Logger;\n  importers?: Importers[];\n  previousResolvedModules?: Set<string>;\n}\n\n/**\n * All available importer types.\n */\ntype Importers =\n  | Importer<'sync'>\n  | Importer<'async'>\n  | FileImporter<'sync'>\n  | FileImporter<'async'>;\n\n/**\n * A response from the Sass render Worker containing the result of the operation.\n */\ninterface RenderResponseMessage {\n  id: number;\n  error?: Exception;\n  result?: Omit<CompileResult, 'loadedUrls'> & { loadedUrls: string[] };\n  warnings?: {\n    message: string;\n    deprecation: boolean;\n    stack?: string;\n    span?: Omit<SourceSpan, 'url'> & { url?: string };\n  }[];\n}\n\n/**\n * A Sass renderer implementation that provides an interface that can be used by Webpack's\n * `sass-loader`. The implementation uses a Worker thread to perform the Sass rendering\n * with the `dart-sass` package.  The `dart-sass` synchronous render function is used within\n * the worker which can be up to two times faster than the asynchronous variant.\n */\nexport class SassWorkerImplementation {\n  private readonly workers: Worker[] = [];\n  private readonly availableWorkers: number[] = [];\n  private readonly requests = new Map<number, RenderRequest>();\n  private readonly workerPath = join(__dirname, './worker.js');\n  private idCounter = 1;\n  private nextWorkerIndex = 0;\n\n  constructor(private rebase = false) {}\n\n  /**\n   * Provides information about the Sass implementation.\n   * This mimics enough of the `dart-sass` value to be used with the `sass-loader`.\n   */\n  get info(): string {\n    return 'dart-sass\\tworker';\n  }\n\n  /**\n   * The synchronous render function is not used by the `sass-loader`.\n   */\n  compileString(): never {\n    throw new Error('Sass compileString is not supported.');\n  }\n\n  /**\n   * Asynchronously request a Sass stylesheet to be renderered.\n   *\n   * @param source The contents to compile.\n   * @param options The `dart-sass` options to use when rendering the stylesheet.\n   */\n  compileStringAsync(\n    source: string,\n    options: StringOptionsWithImporter<'async'> | StringOptionsWithoutImporter<'async'>,\n  ): Promise<CompileResult> {\n    // The `functions`, `logger` and `importer` options are JavaScript functions that cannot be transferred.\n    // If any additional function options are added in the future, they must be excluded as well.\n    const { functions, importers, url, logger, ...serializableOptions } = options;\n\n    // The CLI's configuration does not use or expose the ability to defined custom Sass functions\n    if (functions && Object.keys(functions).length > 0) {\n      throw new Error('Sass custom functions are not supported.');\n    }\n\n    return new Promise<CompileResult>((resolve, reject) => {\n      let workerIndex = this.availableWorkers.pop();\n      if (workerIndex === undefined) {\n        if (this.workers.length < MAX_RENDER_WORKERS) {\n          workerIndex = this.workers.length;\n          this.workers.push(this.createWorker());\n        } else {\n          workerIndex = this.nextWorkerIndex++;\n          if (this.nextWorkerIndex >= this.workers.length) {\n            this.nextWorkerIndex = 0;\n          }\n        }\n      }\n\n      const callback: RenderCallback = (error, result) => {\n        if (error) {\n          const url = error.span?.url as string | undefined;\n          if (url) {\n            error.span.url = pathToFileURL(url);\n          }\n\n          reject(error);\n\n          return;\n        }\n\n        if (!result) {\n          reject(new Error('No result.'));\n\n          return;\n        }\n\n        resolve(result);\n      };\n\n      const request = this.createRequest(workerIndex, callback, logger, importers);\n      this.requests.set(request.id, request);\n\n      this.workers[workerIndex].postMessage({\n        id: request.id,\n        source,\n        hasImporter: !!importers?.length,\n        hasLogger: !!logger,\n        rebase: this.rebase,\n        options: {\n          ...serializableOptions,\n          // URL is not serializable so to convert to string here and back to URL in the worker.\n          url: url ? fileURLToPath(url) : undefined,\n        },\n      });\n    });\n  }\n\n  /**\n   * Shutdown the Sass render worker.\n   * Executing this method will stop any pending render requests.\n   */\n  close(): void {\n    for (const worker of this.workers) {\n      try {\n        void worker.terminate();\n      } catch {}\n    }\n    this.requests.clear();\n  }\n\n  private createWorker(): Worker {\n    const { port1: mainImporterPort, port2: workerImporterPort } = new MessageChannel();\n    const importerSignal = new Int32Array(new SharedArrayBuffer(4));\n\n    const worker = new Worker(this.workerPath, {\n      workerData: { workerImporterPort, importerSignal },\n      transferList: [workerImporterPort],\n    });\n\n    worker.on('message', (response: RenderResponseMessage) => {\n      const request = this.requests.get(response.id);\n      if (!request) {\n        return;\n      }\n\n      this.requests.delete(response.id);\n      this.availableWorkers.push(request.workerIndex);\n\n      if (response.warnings && request.logger?.warn) {\n        for (const { message, span, ...options } of response.warnings) {\n          request.logger.warn(message, {\n            ...options,\n            span: span && {\n              ...span,\n              url: span.url ? pathToFileURL(span.url) : undefined,\n            },\n          });\n        }\n      }\n\n      if (response.result) {\n        request.callback(undefined, {\n          ...response.result,\n          // URL is not serializable so in the worker we convert to string and here back to URL.\n          loadedUrls: response.result.loadedUrls.map((p) => pathToFileURL(p)),\n        });\n      } else {\n        request.callback(response.error);\n      }\n    });\n\n    mainImporterPort.on(\n      'message',\n      ({ id, url, options }: { id: number; url: string; options: FileImporterOptions }) => {\n        const request = this.requests.get(id);\n        if (!request?.importers) {\n          mainImporterPort.postMessage(null);\n          Atomics.store(importerSignal, 0, 1);\n          Atomics.notify(importerSignal, 0);\n\n          return;\n        }\n\n        this.processImporters(request.importers, url, {\n          ...options,\n          previousResolvedModules: request.previousResolvedModules,\n        })\n          .then((result) => {\n            if (result) {\n              request.previousResolvedModules ??= new Set();\n              request.previousResolvedModules.add(dirname(result));\n            }\n\n            mainImporterPort.postMessage(result);\n          })\n          .catch((error) => {\n            mainImporterPort.postMessage(error);\n          })\n          .finally(() => {\n            Atomics.store(importerSignal, 0, 1);\n            Atomics.notify(importerSignal, 0);\n          });\n      },\n    );\n\n    mainImporterPort.unref();\n\n    return worker;\n  }\n\n  private async processImporters(\n    importers: Iterable<Importers>,\n    url: string,\n    options: FileImporterWithRequestContextOptions,\n  ): Promise<string | null> {\n    for (const importer of importers) {\n      if (this.isImporter(importer)) {\n        // Importer\n        throw new Error('Only File Importers are supported.');\n      }\n\n      // File importer (Can be sync or aync).\n      const result = await importer.findFileUrl(url, options);\n      if (result) {\n        return fileURLToPath(result);\n      }\n    }\n\n    return null;\n  }\n\n  private createRequest(\n    workerIndex: number,\n    callback: RenderCallback,\n    logger: Logger | undefined,\n    importers: Importers[] | undefined,\n  ): RenderRequest {\n    return {\n      id: this.idCounter++,\n      workerIndex,\n      callback,\n      logger,\n      importers,\n    };\n  }\n\n  private isImporter(value: Importers): value is Importer {\n    return 'canonicalize' in value && 'load' in value;\n  }\n}\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
export declare function resolve(specifier: string, context: {}, nextResolve: Function): any;
|
|
9
|
+
export declare function load(url: string, context: {
|
|
10
|
+
format?: string | null;
|
|
11
|
+
}, nextLoad: Function): any;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @license
|
|
4
|
+
* Copyright Google LLC All Rights Reserved.
|
|
5
|
+
*
|
|
6
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
7
|
+
* found in the LICENSE file at https://angular.io/license
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.load = exports.resolve = void 0;
|
|
11
|
+
const node_worker_threads_1 = require("node:worker_threads");
|
|
12
|
+
const url_1 = require("url");
|
|
13
|
+
/**
|
|
14
|
+
* Node.js ESM loader to redirect imports to in memory files.
|
|
15
|
+
* @see: https://nodejs.org/api/esm.html#loaders for more information about loaders.
|
|
16
|
+
*/
|
|
17
|
+
const { outputFiles } = node_worker_threads_1.workerData;
|
|
18
|
+
function resolve(specifier, context, nextResolve) {
|
|
19
|
+
if (!isFileProtocol(specifier)) {
|
|
20
|
+
const normalizedSpecifier = specifier.replace(/^\.\//, '');
|
|
21
|
+
if (normalizedSpecifier in outputFiles) {
|
|
22
|
+
return {
|
|
23
|
+
format: 'module',
|
|
24
|
+
shortCircuit: true,
|
|
25
|
+
url: new URL(normalizedSpecifier, 'file:').href,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
// Defer to the next hook in the chain, which would be the
|
|
30
|
+
// Node.js default resolve if this is the last user-specified loader.
|
|
31
|
+
return nextResolve(specifier);
|
|
32
|
+
}
|
|
33
|
+
exports.resolve = resolve;
|
|
34
|
+
function load(url, context, nextLoad) {
|
|
35
|
+
if (isFileProtocol(url)) {
|
|
36
|
+
const source = outputFiles[(0, url_1.fileURLToPath)(url).slice(1)]; // Remove leading slash
|
|
37
|
+
if (source !== undefined) {
|
|
38
|
+
const { format } = context;
|
|
39
|
+
return {
|
|
40
|
+
format,
|
|
41
|
+
shortCircuit: true,
|
|
42
|
+
source,
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
// Let Node.js handle all other URLs.
|
|
47
|
+
return nextLoad(url);
|
|
48
|
+
}
|
|
49
|
+
exports.load = load;
|
|
50
|
+
function isFileProtocol(url) {
|
|
51
|
+
return url.startsWith('file://');
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNtLWluLW1lbW9yeS1maWxlLWxvYWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL3V0aWxzL3NlcnZlci1yZW5kZXJpbmcvZXNtLWluLW1lbW9yeS1maWxlLWxvYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUFFSCw2REFBaUQ7QUFDakQsNkJBQW9DO0FBRXBDOzs7R0FHRztBQUVILE1BQU0sRUFBRSxXQUFXLEVBQUUsR0FBRyxnQ0FFdkIsQ0FBQztBQUVGLFNBQWdCLE9BQU8sQ0FBQyxTQUFpQixFQUFFLE9BQVcsRUFBRSxXQUFxQjtJQUMzRSxJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxFQUFFO1FBQzlCLE1BQU0sbUJBQW1CLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDM0QsSUFBSSxtQkFBbUIsSUFBSSxXQUFXLEVBQUU7WUFDdEMsT0FBTztnQkFDTCxNQUFNLEVBQUUsUUFBUTtnQkFDaEIsWUFBWSxFQUFFLElBQUk7Z0JBQ2xCLEdBQUcsRUFBRSxJQUFJLEdBQUcsQ0FBQyxtQkFBbUIsRUFBRSxPQUFPLENBQUMsQ0FBQyxJQUFJO2FBQ2hELENBQUM7U0FDSDtLQUNGO0lBRUQsMERBQTBEO0lBQzFELHFFQUFxRTtJQUNyRSxPQUFPLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUNoQyxDQUFDO0FBZkQsMEJBZUM7QUFFRCxTQUFnQixJQUFJLENBQUMsR0FBVyxFQUFFLE9BQW1DLEVBQUUsUUFBa0I7SUFDdkYsSUFBSSxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUU7UUFDdkIsTUFBTSxNQUFNLEdBQUcsV0FBVyxDQUFDLElBQUEsbUJBQWEsRUFBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLHVCQUF1QjtRQUNoRixJQUFJLE1BQU0sS0FBSyxTQUFTLEVBQUU7WUFDeEIsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLE9BQU8sQ0FBQztZQUUzQixPQUFPO2dCQUNMLE1BQU07Z0JBQ04sWUFBWSxFQUFFLElBQUk7Z0JBQ2xCLE1BQU07YUFDUCxDQUFDO1NBQ0g7S0FDRjtJQUVELHFDQUFxQztJQUNyQyxPQUFPLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUN2QixDQUFDO0FBaEJELG9CQWdCQztBQUVELFNBQVMsY0FBYyxDQUFDLEdBQVc7SUFDakMsT0FBTyxHQUFHLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQ25DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHsgd29ya2VyRGF0YSB9IGZyb20gJ25vZGU6d29ya2VyX3RocmVhZHMnO1xuaW1wb3J0IHsgZmlsZVVSTFRvUGF0aCB9IGZyb20gJ3VybCc7XG5cbi8qKlxuICogTm9kZS5qcyBFU00gbG9hZGVyIHRvIHJlZGlyZWN0IGltcG9ydHMgdG8gaW4gbWVtb3J5IGZpbGVzLlxuICogQHNlZTogaHR0cHM6Ly9ub2RlanMub3JnL2FwaS9lc20uaHRtbCNsb2FkZXJzIGZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IGxvYWRlcnMuXG4gKi9cblxuY29uc3QgeyBvdXRwdXRGaWxlcyB9ID0gd29ya2VyRGF0YSBhcyB7XG4gIG91dHB1dEZpbGVzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIHJlc29sdmUoc3BlY2lmaWVyOiBzdHJpbmcsIGNvbnRleHQ6IHt9LCBuZXh0UmVzb2x2ZTogRnVuY3Rpb24pIHtcbiAgaWYgKCFpc0ZpbGVQcm90b2NvbChzcGVjaWZpZXIpKSB7XG4gICAgY29uc3Qgbm9ybWFsaXplZFNwZWNpZmllciA9IHNwZWNpZmllci5yZXBsYWNlKC9eXFwuXFwvLywgJycpO1xuICAgIGlmIChub3JtYWxpemVkU3BlY2lmaWVyIGluIG91dHB1dEZpbGVzKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBmb3JtYXQ6ICdtb2R1bGUnLFxuICAgICAgICBzaG9ydENpcmN1aXQ6IHRydWUsXG4gICAgICAgIHVybDogbmV3IFVSTChub3JtYWxpemVkU3BlY2lmaWVyLCAnZmlsZTonKS5ocmVmLFxuICAgICAgfTtcbiAgICB9XG4gIH1cblxuICAvLyBEZWZlciB0byB0aGUgbmV4dCBob29rIGluIHRoZSBjaGFpbiwgd2hpY2ggd291bGQgYmUgdGhlXG4gIC8vIE5vZGUuanMgZGVmYXVsdCByZXNvbHZlIGlmIHRoaXMgaXMgdGhlIGxhc3QgdXNlci1zcGVjaWZpZWQgbG9hZGVyLlxuICByZXR1cm4gbmV4dFJlc29sdmUoc3BlY2lmaWVyKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGxvYWQodXJsOiBzdHJpbmcsIGNvbnRleHQ6IHsgZm9ybWF0Pzogc3RyaW5nIHwgbnVsbCB9LCBuZXh0TG9hZDogRnVuY3Rpb24pIHtcbiAgaWYgKGlzRmlsZVByb3RvY29sKHVybCkpIHtcbiAgICBjb25zdCBzb3VyY2UgPSBvdXRwdXRGaWxlc1tmaWxlVVJMVG9QYXRoKHVybCkuc2xpY2UoMSldOyAvLyBSZW1vdmUgbGVhZGluZyBzbGFzaFxuICAgIGlmIChzb3VyY2UgIT09IHVuZGVmaW5lZCkge1xuICAgICAgY29uc3QgeyBmb3JtYXQgfSA9IGNvbnRleHQ7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGZvcm1hdCxcbiAgICAgICAgc2hvcnRDaXJjdWl0OiB0cnVlLFxuICAgICAgICBzb3VyY2UsXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIC8vIExldCBOb2RlLmpzIGhhbmRsZSBhbGwgb3RoZXIgVVJMcy5cbiAgcmV0dXJuIG5leHRMb2FkKHVybCk7XG59XG5cbmZ1bmN0aW9uIGlzRmlsZVByb3RvY29sKHVybDogc3RyaW5nKTogYm9vbGVhbiB7XG4gIHJldHVybiB1cmwuc3RhcnRzV2l0aCgnZmlsZTovLycpO1xufVxuIl19
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { OutputFile } from 'esbuild';
|
|
9
|
+
interface PrerenderOptions {
|
|
10
|
+
routesFile?: string;
|
|
11
|
+
discoverRoutes?: boolean;
|
|
12
|
+
routes?: string[];
|
|
13
|
+
}
|
|
14
|
+
interface AppShellOptions {
|
|
15
|
+
route?: string;
|
|
16
|
+
}
|
|
17
|
+
export declare function prerenderPages(tsConfigPath: string, appShellOptions: AppShellOptions | undefined, prerenderOptions: PrerenderOptions | undefined, outputFiles: Readonly<OutputFile[]>, document: string, inlineCriticalCss?: boolean, maxThreads?: number): Promise<{
|
|
18
|
+
output: Record<string, string>;
|
|
19
|
+
warnings: string[];
|
|
20
|
+
errors: string[];
|
|
21
|
+
}>;
|
|
22
|
+
export {};
|