@angular-devkit/build-angular 16.2.0-next.2 → 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 +10 -10
- package/src/tools/babel/plugins/adjust-typescript-enums.js +21 -31
- package/src/tools/esbuild/angular/compilation/angular-compilation.js +2 -1
- package/src/tools/esbuild/application-code-bundle.js +2 -1
- package/src/tools/esbuild/stylesheets/sass-language.js +58 -28
- 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
|
@@ -0,0 +1,248 @@
|
|
|
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.findImports = exports.findUrls = void 0;
|
|
11
|
+
// TODO: Combine everything into a single pass lexer
|
|
12
|
+
/**
|
|
13
|
+
* Determines if a unicode code point is a CSS whitespace character.
|
|
14
|
+
* @param code The unicode code point to test.
|
|
15
|
+
* @returns true, if the code point is CSS whitespace; false, otherwise.
|
|
16
|
+
*/
|
|
17
|
+
function isWhitespace(code) {
|
|
18
|
+
// Based on https://www.w3.org/TR/css-syntax-3/#whitespace
|
|
19
|
+
switch (code) {
|
|
20
|
+
case 0x0009: // tab
|
|
21
|
+
case 0x0020: // space
|
|
22
|
+
case 0x000a: // line feed
|
|
23
|
+
case 0x000c: // form feed
|
|
24
|
+
case 0x000d: // carriage return
|
|
25
|
+
return true;
|
|
26
|
+
default:
|
|
27
|
+
return false;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Scans a CSS or Sass file and locates all valid url function values as defined by the
|
|
32
|
+
* syntax specification.
|
|
33
|
+
* @param contents A string containing a CSS or Sass file to scan.
|
|
34
|
+
* @returns An iterable that yields each CSS url function value found.
|
|
35
|
+
*/
|
|
36
|
+
function* findUrls(contents) {
|
|
37
|
+
let pos = 0;
|
|
38
|
+
let width = 1;
|
|
39
|
+
let current = -1;
|
|
40
|
+
const next = () => {
|
|
41
|
+
pos += width;
|
|
42
|
+
current = contents.codePointAt(pos) ?? -1;
|
|
43
|
+
width = current > 0xffff ? 2 : 1;
|
|
44
|
+
return current;
|
|
45
|
+
};
|
|
46
|
+
// Based on https://www.w3.org/TR/css-syntax-3/#consume-ident-like-token
|
|
47
|
+
while ((pos = contents.indexOf('url(', pos)) !== -1) {
|
|
48
|
+
// Set to position of the (
|
|
49
|
+
pos += 3;
|
|
50
|
+
width = 1;
|
|
51
|
+
// Consume all leading whitespace
|
|
52
|
+
while (isWhitespace(next())) {
|
|
53
|
+
/* empty */
|
|
54
|
+
}
|
|
55
|
+
// Initialize URL state
|
|
56
|
+
const url = { start: pos, end: -1, value: '' };
|
|
57
|
+
let complete = false;
|
|
58
|
+
// If " or ', then consume the value as a string
|
|
59
|
+
if (current === 0x0022 || current === 0x0027) {
|
|
60
|
+
const ending = current;
|
|
61
|
+
// Based on https://www.w3.org/TR/css-syntax-3/#consume-string-token
|
|
62
|
+
while (!complete) {
|
|
63
|
+
switch (next()) {
|
|
64
|
+
case -1: // EOF
|
|
65
|
+
return;
|
|
66
|
+
case 0x000a: // line feed
|
|
67
|
+
case 0x000c: // form feed
|
|
68
|
+
case 0x000d: // carriage return
|
|
69
|
+
// Invalid
|
|
70
|
+
complete = true;
|
|
71
|
+
break;
|
|
72
|
+
case 0x005c: // \ -- character escape
|
|
73
|
+
// If not EOF or newline, add the character after the escape
|
|
74
|
+
switch (next()) {
|
|
75
|
+
case -1:
|
|
76
|
+
return;
|
|
77
|
+
case 0x000a: // line feed
|
|
78
|
+
case 0x000c: // form feed
|
|
79
|
+
case 0x000d: // carriage return
|
|
80
|
+
// Skip when inside a string
|
|
81
|
+
break;
|
|
82
|
+
default:
|
|
83
|
+
// TODO: Handle hex escape codes
|
|
84
|
+
url.value += String.fromCodePoint(current);
|
|
85
|
+
break;
|
|
86
|
+
}
|
|
87
|
+
break;
|
|
88
|
+
case ending:
|
|
89
|
+
// Full string position should include the quotes for replacement
|
|
90
|
+
url.end = pos + 1;
|
|
91
|
+
complete = true;
|
|
92
|
+
yield url;
|
|
93
|
+
break;
|
|
94
|
+
default:
|
|
95
|
+
url.value += String.fromCodePoint(current);
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
next();
|
|
100
|
+
continue;
|
|
101
|
+
}
|
|
102
|
+
// Based on https://www.w3.org/TR/css-syntax-3/#consume-url-token
|
|
103
|
+
while (!complete) {
|
|
104
|
+
switch (current) {
|
|
105
|
+
case -1: // EOF
|
|
106
|
+
return;
|
|
107
|
+
case 0x0022: // "
|
|
108
|
+
case 0x0027: // '
|
|
109
|
+
case 0x0028: // (
|
|
110
|
+
// Invalid
|
|
111
|
+
complete = true;
|
|
112
|
+
break;
|
|
113
|
+
case 0x0029: // )
|
|
114
|
+
// URL is valid and complete
|
|
115
|
+
url.end = pos;
|
|
116
|
+
complete = true;
|
|
117
|
+
break;
|
|
118
|
+
case 0x005c: // \ -- character escape
|
|
119
|
+
// If not EOF or newline, add the character after the escape
|
|
120
|
+
switch (next()) {
|
|
121
|
+
case -1: // EOF
|
|
122
|
+
return;
|
|
123
|
+
case 0x000a: // line feed
|
|
124
|
+
case 0x000c: // form feed
|
|
125
|
+
case 0x000d: // carriage return
|
|
126
|
+
// Invalid
|
|
127
|
+
complete = true;
|
|
128
|
+
break;
|
|
129
|
+
default:
|
|
130
|
+
// TODO: Handle hex escape codes
|
|
131
|
+
url.value += String.fromCodePoint(current);
|
|
132
|
+
break;
|
|
133
|
+
}
|
|
134
|
+
break;
|
|
135
|
+
default:
|
|
136
|
+
if (isWhitespace(current)) {
|
|
137
|
+
while (isWhitespace(next())) {
|
|
138
|
+
/* empty */
|
|
139
|
+
}
|
|
140
|
+
// Unescaped whitespace is only valid before the closing )
|
|
141
|
+
if (current === 0x0029) {
|
|
142
|
+
// URL is valid
|
|
143
|
+
url.end = pos;
|
|
144
|
+
}
|
|
145
|
+
complete = true;
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
// Add the character to the url value
|
|
149
|
+
url.value += String.fromCodePoint(current);
|
|
150
|
+
}
|
|
151
|
+
break;
|
|
152
|
+
}
|
|
153
|
+
next();
|
|
154
|
+
}
|
|
155
|
+
// An end position indicates a URL was found
|
|
156
|
+
if (url.end !== -1) {
|
|
157
|
+
yield url;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
exports.findUrls = findUrls;
|
|
162
|
+
/**
|
|
163
|
+
* Scans a CSS or Sass file and locates all valid import/use directive values as defined by the
|
|
164
|
+
* syntax specification.
|
|
165
|
+
* @param contents A string containing a CSS or Sass file to scan.
|
|
166
|
+
* @returns An iterable that yields each CSS directive value found.
|
|
167
|
+
*/
|
|
168
|
+
function* findImports(contents) {
|
|
169
|
+
yield* find(contents, '@import ');
|
|
170
|
+
yield* find(contents, '@use ');
|
|
171
|
+
}
|
|
172
|
+
exports.findImports = findImports;
|
|
173
|
+
/**
|
|
174
|
+
* Scans a CSS or Sass file and locates all valid function/directive values as defined by the
|
|
175
|
+
* syntax specification.
|
|
176
|
+
* @param contents A string containing a CSS or Sass file to scan.
|
|
177
|
+
* @param prefix The prefix to start a valid segment.
|
|
178
|
+
* @returns An iterable that yields each CSS url function value found.
|
|
179
|
+
*/
|
|
180
|
+
function* find(contents, prefix) {
|
|
181
|
+
let pos = 0;
|
|
182
|
+
let width = 1;
|
|
183
|
+
let current = -1;
|
|
184
|
+
const next = () => {
|
|
185
|
+
pos += width;
|
|
186
|
+
current = contents.codePointAt(pos) ?? -1;
|
|
187
|
+
width = current > 0xffff ? 2 : 1;
|
|
188
|
+
return current;
|
|
189
|
+
};
|
|
190
|
+
// Based on https://www.w3.org/TR/css-syntax-3/#consume-ident-like-token
|
|
191
|
+
while ((pos = contents.indexOf(prefix, pos)) !== -1) {
|
|
192
|
+
// Set to position of the last character in prefix
|
|
193
|
+
pos += prefix.length - 1;
|
|
194
|
+
width = 1;
|
|
195
|
+
// Consume all leading whitespace
|
|
196
|
+
while (isWhitespace(next())) {
|
|
197
|
+
/* empty */
|
|
198
|
+
}
|
|
199
|
+
// Initialize URL state
|
|
200
|
+
const url = { start: pos, end: -1, specifier: '' };
|
|
201
|
+
let complete = false;
|
|
202
|
+
// If " or ', then consume the value as a string
|
|
203
|
+
if (current === 0x0022 || current === 0x0027) {
|
|
204
|
+
const ending = current;
|
|
205
|
+
// Based on https://www.w3.org/TR/css-syntax-3/#consume-string-token
|
|
206
|
+
while (!complete) {
|
|
207
|
+
switch (next()) {
|
|
208
|
+
case -1: // EOF
|
|
209
|
+
return;
|
|
210
|
+
case 0x000a: // line feed
|
|
211
|
+
case 0x000c: // form feed
|
|
212
|
+
case 0x000d: // carriage return
|
|
213
|
+
// Invalid
|
|
214
|
+
complete = true;
|
|
215
|
+
break;
|
|
216
|
+
case 0x005c: // \ -- character escape
|
|
217
|
+
// If not EOF or newline, add the character after the escape
|
|
218
|
+
switch (next()) {
|
|
219
|
+
case -1:
|
|
220
|
+
return;
|
|
221
|
+
case 0x000a: // line feed
|
|
222
|
+
case 0x000c: // form feed
|
|
223
|
+
case 0x000d: // carriage return
|
|
224
|
+
// Skip when inside a string
|
|
225
|
+
break;
|
|
226
|
+
default:
|
|
227
|
+
// TODO: Handle hex escape codes
|
|
228
|
+
url.specifier += String.fromCodePoint(current);
|
|
229
|
+
break;
|
|
230
|
+
}
|
|
231
|
+
break;
|
|
232
|
+
case ending:
|
|
233
|
+
// Full string position should include the quotes for replacement
|
|
234
|
+
url.end = pos + 1;
|
|
235
|
+
complete = true;
|
|
236
|
+
yield url;
|
|
237
|
+
break;
|
|
238
|
+
default:
|
|
239
|
+
url.specifier += String.fromCodePoint(current);
|
|
240
|
+
break;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
next();
|
|
244
|
+
continue;
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lexer.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/sass/lexer.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\n// TODO: Combine everything into a single pass lexer\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\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 */\nexport function* findUrls(\n  contents: string,\n): 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 * Scans a CSS or Sass file and locates all valid import/use directive values as defined by the\n * syntax specification.\n * @param contents A string containing a CSS or Sass file to scan.\n * @returns An iterable that yields each CSS directive value found.\n */\nexport function* findImports(\n  contents: string,\n): Iterable<{ start: number; end: number; specifier: string }> {\n  yield* find(contents, '@import ');\n  yield* find(contents, '@use ');\n}\n\n/**\n * Scans a CSS or Sass file and locates all valid function/directive values as defined by the\n * syntax specification.\n * @param contents A string containing a CSS or Sass file to scan.\n * @param prefix The prefix to start a valid segment.\n * @returns An iterable that yields each CSS url function value found.\n */\nfunction* find(\n  contents: string,\n  prefix: string,\n): Iterable<{ start: number; end: number; specifier: 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(prefix, pos)) !== -1) {\n    // Set to position of the last character in prefix\n    pos += prefix.length - 1;\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, specifier: '' };\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.specifier += 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.specifier += String.fromCodePoint(current);\n            break;\n        }\n      }\n\n      next();\n      continue;\n    }\n  }\n}\n"]}
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
8
|
import { RawSourceMap } from '@ampproject/remapping';
|
|
9
|
-
import type {
|
|
9
|
+
import type { Importer, ImporterResult } from 'sass';
|
|
10
10
|
/**
|
|
11
11
|
* A preprocessed cache entry for the files and directories within a previously searched
|
|
12
12
|
* directory when performing Sass import resolution.
|
|
@@ -76,7 +76,10 @@ export declare class RelativeUrlRebasingImporter extends UrlRebasingImporter {
|
|
|
76
76
|
*/
|
|
77
77
|
export declare class ModuleUrlRebasingImporter extends RelativeUrlRebasingImporter {
|
|
78
78
|
private finder;
|
|
79
|
-
constructor(entryDirectory: string, directoryCache: Map<string, DirectoryEntry>, rebaseSourceMaps: Map<string, RawSourceMap> | undefined, finder:
|
|
79
|
+
constructor(entryDirectory: string, directoryCache: Map<string, DirectoryEntry>, rebaseSourceMaps: Map<string, RawSourceMap> | undefined, finder: (specifier: string, options: {
|
|
80
|
+
fromImport: boolean;
|
|
81
|
+
resolveDir?: string;
|
|
82
|
+
}) => URL | null);
|
|
80
83
|
canonicalize(url: string, options: {
|
|
81
84
|
fromImport: boolean;
|
|
82
85
|
}): URL | null;
|