Reformat versioning script; provide instructions for installing CLI from source
This commit is contained in:
parent
3aa752e46b
commit
ab4b1e3293
|
@ -23,9 +23,9 @@ Speed and effectiveness of Node.js version compared to [html-minfier](https://gi
|
||||||
|
|
||||||
### CLI
|
### CLI
|
||||||
|
|
||||||
##### Get
|
Precompiled binaries are available for x86-64 Windows, macOS, and Linux. To compile and install from source, run `cargo install hyperbuild`, which requires [Rust](https://www.rust-lang.org/tools/install).
|
||||||
|
|
||||||
Supports x86-64 only.
|
##### Get
|
||||||
|
|
||||||
[Windows](https://wilsonl.in/hyperbuild/bin/0.0.39-windows-x86_64.exe) |
|
[Windows](https://wilsonl.in/hyperbuild/bin/0.0.39-windows-x86_64.exe) |
|
||||||
[macOS](https://wilsonl.in/hyperbuild/bin/0.0.39-macos-x86_64) |
|
[macOS](https://wilsonl.in/hyperbuild/bin/0.0.39-macos-x86_64) |
|
||||||
|
|
25
version
25
version
|
@ -1,4 +1,5 @@
|
||||||
#!/usr/bin/env node
|
#!/usr/bin/env node
|
||||||
|
|
||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
const {readFileSync, writeFileSync} = require('fs');
|
const {readFileSync, writeFileSync} = require('fs');
|
||||||
|
@ -8,7 +9,7 @@ const currentVersion = /^version = "(\d+)\.(\d+)\.(\d+)"\s*$/m.exec(readFileSync
|
||||||
|
|
||||||
const assertBetween = (n, min, max) => {
|
const assertBetween = (n, min, max) => {
|
||||||
if (n < min || n > max) {
|
if (n < min || n > max) {
|
||||||
throw new Error(`Invalid argument`);
|
throw new Error('Invalid argument');
|
||||||
}
|
}
|
||||||
return n;
|
return n;
|
||||||
};
|
};
|
||||||
|
@ -29,7 +30,7 @@ const cmd = (...cfg) => {
|
||||||
throwOnSignal = true,
|
throwOnSignal = true,
|
||||||
captureStdio = false,
|
captureStdio = false,
|
||||||
throwOnStdErr = false,
|
throwOnStdErr = false,
|
||||||
} = typeof args[args.length - 1] == "object" ? args.pop() : {};
|
} = typeof args[args.length - 1] == 'object' ? args.pop() : {};
|
||||||
|
|
||||||
const throwErr = msg => {
|
const throwErr = msg => {
|
||||||
throw new Error(`${msg}\n ${command} ${args.join(' ')}`);
|
throw new Error(`${msg}\n ${command} ${args.join(' ')}`);
|
||||||
|
@ -55,41 +56,41 @@ const cmd = (...cfg) => {
|
||||||
return {status, signal, stdout, stderr};
|
return {status, signal, stdout, stderr};
|
||||||
};
|
};
|
||||||
|
|
||||||
const replaceInFile = (path, pattern, replacement) => writeFileSync(path, readFileSync(path, "utf8").replace(pattern, replacement));
|
const replaceInFile = (path, pattern, replacement) => writeFileSync(path, readFileSync(path, 'utf8').replace(pattern, replacement));
|
||||||
|
|
||||||
if (cmd('git', 'status', '--porcelain', {throwOnStderr: true, captureStdio: true}).stdout) {
|
if (cmd('git', 'status', '--porcelain', {throwOnStderr: true, captureStdio: true}).stdout) {
|
||||||
throw new Error(`Working directory not clean`);
|
throw new Error('Working directory not clean');
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["Cargo.toml", "nodejs/native/Cargo.toml", "java/Cargo.toml", "python/Cargo.toml", "ruby/Cargo.toml"]) {
|
for (const f of ['Cargo.toml', 'nodejs/native/Cargo.toml', 'java/Cargo.toml', 'python/Cargo.toml', 'ruby/Cargo.toml']) {
|
||||||
replaceInFile(f, /^version = "\d+\.\d+\.\d+"\s*$/m, `version = "${NEW_VERSION}"`);
|
replaceInFile(f, /^version = "\d+\.\d+\.\d+"\s*$/m, `version = "${NEW_VERSION}"`);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["python/setup.py"]) {
|
for (const f of ['python/setup.py']) {
|
||||||
replaceInFile(f, /^(\s*version=)"\d+\.\d+\.\d+",\s*$/m, `$1"${NEW_VERSION}",`);
|
replaceInFile(f, /^(\s*version=)"\d+\.\d+\.\d+",\s*$/m, `$1"${NEW_VERSION}",`);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["README.md", "nodejs/native/Cargo.toml", "java/Cargo.toml", "python/Cargo.toml", "ruby/Cargo.toml"]) {
|
for (const f of ['README.md', 'nodejs/native/Cargo.toml', 'java/Cargo.toml', 'python/Cargo.toml', 'ruby/Cargo.toml']) {
|
||||||
replaceInFile(f, /^hyperbuild = "\d+\.\d+\.\d+"\s*$/m, `hyperbuild = "${NEW_VERSION}"`);
|
replaceInFile(f, /^hyperbuild = "\d+\.\d+\.\d+"\s*$/m, `hyperbuild = "${NEW_VERSION}"`);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["nodejs/package.json"]) {
|
for (const f of ['nodejs/package.json']) {
|
||||||
replaceInFile(f, /^(\s*"version": )"\d+\.\d+\.\d+",\s*$/m, `$1"${NEW_VERSION}",`);
|
replaceInFile(f, /^(\s*"version": )"\d+\.\d+\.\d+",\s*$/m, `$1"${NEW_VERSION}",`);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["ruby/hyperbuild.gemspec"]) {
|
for (const f of ['ruby/hyperbuild.gemspec']) {
|
||||||
replaceInFile(f, /^(\s*spec\.version\s*=\s*)"\d+\.\d+\.\d+"\s*$/m, `$1"${NEW_VERSION}"`);
|
replaceInFile(f, /^(\s*spec\.version\s*=\s*)"\d+\.\d+\.\d+"\s*$/m, `$1"${NEW_VERSION}"`);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["java/pom.xml", "README.md"]) {
|
for (const f of ['java/pom.xml', 'README.md']) {
|
||||||
replaceInFile(f, /(<artifactId>hyperbuild<\/artifactId>\s*<version>)\d+\.\d+\.\d+(<\/version>)/, `$1${NEW_VERSION}$2`);
|
replaceInFile(f, /(<artifactId>hyperbuild<\/artifactId>\s*<version>)\d+\.\d+\.\d+(<\/version>)/, `$1${NEW_VERSION}$2`);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["README.md"]) {
|
for (const f of ['README.md']) {
|
||||||
replaceInFile(f, /(wilsonl\.in\/hyperbuild\/bin\/)\d+\.\d+\.\d+/g, `$1${NEW_VERSION}`);
|
replaceInFile(f, /(wilsonl\.in\/hyperbuild\/bin\/)\d+\.\d+\.\d+/g, `$1${NEW_VERSION}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const f of ["README.md", "bench/README.md"]) {
|
for (const f of ['README.md', 'bench/README.md']) {
|
||||||
replaceInFile(f, /(wilsonl\.in\/hyperbuild\/bench\/)\d+\.\d+\.\d+/g, `$1${NEW_VERSION}`);
|
replaceInFile(f, /(wilsonl\.in\/hyperbuild\/bench\/)\d+\.\d+\.\d+/g, `$1${NEW_VERSION}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue