-
Notifications
You must be signed in to change notification settings - Fork 8
/
doc.go
870 lines (671 loc) · 33.5 KB
/
doc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
// Copyright 2015 The Vanadium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// This file was auto-generated via go generate.
// DO NOT UPDATE MANUALLY
/*
Multi-device Android Debug Bridge
The madb command wraps Android Debug Bridge (adb) command line tool and provides
various features for controlling multiple Android devices concurrently.
Usage:
madb [flags] <command>
The madb commands are:
clear-data Clear your app data from all devices
exec Run the provided adb command on all devices and emulators
concurrently
extern Run the provided external command for all devices
group Manage device groups
install Install your app on all devices
name Manage device nicknames
resolve Resolve device specifiers into device serials
shell Run the provided adb shell command on all devices and emulators
concurrently
start Launch your app on all devices
stop Stop your app on all devices
uninstall Uninstall your app from all devices
user Manage default user settings for each device
version Print the madb version number
help Display help for commands or topics
The madb flags are:
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
The global flags are:
-metadata=<just specify -metadata to activate>
Displays metadata for the program and exits.
-time=false
Dump timing information to stderr before exiting the program.
Madb clear-data - Clear your app data from all devices
Clears your app data from all devices.
To specify which user's data should be cleared, use 'madb user set' command to
set the default user ID for that device. (See 'madb help user' for more
details.)
Usage:
madb clear-data [flags] [<application_id>]
<application_id> is usually the package name where the activities are defined.
(See:
http://tools.android.com/tech-docs/new-build-system/applicationid-vs-packagename)
If the application ID is not specified, madb automatically determines which app
to be cleared, based on the build scripts found in the current working
directory.
If the working directory contains a Gradle Android project (i.e., has
"build.gradle"), run a small Gradle script to extract the application ID. In
this case, the extracted ID is cached, so that "madb clear-data" can be repeated
without even running the Gradle script again. The ID can be re-extracted by
clearing the cache by providing "-clear-cache" flag.
The madb clear-data flags are:
-clear-cache=false
Clear the cache and re-extract the variant properties such as the application
ID and the main activity name. Only takes effect when no arguments are
provided.
-module=
Specify which application module to use, when the current directory is the
top level Gradle project containing multiple sub-modules. When not specified,
the first available application module is used. Only takes effect when no
arguments are provided.
-variant=
Specify which build variant to use. When not specified, the first available
build variant is used. Only takes effect when no arguments are provided.
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb exec - Run the provided adb command on all devices and emulators concurrently
Runs the provided adb command on all devices and emulators concurrently.
For example, the following line:
madb exec push ./foo.txt /sdcard/foo.txt
copies the ./foo.txt file to /sdcard/foo.txt for all the currently connected
devices.
There are a few pre-defined keywords that can be expanded within an argument.
"{{index}}" : the index of the current device, starting from 1.
"{{name}}" : the nickname of the current device, or the serial number if a nickname is not set.
"{{serial}}" : the serial number of the current device.
For example, the following line:
madb exec -n=Alice,Bob push ./{{name}}.txt /sdcard/{{name}}.txt
copies the ./Alice.txt file to the device named Alice, and ./Bob.txt to the
device named Bob. Note that you should type in "{{name}}" as-is, with the
opening/closing curly braces, similar to when you're using a template library
such as mustache.
To see the list of available adb commands, type 'adb help'.
Usage:
madb exec [flags] <command>
<command> is a normal adb command, which will be executed on all devices and
emulators.
The madb exec flags are:
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb extern - Run the provided external command for all devices
Runs the provided external command for all devices and emulators concurrently.
For each available device, this command will spawn a sub-shell with the
ANDROID_SERIAL environmental variable set to the target device serial, and then
will run the provided external command.
There are a few pre-defined keywords that can be expanded within an argument.
"{{index}}" : the index of the current device, starting from 1.
"{{name}}" : the nickname of the current device, or the serial number if a nickname is not set.
"{{serial}}" : the serial number of the current device.
For example, the following line:
madb extern echo I am {{name}}, and my serial number is {{serial}}.
prints out the name and serial pairs for each device.
Note that you should type in "{{name}}" as-is, with the opening/closing curly
braces, similar to when you're using a template library such as mustache.
This command is intended to be used with external commands that are designed to
work with only a single device at a time (e.g. gomobile, flutter).
Usage:
madb extern [flags] <external_command>
<external_command> is an external shell command to run for all devices and
emulators.
The madb extern flags are:
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb group - Manage device groups
Manages device groups, each of which can have one or more device members. The
device groups can be used for specifying the target devices of other madb
commands.
Usage:
madb group [flags] <command>
The madb group commands are:
add Add members to a device group
clear-all Clear all the existing device groups
delete Delete an existing device group
list List all the existing device groups
remove Remove members from a device group
rename Rename an existing device group
Madb group add - Add members to a device group
Adds members to a device group. This command also creates the group, if the
group does not exist yet. The device group can be used when specifying devices
in any madb commands.
When creating a new device group with this command, the provided name must not
conflict with an existing device nickname (see: madb help name set).
A group can contain another device group, in which case all the members of the
other group will also be considered as members of the current group.
Usage:
madb group add [flags] <group_name> <member1> [<member2> ...]
<group_name> is an alpha-numeric string with no special characters or spaces.
This name must not be an existing device nickname.
<member> is a member specifier, which can be one of device serial, qualifier,
device index (e.g., '@1', '@2'), device nickname, or another device group.
Madb group clear-all - Clear all the existing device groups
Clears all the existing device groups.
Usage:
madb group clear-all [flags]
Madb group delete - Delete an existing device group
Deletes an existing device group.
Usage:
madb group delete [flags] <group_name1> [<group_name2> ...]
<group_name> the name of an existing device group. You can specify more than one
group names.
Madb group list - List all the existing device groups
Lists the name and members of all the existing device groups.
Usage:
madb group list [flags]
Madb group remove - Remove members from a device group
Removes members from an existing device group. If there are no remaining members
after that, the group gets deleted.
Usage:
madb group remove [flags] <group_name> <member1> [<member2> ...]
<group_name> is an alpha-numeric string with no special characters or spaces.
This name must be an existing device group name.
<member> is a member specifier, which can be one of device serial, qualifier,
device index (e.g., '@1', '@2'), device nickname, or another device group.
Madb group rename - Rename an existing device group
Renames an existing device group.
Usage:
madb group rename [flags] <old_name> <new_name>
<old_name> is the name of an existing device group.
<new_name> is the new name for the existing group. This must be an alpha-numeric
string with no special characters or spaces, and must not conflict with another
existing device or group name.
Madb install - Install your app on all devices
Installs your app on all devices.
If the working directory contains a Gradle Android project (i.e., has
"build.gradle"), this command will first run a small Gradle script to extract
the variant properties, which will be used to find the best matching .apk for
each device. These extracted properties are cached, and "madb install" can be
repeated without running this Gradle script again. The properties can be
re-extracted by clearing the cache by providing "-clear-cache" flag.
Once the variant properties are extracted, the best matching .apk for each
device will be installed in parallel.
This command is similar to running "gradlew :<moduleName>:<variantName>Install",
but "madb install" is more flexible: 1) you can install the app to a subset of
the devices, and 2) the app is installed concurrently, which saves a lot of
time.
If the working directory contains a Flutter project (i.e., has "flutter.yaml"),
this command will run "flutter install --device-id <device serial>" for all
devices.
To install your app for a specific user on a particular device, use 'madb user
set' command to set the default user ID for that device. (See 'madb help user'
for more details.)
To install a specific .apk file to all devices, use "madb exec install
<path_to_apk>" instead.
Usage:
madb install [flags]
The madb install flags are:
-build=true
Build the target app variant before installing or running the app.
-clear-cache=false
Clear the cache and re-extract the variant properties such as the application
ID and the main activity name. Only takes effect when no arguments are
provided.
-module=
Specify which application module to use, when the current directory is the
top level Gradle project containing multiple sub-modules. When not specified,
the first available application module is used. Only takes effect when no
arguments are provided.
-variant=
Specify which build variant to use. When not specified, the first available
build variant is used. Only takes effect when no arguments are provided.
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb name - Manage device nicknames
Manages device nicknames, which are meant to be more human-friendly compared to
the device serials provided by adb tool.
Usage:
madb name [flags] <command>
The madb name commands are:
set Set a nickname to be used in place of the device serial.
unset Unset a nickname set by the 'madb name set' command.
list List all the existing nicknames.
clear-all Clear all the existing nicknames.
Madb name set
Sets a human-friendly nickname that can be used when specifying the device in
any madb commands.
The device serial can be obtained using the 'adb devices -l' command. For
example, consider the following example output:
HT4BVWV00023 device usb:3-3.4.2 product:volantisg model:Nexus_9 device:flounder_lte
The first value, 'HT4BVWV00023', is the device serial. To assign a nickname for
this device, run the following command:
madb name set HT4BVWV00023 MyTablet
and it will assign the 'MyTablet' nickname to the device serial 'HT4BVWV00023'.
The alternative device specifiers (e.g., 'usb:3-3.4.2', 'product:volantisg') can
also have nicknames.
When a nickname is set for a device serial, the nickname can be used to specify
the device within madb commands.
There can only be one nickname for a device serial. When the 'madb name set'
command is invoked with a device serial with an already assigned nickname, the
old one will be replaced with the newly provided one.
Usage:
madb name set [flags] <device_serial> <nickname>
<device_serial> is a device serial (e.g., 'HT4BVWV00023') or an alternative
device qualifier (e.g., 'usb:3-3.4.2') obtained from 'adb devices -l' command
<nickname> is an alpha-numeric string with no special characters or spaces.
Madb name unset
Unsets a nickname assigned by the 'madb name set' command. Either the device
serial or the assigned nickname can be specified to remove the mapping.
Usage:
madb name unset [flags] <device_serial | nickname>
There should be only one argument, which is either the device serial or the
nickname.
Madb name list
Lists all the currently stored nicknames of device serials.
Usage:
madb name list [flags]
Madb name clear-all
Clears all the currently stored nicknames of device serials.
Usage:
madb name clear-all [flags]
Madb resolve - Resolve device specifiers into device serials
Resolves the provided device specifiers and prints out their device serials,
each in a separate line. This command only displays the unique serials of the
devices that are currently available.
This command can be useful when you want to use the device nicknames and groups
defined by madb in other command line tools. For example, to run a flutter app
on "MyTablet" device, you can use the following command (in Bash):
flutter run --device $(madb resolve MyTablet)
Usage:
madb resolve [flags] <specifier1> [<specifier2> ...]
<specifier> can be anything that is accepted in the '-n' flag (see 'madb help').
It can be a device serial, qualifier, index, nickname, or a device group name.
Madb shell - Run the provided adb shell command on all devices and emulators concurrently
Runs the provided adb shell command on all devices and emulators concurrently.
This command is a shorthand syntax for 'madb exec shell <command...>'. See 'madb
help exec' for more details.
Usage:
madb shell [flags] <command>
<command> is a normal adb shell command, which will be executed on all devices
and emulators.
The madb shell flags are:
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb start - Launch your app on all devices
Launches your app on all devices.
In most cases, running "madb start" from an Android Gradle project directory
will do the right thing for you. "madb start" will build the project first.
After the project build is completed, this command will install the best
matching .apk for each device, only if one or more of the following conditions
are met:
- the app is not found on the device
- the installed app is outdated (determined by comparing the last update time of the
installed app and the last modification time of the local .apk file)
- "-force-install" flag is set
If you would like to run the same version of the app repeatedly (e.g., for QA
testing), you can explicitly turn off the build flag by providing "-build=false"
to skip the build step.
To run your app as a specific user on a particular device, use 'madb user set'
command to set the default user ID for that device. (See 'madb help user' for
more details.)
Usage:
madb start [flags] [<application_id> <activity_name>]
<application_id> is usually the package name where the activities are defined.
(See:
http://tools.android.com/tech-docs/new-build-system/applicationid-vs-packagename)
<activity_name> is the Java class name for the activity you want to launch. If
the package name of the activity is different from the application ID, the
activity name must be a fully-qualified name (e.g.,
com.yourcompany.yourapp.MainActivity).
If either <application_id> or <activity_name> is provided, the other must be
provided as well.
If no arguments are specified, madb automatically determines which app to
launch, based on the build scripts found in the current working directory.
1) If the working directory contains a Flutter project (i.e., has
"flutter.yaml"), this command will run "flutter start --device-id <device
serial>" for all the specified devices.
2) If the working directory contains a Gradle Android project (i.e., has
"build.gradle"), this command will run a small Gradle script to extract the
application ID and the main activity name. In this case, the extracted IDs are
cached, so that "madb start" can be repeated without even running the Gradle
script again. The IDs can be re-extracted by clearing the cache by providing
"-clear-cache" flag.
The madb start flags are:
-build=true
Build the target app variant before installing or running the app.
-clear-cache=false
Clear the cache and re-extract the variant properties such as the application
ID and the main activity name. Only takes effect when no arguments are
provided.
-force-install=false
Force install the target app before starting the activity.
-force-stop=true
Force stop the target app before starting the activity.
-module=
Specify which application module to use, when the current directory is the
top level Gradle project containing multiple sub-modules. When not specified,
the first available application module is used. Only takes effect when no
arguments are provided.
-variant=
Specify which build variant to use. When not specified, the first available
build variant is used. Only takes effect when no arguments are provided.
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb stop - Stop your app on all devices
Stops your app on all devices.
To stop your app for a specific user on a particular device, use 'madb user set'
command to set the default user ID for that device. (See 'madb help user' for
more details.)
Usage:
madb stop [flags] [<application_id>]
<application_id> is usually the package name where the activities are defined.
(See:
http://tools.android.com/tech-docs/new-build-system/applicationid-vs-packagename)
If the application ID is not specified, madb automatically determines which app
to stop, based on the build scripts found in the current working directory.
1) If the working directory contains a Flutter project (i.e., has
"flutter.yaml"), this command will run "flutter stop --device-id <device
serial>" for all the specified devices.
2) If the working directory contains a Gradle Android project (i.e., has
"build.gradle"), run a small Gradle script to extract the application ID. In
this case, the extracted ID is cached, so that "madb stop" can be repeated
without even running the Gradle script again. The ID can be re-extracted by
clearing the cache by providing "-clear-cache" flag.
The madb stop flags are:
-clear-cache=false
Clear the cache and re-extract the variant properties such as the application
ID and the main activity name. Only takes effect when no arguments are
provided.
-module=
Specify which application module to use, when the current directory is the
top level Gradle project containing multiple sub-modules. When not specified,
the first available application module is used. Only takes effect when no
arguments are provided.
-variant=
Specify which build variant to use. When not specified, the first available
build variant is used. Only takes effect when no arguments are provided.
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb uninstall - Uninstall your app from all devices
Uninstall your app from all devices.
To uninstall your app for a specific user on a particular device, use 'madb user
set' command to set the default user ID for that device. (See 'madb help user'
for more details.)
Usage:
madb uninstall [flags] [<application_id>]
<application_id> is usually the package name where the activities are defined.
(See:
http://tools.android.com/tech-docs/new-build-system/applicationid-vs-packagename)
If the application_id is not specified, madb automatically determines which app
to uninstall, based on the build scripts found in the current working directory.
If the working directory contains a Gradle Android project (i.e., has
"build.gradle"), run a small Gradle script to extract the application ID. In
this case, the extracted ID is cached, so that "madb uninstall" can be repeated
without even running the Gradle script again. The ID can be re-extracted by
clearing the cache by providing "-clear-cache" flag.
The madb uninstall flags are:
-clear-cache=false
Clear the cache and re-extract the variant properties such as the application
ID and the main activity name. Only takes effect when no arguments are
provided.
-keep-data=false
Keep the application data and cache directories. Equivalent to '-k' flag in
'adb uninstall' command.
-module=
Specify which application module to use, when the current directory is the
top level Gradle project containing multiple sub-modules. When not specified,
the first available application module is used. Only takes effect when no
arguments are provided.
-variant=
Specify which build variant to use. When not specified, the first available
build variant is used. Only takes effect when no arguments are provided.
-d=false
Restrict the command to only run on real devices.
-e=false
Restrict the command to only run on emulators.
-n=
Comma-separated device serials, qualifiers, device indices (e.g., '@1',
'@2'), nicknames (set by 'madb name'), or group names (set by 'madb group').
A device index is specified by an '@' sign followed by the index of the
device in the output of 'adb devices' command, starting from 1. Command will
be run only on specified devices.
-prefix=name
Specify which output prefix to use. You can choose from the following
options:
name - Display the nickname of the device. The serial number is used instead if the
nickname is not set for the given device.
serial - Display the serial number of the device.
none - Do not display the output prefix.
-seq=false
Run the command sequentially, instead of running it in parallel.
Madb user - Manage default user settings for each device
Manages default user settings for each device.
An Android device can have multiple user accounts, and each user account has a
numeric ID associated with it. Certain adb commands accept '--user <user_id>' as
a parameter to allow specifying which of the Android user account should be used
when running the command. The default behavior when the user ID is not provided
varies by the adb command being run.
Some madb commands internally run these adb commands which accept the '--user'
flag. You can let madb use different user IDs for different devices by storing
the default user ID for each device using 'madb user set' command. If the
default user ID is not set for a particular device, madb will not provide the
'--user' flag to the underlying adb command, and the current user will be used
for that device as a result.
Below is the list of madb commands which are affected by the default user ID
settings:
madb clear-data
madb install
madb start
madb stop
madb uninstall
For more details on how to obtain the user ID from an Android device, see 'madb
user help set'.
Usage:
madb user [flags] <command>
The madb user commands are:
set Set a default user ID to be used for the given device.
unset Unset the default user ID set by the 'madb user set' command.
list List all the existing default user IDs.
clear-all Clear all the existing default user settings.
Madb user set
Sets a default user ID to be used for the specified device, when there are
multiple user accounts on a single device.
The user IDs can be obtained using the 'adb [<device_serial>] shell pm list
users' command. Alternatively, you can use 'madb exec' if you want to specify
the device with a nickname. For example, running the following command:
madb -n=MyPhone exec shell pm list users
will list the available users and their IDs on the MyPhone device. Consider the
following example output:
[MyPhone] Users:
[MyPhone] UserInfo{0:John Doe:13} running
[MyPhone] UserInfo{10:Work profile:30} running
There are two available users, "John Doe" and "Work profile". Each user is
assigned a "user ID", which appears on the left of the user name. In this case,
the user ID of "John Doe" is "0", and the user ID of the "Work profile" is "10".
To use the "Work profile" as the default user when running madb commands on this
device, run the following command:
madb user set MyPhone 10
and then madb will use "Work profile" as the default user for device "MyPhone"
in any of the subsequence madb commands.
Usage:
madb user set [flags] <device_serial> <user_id>
<device_serial> is the unique serial number for the device, which can be
obtained from 'adb devices'. <user_id> is one of the user IDs obtained from 'adb
shell pm list users' command.
Madb user unset
Unsets the default user ID assigned by the 'madb user set' command for the
specified device.
Running this command without any device specifiers will unset the default users
only for the currently available devices and emulators, while keeping the
default user IDs for the other devices.
Usage:
madb user unset [flags] <device_serial>
<device_serial> is the unique serial number for the device, which can be
obtained from 'adb devices'.
Madb user list
Lists all the currently stored default user IDs for devices.
Usage:
madb user list [flags]
Madb user clear-all
Clears all the currently stored default user IDs for devices.
This command clears the default user IDs regardless of whether the device is
currently connected or not.
Usage:
madb user clear-all [flags]
Madb version - Print the madb version number
Prints the madb version number to the console.
If this version of madb binary is an official release, this command will show
the version number. Otherwise, the version will be in the form of
"<version>-develop", where the version indicates the most recent stable release
version prior to this version of madb binary.
Usage:
madb version [flags]
Madb help - Display help for commands or topics
Help with no args displays the usage of the parent command.
Help with args displays the usage of the specified sub-command or help topic.
"help ..." recursively displays help for all commands and topics.
Usage:
madb help [flags] [command/topic ...]
[command/topic ...] optionally identifies a specific sub-command or help topic.
The madb help flags are:
-style=compact
The formatting style for help output:
compact - Good for compact cmdline output.
full - Good for cmdline output, shows all global flags.
godoc - Good for godoc processing.
shortonly - Only output short description.
Override the default by setting the CMDLINE_STYLE environment variable.
-width=<terminal width>
Format output to this target width in runes, or unlimited if width < 0.
Defaults to the terminal width if available. Override the default by setting
the CMDLINE_WIDTH environment variable.
*/
package main