nx 18.1.3 → 18.2.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/package.json +12 -12
- package/schemas/nx-schema.json +32 -6
- package/src/adapter/compat.d.ts +1 -1
- package/src/adapter/compat.js +1 -0
- package/src/command-line/affected/command-object.js +49 -22
- package/src/command-line/generate/generate.js +3 -3
- package/src/command-line/run/command-object.js +9 -2
- package/src/command-line/run/run-one.js +1 -1
- package/src/command-line/run-many/command-object.js +4 -1
- package/src/command-line/show/command-object.d.ts +2 -0
- package/src/command-line/show/command-object.js +19 -2
- package/src/config/nx-json.d.ts +2 -0
- package/src/config/workspace-json-project-json.d.ts +4 -0
- package/src/core/graph/3rdpartylicenses.txt +2 -53
- package/src/core/graph/main.js +1 -1
- package/src/core/graph/polyfills.js +1 -1
- package/src/core/graph/runtime.js +1 -1
- package/src/core/graph/styles.js +1 -1
- package/src/daemon/client/client.js +19 -7
- package/src/daemon/daemon-project-graph-error.d.ts +8 -0
- package/src/daemon/daemon-project-graph-error.js +13 -0
- package/src/daemon/server/handle-hash-tasks.js +11 -1
- package/src/daemon/server/project-graph-incremental-recomputation.d.ts +1 -0
- package/src/daemon/server/project-graph-incremental-recomputation.js +55 -6
- package/src/daemon/server/shutdown-utils.js +1 -3
- package/src/daemon/socket-utils.js +7 -1
- package/src/plugins/js/versions.d.ts +1 -1
- package/src/plugins/js/versions.js +1 -1
- package/src/project-graph/build-project-graph.d.ts +18 -1
- package/src/project-graph/build-project-graph.js +71 -24
- package/src/project-graph/project-graph.d.ts +23 -2
- package/src/project-graph/project-graph.js +117 -14
- package/src/project-graph/utils/project-configuration-utils.d.ts +27 -4
- package/src/project-graph/utils/project-configuration-utils.js +195 -47
- package/src/project-graph/utils/retrieve-workspace-files.d.ts +4 -12
- package/src/project-graph/utils/retrieve-workspace-files.js +3 -16
- package/src/utils/nx-plugin.d.ts +2 -0
- package/src/utils/nx-plugin.js +18 -2
- package/src/utils/output.d.ts +1 -1
- package/src/utils/params.d.ts +2 -2
- package/src/utils/params.js +14 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.configurationGlobs = exports.
|
3
|
+
exports.configurationGlobs = exports.retrieveProjectConfigurationsWithoutPluginInference = exports.retrieveProjectConfigurationPaths = exports.retrieveProjectConfigurationsWithAngularProjects = exports.retrieveProjectConfigurations = exports.retrieveWorkspaceFiles = void 0;
|
4
4
|
const perf_hooks_1 = require("perf_hooks");
|
5
5
|
const installation_directory_1 = require("../../utils/installation-directory");
|
6
6
|
const angular_json_1 = require("../../adapter/angular-json");
|
@@ -58,7 +58,7 @@ exports.retrieveProjectConfigurationsWithAngularProjects = retrieveProjectConfig
|
|
58
58
|
function _retrieveProjectConfigurations(workspaceRoot, nxJson, plugins) {
|
59
59
|
const globPatterns = configurationGlobs(plugins);
|
60
60
|
const workspaceFiles = (0, workspace_context_1.globWithWorkspaceContext)(workspaceRoot, globPatterns);
|
61
|
-
return createProjectConfigurations(workspaceRoot, nxJson, workspaceFiles, plugins);
|
61
|
+
return (0, project_configuration_utils_1.createProjectConfigurations)(workspaceRoot, nxJson, workspaceFiles, plugins);
|
62
62
|
}
|
63
63
|
function retrieveProjectConfigurationPaths(root, plugins) {
|
64
64
|
const projectGlobPatterns = configurationGlobs(plugins);
|
@@ -76,7 +76,7 @@ async function retrieveProjectConfigurationsWithoutPluginInference(root) {
|
|
76
76
|
return projectsWithoutPluginCache.get(cacheKey);
|
77
77
|
}
|
78
78
|
const projectFiles = (0, workspace_context_1.globWithWorkspaceContext)(root, projectGlobPatterns) ?? [];
|
79
|
-
const { projects } = await createProjectConfigurations(root, nxJson, projectFiles, [
|
79
|
+
const { projects } = await (0, project_configuration_utils_1.createProjectConfigurations)(root, nxJson, projectFiles, [
|
80
80
|
{ plugin: (0, package_json_workspaces_1.getNxPackageJsonWorkspacesPlugin)(root) },
|
81
81
|
{ plugin: project_json_1.ProjectJsonProjectsPlugin },
|
82
82
|
]);
|
@@ -84,19 +84,6 @@ async function retrieveProjectConfigurationsWithoutPluginInference(root) {
|
|
84
84
|
return projects;
|
85
85
|
}
|
86
86
|
exports.retrieveProjectConfigurationsWithoutPluginInference = retrieveProjectConfigurationsWithoutPluginInference;
|
87
|
-
async function createProjectConfigurations(workspaceRoot, nxJson, configFiles, plugins) {
|
88
|
-
perf_hooks_1.performance.mark('build-project-configs:start');
|
89
|
-
const { projects, externalNodes, rootMap, sourceMaps } = await (0, project_configuration_utils_1.buildProjectsConfigurationsFromProjectPathsAndPlugins)(nxJson, configFiles, plugins, workspaceRoot);
|
90
|
-
perf_hooks_1.performance.mark('build-project-configs:end');
|
91
|
-
perf_hooks_1.performance.measure('build-project-configs', 'build-project-configs:start', 'build-project-configs:end');
|
92
|
-
return {
|
93
|
-
projects,
|
94
|
-
externalNodes,
|
95
|
-
projectRootMap: rootMap,
|
96
|
-
sourceMaps,
|
97
|
-
};
|
98
|
-
}
|
99
|
-
exports.createProjectConfigurations = createProjectConfigurations;
|
100
87
|
function configurationGlobs(plugins) {
|
101
88
|
const globPatterns = [];
|
102
89
|
for (const { plugin } of plugins) {
|
package/src/utils/nx-plugin.d.ts
CHANGED
@@ -91,6 +91,8 @@ export type NxPlugin = NxPluginV1 | NxPluginV2;
|
|
91
91
|
export type LoadedNxPlugin = {
|
92
92
|
plugin: NxPluginV2 & Pick<NxPluginV1, 'processProjectGraph'>;
|
93
93
|
options?: unknown;
|
94
|
+
include?: string[];
|
95
|
+
exclude?: string[];
|
94
96
|
};
|
95
97
|
export declare const nxPluginCache: Map<string, LoadedNxPlugin['plugin']>;
|
96
98
|
export declare function getPluginPathAndName(moduleName: string, paths: string[], projects: Record<string, ProjectConfiguration>, root: string): {
|
package/src/utils/nx-plugin.js
CHANGED
@@ -71,8 +71,19 @@ async function loadNxPluginAsync(pluginConfiguration, paths, projects, root) {
|
|
71
71
|
? pluginConfiguration
|
72
72
|
: { plugin: pluginConfiguration, options: undefined };
|
73
73
|
let pluginModule = exports.nxPluginCache.get(moduleName);
|
74
|
+
const include = typeof pluginConfiguration === 'object'
|
75
|
+
? pluginConfiguration.include
|
76
|
+
: undefined;
|
77
|
+
const exclude = typeof pluginConfiguration === 'object'
|
78
|
+
? pluginConfiguration.exclude
|
79
|
+
: undefined;
|
74
80
|
if (pluginModule) {
|
75
|
-
return {
|
81
|
+
return {
|
82
|
+
plugin: pluginModule,
|
83
|
+
options,
|
84
|
+
include,
|
85
|
+
exclude,
|
86
|
+
};
|
76
87
|
}
|
77
88
|
performance.mark(`Load Nx Plugin: ${moduleName} - start`);
|
78
89
|
let { pluginPath, name } = await getPluginPathAndName(moduleName, paths, projects, root);
|
@@ -81,7 +92,12 @@ async function loadNxPluginAsync(pluginConfiguration, paths, projects, root) {
|
|
81
92
|
exports.nxPluginCache.set(moduleName, plugin);
|
82
93
|
performance.mark(`Load Nx Plugin: ${moduleName} - end`);
|
83
94
|
performance.measure(`Load Nx Plugin: ${moduleName}`, `Load Nx Plugin: ${moduleName} - start`, `Load Nx Plugin: ${moduleName} - end`);
|
84
|
-
return {
|
95
|
+
return {
|
96
|
+
plugin,
|
97
|
+
options,
|
98
|
+
include,
|
99
|
+
exclude,
|
100
|
+
};
|
85
101
|
}
|
86
102
|
exports.loadNxPluginAsync = loadNxPluginAsync;
|
87
103
|
async function loadNxPlugins(plugins, paths = (0, installation_directory_1.getNxRequirePaths)(), root = workspace_root_1.workspaceRoot, projects) {
|
package/src/utils/output.d.ts
CHANGED
package/src/utils/params.d.ts
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
import { NxJsonConfiguration } from '../config/nx-json';
|
2
|
-
import { TargetConfiguration, ProjectsConfigurations } from '../config/workspace-json-project-json';
|
1
|
+
import type { NxJsonConfiguration } from '../config/nx-json';
|
2
|
+
import type { TargetConfiguration, ProjectsConfigurations } from '../config/workspace-json-project-json';
|
3
3
|
type PropertyDescription = {
|
4
4
|
type?: string | string[];
|
5
5
|
required?: string[];
|
package/src/utils/params.js
CHANGED
@@ -13,6 +13,20 @@ async function handleErrors(isVerbose, fn) {
|
|
13
13
|
if (err.constructor.name === 'UnsuccessfulWorkflowExecution') {
|
14
14
|
logger_1.logger.error('The generator workflow failed. See above.');
|
15
15
|
}
|
16
|
+
else if (err.name === 'ProjectGraphError') {
|
17
|
+
const projectGraphError = err;
|
18
|
+
let title = projectGraphError.message;
|
19
|
+
if (isVerbose) {
|
20
|
+
title += ' See errors below.';
|
21
|
+
}
|
22
|
+
const bodyLines = isVerbose
|
23
|
+
? [projectGraphError.stack]
|
24
|
+
: ['Pass --verbose to see the stacktraces.'];
|
25
|
+
output_1.output.error({
|
26
|
+
title,
|
27
|
+
bodyLines: bodyLines,
|
28
|
+
});
|
29
|
+
}
|
16
30
|
else {
|
17
31
|
const lines = (err.message ? err.message : err.toString()).split('\n');
|
18
32
|
const bodyLines = lines.slice(1);
|