mirror of
https://github.com/vlang/v.git
synced 2025-09-13 14:32:26 +03:00
flag: improve the fix for #25166 tail/single bool flag error in flag_to.v
(#25189)
Some checks are pending
Graphics CI / gg-regressions (push) Waiting to run
vlib modules CI / build-module-docs (push) Waiting to run
native backend CI / native-backend-ubuntu (push) Waiting to run
native backend CI / native-backend-windows (push) Waiting to run
Shy and PV CI / v-compiles-puzzle-vibes (push) Waiting to run
Sanitized CI / sanitize-undefined-clang (push) Waiting to run
Sanitized CI / sanitize-undefined-gcc (push) Waiting to run
Sanitized CI / tests-sanitize-address-clang (push) Waiting to run
Sanitized CI / sanitize-address-msvc (push) Waiting to run
Sanitized CI / sanitize-address-gcc (push) Waiting to run
Sanitized CI / sanitize-memory-clang (push) Waiting to run
sdl CI / v-compiles-sdl-examples (push) Waiting to run
Time CI / time-linux (push) Waiting to run
Time CI / time-macos (push) Waiting to run
Time CI / time-windows (push) Waiting to run
toml CI / toml-module-pass-external-test-suites (push) Waiting to run
Tools CI / tools-linux (clang) (push) Waiting to run
Tools CI / tools-linux (gcc) (push) Waiting to run
Tools CI / tools-linux (tcc) (push) Waiting to run
Tools CI / tools-macos (clang) (push) Waiting to run
Tools CI / tools-windows (gcc) (push) Waiting to run
Tools CI / tools-windows (msvc) (push) Waiting to run
Tools CI / tools-windows (tcc) (push) Waiting to run
Tools CI / tools-docker-ubuntu-musl (push) Waiting to run
vab CI / vab-compiles-v-examples (push) Waiting to run
vab CI / v-compiles-os-android (push) Waiting to run
wasm backend CI / wasm-backend (ubuntu-22.04) (push) Waiting to run
wasm backend CI / wasm-backend (windows-2022) (push) Waiting to run
Some checks are pending
Graphics CI / gg-regressions (push) Waiting to run
vlib modules CI / build-module-docs (push) Waiting to run
native backend CI / native-backend-ubuntu (push) Waiting to run
native backend CI / native-backend-windows (push) Waiting to run
Shy and PV CI / v-compiles-puzzle-vibes (push) Waiting to run
Sanitized CI / sanitize-undefined-clang (push) Waiting to run
Sanitized CI / sanitize-undefined-gcc (push) Waiting to run
Sanitized CI / tests-sanitize-address-clang (push) Waiting to run
Sanitized CI / sanitize-address-msvc (push) Waiting to run
Sanitized CI / sanitize-address-gcc (push) Waiting to run
Sanitized CI / sanitize-memory-clang (push) Waiting to run
sdl CI / v-compiles-sdl-examples (push) Waiting to run
Time CI / time-linux (push) Waiting to run
Time CI / time-macos (push) Waiting to run
Time CI / time-windows (push) Waiting to run
toml CI / toml-module-pass-external-test-suites (push) Waiting to run
Tools CI / tools-linux (clang) (push) Waiting to run
Tools CI / tools-linux (gcc) (push) Waiting to run
Tools CI / tools-linux (tcc) (push) Waiting to run
Tools CI / tools-macos (clang) (push) Waiting to run
Tools CI / tools-windows (gcc) (push) Waiting to run
Tools CI / tools-windows (msvc) (push) Waiting to run
Tools CI / tools-windows (tcc) (push) Waiting to run
Tools CI / tools-docker-ubuntu-musl (push) Waiting to run
vab CI / vab-compiles-v-examples (push) Waiting to run
vab CI / v-compiles-os-android (push) Waiting to run
wasm backend CI / wasm-backend (ubuntu-22.04) (push) Waiting to run
wasm backend CI / wasm-backend (windows-2022) (push) Waiting to run
This commit is contained in:
parent
214628a939
commit
7831fb0b82
2 changed files with 52 additions and 10 deletions
|
@ -934,10 +934,8 @@ pub fn (fm FlagMapper) to_struct[T](defaults ?T) !T {
|
|||
.f64()
|
||||
} $else $if field.typ is bool {
|
||||
if arg := f.arg {
|
||||
if arg != '' {
|
||||
return error('can not assign `${arg}` to bool field `${field.name}`')
|
||||
}
|
||||
}
|
||||
result.$(field.name) = !the_default.$(field.name)
|
||||
} $else $if field.typ is string {
|
||||
trace_dbg_println('${@FN}: assigning (string) ${struct_name}.${field.name} = ${f.arg or {
|
||||
|
@ -1037,7 +1035,7 @@ fn (mut fm FlagMapper) map_v(flag_ctx FlagContext, field StructField) !bool {
|
|||
next := flag_ctx.next
|
||||
|
||||
if field.hints.has(.is_bool) {
|
||||
if flag_name == field.match_name {
|
||||
if flag_name == field.match_name || flag_name == field.short {
|
||||
arg := if flag_raw.contains('=') { flag_raw.all_after('=') } else { '' }
|
||||
if arg != '' {
|
||||
return error('flag `${flag_raw}` can not be assigned to bool field "${field.name}"')
|
||||
|
|
|
@ -1,14 +1,22 @@
|
|||
import flag
|
||||
|
||||
const args_bool_short = ['some.exe', '-h']
|
||||
const args_bool_long = ['some.exe', '-help']
|
||||
const args_bool_short_tail = ['some.exe', '-h']
|
||||
const args_bool_long_tail = ['some.exe', '-help']
|
||||
|
||||
const args_bool_short_mixed = ['some.exe', '-h', '-long', 'val']
|
||||
const args_bool_long_mixed = ['some.exe', '-help', '-long', 'val']
|
||||
|
||||
struct CliOptions {
|
||||
show_help bool @[long: 'help'; short: h]
|
||||
}
|
||||
|
||||
fn test_short_tail_bool() {
|
||||
cli_options, unmatched := flag.to_struct[CliOptions](args_bool_short,
|
||||
struct CliOptions2 {
|
||||
show_help bool @[long: 'help'; short: h]
|
||||
long string
|
||||
}
|
||||
|
||||
fn test_v_style_short_tail_bool() {
|
||||
cli_options, unmatched := flag.to_struct[CliOptions](args_bool_short_tail,
|
||||
skip: 1
|
||||
style: .v
|
||||
mode: .relaxed
|
||||
|
@ -24,8 +32,8 @@ fn test_short_tail_bool() {
|
|||
}
|
||||
}
|
||||
|
||||
fn test_long_tail_bool() {
|
||||
cli_options, unmatched := flag.to_struct[CliOptions](args_bool_long,
|
||||
fn test_v_style_long_tail_bool() {
|
||||
cli_options, unmatched := flag.to_struct[CliOptions](args_bool_long_tail,
|
||||
skip: 1
|
||||
style: .v
|
||||
mode: .relaxed
|
||||
|
@ -40,3 +48,39 @@ fn test_long_tail_bool() {
|
|||
assert false
|
||||
}
|
||||
}
|
||||
|
||||
fn test_v_style_short_bool() {
|
||||
cli_options, unmatched := flag.to_struct[CliOptions2](args_bool_short_mixed,
|
||||
skip: 1
|
||||
style: .v
|
||||
mode: .relaxed
|
||||
)!
|
||||
|
||||
if unmatched.len > 0 {
|
||||
assert false
|
||||
}
|
||||
if cli_options.show_help {
|
||||
assert true
|
||||
} else {
|
||||
assert false
|
||||
}
|
||||
assert cli_options.long == 'val'
|
||||
}
|
||||
|
||||
fn test_v_style_long_bool() {
|
||||
cli_options, unmatched := flag.to_struct[CliOptions2](args_bool_long_mixed,
|
||||
skip: 1
|
||||
style: .v
|
||||
mode: .relaxed
|
||||
)!
|
||||
|
||||
if unmatched.len > 0 {
|
||||
assert false
|
||||
}
|
||||
if cli_options.show_help {
|
||||
assert true
|
||||
} else {
|
||||
assert false
|
||||
}
|
||||
assert cli_options.long == 'val'
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue