feat: support --cargo-name config in napi cli

This commit is contained in:
LongYinan 2020-09-05 01:20:30 +08:00
parent 9c45704eae
commit 4226561c7e
No known key found for this signature in database
GPG key ID: C3666B7FC82ADAD7

View file

@ -28,6 +28,9 @@ export class BuildCommand extends Command {
@Command.String('--config,-c') @Command.String('--config,-c')
configFileName?: string configFileName?: string
@Command.String('--cargo-name')
cargoName?: string
@Command.String({ @Command.String({
required: false, required: false,
}) })
@ -36,6 +39,8 @@ export class BuildCommand extends Command {
@Command.Path('build') @Command.Path('build')
async execute() { async execute() {
const { binaryName } = getNapiConfig(this.configFileName) const { binaryName } = getNapiConfig(this.configFileName)
let dylibName = this.cargoName
if (!dylibName) {
let tomlContentString: string let tomlContentString: string
let tomlContent: any let tomlContent: any
try { try {
@ -55,13 +60,12 @@ export class BuildCommand extends Command {
throw new TypeError('Could not parse the Cargo.toml') throw new TypeError('Could not parse the Cargo.toml')
} }
let dylibName
if (tomlContent.package ?? tomlContent.package.name) { if (tomlContent.package ?? tomlContent.package.name) {
dylibName = tomlContent.package.name.replace(/-/g, '_') dylibName = tomlContent.package.name.replace(/-/g, '_')
} else { } else {
throw new TypeError('No package.name field in Cargo.toml') throw new TypeError('No package.name field in Cargo.toml')
} }
}
debug(`Dylib name: ${chalk.greenBright(dylibName)}`) debug(`Dylib name: ${chalk.greenBright(dylibName)}`)