mirror of
https://github.com/lightbend/config.git
synced 2025-01-29 05:30:08 +08:00
support "on" and "off" when converting string to boolean
This commit is contained in:
parent
61b1281e90
commit
20b75542e4
10
HOCON.md
10
HOCON.md
@ -652,11 +652,11 @@ implementation should attempt to convert types as follows:
|
|||||||
representation that would be a valid number in JSON.
|
representation that would be a valid number in JSON.
|
||||||
- boolean to string: should become the string "true" or "false"
|
- boolean to string: should become the string "true" or "false"
|
||||||
- string to number: parse the number with the JSON rules
|
- string to number: parse the number with the JSON rules
|
||||||
- string to boolean: the strings "true", "yes", "false", "no"
|
- string to boolean: the strings "true", "yes", "on", "false",
|
||||||
should be converted to boolean values. It's tempting to
|
"no", "off" should be converted to boolean values. It's
|
||||||
support a long list of other ways to write a boolean, but
|
tempting to support a long list of other ways to write a
|
||||||
for interoperability and keeping it simple, it's recommended to
|
boolean, but for interoperability and keeping it simple, it's
|
||||||
stick to these four.
|
recommended to stick to these six.
|
||||||
- string to null: the string `"null"` should be converted to a
|
- string to null: the string `"null"` should be converted to a
|
||||||
null value if the application specifically asks for a null
|
null value if the application specifically asks for a null
|
||||||
value, though there's probably no reason an app would do this.
|
value, though there's probably no reason an app would do this.
|
||||||
|
@ -31,9 +31,10 @@ final class DefaultTransformer {
|
|||||||
return new ConfigNull(value.origin());
|
return new ConfigNull(value.origin());
|
||||||
break;
|
break;
|
||||||
case BOOLEAN:
|
case BOOLEAN:
|
||||||
if (s.equals("true") || s.equals("yes")) {
|
if (s.equals("true") || s.equals("yes") || s.equals("on")) {
|
||||||
return new ConfigBoolean(value.origin(), true);
|
return new ConfigBoolean(value.origin(), true);
|
||||||
} else if (s.equals("false") || s.equals("no")) {
|
} else if (s.equals("false") || s.equals("no")
|
||||||
|
|| s.equals("off")) {
|
||||||
return new ConfigBoolean(value.origin(), false);
|
return new ConfigBoolean(value.origin(), false);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -422,4 +422,17 @@ class ConfigValueTest extends TestUtils {
|
|||||||
assertEquals(Int.MaxValue + 1L, nD(Int.MaxValue + 1.0).unwrapped())
|
assertEquals(Int.MaxValue + 1L, nD(Int.MaxValue + 1.0).unwrapped())
|
||||||
assertEquals(Int.MinValue - 1L, nD(Int.MinValue - 1.0).unwrapped())
|
assertEquals(Int.MinValue - 1L, nD(Int.MinValue - 1.0).unwrapped())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
def automaticBooleanConversions() {
|
||||||
|
val trues = parseObject("{ a=true, b=yes, c=on }")
|
||||||
|
assertEquals(true, trues.getBoolean("a"))
|
||||||
|
assertEquals(true, trues.getBoolean("b"))
|
||||||
|
assertEquals(true, trues.getBoolean("c"))
|
||||||
|
|
||||||
|
val falses = parseObject("{ a=false, b=no, c=off }")
|
||||||
|
assertEquals(false, falses.getBoolean("a"))
|
||||||
|
assertEquals(false, falses.getBoolean("b"))
|
||||||
|
assertEquals(false, falses.getBoolean("c"))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user