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

This commit is contained in:
larpon 2025-08-29 18:00:06 +02:00 committed by GitHub
parent 214628a939
commit 7831fb0b82
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 52 additions and 10 deletions

View file

@ -934,9 +934,7 @@ pub fn (fm FlagMapper) to_struct[T](defaults ?T) !T {
.f64() .f64()
} $else $if field.typ is bool { } $else $if field.typ is bool {
if arg := f.arg { if arg := f.arg {
if arg != '' { return error('can not assign `${arg}` to bool field `${field.name}`')
return error('can not assign `${arg}` to bool field `${field.name}`')
}
} }
result.$(field.name) = !the_default.$(field.name) result.$(field.name) = !the_default.$(field.name)
} $else $if field.typ is string { } $else $if field.typ is string {
@ -1037,7 +1035,7 @@ fn (mut fm FlagMapper) map_v(flag_ctx FlagContext, field StructField) !bool {
next := flag_ctx.next next := flag_ctx.next
if field.hints.has(.is_bool) { 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 { '' } arg := if flag_raw.contains('=') { flag_raw.all_after('=') } else { '' }
if arg != '' { if arg != '' {
return error('flag `${flag_raw}` can not be assigned to bool field "${field.name}"') return error('flag `${flag_raw}` can not be assigned to bool field "${field.name}"')

View file

@ -1,14 +1,22 @@
import flag import flag
const args_bool_short = ['some.exe', '-h'] const args_bool_short_tail = ['some.exe', '-h']
const args_bool_long = ['some.exe', '-help'] 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 { struct CliOptions {
show_help bool @[long: 'help'; short: h] show_help bool @[long: 'help'; short: h]
} }
fn test_short_tail_bool() { struct CliOptions2 {
cli_options, unmatched := flag.to_struct[CliOptions](args_bool_short, 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 skip: 1
style: .v style: .v
mode: .relaxed mode: .relaxed
@ -24,8 +32,8 @@ fn test_short_tail_bool() {
} }
} }
fn test_long_tail_bool() { fn test_v_style_long_tail_bool() {
cli_options, unmatched := flag.to_struct[CliOptions](args_bool_long, cli_options, unmatched := flag.to_struct[CliOptions](args_bool_long_tail,
skip: 1 skip: 1
style: .v style: .v
mode: .relaxed mode: .relaxed
@ -40,3 +48,39 @@ fn test_long_tail_bool() {
assert false 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'
}