@limrun/cli 0.3.1 → 0.4.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/README.md +37 -10
- package/dist/base-command.d.ts +6 -0
- package/dist/base-command.d.ts.map +1 -1
- package/dist/base-command.js +26 -5
- package/dist/base-command.js.map +1 -1
- package/dist/commands/android/connect.d.ts +1 -0
- package/dist/commands/android/connect.d.ts.map +1 -1
- package/dist/commands/android/create.d.ts +1 -0
- package/dist/commands/android/create.d.ts.map +1 -1
- package/dist/commands/android/create.js +12 -10
- package/dist/commands/android/create.js.map +1 -1
- package/dist/commands/android/delete.d.ts +1 -0
- package/dist/commands/android/delete.d.ts.map +1 -1
- package/dist/commands/android/element-tree.d.ts +14 -1
- package/dist/commands/android/element-tree.d.ts.map +1 -1
- package/dist/commands/android/element-tree.js +59 -6
- package/dist/commands/android/element-tree.js.map +1 -1
- package/dist/commands/android/find-element.d.ts +27 -0
- package/dist/commands/android/find-element.d.ts.map +1 -0
- package/dist/commands/android/find-element.js +72 -0
- package/dist/commands/android/find-element.js.map +1 -0
- package/dist/commands/android/get.d.ts +1 -0
- package/dist/commands/android/get.d.ts.map +1 -1
- package/dist/commands/android/install-app.d.ts +16 -1
- package/dist/commands/android/install-app.d.ts.map +1 -1
- package/dist/commands/android/install-app.js +66 -3
- package/dist/commands/android/install-app.js.map +1 -1
- package/dist/commands/android/list.d.ts +1 -0
- package/dist/commands/android/list.d.ts.map +1 -1
- package/dist/commands/android/open-url.d.ts +16 -1
- package/dist/commands/android/open-url.d.ts.map +1 -1
- package/dist/commands/android/open-url.js +50 -6
- package/dist/commands/android/open-url.js.map +1 -1
- package/dist/commands/android/press-key.d.ts +17 -1
- package/dist/commands/android/press-key.d.ts.map +1 -1
- package/dist/commands/android/press-key.js +51 -6
- package/dist/commands/android/press-key.js.map +1 -1
- package/dist/commands/android/record.d.ts +20 -1
- package/dist/commands/android/record.d.ts.map +1 -1
- package/dist/commands/android/record.js +99 -3
- package/dist/commands/android/record.js.map +1 -1
- package/dist/commands/android/screenshot.d.ts +15 -1
- package/dist/commands/android/screenshot.d.ts.map +1 -1
- package/dist/commands/android/screenshot.js +64 -3
- package/dist/commands/android/screenshot.js.map +1 -1
- package/dist/commands/android/scroll.d.ts +30 -1
- package/dist/commands/android/scroll.d.ts.map +1 -1
- package/dist/commands/android/scroll.js +70 -6
- package/dist/commands/android/scroll.js.map +1 -1
- package/dist/commands/android/tap-element.d.ts +25 -1
- package/dist/commands/android/tap-element.d.ts.map +1 -1
- package/dist/commands/android/tap-element.js +59 -6
- package/dist/commands/android/tap-element.js.map +1 -1
- package/dist/commands/android/tap.d.ts +23 -1
- package/dist/commands/android/tap.d.ts.map +1 -1
- package/dist/commands/android/tap.js +54 -6
- package/dist/commands/android/tap.js.map +1 -1
- package/dist/commands/android/type.d.ts +29 -1
- package/dist/commands/android/type.d.ts.map +1 -1
- package/dist/commands/android/type.js +52 -6
- package/dist/commands/android/type.js.map +1 -1
- package/dist/commands/asset/delete.d.ts +1 -0
- package/dist/commands/asset/delete.d.ts.map +1 -1
- package/dist/commands/asset/list.d.ts +2 -0
- package/dist/commands/asset/list.d.ts.map +1 -1
- package/dist/commands/asset/list.js +6 -0
- package/dist/commands/asset/list.js.map +1 -1
- package/dist/commands/asset/pull.d.ts +1 -0
- package/dist/commands/asset/pull.d.ts.map +1 -1
- package/dist/commands/asset/pull.js +2 -2
- package/dist/commands/asset/pull.js.map +1 -1
- package/dist/commands/asset/push.d.ts +1 -0
- package/dist/commands/asset/push.d.ts.map +1 -1
- package/dist/commands/asset/push.js +2 -3
- package/dist/commands/asset/push.js.map +1 -1
- package/dist/commands/ios/{log.d.ts → app-log.d.ts} +4 -3
- package/dist/commands/ios/app-log.d.ts.map +1 -0
- package/dist/commands/ios/{log.js → app-log.js} +20 -21
- package/dist/commands/ios/app-log.js.map +1 -0
- package/dist/commands/{exec/type.d.ts → ios/cp.d.ts} +5 -4
- package/dist/commands/ios/cp.d.ts.map +1 -0
- package/dist/commands/ios/cp.js +66 -0
- package/dist/commands/ios/cp.js.map +1 -0
- package/dist/commands/ios/create.d.ts +1 -0
- package/dist/commands/ios/create.d.ts.map +1 -1
- package/dist/commands/ios/create.js +27 -13
- package/dist/commands/ios/create.js.map +1 -1
- package/dist/commands/ios/delete.d.ts +1 -0
- package/dist/commands/ios/delete.d.ts.map +1 -1
- package/dist/commands/ios/element-tree.d.ts +14 -1
- package/dist/commands/ios/element-tree.d.ts.map +1 -1
- package/dist/commands/ios/element-tree.js +56 -6
- package/dist/commands/ios/element-tree.js.map +1 -1
- package/dist/commands/ios/get.d.ts +1 -0
- package/dist/commands/ios/get.d.ts.map +1 -1
- package/dist/commands/ios/info.d.ts +1 -0
- package/dist/commands/ios/info.d.ts.map +1 -1
- package/dist/commands/ios/install-app.d.ts +18 -1
- package/dist/commands/ios/install-app.d.ts.map +1 -1
- package/dist/commands/ios/install-app.js +93 -3
- package/dist/commands/ios/install-app.js.map +1 -1
- package/dist/commands/ios/launch-app.d.ts +1 -0
- package/dist/commands/ios/launch-app.d.ts.map +1 -1
- package/dist/commands/ios/list-apps.d.ts +1 -0
- package/dist/commands/ios/list-apps.d.ts.map +1 -1
- package/dist/commands/ios/list.d.ts +1 -0
- package/dist/commands/ios/list.d.ts.map +1 -1
- package/dist/commands/{exec/element-tree.d.ts → ios/lsof.d.ts} +3 -2
- package/dist/commands/ios/lsof.d.ts.map +1 -0
- package/dist/commands/ios/lsof.js +49 -0
- package/dist/commands/ios/lsof.js.map +1 -0
- package/dist/commands/ios/open-url.d.ts +16 -1
- package/dist/commands/ios/open-url.d.ts.map +1 -1
- package/dist/commands/ios/open-url.js +50 -6
- package/dist/commands/ios/open-url.js.map +1 -1
- package/dist/commands/ios/perform.d.ts +16 -1
- package/dist/commands/ios/perform.d.ts.map +1 -1
- package/dist/commands/ios/perform.js +224 -3
- package/dist/commands/ios/perform.js.map +1 -1
- package/dist/commands/ios/press-key.d.ts +17 -1
- package/dist/commands/ios/press-key.d.ts.map +1 -1
- package/dist/commands/ios/press-key.js +51 -6
- package/dist/commands/ios/press-key.js.map +1 -1
- package/dist/commands/ios/record.d.ts +20 -1
- package/dist/commands/ios/record.d.ts.map +1 -1
- package/dist/commands/ios/record.js +100 -3
- package/dist/commands/ios/record.js.map +1 -1
- package/dist/commands/ios/screenshot.d.ts +15 -1
- package/dist/commands/ios/screenshot.d.ts.map +1 -1
- package/dist/commands/ios/screenshot.js +63 -3
- package/dist/commands/ios/screenshot.js.map +1 -1
- package/dist/commands/ios/scroll.d.ts +17 -1
- package/dist/commands/ios/scroll.d.ts.map +1 -1
- package/dist/commands/ios/scroll.js +55 -6
- package/dist/commands/ios/scroll.js.map +1 -1
- package/dist/commands/{exec/install-app.d.ts → ios/simctl.d.ts} +5 -5
- package/dist/commands/ios/simctl.d.ts.map +1 -0
- package/dist/commands/ios/simctl.js +75 -0
- package/dist/commands/ios/simctl.js.map +1 -0
- package/dist/commands/ios/sync.d.ts +3 -0
- package/dist/commands/ios/sync.d.ts.map +1 -1
- package/dist/commands/ios/sync.js +13 -4
- package/dist/commands/ios/sync.js.map +1 -1
- package/dist/commands/{exec/open-url.d.ts → ios/syslog.d.ts} +4 -5
- package/dist/commands/ios/syslog.d.ts.map +1 -0
- package/dist/commands/ios/syslog.js +65 -0
- package/dist/commands/ios/syslog.js.map +1 -0
- package/dist/commands/ios/tap-element.d.ts +21 -1
- package/dist/commands/ios/tap-element.d.ts.map +1 -1
- package/dist/commands/ios/tap-element.js +91 -6
- package/dist/commands/ios/tap-element.js.map +1 -1
- package/dist/commands/ios/tap.d.ts +23 -1
- package/dist/commands/ios/tap.d.ts.map +1 -1
- package/dist/commands/ios/tap.js +54 -6
- package/dist/commands/ios/tap.js.map +1 -1
- package/dist/commands/ios/terminate-app.d.ts +1 -0
- package/dist/commands/ios/terminate-app.d.ts.map +1 -1
- package/dist/commands/ios/type.d.ts +17 -1
- package/dist/commands/ios/type.d.ts.map +1 -1
- package/dist/commands/ios/type.js +52 -6
- package/dist/commands/ios/type.js.map +1 -1
- package/dist/commands/{exec/screenshot.d.ts → ios/xcodebuild.d.ts} +4 -3
- package/dist/commands/ios/xcodebuild.d.ts.map +1 -0
- package/dist/commands/ios/xcodebuild.js +61 -0
- package/dist/commands/ios/xcodebuild.js.map +1 -0
- package/dist/commands/ios/xcrun.d.ts +16 -0
- package/dist/commands/ios/xcrun.d.ts.map +1 -0
- package/dist/commands/ios/xcrun.js +62 -0
- package/dist/commands/ios/xcrun.js.map +1 -0
- package/dist/commands/login.d.ts +7 -2
- package/dist/commands/login.d.ts.map +1 -1
- package/dist/commands/login.js +5 -2
- package/dist/commands/login.js.map +1 -1
- package/dist/commands/logout.d.ts +7 -2
- package/dist/commands/logout.d.ts.map +1 -1
- package/dist/commands/logout.js +5 -2
- package/dist/commands/logout.js.map +1 -1
- package/dist/commands/session/start.d.ts +1 -0
- package/dist/commands/session/start.d.ts.map +1 -1
- package/dist/commands/session/status.d.ts +1 -0
- package/dist/commands/session/status.d.ts.map +1 -1
- package/dist/commands/session/stop.d.ts +5 -2
- package/dist/commands/session/stop.d.ts.map +1 -1
- package/dist/commands/session/stop.js +4 -2
- package/dist/commands/session/stop.js.map +1 -1
- package/dist/commands/xcode/build.d.ts +4 -0
- package/dist/commands/xcode/build.d.ts.map +1 -1
- package/dist/commands/xcode/build.js +28 -9
- package/dist/commands/xcode/build.js.map +1 -1
- package/dist/commands/xcode/create.d.ts +1 -0
- package/dist/commands/xcode/create.d.ts.map +1 -1
- package/dist/commands/xcode/create.js +13 -7
- package/dist/commands/xcode/create.js.map +1 -1
- package/dist/commands/xcode/delete.d.ts +1 -0
- package/dist/commands/xcode/delete.d.ts.map +1 -1
- package/dist/commands/xcode/get.d.ts +1 -0
- package/dist/commands/xcode/get.d.ts.map +1 -1
- package/dist/commands/xcode/list.d.ts +1 -0
- package/dist/commands/xcode/list.d.ts.map +1 -1
- package/dist/commands/xcode/sync.d.ts +4 -0
- package/dist/commands/xcode/sync.d.ts.map +1 -1
- package/dist/commands/xcode/sync.js +19 -3
- package/dist/commands/xcode/sync.js.map +1 -1
- package/dist/lib/android-selector.d.ts +50 -0
- package/dist/lib/android-selector.d.ts.map +1 -0
- package/dist/lib/android-selector.js +103 -0
- package/dist/lib/android-selector.js.map +1 -0
- package/dist/lib/config.js +1 -1
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/daemon.d.ts.map +1 -1
- package/dist/lib/daemon.js +25 -3
- package/dist/lib/daemon.js.map +1 -1
- package/dist/lib/ignore-patterns.d.ts +2 -0
- package/dist/lib/ignore-patterns.d.ts.map +1 -0
- package/dist/lib/ignore-patterns.js +18 -0
- package/dist/lib/ignore-patterns.js.map +1 -0
- package/package.json +3 -6
- package/dist/commands/exec/element-tree.d.ts.map +0 -1
- package/dist/commands/exec/element-tree.js +0 -61
- package/dist/commands/exec/element-tree.js.map +0 -1
- package/dist/commands/exec/install-app.d.ts.map +0 -1
- package/dist/commands/exec/install-app.js +0 -84
- package/dist/commands/exec/install-app.js.map +0 -1
- package/dist/commands/exec/open-url.d.ts.map +0 -1
- package/dist/commands/exec/open-url.js +0 -48
- package/dist/commands/exec/open-url.js.map +0 -1
- package/dist/commands/exec/perform.d.ts +0 -16
- package/dist/commands/exec/perform.d.ts.map +0 -1
- package/dist/commands/exec/perform.js +0 -232
- package/dist/commands/exec/perform.js.map +0 -1
- package/dist/commands/exec/press-key.d.ts +0 -17
- package/dist/commands/exec/press-key.d.ts.map +0 -1
- package/dist/commands/exec/press-key.js +0 -49
- package/dist/commands/exec/press-key.js.map +0 -1
- package/dist/commands/exec/record.d.ts +0 -20
- package/dist/commands/exec/record.d.ts.map +0 -1
- package/dist/commands/exec/record.js +0 -101
- package/dist/commands/exec/record.js.map +0 -1
- package/dist/commands/exec/screenshot.d.ts.map +0 -1
- package/dist/commands/exec/screenshot.js +0 -72
- package/dist/commands/exec/screenshot.js.map +0 -1
- package/dist/commands/exec/scroll.d.ts +0 -17
- package/dist/commands/exec/scroll.d.ts.map +0 -1
- package/dist/commands/exec/scroll.js +0 -58
- package/dist/commands/exec/scroll.js.map +0 -1
- package/dist/commands/exec/tap-element.d.ts +0 -18
- package/dist/commands/exec/tap-element.d.ts.map +0 -1
- package/dist/commands/exec/tap-element.js +0 -102
- package/dist/commands/exec/tap-element.js.map +0 -1
- package/dist/commands/exec/tap.d.ts +0 -23
- package/dist/commands/exec/tap.d.ts.map +0 -1
- package/dist/commands/exec/tap.js +0 -57
- package/dist/commands/exec/tap.js.map +0 -1
- package/dist/commands/exec/type.d.ts.map +0 -1
- package/dist/commands/exec/type.js +0 -54
- package/dist/commands/exec/type.js.map +0 -1
- package/dist/commands/ios/log.d.ts.map +0 -1
- package/dist/commands/ios/log.js.map +0 -1
|
@@ -3,7 +3,104 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
const path_1 = __importDefault(require("path"));
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
const base_command_1 = require("../../base-command");
|
|
9
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
10
|
+
class IosRecord extends base_command_1.BaseCommand {
|
|
11
|
+
async run() {
|
|
12
|
+
const { args, flags } = await this.parse(IosRecord);
|
|
13
|
+
this.setParsedFlags(flags);
|
|
14
|
+
await this.withAuth(async () => {
|
|
15
|
+
const id = this.resolveId(flags.id);
|
|
16
|
+
if ((0, instance_client_factory_1.detectInstanceType)(id) !== 'ios') {
|
|
17
|
+
this.error('ios record only supports iOS instances');
|
|
18
|
+
}
|
|
19
|
+
if (args.action === 'start') {
|
|
20
|
+
if ((0, instance_client_factory_1.hasActiveSession)(id)) {
|
|
21
|
+
await (0, instance_client_factory_1.sendSessionCommand)(id, 'start-recording', [flags.quality]);
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, id);
|
|
25
|
+
try {
|
|
26
|
+
if (type !== 'ios') {
|
|
27
|
+
this.error('ios record only supports iOS instances');
|
|
28
|
+
}
|
|
29
|
+
await client.startRecording({ quality: flags.quality });
|
|
30
|
+
}
|
|
31
|
+
finally {
|
|
32
|
+
disconnect();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
this.log('Recording started');
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const outputPath = flags.output ? path_1.default.resolve(flags.output) : this.defaultRecordingPath();
|
|
39
|
+
const saveTo = {
|
|
40
|
+
localPath: outputPath,
|
|
41
|
+
presignedUrl: flags['presigned-url'],
|
|
42
|
+
};
|
|
43
|
+
if ((0, instance_client_factory_1.hasActiveSession)(id)) {
|
|
44
|
+
await (0, instance_client_factory_1.sendSessionCommand)(id, 'stop-recording', [saveTo]);
|
|
45
|
+
this.log(`Recording saved to ${outputPath}`);
|
|
46
|
+
if (flags['presigned-url']) {
|
|
47
|
+
this.log('Recording uploaded using the provided presigned URL');
|
|
48
|
+
}
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, id);
|
|
52
|
+
try {
|
|
53
|
+
if (type !== 'ios') {
|
|
54
|
+
this.error('ios record only supports iOS instances');
|
|
55
|
+
}
|
|
56
|
+
await client.stopRecording(saveTo);
|
|
57
|
+
this.log(`Recording saved to ${outputPath}`);
|
|
58
|
+
if (flags['presigned-url']) {
|
|
59
|
+
this.log('Recording uploaded using the provided presigned URL');
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
finally {
|
|
63
|
+
disconnect();
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
defaultRecordingPath() {
|
|
68
|
+
const timestamp = new Date().toISOString().replace(/[:.]/g, '-');
|
|
69
|
+
return path_1.default.join(process.cwd(), `video_${timestamp}.mp4`);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
IosRecord.summary = 'Start or stop video recording on a running iOS instance';
|
|
73
|
+
IosRecord.description = 'Control screen recording on a running iOS instance. Start recording first, then stop recording to download the file locally or upload it directly with `--presigned-url`.';
|
|
74
|
+
IosRecord.examples = [
|
|
75
|
+
'<%= config.bin %> ios record start',
|
|
76
|
+
'<%= config.bin %> ios record stop',
|
|
77
|
+
'<%= config.bin %> ios record stop -o recording.mp4 --id <instance-ID>',
|
|
78
|
+
'<%= config.bin %> ios record stop --presigned-url https://example.com/upload --id <instance-ID>',
|
|
79
|
+
'<%= config.bin %> ios record start --quality 8',
|
|
80
|
+
];
|
|
81
|
+
IosRecord.args = {
|
|
82
|
+
action: core_1.Args.string({
|
|
83
|
+
description: 'Recording action to perform: `start` begins capturing and `stop` finalizes the video file',
|
|
84
|
+
required: true,
|
|
85
|
+
options: ['start', 'stop'],
|
|
86
|
+
}),
|
|
87
|
+
};
|
|
88
|
+
IosRecord.flags = {
|
|
89
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
90
|
+
id: core_1.Flags.string({
|
|
91
|
+
description: 'iOS instance ID to record. Defaults to the last created iOS instance.',
|
|
92
|
+
}),
|
|
93
|
+
quality: core_1.Flags.integer({
|
|
94
|
+
description: 'Recording quality from 5 to 10. Higher values increase quality and file size when starting a recording.',
|
|
95
|
+
default: 5,
|
|
96
|
+
}),
|
|
97
|
+
output: core_1.Flags.string({
|
|
98
|
+
char: 'o',
|
|
99
|
+
description: 'Local file path for the finished recording when using the `stop` action. Defaults to a timestamped mp4 in the current directory.',
|
|
100
|
+
}),
|
|
101
|
+
'presigned-url': core_1.Flags.string({
|
|
102
|
+
description: 'Presigned upload URL to receive the recording when using the `stop` action. Use this if you will upload the recording to a bucket.',
|
|
103
|
+
}),
|
|
104
|
+
};
|
|
105
|
+
exports.default = IosRecord;
|
|
9
106
|
//# sourceMappingURL=record.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"record.js","sourceRoot":"","sources":["../../../src/commands/ios/record.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"record.js","sourceRoot":"","sources":["../../../src/commands/ios/record.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,16 @@
|
|
|
1
|
-
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class IosScreenshot extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static examples: string[];
|
|
6
|
+
static args: {};
|
|
7
|
+
static flags: {
|
|
8
|
+
id: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
9
|
+
output: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
|
+
quiet: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
2
16
|
//# sourceMappingURL=screenshot.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"screenshot.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/screenshot.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"screenshot.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/screenshot.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAQjD,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,WAAW;IACpD,MAAM,CAAC,OAAO,SAAsD;IACpE,MAAM,CAAC,WAAW,SACmI;IACrJ,MAAM,CAAC,QAAQ,WAIb;IAEF,MAAM,CAAC,IAAI,KAAM;IAEjB,MAAM,CAAC,KAAK;;;;;;MASV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAoC3B"}
|
|
@@ -3,7 +3,67 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
const fs_1 = __importDefault(require("fs"));
|
|
7
|
+
const path_1 = __importDefault(require("path"));
|
|
8
|
+
const core_1 = require("@oclif/core");
|
|
9
|
+
const base_command_1 = require("../../base-command");
|
|
10
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
11
|
+
class IosScreenshot extends base_command_1.BaseCommand {
|
|
12
|
+
async run() {
|
|
13
|
+
const { flags } = await this.parse(IosScreenshot);
|
|
14
|
+
this.setParsedFlags(flags);
|
|
15
|
+
await this.withAuth(async () => {
|
|
16
|
+
const id = this.resolveId(flags.id);
|
|
17
|
+
if ((0, instance_client_factory_1.detectInstanceType)(id) !== 'ios') {
|
|
18
|
+
this.error('ios screenshot only supports iOS instances');
|
|
19
|
+
}
|
|
20
|
+
let screenshot;
|
|
21
|
+
if ((0, instance_client_factory_1.hasActiveSession)(id)) {
|
|
22
|
+
screenshot = await (0, instance_client_factory_1.sendSessionCommand)(id, 'screenshot');
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, id);
|
|
26
|
+
try {
|
|
27
|
+
if (type !== 'ios') {
|
|
28
|
+
this.error('ios screenshot only supports iOS instances');
|
|
29
|
+
}
|
|
30
|
+
screenshot = await client.screenshot();
|
|
31
|
+
}
|
|
32
|
+
finally {
|
|
33
|
+
disconnect();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
if (flags.output) {
|
|
37
|
+
const outPath = path_1.default.resolve(flags.output);
|
|
38
|
+
fs_1.default.writeFileSync(outPath, Buffer.from(screenshot.base64, 'base64'));
|
|
39
|
+
this.log(`Screenshot saved to ${outPath}`);
|
|
40
|
+
}
|
|
41
|
+
else if (flags.json) {
|
|
42
|
+
this.outputJson(screenshot);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.log(screenshot.base64);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
IosScreenshot.summary = 'Capture a screenshot from a running iOS instance';
|
|
51
|
+
IosScreenshot.description = 'Capture the current screen from a running iOS instance. Save the image to a file with `-o`, or use `--json` to inspect the raw response payload.';
|
|
52
|
+
IosScreenshot.examples = [
|
|
53
|
+
'<%= config.bin %> ios screenshot -o screenshot.png',
|
|
54
|
+
'<%= config.bin %> ios screenshot --id <instance-ID>',
|
|
55
|
+
'<%= config.bin %> ios screenshot --json',
|
|
56
|
+
];
|
|
57
|
+
IosScreenshot.args = {};
|
|
58
|
+
IosScreenshot.flags = {
|
|
59
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
60
|
+
id: core_1.Flags.string({
|
|
61
|
+
description: 'iOS instance ID to capture. Defaults to the last created iOS instance.',
|
|
62
|
+
}),
|
|
63
|
+
output: core_1.Flags.string({
|
|
64
|
+
char: 'o',
|
|
65
|
+
description: 'File path where the screenshot should be written instead of printing the raw image data',
|
|
66
|
+
}),
|
|
67
|
+
};
|
|
68
|
+
exports.default = IosScreenshot;
|
|
9
69
|
//# sourceMappingURL=screenshot.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"screenshot.js","sourceRoot":"","sources":["../../../src/commands/ios/screenshot.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"screenshot.js","sourceRoot":"","sources":["../../../src/commands/ios/screenshot.ts"],"names":[],"mappings":";;;;;AAAA,4CAAoB;AACpB,gDAAwB;AACxB,sCAAoC;AACpC,qDAAiD;AACjD,+EAK2C;AAE3C,MAAqB,aAAc,SAAQ,0BAAW;IAuBpD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAClD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,IAAA,4CAAkB,EAAC,EAAE,CAAC,KAAK,KAAK,EAAE,CAAC;gBACrC,IAAI,CAAC,KAAK,CAAC,4CAA4C,CAAC,CAAC;YAC3D,CAAC;YAED,IAAI,UAAe,CAAC;YACpB,IAAI,IAAA,0CAAgB,EAAC,EAAE,CAAC,EAAE,CAAC;gBACzB,UAAU,GAAG,MAAM,IAAA,4CAAkB,EAAC,EAAE,EAAE,YAAY,CAAC,CAAC;YAC1D,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAC9E,IAAI,CAAC;oBACH,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;wBACnB,IAAI,CAAC,KAAK,CAAC,4CAA4C,CAAC,CAAC;oBAC3D,CAAC;oBACD,UAAU,GAAG,MAAM,MAAM,CAAC,UAAU,EAAE,CAAC;gBACzC,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YAED,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjB,MAAM,OAAO,GAAG,cAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC3C,YAAE,CAAC,aAAa,CAAC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;gBACpE,IAAI,CAAC,GAAG,CAAC,uBAAuB,OAAO,EAAE,CAAC,CAAC;YAC7C,CAAC;iBAAM,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACtB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;YAC9B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YAC9B,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;;AAzDM,qBAAO,GAAG,kDAAkD,CAAC;AAC7D,yBAAW,GAChB,kJAAkJ,CAAC;AAC9I,sBAAQ,GAAG;IAChB,oDAAoD;IACpD,qDAAqD;IACrD,yCAAyC;CAC1C,CAAC;AAEK,kBAAI,GAAG,EAAE,CAAC;AAEV,mBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,EAAE,EAAE,YAAK,CAAC,MAAM,CAAC;QACf,WAAW,EAAE,wEAAwE;KACtF,CAAC;IACF,MAAM,EAAE,YAAK,CAAC,MAAM,CAAC;QACnB,IAAI,EAAE,GAAG;QACT,WAAW,EAAE,yFAAyF;KACvG,CAAC;CACH,CAAC;kBArBiB,aAAa"}
|
|
@@ -1,2 +1,18 @@
|
|
|
1
|
-
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class IosScroll extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static description: string;
|
|
5
|
+
static examples: string[];
|
|
6
|
+
static args: {
|
|
7
|
+
direction: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
id: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
amount: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
quiet: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
15
|
+
};
|
|
16
|
+
run(): Promise<void>;
|
|
17
|
+
}
|
|
2
18
|
//# sourceMappingURL=scroll.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scroll.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/scroll.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"scroll.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/scroll.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAQjD,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,WAAW;IAChD,MAAM,CAAC,OAAO,SAAsC;IACpD,MAAM,CAAC,WAAW,SAC4E;IAC9F,MAAM,CAAC,QAAQ,WAGb;IAEF,MAAM,CAAC,IAAI;;MAMT;IAEF,MAAM,CAAC,KAAK;;;;;;MASV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA0B3B"}
|
|
@@ -1,9 +1,58 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class IosScroll extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(IosScroll);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
const id = this.resolveId(flags.id);
|
|
12
|
+
if ((0, instance_client_factory_1.detectInstanceType)(id) !== 'ios') {
|
|
13
|
+
this.error('ios scroll only supports iOS instances');
|
|
14
|
+
}
|
|
15
|
+
if ((0, instance_client_factory_1.hasActiveSession)(id)) {
|
|
16
|
+
await (0, instance_client_factory_1.sendSessionCommand)(id, 'scroll', [args.direction, flags.amount]);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, id);
|
|
20
|
+
try {
|
|
21
|
+
if (type !== 'ios') {
|
|
22
|
+
this.error('ios scroll only supports iOS instances');
|
|
23
|
+
}
|
|
24
|
+
await client.scroll(args.direction, flags.amount);
|
|
25
|
+
}
|
|
26
|
+
finally {
|
|
27
|
+
disconnect();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
this.log(`Scrolled ${args.direction}`);
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
IosScroll.summary = 'Scroll on a running iOS instance';
|
|
35
|
+
IosScroll.description = 'Scroll the current screen on a running iOS instance. The amount is interpreted as pixels.';
|
|
36
|
+
IosScroll.examples = [
|
|
37
|
+
'<%= config.bin %> ios scroll down --amount 500',
|
|
38
|
+
'<%= config.bin %> ios scroll down --amount 500 --id <instance-ID>',
|
|
39
|
+
];
|
|
40
|
+
IosScroll.args = {
|
|
41
|
+
direction: core_1.Args.string({
|
|
42
|
+
description: 'Scroll direction to apply',
|
|
43
|
+
required: true,
|
|
44
|
+
options: ['up', 'down', 'left', 'right'],
|
|
45
|
+
}),
|
|
46
|
+
};
|
|
47
|
+
IosScroll.flags = {
|
|
48
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
49
|
+
id: core_1.Flags.string({
|
|
50
|
+
description: 'iOS instance ID to target. Defaults to the last created iOS instance.',
|
|
51
|
+
}),
|
|
52
|
+
amount: core_1.Flags.integer({
|
|
53
|
+
description: 'Scroll amount in pixels.',
|
|
54
|
+
default: 300,
|
|
55
|
+
}),
|
|
56
|
+
};
|
|
57
|
+
exports.default = IosScroll;
|
|
9
58
|
//# sourceMappingURL=scroll.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scroll.js","sourceRoot":"","sources":["../../../src/commands/ios/scroll.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"scroll.js","sourceRoot":"","sources":["../../../src/commands/ios/scroll.ts"],"names":[],"mappings":";;AAAA,sCAA0C;AAC1C,qDAAiD;AACjD,+EAK2C;AAE3C,MAAqB,SAAU,SAAQ,0BAAW;IA4BhD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QACpD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,IAAA,4CAAkB,EAAC,EAAE,CAAC,KAAK,KAAK,EAAE,CAAC;gBACrC,IAAI,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;YACvD,CAAC;YAED,IAAI,IAAA,0CAAgB,EAAC,EAAE,CAAC,EAAE,CAAC;gBACzB,MAAM,IAAA,4CAAkB,EAAC,EAAE,EAAE,QAAQ,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;YACzE,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAC9E,IAAI,CAAC;oBACH,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;wBACnB,IAAI,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;oBACvD,CAAC;oBACD,MAAO,MAAc,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC7D,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;;AApDM,iBAAO,GAAG,kCAAkC,CAAC;AAC7C,qBAAW,GAChB,2FAA2F,CAAC;AACvF,kBAAQ,GAAG;IAChB,gDAAgD;IAChD,mEAAmE;CACpE,CAAC;AAEK,cAAI,GAAG;IACZ,SAAS,EAAE,WAAI,CAAC,MAAM,CAAC;QACrB,WAAW,EAAE,2BAA2B;QACxC,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC;KACzC,CAAC;CACH,CAAC;AAEK,eAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,EAAE,EAAE,YAAK,CAAC,MAAM,CAAC;QACf,WAAW,EAAE,uEAAuE;KACrF,CAAC;IACF,MAAM,EAAE,YAAK,CAAC,OAAO,CAAC;QACpB,WAAW,EAAE,0BAA0B;QACvC,OAAO,EAAE,GAAG;KACb,CAAC;CACH,CAAC;kBA1BiB,SAAS"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { BaseCommand } from '../../base-command';
|
|
2
|
-
export default class
|
|
2
|
+
export default class IosSimctl extends BaseCommand {
|
|
3
3
|
static summary: string;
|
|
4
4
|
static description: string;
|
|
5
5
|
static examples: string[];
|
|
6
|
-
static
|
|
7
|
-
|
|
8
|
-
};
|
|
6
|
+
static strict: boolean;
|
|
7
|
+
static args: {};
|
|
9
8
|
static flags: {
|
|
10
9
|
id: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
10
|
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
11
|
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
|
+
quiet: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
13
|
};
|
|
14
14
|
run(): Promise<void>;
|
|
15
15
|
}
|
|
16
|
-
//# sourceMappingURL=
|
|
16
|
+
//# sourceMappingURL=simctl.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"simctl.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/simctl.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AASjD,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,WAAW;IAChD,MAAM,CAAC,OAAO,SAA0C;IACxD,MAAM,CAAC,WAAW,SAC+J;IACjL,MAAM,CAAC,QAAQ,WAIb;IAEF,MAAM,CAAC,MAAM,UAAS;IAEtB,MAAM,CAAC,IAAI,KAAM;IAEjB,MAAM,CAAC,KAAK;;;;;MAKV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAyD3B"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class IosSimctl extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const parsed = await this.parse(IosSimctl);
|
|
9
|
+
const flags = parsed.flags;
|
|
10
|
+
const rawArgs = parsed.argv ?? [];
|
|
11
|
+
this.setParsedFlags(flags);
|
|
12
|
+
await this.withAuth(async () => {
|
|
13
|
+
if (rawArgs.length === 0) {
|
|
14
|
+
this.error('Provide at least one simctl argument after `lim ios simctl --`.');
|
|
15
|
+
}
|
|
16
|
+
const id = this.resolveId(flags.id);
|
|
17
|
+
if ((0, instance_client_factory_1.detectInstanceType)(id) !== 'ios') {
|
|
18
|
+
this.error('ios simctl only supports iOS instances');
|
|
19
|
+
}
|
|
20
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, id);
|
|
21
|
+
if (type !== 'ios') {
|
|
22
|
+
disconnect();
|
|
23
|
+
this.error('ios simctl only supports iOS instances');
|
|
24
|
+
}
|
|
25
|
+
try {
|
|
26
|
+
const execution = client.simctl(rawArgs);
|
|
27
|
+
if (flags.json) {
|
|
28
|
+
const result = (await execution.wait());
|
|
29
|
+
this.outputJson(result);
|
|
30
|
+
if (result.code !== 0)
|
|
31
|
+
this.exit(result.code);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
execution.on('stdout', (chunk) => {
|
|
35
|
+
process.stdout.write(chunk);
|
|
36
|
+
});
|
|
37
|
+
execution.on('stderr', (chunk) => {
|
|
38
|
+
process.stderr.write(chunk);
|
|
39
|
+
});
|
|
40
|
+
const result = (await new Promise((resolve, reject) => {
|
|
41
|
+
execution.once('exit', (code) => {
|
|
42
|
+
execution
|
|
43
|
+
.wait()
|
|
44
|
+
.then((waitResult) => resolve({ ...waitResult, code }))
|
|
45
|
+
.catch(reject);
|
|
46
|
+
});
|
|
47
|
+
execution.once('error', reject);
|
|
48
|
+
}));
|
|
49
|
+
if (result.code !== 0) {
|
|
50
|
+
this.error(`simctl failed with exit code ${result.code}`, { exit: result.code });
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
finally {
|
|
54
|
+
disconnect();
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
IosSimctl.summary = 'Run simctl on a running iOS instance';
|
|
60
|
+
IosSimctl.description = 'Run `simctl` against the target iOS instance with streaming stdout/stderr. Pass the command arguments after the subcommand, for example `lim ios simctl -- listapps booted`.';
|
|
61
|
+
IosSimctl.examples = [
|
|
62
|
+
'<%= config.bin %> ios simctl -- listapps booted',
|
|
63
|
+
'<%= config.bin %> ios simctl -- getenv booted HOME',
|
|
64
|
+
'<%= config.bin %> ios simctl -- listapps booted --json',
|
|
65
|
+
];
|
|
66
|
+
IosSimctl.strict = false;
|
|
67
|
+
IosSimctl.args = {};
|
|
68
|
+
IosSimctl.flags = {
|
|
69
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
70
|
+
id: core_1.Flags.string({
|
|
71
|
+
description: 'iOS instance ID to target. Defaults to the last created iOS instance.',
|
|
72
|
+
}),
|
|
73
|
+
};
|
|
74
|
+
exports.default = IosSimctl;
|
|
75
|
+
//# sourceMappingURL=simctl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"simctl.js","sourceRoot":"","sources":["../../../src/commands/ios/simctl.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,8 +11,11 @@ export default class IosSync extends BaseCommand {
|
|
|
11
11
|
watch: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
12
|
install: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
13
|
'launch-mode': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
14
|
+
'basis-cache-dir': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
15
|
+
'max-patch-bytes': import("@oclif/core/lib/interfaces").OptionFlag<number | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
14
16
|
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
15
17
|
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
18
|
+
quiet: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
16
19
|
};
|
|
17
20
|
run(): Promise<void>;
|
|
18
21
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/sync.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,OAAQ,SAAQ,WAAW;IAC9C,MAAM,CAAC,OAAO,SAAuD;IACrE,MAAM,CAAC,WAAW,SAC8M;IAEhO,MAAM,CAAC,QAAQ,
|
|
1
|
+
{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/sync.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,OAAQ,SAAQ,WAAW;IAC9C,MAAM,CAAC,OAAO,SAAuD;IACrE,MAAM,CAAC,WAAW,SAC8M;IAEhO,MAAM,CAAC,QAAQ,WAOb;IAEF,MAAM,CAAC,IAAI;;MAKT;IAEF,MAAM,CAAC,KAAK;;;;;;;;;;MAyBV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAsD3B"}
|
|
@@ -22,18 +22,20 @@ class IosSync extends base_command_1.BaseCommand {
|
|
|
22
22
|
apiUrl: instance.status.apiUrl,
|
|
23
23
|
token: instance.status.token,
|
|
24
24
|
});
|
|
25
|
-
this.
|
|
25
|
+
this.info(`Syncing app bundle ${syncPath} to instance ${id}...`);
|
|
26
26
|
const result = await iosClient.syncApp(syncPath, {
|
|
27
27
|
watch: flags.watch,
|
|
28
28
|
install: flags.install,
|
|
29
|
+
basisCacheDir: flags['basis-cache-dir'],
|
|
30
|
+
maxPatchBytes: flags['max-patch-bytes'],
|
|
29
31
|
launchMode: flags['launch-mode'],
|
|
30
32
|
});
|
|
31
|
-
this.
|
|
33
|
+
this.output('App sync complete.');
|
|
32
34
|
if (result.installedBundleId) {
|
|
33
|
-
this.
|
|
35
|
+
this.output(`Installed bundle ID: ${result.installedBundleId}`);
|
|
34
36
|
}
|
|
35
37
|
if (flags.watch && result.stopWatching) {
|
|
36
|
-
this.
|
|
38
|
+
this.output('Watching for changes. Press Ctrl+C to stop.');
|
|
37
39
|
await new Promise((resolve) => {
|
|
38
40
|
const keepAlive = setInterval(() => { }, 1 << 30);
|
|
39
41
|
const shutdown = () => {
|
|
@@ -60,6 +62,7 @@ IosSync.examples = [
|
|
|
60
62
|
'<%= config.bin %> ios sync ./MyApp.app --watch',
|
|
61
63
|
'<%= config.bin %> ios sync ./MyApp.app --no-install',
|
|
62
64
|
'<%= config.bin %> ios sync ./MyApp.app --launch-mode RelaunchIfRunning',
|
|
65
|
+
'<%= config.bin %> ios sync ./MyApp.app --basis-cache-dir ./.limrun-cache --max-patch-bytes 2097152',
|
|
63
66
|
];
|
|
64
67
|
IosSync.args = {
|
|
65
68
|
path: core_1.Args.string({
|
|
@@ -86,6 +89,12 @@ IosSync.flags = {
|
|
|
86
89
|
description: 'Launch behavior after install when installation is enabled',
|
|
87
90
|
options: ['ForegroundIfRunning', 'RelaunchIfRunning'],
|
|
88
91
|
}),
|
|
92
|
+
'basis-cache-dir': core_1.Flags.string({
|
|
93
|
+
description: 'Directory to use for the client-side delta sync cache.',
|
|
94
|
+
}),
|
|
95
|
+
'max-patch-bytes': core_1.Flags.integer({
|
|
96
|
+
description: 'Maximum patch size in bytes before falling back to a full upload.',
|
|
97
|
+
}),
|
|
89
98
|
};
|
|
90
99
|
exports.default = IosSync;
|
|
91
100
|
//# sourceMappingURL=sync.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../../src/commands/ios/sync.ts"],"names":[],"mappings":";;AAAA,sCAA0C;AAC1C,qCAAkC;AAClC,qDAAiD;AACjD,+EAAuE;AAEvE,MAAqB,OAAQ,SAAQ,0BAAW;
|
|
1
|
+
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../../src/commands/ios/sync.ts"],"names":[],"mappings":";;AAAA,sCAA0C;AAC1C,qCAAkC;AAClC,qDAAiD;AACjD,+EAAuE;AAEvE,MAAqB,OAAQ,SAAQ,0BAAW;IAgD9C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAClD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,IAAA,4CAAkB,EAAC,EAAE,CAAC,KAAK,KAAK,EAAE,CAAC;gBACrC,IAAI,CAAC,KAAK,CAAC,qFAAqF,CAAC,CAAC;YACpG,CAAC;YAED,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACxD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;gBAC5B,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,wCAAwC,CAAC,CAAC;YACrE,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YAC5C,MAAM,SAAS,GAAG,MAAM,SAAG,CAAC,oBAAoB,CAAC;gBAC/C,MAAM,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM;gBAC9B,KAAK,EAAE,QAAQ,CAAC,MAAM,CAAC,KAAK;aAC7B,CAAC,CAAC;YAEH,IAAI,CAAC,IAAI,CAAC,sBAAsB,QAAQ,gBAAgB,EAAE,KAAK,CAAC,CAAC;YAEjE,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,OAAO,CAAC,QAAQ,EAAE;gBAC/C,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC;gBACvC,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC;gBACvC,UAAU,EAAE,KAAK,CAAC,aAAa,CAA4D;aAC5F,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;YAClC,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;gBAC7B,IAAI,CAAC,MAAM,CAAC,wBAAwB,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC;YAClE,CAAC;YAED,IAAI,KAAK,CAAC,KAAK,IAAI,MAAM,CAAC,YAAY,EAAE,CAAC;gBACvC,IAAI,CAAC,MAAM,CAAC,6CAA6C,CAAC,CAAC;gBAC3D,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;oBAClC,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;oBACjD,MAAM,QAAQ,GAAG,GAAG,EAAE;wBACpB,aAAa,CAAC,SAAS,CAAC,CAAC;wBACzB,MAAM,CAAC,YAAa,EAAE,CAAC;wBACvB,SAAS,CAAC,UAAU,EAAE,CAAC;wBACvB,OAAO,EAAE,CAAC;oBACZ,CAAC,CAAC;oBACF,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;oBAC/B,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;gBAClC,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,SAAS,CAAC,UAAU,EAAE,CAAC;YACzB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;;AApGM,eAAO,GAAG,mDAAmD,CAAC;AAC9D,mBAAW,GAChB,6NAA6N,CAAC;AAEzN,gBAAQ,GAAG;IAChB,6EAA6E;IAC7E,+DAA+D;IAC/D,gDAAgD;IAChD,qDAAqD;IACrD,wEAAwE;IACxE,oGAAoG;CACrG,CAAC;AAEK,YAAI,GAAG;IACZ,IAAI,EAAE,WAAI,CAAC,MAAM,CAAC;QAChB,WAAW,EAAE,gFAAgF;QAC7F,QAAQ,EAAE,KAAK;KAChB,CAAC;CACH,CAAC;AAEK,aAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,EAAE,EAAE,YAAK,CAAC,MAAM,CAAC;QACf,WAAW,EAAE,wEAAwE;KACtF,CAAC;IACF,KAAK,EAAE,YAAK,CAAC,OAAO,CAAC;QACnB,WAAW,EAAE,oEAAoE;QACjF,OAAO,EAAE,KAAK;QACd,OAAO,EAAE,IAAI;KACd,CAAC;IACF,OAAO,EAAE,YAAK,CAAC,OAAO,CAAC;QACrB,WAAW,EAAE,wCAAwC;QACrD,OAAO,EAAE,IAAI;QACb,OAAO,EAAE,IAAI;KACd,CAAC;IACF,aAAa,EAAE,YAAK,CAAC,MAAM,CAAC;QAC1B,WAAW,EAAE,4DAA4D;QACzE,OAAO,EAAE,CAAC,qBAAqB,EAAE,mBAAmB,CAAC;KACtD,CAAC;IACF,iBAAiB,EAAE,YAAK,CAAC,MAAM,CAAC;QAC9B,WAAW,EAAE,wDAAwD;KACtE,CAAC;IACF,iBAAiB,EAAE,YAAK,CAAC,OAAO,CAAC;QAC/B,WAAW,EAAE,mEAAmE;KACjF,CAAC;CACH,CAAC;kBA9CiB,OAAO"}
|
|
@@ -1,16 +1,15 @@
|
|
|
1
1
|
import { BaseCommand } from '../../base-command';
|
|
2
|
-
export default class
|
|
2
|
+
export default class IosSyslog extends BaseCommand {
|
|
3
3
|
static summary: string;
|
|
4
4
|
static description: string;
|
|
5
5
|
static examples: string[];
|
|
6
|
-
static args: {
|
|
7
|
-
url: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
-
};
|
|
6
|
+
static args: {};
|
|
9
7
|
static flags: {
|
|
10
8
|
id: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
9
|
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
10
|
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
quiet: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
12
|
};
|
|
14
13
|
run(): Promise<void>;
|
|
15
14
|
}
|
|
16
|
-
//# sourceMappingURL=
|
|
15
|
+
//# sourceMappingURL=syslog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"syslog.d.ts","sourceRoot":"","sources":["../../../src/commands/ios/syslog.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,WAAW;IAChD,MAAM,CAAC,OAAO,SAA+C;IAC7D,MAAM,CAAC,WAAW,SACyI;IAC3J,MAAM,CAAC,QAAQ,WAIb;IAEF,MAAM,CAAC,IAAI,KAAM;IAEjB,MAAM,CAAC,KAAK;;;;;MAKV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA4C3B"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class IosSyslog extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { flags } = await this.parse(IosSyslog);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
const id = this.resolveId(flags.id);
|
|
12
|
+
if ((0, instance_client_factory_1.detectInstanceType)(id) !== 'ios') {
|
|
13
|
+
this.error('ios syslog only supports iOS instances');
|
|
14
|
+
}
|
|
15
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, id);
|
|
16
|
+
if (type !== 'ios') {
|
|
17
|
+
disconnect();
|
|
18
|
+
this.error('ios syslog only supports iOS instances');
|
|
19
|
+
}
|
|
20
|
+
try {
|
|
21
|
+
const stream = client.streamSyslog();
|
|
22
|
+
stream.on('line', (line) => {
|
|
23
|
+
if (flags.json) {
|
|
24
|
+
this.outputJson({ line });
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
process.stdout.write(line + '\n');
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
stream.on('error', (err) => {
|
|
31
|
+
this.warn(`Syslog stream error: ${err.message}`);
|
|
32
|
+
});
|
|
33
|
+
await new Promise((resolve) => {
|
|
34
|
+
const keepAlive = setInterval(() => { }, 1 << 30);
|
|
35
|
+
const shutdown = () => {
|
|
36
|
+
clearInterval(keepAlive);
|
|
37
|
+
stream.stop();
|
|
38
|
+
resolve();
|
|
39
|
+
};
|
|
40
|
+
process.on('SIGINT', shutdown);
|
|
41
|
+
process.on('SIGTERM', shutdown);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
finally {
|
|
45
|
+
disconnect();
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
IosSyslog.summary = 'Stream syslog from a running iOS instance';
|
|
51
|
+
IosSyslog.description = 'Stream simulator syslog lines from a running iOS instance until interrupted. This is useful for low-level debugging beyond app-specific stdout/stderr.';
|
|
52
|
+
IosSyslog.examples = [
|
|
53
|
+
'<%= config.bin %> ios syslog',
|
|
54
|
+
'<%= config.bin %> ios syslog --id <instance-ID>',
|
|
55
|
+
'<%= config.bin %> ios syslog --json',
|
|
56
|
+
];
|
|
57
|
+
IosSyslog.args = {};
|
|
58
|
+
IosSyslog.flags = {
|
|
59
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
60
|
+
id: core_1.Flags.string({
|
|
61
|
+
description: 'iOS instance ID to target. Defaults to the last created iOS instance.',
|
|
62
|
+
}),
|
|
63
|
+
};
|
|
64
|
+
exports.default = IosSyslog;
|
|
65
|
+
//# sourceMappingURL=syslog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"syslog.js","sourceRoot":"","sources":["../../../src/commands/ios/syslog.ts"],"names":[],"mappings":";;AAAA,sCAAoC;AACpC,qDAAiD;AACjD,+EAA0F;AAE1F,MAAqB,SAAU,SAAQ,0BAAW;IAmBhD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC9C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,IAAA,4CAAkB,EAAC,EAAE,CAAC,KAAK,KAAK,EAAE,CAAC;gBACrC,IAAI,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;YACvD,CAAC;YAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YAC9E,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;gBACnB,UAAU,EAAE,CAAC;gBACb,IAAI,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;YACvD,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,MAAM,GAAI,MAAc,CAAC,YAAY,EAAE,CAAC;gBAC9C,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;oBACjC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;wBACf,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;oBAC5B,CAAC;yBAAM,CAAC;wBACN,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;oBACpC,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAU,EAAE,EAAE;oBAChC,IAAI,CAAC,IAAI,CAAC,wBAAwB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;gBACnD,CAAC,CAAC,CAAC;gBAEH,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;oBAClC,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;oBACjD,MAAM,QAAQ,GAAG,GAAG,EAAE;wBACpB,aAAa,CAAC,SAAS,CAAC,CAAC;wBACzB,MAAM,CAAC,IAAI,EAAE,CAAC;wBACd,OAAO,EAAE,CAAC;oBACZ,CAAC,CAAC;oBACF,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;oBAC/B,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;gBAClC,CAAC,CAAC,CAAC;YACL,CAAC;oBAAS,CAAC;gBACT,UAAU,EAAE,CAAC;YACf,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;;AA7DM,iBAAO,GAAG,2CAA2C,CAAC;AACtD,qBAAW,GAChB,wJAAwJ,CAAC;AACpJ,kBAAQ,GAAG;IAChB,8BAA8B;IAC9B,iDAAiD;IACjD,qCAAqC;CACtC,CAAC;AAEK,cAAI,GAAG,EAAE,CAAC;AAEV,eAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,EAAE,EAAE,YAAK,CAAC,MAAM,CAAC;QACf,WAAW,EAAE,uEAAuE;KACrF,CAAC;CACH,CAAC;kBAjBiB,SAAS"}
|