forked from stovmascript/react-native-version
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcli.js
executable file
·58 lines (54 loc) · 2.56 KB
/
cli.js
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
#!/usr/bin/env node
const list = require("./util").list;
const pkg = require("./package");
const program = require("commander");
const rnv = require("./");
const defaults = rnv.getDefaults();
program
.version(pkg.version)
.description(pkg.description)
.arguments("[projectPath]")
.option(
"-a, --amend",
`Amend the previous commit. This is done automatically when ${pkg.name} is run from the "version" or "postversion" npm script. Use "--never-amend" if you never want to amend. Also, if the previous commit is a valid npm-version commit, ${pkg.name} will update the Git tag pointing to this commit.`
)
.option(
"--skip-tag",
'For use with "--amend", if you don\'t want to update Git tags. Use this option if you have git-tag-version set to false in your npm config or you use "--no-git-tag-version" during npm-version.'
)
.option("-A, --never-amend", "Never amend the previous commit.")
.option("-b, --increment-build", "Only increment build number.")
.option("-B, --never-increment-build", "Never increment build number.")
.option(
"-d, --android [path]",
'Path to your "android/app/build.gradle" file.',
defaults.android
)
.option("-i, --ios [path]", 'Path to your "ios/" folder.', defaults.ios)
.option(
"-L, --legacy",
"Version iOS using agvtool (macOS only). Requires Xcode Command Line Tools."
)
.option("-q, --quiet", "Be quiet, only report errors.")
.option(
"-r, --reset-build",
'Reset build number back to "1" (iOS only). Unlike Android\'s "versionCode", iOS doesn\'t require you to bump the "CFBundleVersion", as long as "CFBundleShortVersionString" changes. To make it consistent across platforms, ' +
pkg.name +
' bumps both by default. You can use this option if you prefer to keep the build number value at "1" after every version change. If you then need to push another build under the same version, you can use "-bt ios" to increment.'
)
.option(
"-s, --set-build <number>",
"Set a build number. WARNING: Watch out when setting high values. This option follows Android's app versioning specifics - the value has to be an integer and cannot be greater than 2100000000. You cannot decrement this value after publishing to Google Play! More info at: https://developer.android.com/studio/publish/versioning.html#appversioning",
parseInt
)
.option(
"--generate-build",
"Generate build number from the package version number. (e.g. build number for version 1.22.3 will be 1022003)"
)
.option(
"-t, --target <platforms>",
'Only version specified platforms, e.g. "--target android,ios".',
list
)
.parse(process.argv);
rnv.version(program);