@nx/gradle 20.5.0-beta.2 → 20.5.0-canary.20250128-e0c49d3

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/generators.json CHANGED
@@ -5,8 +5,7 @@
5
5
  "init": {
6
6
  "factory": "./src/generators/init/init#initGenerator",
7
7
  "schema": "./src/generators/init/schema.json",
8
- "description": "Initializes a Gradle project in the current workspace",
9
- "hidden": true
8
+ "description": "Initializes a Gradle project in the current workspace"
10
9
  },
11
10
  "ci-workflow": {
12
11
  "factory": "./src/generators/ci-workflow/generator",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nx/gradle",
3
- "version": "20.5.0-beta.2",
3
+ "version": "20.5.0-canary.20250128-e0c49d3",
4
4
  "private": false,
5
5
  "description": "The Nx Plugin for Gradle allows Gradle tasks to be run through Nx",
6
6
  "repository": {
@@ -34,7 +34,7 @@
34
34
  "migrations": "./migrations.json"
35
35
  },
36
36
  "dependencies": {
37
- "@nx/devkit": "20.5.0-beta.2"
37
+ "@nx/devkit": "20.5.0-canary.20250128-e0c49d3"
38
38
  },
39
39
  "publishConfig": {
40
40
  "access": "public"
@@ -1,2 +1,3 @@
1
- import { CreateDependencies } from '@nx/devkit';
1
+ import { CreateDependencies, CreateDependenciesContext, RawProjectGraphDependency } from '@nx/devkit';
2
2
  export declare const createDependencies: CreateDependencies;
3
+ export declare function processGradleDependencies(depsFile: string, gradleProjectNameToProjectRoot: Map<string, string>, sourceProjectName: string, gradleFile: string, context: CreateDependenciesContext, dependencies: Set<RawProjectGraphDependency>): void;
@@ -1,10 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.createDependencies = void 0;
4
+ exports.processGradleDependencies = processGradleDependencies;
4
5
  const devkit_1 = require("@nx/devkit");
6
+ const node_fs_1 = require("node:fs");
5
7
  const node_path_1 = require("node:path");
6
8
  const get_gradle_report_1 = require("../utils/get-gradle-report");
7
9
  const split_config_files_1 = require("../utils/split-config-files");
10
+ const get_project_report_lines_1 = require("../utils/get-project-report-lines");
8
11
  const createDependencies = async (_, context) => {
9
12
  const gradleFiles = findGradleFiles(context.filesToProcess);
10
13
  if (gradleFiles.length === 0) {
@@ -16,20 +19,9 @@ const createDependencies = async (_, context) => {
16
19
  for (const gradleFile of gradleFiles) {
17
20
  const gradleProject = gradleFileToGradleProjectMap.get(gradleFile);
18
21
  const projectName = Object.values(context.projects).find((project) => project.root === (0, node_path_1.dirname)(gradleFile))?.name;
19
- const dependedProjects = buildFileToDepsMap.get(gradleFile);
20
- if (projectName && dependedProjects?.size) {
21
- dependedProjects?.forEach((dependedProject) => {
22
- const targetProjectRoot = gradleProjectNameToProjectRootMap.get(dependedProject);
23
- const targetProjectName = Object.values(context.projects).find((project) => project.root === targetProjectRoot)?.name;
24
- const dependency = {
25
- source: projectName,
26
- target: targetProjectName,
27
- type: devkit_1.DependencyType.static,
28
- sourceFile: gradleFile,
29
- };
30
- (0, devkit_1.validateDependency)(dependency, context);
31
- dependencies.add(dependency);
32
- });
22
+ const depsFile = buildFileToDepsMap.get(gradleFile);
23
+ if (projectName && depsFile) {
24
+ processGradleDependencies(depsFile, gradleProjectNameToProjectRootMap, projectName, gradleFile, context, dependencies);
33
25
  }
34
26
  gradleProjectToChildProjects.get(gradleProject)?.forEach((childProject) => {
35
27
  if (childProject) {
@@ -60,3 +52,46 @@ function findGradleFiles(fileMap) {
60
52
  }
61
53
  return gradleFiles;
62
54
  }
55
+ function processGradleDependencies(depsFile, gradleProjectNameToProjectRoot, sourceProjectName, gradleFile, context, dependencies) {
56
+ const lines = (0, node_fs_1.readFileSync)(depsFile).toString().split(get_project_report_lines_1.newLineSeparator);
57
+ let inDeps = false;
58
+ for (const line of lines) {
59
+ if (line.startsWith('implementationDependenciesMetadata') ||
60
+ line.startsWith('compileClasspath')) {
61
+ inDeps = true;
62
+ continue;
63
+ }
64
+ if (inDeps) {
65
+ if (line === '') {
66
+ inDeps = false;
67
+ continue;
68
+ }
69
+ const [indents, dep] = line.split('--- ');
70
+ if (indents === '\\' || indents === '+') {
71
+ let gradleProjectName;
72
+ if (dep.startsWith('project ')) {
73
+ gradleProjectName = dep
74
+ .substring('project '.length)
75
+ .replace(/ \(n\)$/, '')
76
+ .trim();
77
+ }
78
+ else if (dep.includes('-> project')) {
79
+ const [_, projectName] = dep.split('-> project');
80
+ gradleProjectName = projectName.trim();
81
+ }
82
+ const targetProjectRoot = gradleProjectNameToProjectRoot.get(gradleProjectName);
83
+ const targetProjectName = Object.values(context.projects).find((project) => project.root === targetProjectRoot)?.name;
84
+ if (targetProjectName) {
85
+ const dependency = {
86
+ source: sourceProjectName,
87
+ target: targetProjectName,
88
+ type: devkit_1.DependencyType.static,
89
+ sourceFile: gradleFile,
90
+ };
91
+ (0, devkit_1.validateDependency)(dependency, context);
92
+ dependencies.add(dependency);
93
+ }
94
+ }
95
+ }
96
+ }
97
+ }
@@ -94,7 +94,7 @@ async function createGradleProject(gradleReport, gradleFilePath, options, contex
94
94
  let tasks = [];
95
95
  tasksSet.forEach((taskName) => {
96
96
  tasks.push({
97
- type: tasksTypeMap?.get(taskName),
97
+ type: tasksTypeMap.get(taskName),
98
98
  name: taskName,
99
99
  });
100
100
  });
@@ -7,7 +7,6 @@ const devkit_1 = require("@nx/devkit");
7
7
  const node_child_process_1 = require("node:child_process");
8
8
  const node_fs_1 = require("node:fs");
9
9
  const node_path_1 = require("node:path");
10
- const run_commands_impl_1 = require("nx/src/executors/run-commands/run-commands.impl");
11
10
  /**
12
11
  * For gradle command, it needs to be run from the directory of the gradle binary
13
12
  * @returns gradle binary file name
@@ -29,7 +28,6 @@ function execGradleAsync(gradleBinaryPath, args, execOptions = {}) {
29
28
  shell: true,
30
29
  windowsHide: true,
31
30
  env: process.env,
32
- maxBuffer: run_commands_impl_1.LARGE_BUFFER,
33
31
  ...execOptions,
34
32
  });
35
33
  let stdout = Buffer.from('');
@@ -1,9 +1,9 @@
1
1
  export interface GradleReport {
2
2
  gradleFileToGradleProjectMap: Map<string, string>;
3
- buildFileToDepsMap: Map<string, Set<string>>;
3
+ buildFileToDepsMap: Map<string, string>;
4
4
  gradleFileToOutputDirsMap: Map<string, Map<string, string>>;
5
5
  gradleProjectToTasksTypeMap: Map<string, Map<string, string>>;
6
- gradleProjectToTasksMap: Map<string, Set<string>>;
6
+ gradleProjectToTasksMap: Map<string, Set<String>>;
7
7
  gradleProjectToProjectName: Map<string, string>;
8
8
  gradleProjectNameToProjectRootMap: Map<string, string>;
9
9
  gradleProjectToChildProjects: Map<string, string[]>;
@@ -11,10 +11,10 @@ export interface GradleReport {
11
11
  export interface GradleReportJSON {
12
12
  hash: string;
13
13
  gradleFileToGradleProjectMap: Record<string, string>;
14
- buildFileToDepsMap: Record<string, Set<string>>;
14
+ buildFileToDepsMap: Record<string, string>;
15
15
  gradleFileToOutputDirsMap: Record<string, Record<string, string>>;
16
16
  gradleProjectToTasksTypeMap: Record<string, Record<string, string>>;
17
- gradleProjectToTasksMap: Record<string, Array<string>>;
17
+ gradleProjectToTasksMap: Record<string, Array<String>>;
18
18
  gradleProjectToProjectName: Record<string, string>;
19
19
  gradleProjectNameToProjectRootMap: Record<string, string>;
20
20
  gradleProjectToChildProjects: Record<string, string[]>;
@@ -33,4 +33,3 @@ export declare function getCurrentGradleReport(): GradleReport;
33
33
  */
34
34
  export declare function populateGradleReport(workspaceRoot: string, gradlewFiles: string[]): Promise<void>;
35
35
  export declare function processProjectReports(projectReportLines: string[]): GradleReport;
36
- export declare function processGradleDependencies(depsFile: string): Set<string>;
@@ -4,7 +4,6 @@ exports.writeGradleReportToCache = writeGradleReportToCache;
4
4
  exports.getCurrentGradleReport = getCurrentGradleReport;
5
5
  exports.populateGradleReport = populateGradleReport;
6
6
  exports.processProjectReports = processProjectReports;
7
- exports.processGradleDependencies = processGradleDependencies;
8
7
  const node_fs_1 = require("node:fs");
9
8
  const node_path_1 = require("node:path");
10
9
  const devkit_1 = require("@nx/devkit");
@@ -185,10 +184,7 @@ function processProjectReports(projectReportLines) {
185
184
  }
186
185
  const buildFile = (0, devkit_1.normalizePath)((0, node_path_1.relative)(devkit_1.workspaceRoot, absBuildFilePath));
187
186
  const buildDir = (0, node_path_1.relative)(devkit_1.workspaceRoot, absBuildDirPath);
188
- const depsFile = dependenciesMap.get(gradleProject);
189
- if (depsFile) {
190
- buildFileToDepsMap.set(buildFile, processGradleDependencies(depsFile));
191
- }
187
+ buildFileToDepsMap.set(buildFile, dependenciesMap.get(gradleProject));
192
188
  outputDirMap.set('build', `{workspaceRoot}/${buildDir}`);
193
189
  outputDirMap.set('classes', `{workspaceRoot}/${(0, node_path_1.join)(buildDir, 'classes')}`);
194
190
  gradleFileToOutputDirsMap.set(buildFile, outputDirMap);
@@ -242,39 +238,3 @@ function processProjectReports(projectReportLines) {
242
238
  gradleProjectToChildProjects,
243
239
  };
244
240
  }
245
- function processGradleDependencies(depsFile) {
246
- const dependedProjects = new Set();
247
- const lines = (0, node_fs_1.readFileSync)(depsFile).toString().split(get_project_report_lines_1.newLineSeparator);
248
- let inDeps = false;
249
- for (const line of lines) {
250
- if (line.startsWith('implementationDependenciesMetadata') ||
251
- line.startsWith('compileClasspath')) {
252
- inDeps = true;
253
- continue;
254
- }
255
- if (inDeps) {
256
- if (line === '') {
257
- inDeps = false;
258
- continue;
259
- }
260
- const [indents, dep] = line.split('--- ');
261
- if (indents === '\\' || indents === '+') {
262
- let targetProjectName;
263
- if (dep.startsWith('project ')) {
264
- targetProjectName = dep
265
- .substring('project '.length)
266
- .replace(/ \(n\)$/, '')
267
- .trim();
268
- }
269
- else if (dep.includes('-> project')) {
270
- const [_, projectName] = dep.split('-> project');
271
- targetProjectName = projectName.trim();
272
- }
273
- if (targetProjectName) {
274
- dependedProjects.add(targetProjectName);
275
- }
276
- }
277
- }
278
- }
279
- return dependedProjects;
280
- }