@rnx-kit/cli 0.18.9 → 0.18.11
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/lib/build/android.d.ts +1 -1
- package/lib/build/android.js +2 -2
- package/lib/build.d.ts +1 -1
- package/lib/build.js +2 -2
- package/lib/bundle/hermes.js +2 -1
- package/lib/bundle/metro.js +4 -4
- package/lib/copy-assets.js +4 -4
- package/lib/run/android.d.ts +1 -1
- package/lib/run/android.js +2 -2
- package/lib/run.d.ts +1 -1
- package/lib/run.js +2 -2
- package/lib/serve/keyboard.d.ts +4 -1
- package/lib/serve/keyboard.js +3 -2
- package/package.json +4 -4
- package/lib/helpers/filesystem.d.ts +0 -3
- package/lib/helpers/filesystem.js +0 -41
package/lib/build/android.d.ts
CHANGED
|
@@ -2,5 +2,5 @@ import type { Config } from "@react-native-community/cli-types";
|
|
|
2
2
|
import ora from "ora";
|
|
3
3
|
import type { AndroidBuildParams } from "./types";
|
|
4
4
|
export type BuildResult = string | number | null;
|
|
5
|
-
export declare function buildAndroid(config: Config, buildParams: AndroidBuildParams, logger?: ora.Ora): Promise<BuildResult>;
|
|
5
|
+
export declare function buildAndroid(config: Config, buildParams: AndroidBuildParams, additionalArgs: string[], logger?: ora.Ora): Promise<BuildResult>;
|
|
6
6
|
//# sourceMappingURL=android.d.ts.map
|
package/lib/build/android.js
CHANGED
|
@@ -7,7 +7,7 @@ exports.buildAndroid = buildAndroid;
|
|
|
7
7
|
const cache_1 = require("@rnx-kit/tools-react-native/cache");
|
|
8
8
|
const ora_1 = __importDefault(require("ora"));
|
|
9
9
|
const watcher_1 = require("./watcher");
|
|
10
|
-
function buildAndroid(config, buildParams, logger = (0, ora_1.default)()) {
|
|
10
|
+
function buildAndroid(config, buildParams, additionalArgs, logger = (0, ora_1.default)()) {
|
|
11
11
|
const { sourceDir } = config.project.android ?? {};
|
|
12
12
|
if (!sourceDir) {
|
|
13
13
|
(0, cache_1.invalidateState)();
|
|
@@ -16,7 +16,7 @@ function buildAndroid(config, buildParams, logger = (0, ora_1.default)()) {
|
|
|
16
16
|
return Promise.resolve(null);
|
|
17
17
|
}
|
|
18
18
|
return import("@rnx-kit/tools-android").then(({ assemble }) => {
|
|
19
|
-
const gradle = assemble(sourceDir, buildParams);
|
|
19
|
+
const gradle = assemble(sourceDir, buildParams, additionalArgs);
|
|
20
20
|
return (0, watcher_1.watch)(gradle, logger, () => sourceDir);
|
|
21
21
|
});
|
|
22
22
|
}
|
package/lib/build.d.ts
CHANGED
|
@@ -4,7 +4,7 @@ import { setCcacheDir } from "./build/ccache";
|
|
|
4
4
|
import type { BuildConfiguration, DeviceType, InputParams } from "./build/types";
|
|
5
5
|
declare function asConfiguration(configuration: string): BuildConfiguration;
|
|
6
6
|
declare function asDestination(destination: string): DeviceType;
|
|
7
|
-
export declare function rnxBuild(
|
|
7
|
+
export declare function rnxBuild(argv: string[], config: Config, buildParams: InputParams): Promise<import("./build/android").BuildResult> | Promise<import("./build/apple").BuildResult>;
|
|
8
8
|
export declare const rnxBuildCommand: {
|
|
9
9
|
[RNX_FAST_PATH]: boolean;
|
|
10
10
|
name: string;
|
package/lib/build.js
CHANGED
|
@@ -38,10 +38,10 @@ function asSupportedPlatform(platform) {
|
|
|
38
38
|
throw new commander_1.InvalidArgumentError("Supported platforms: 'android', 'ios', 'macos', 'visionos'.");
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
|
-
function rnxBuild(
|
|
41
|
+
function rnxBuild(argv, config, buildParams) {
|
|
42
42
|
switch (buildParams.platform) {
|
|
43
43
|
case "android":
|
|
44
|
-
return (0, android_1.buildAndroid)(config, buildParams);
|
|
44
|
+
return (0, android_1.buildAndroid)(config, buildParams, argv);
|
|
45
45
|
case "ios":
|
|
46
46
|
case "visionos":
|
|
47
47
|
return (0, ios_1.buildIOS)(config, buildParams);
|
package/lib/bundle/hermes.js
CHANGED
|
@@ -35,6 +35,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
36
|
exports.emitBytecode = emitBytecode;
|
|
37
37
|
const console_1 = require("@rnx-kit/console");
|
|
38
|
+
const tools_filesystem_1 = require("@rnx-kit/tools-filesystem");
|
|
38
39
|
const package_1 = require("@rnx-kit/tools-node/package");
|
|
39
40
|
const metro_1 = require("@rnx-kit/tools-react-native/metro");
|
|
40
41
|
const node_child_process_1 = require("node:child_process");
|
|
@@ -121,7 +122,7 @@ function emitBytecode(cliConfig, input, sourcemap, options) {
|
|
|
121
122
|
// @ts-expect-error Property 'composeSourceMaps' does not exist
|
|
122
123
|
const { composeSourceMaps } = (0, metro_1.requireModuleFromMetro)("metro-source-map");
|
|
123
124
|
const composed = composeSourceMaps([packagerSourcemap, compilerSourcemap]);
|
|
124
|
-
|
|
125
|
+
(0, tools_filesystem_1.writeJSONFile)(outputMap, composed, 0);
|
|
125
126
|
}
|
|
126
127
|
}
|
|
127
128
|
//# sourceMappingURL=hermes.js.map
|
package/lib/bundle/metro.js
CHANGED
|
@@ -36,9 +36,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
36
36
|
exports.metroBundle = metroBundle;
|
|
37
37
|
const console_1 = require("@rnx-kit/console");
|
|
38
38
|
const metro_service_1 = require("@rnx-kit/metro-service");
|
|
39
|
+
const tools_filesystem_1 = require("@rnx-kit/tools-filesystem");
|
|
39
40
|
const nodefs = __importStar(require("node:fs"));
|
|
40
41
|
const path = __importStar(require("node:path"));
|
|
41
|
-
const filesystem_1 = require("../helpers/filesystem");
|
|
42
42
|
const metro_config_1 = require("../helpers/metro-config");
|
|
43
43
|
/**
|
|
44
44
|
* Run the Metro bundler.
|
|
@@ -74,12 +74,12 @@ async function metroBundle(metroConfig, bundleConfig, dev, minify, output = metr
|
|
|
74
74
|
minify,
|
|
75
75
|
};
|
|
76
76
|
// ensure all output directories exist
|
|
77
|
-
(0,
|
|
77
|
+
(0, tools_filesystem_1.ensureDir)(path.dirname(metroBundleArgs.bundleOutput), fs);
|
|
78
78
|
if (metroBundleArgs.sourcemapOutput) {
|
|
79
|
-
(0,
|
|
79
|
+
(0, tools_filesystem_1.ensureDir)(path.dirname(metroBundleArgs.sourcemapOutput), fs);
|
|
80
80
|
}
|
|
81
81
|
if (metroBundleArgs.assetsDest) {
|
|
82
|
-
(0,
|
|
82
|
+
(0, tools_filesystem_1.ensureDir)(metroBundleArgs.assetsDest, fs);
|
|
83
83
|
}
|
|
84
84
|
// create the bundle
|
|
85
85
|
await output(metroBundleArgs, metroConfig);
|
package/lib/copy-assets.js
CHANGED
|
@@ -40,6 +40,7 @@ exports.copyAssets = copyAssets;
|
|
|
40
40
|
exports.gatherConfigs = gatherConfigs;
|
|
41
41
|
exports.copyProjectAssets = copyProjectAssets;
|
|
42
42
|
const console_1 = require("@rnx-kit/console");
|
|
43
|
+
const tools_filesystem_1 = require("@rnx-kit/tools-filesystem");
|
|
43
44
|
const properties_1 = require("@rnx-kit/tools-language/properties");
|
|
44
45
|
const package_1 = require("@rnx-kit/tools-node/package");
|
|
45
46
|
const path_1 = require("@rnx-kit/tools-node/path");
|
|
@@ -48,7 +49,6 @@ const node_child_process_1 = require("node:child_process");
|
|
|
48
49
|
const nodefs = __importStar(require("node:fs"));
|
|
49
50
|
const os = __importStar(require("node:os"));
|
|
50
51
|
const path = __importStar(require("node:path"));
|
|
51
|
-
const filesystem_1 = require("./helpers/filesystem");
|
|
52
52
|
const defaultAndroidConfig = {
|
|
53
53
|
androidPluginVersion: "7.2.2",
|
|
54
54
|
compileSdkVersion: 33,
|
|
@@ -161,7 +161,7 @@ async function assembleAarBundle(context, packageName, { aar }, fs = nodefs) {
|
|
|
161
161
|
...customEnv,
|
|
162
162
|
};
|
|
163
163
|
const outputDir = path.join(context.options.assetsDest, "aar");
|
|
164
|
-
(0,
|
|
164
|
+
(0, tools_filesystem_1.ensureDir)(outputDir);
|
|
165
165
|
const dest = path.join(outputDir, `${targetName}-${version}.aar`);
|
|
166
166
|
const targets = [`:${targetName}:assembleRelease`];
|
|
167
167
|
const targetsToCopy = [[output, dest]];
|
|
@@ -234,7 +234,7 @@ async function assembleAarBundle(context, packageName, { aar }, fs = nodefs) {
|
|
|
234
234
|
`project(":${targetName}").projectDir = file(${JSON.stringify(androidProject)})`,
|
|
235
235
|
"",
|
|
236
236
|
].join("\n");
|
|
237
|
-
(0,
|
|
237
|
+
(0, tools_filesystem_1.ensureDir)(buildDir);
|
|
238
238
|
fs.writeFileSync(path.join(buildDir, "build.gradle"), buildGradle);
|
|
239
239
|
fs.writeFileSync(path.join(buildDir, "gradle.properties"), gradleProperties);
|
|
240
240
|
fs.writeFileSync(path.join(buildDir, "settings.gradle"), settingsGradle);
|
|
@@ -247,7 +247,7 @@ function copyFiles(files, destination, fs = nodefs) {
|
|
|
247
247
|
if (!Array.isArray(files) || files.length === 0) {
|
|
248
248
|
return [];
|
|
249
249
|
}
|
|
250
|
-
(0,
|
|
250
|
+
(0, tools_filesystem_1.ensureDir)(destination, fs);
|
|
251
251
|
return files.map((file) => {
|
|
252
252
|
return cp_r(file, `${destination}/${path.basename(file)}`, fs);
|
|
253
253
|
});
|
package/lib/run/android.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import type { Config } from "@react-native-community/cli-types";
|
|
2
2
|
import type { AndroidInputParams } from "../build/types";
|
|
3
|
-
export declare function runAndroid(config: Config, buildParams: AndroidInputParams): Promise<void>;
|
|
3
|
+
export declare function runAndroid(config: Config, buildParams: AndroidInputParams, additionalArgs: string[]): Promise<void>;
|
|
4
4
|
//# sourceMappingURL=android.d.ts.map
|
package/lib/run/android.js
CHANGED
|
@@ -40,9 +40,9 @@ exports.runAndroid = runAndroid;
|
|
|
40
40
|
const path = __importStar(require("node:path"));
|
|
41
41
|
const ora_1 = __importDefault(require("ora"));
|
|
42
42
|
const android_1 = require("../build/android");
|
|
43
|
-
async function runAndroid(config, buildParams) {
|
|
43
|
+
async function runAndroid(config, buildParams, additionalArgs) {
|
|
44
44
|
const logger = (0, ora_1.default)();
|
|
45
|
-
const projectDir = await (0, android_1.buildAndroid)(config, buildParams, logger);
|
|
45
|
+
const projectDir = await (0, android_1.buildAndroid)(config, buildParams, additionalArgs, logger);
|
|
46
46
|
if (typeof projectDir !== "string") {
|
|
47
47
|
return;
|
|
48
48
|
}
|
package/lib/run.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Config } from "@react-native-community/cli-types";
|
|
2
2
|
import { RNX_FAST_PATH } from "./bin/constants";
|
|
3
3
|
import type { InputParams } from "./build/types";
|
|
4
|
-
export declare function rnxRun(
|
|
4
|
+
export declare function rnxRun(argv: string[], config: Config, buildParams: InputParams): Promise<void>;
|
|
5
5
|
export declare const rnxRunCommand: {
|
|
6
6
|
[RNX_FAST_PATH]: boolean;
|
|
7
7
|
name: string;
|
package/lib/run.js
CHANGED
|
@@ -7,10 +7,10 @@ const build_1 = require("./build");
|
|
|
7
7
|
const android_1 = require("./run/android");
|
|
8
8
|
const ios_1 = require("./run/ios");
|
|
9
9
|
const macos_1 = require("./run/macos");
|
|
10
|
-
function rnxRun(
|
|
10
|
+
function rnxRun(argv, config, buildParams) {
|
|
11
11
|
switch (buildParams.platform) {
|
|
12
12
|
case "android":
|
|
13
|
-
return (0, android_1.runAndroid)(config, buildParams);
|
|
13
|
+
return (0, android_1.runAndroid)(config, buildParams, argv);
|
|
14
14
|
case "ios":
|
|
15
15
|
case "visionos":
|
|
16
16
|
return (0, ios_1.runIOS)(config, buildParams);
|
package/lib/serve/keyboard.d.ts
CHANGED
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import type { MetroTerminal } from "@rnx-kit/metro-service";
|
|
2
2
|
import type { Server } from "node:http";
|
|
3
3
|
import type { DevServerMiddleware } from "./types";
|
|
4
|
+
type HttpServer = Server & {
|
|
5
|
+
httpServer?: Server;
|
|
6
|
+
};
|
|
4
7
|
type Params = {
|
|
5
8
|
devServerUrl: string;
|
|
6
9
|
help: () => void;
|
|
@@ -8,6 +11,6 @@ type Params = {
|
|
|
8
11
|
metroTerminal: MetroTerminal;
|
|
9
12
|
reactNativePath: string;
|
|
10
13
|
};
|
|
11
|
-
export declare function attachKeyHandlers(server:
|
|
14
|
+
export declare function attachKeyHandlers(server: HttpServer, params: Params): void;
|
|
12
15
|
export {};
|
|
13
16
|
//# sourceMappingURL=keyboard.d.ts.map
|
package/lib/serve/keyboard.js
CHANGED
|
@@ -72,8 +72,9 @@ function attachKeyHandlers(server, params) {
|
|
|
72
72
|
process.stdin.pause();
|
|
73
73
|
process.stdin.setRawMode(false);
|
|
74
74
|
(0, console_1.info)("Exiting...");
|
|
75
|
-
server.
|
|
76
|
-
|
|
75
|
+
const httpServer = server.httpServer ?? server;
|
|
76
|
+
httpServer.close();
|
|
77
|
+
httpServer.closeAllConnections?.(); // This method was added in Node v18.2.0
|
|
77
78
|
// Even when we close all connections, clients may keep the server alive.
|
|
78
79
|
process.exit();
|
|
79
80
|
});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rnx-kit/cli",
|
|
3
|
-
"version": "0.18.
|
|
3
|
+
"version": "0.18.11",
|
|
4
4
|
"description": "Command-line interface for working with kit packages in your repo",
|
|
5
5
|
"homepage": "https://github.com/microsoft/rnx-kit/tree/main/packages/cli#readme",
|
|
6
6
|
"license": "MIT",
|
|
@@ -39,7 +39,7 @@
|
|
|
39
39
|
"test": "rnx-kit-scripts test"
|
|
40
40
|
},
|
|
41
41
|
"dependencies": {
|
|
42
|
-
"@rnx-kit/align-deps": "^3.0
|
|
42
|
+
"@rnx-kit/align-deps": "^3.1.0",
|
|
43
43
|
"@rnx-kit/config": "^0.7.0",
|
|
44
44
|
"@rnx-kit/console": "^2.0.0",
|
|
45
45
|
"@rnx-kit/metro-plugin-cyclic-dependencies-detector": "^2.0.0",
|
|
@@ -49,8 +49,9 @@
|
|
|
49
49
|
"@rnx-kit/metro-serializer-esbuild": "^0.2.1",
|
|
50
50
|
"@rnx-kit/metro-service": "^4.0.2",
|
|
51
51
|
"@rnx-kit/third-party-notices": "^2.0.0",
|
|
52
|
-
"@rnx-kit/tools-android": "^0.2.
|
|
52
|
+
"@rnx-kit/tools-android": "^0.2.1",
|
|
53
53
|
"@rnx-kit/tools-apple": "^0.2.1",
|
|
54
|
+
"@rnx-kit/tools-filesystem": "^0.1.0",
|
|
54
55
|
"@rnx-kit/tools-language": "^3.0.0",
|
|
55
56
|
"@rnx-kit/tools-node": "^3.0.0",
|
|
56
57
|
"@rnx-kit/tools-react-native": "^2.0.3",
|
|
@@ -77,7 +78,6 @@
|
|
|
77
78
|
"@rnx-kit/eslint-config": "*",
|
|
78
79
|
"@rnx-kit/jest-preset": "*",
|
|
79
80
|
"@rnx-kit/scripts": "*",
|
|
80
|
-
"@rnx-kit/tools-filesystem": "*",
|
|
81
81
|
"@rnx-kit/tsconfig": "*",
|
|
82
82
|
"@types/connect": "^3.4.36",
|
|
83
83
|
"@types/node": "^22.0.0",
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.ensureDir = ensureDir;
|
|
37
|
-
const nodefs = __importStar(require("node:fs"));
|
|
38
|
-
function ensureDir(p, fs = nodefs) {
|
|
39
|
-
fs.mkdirSync(p, { recursive: true, mode: 0o755 });
|
|
40
|
-
}
|
|
41
|
-
//# sourceMappingURL=filesystem.js.map
|