mirror of https://github.com/databricks/cli.git
json pointer comment
This commit is contained in:
parent
be0ad482ff
commit
8575c47626
|
@ -35,12 +35,16 @@ type constructor struct {
|
||||||
root reflect.Type
|
root reflect.Type
|
||||||
}
|
}
|
||||||
|
|
||||||
// The $defs block in a JSON schema cannot contain "/", otherwise it will not be
|
// JSON pointers use "/" as a delimiter to represent nested objects. This means
|
||||||
// correctly parsed by a JSON schema validator (like the Red Hat YAML extension for VSCode).
|
// we would instead need to use "~1" to represent "/" if we wish to refer to a
|
||||||
// So we replace "/" with an additional level of nesting in the output map.
|
// key in a JSON object with a "/" in it. Instead of doing that we replace "/" with an
|
||||||
|
// additional level of nesting in the output map. Thus the $refs in the generated
|
||||||
|
// JSON schema can contain "/" without any issues.
|
||||||
|
// see: https://datatracker.ietf.org/doc/html/rfc6901
|
||||||
//
|
//
|
||||||
// For example:
|
// For example:
|
||||||
// {"a/b/c": "value"} is converted to {"a": {"b": {"c": "value"}}}
|
// {"a/b/c": "value"} is converted to {"a": {"b": {"c": "value"}}}
|
||||||
|
// the $ref for "value" would be "#/$defs/a/b/c" in the generated JSON schema.
|
||||||
func (c *constructor) Definitions() any {
|
func (c *constructor) Definitions() any {
|
||||||
defs := maps.Clone(c.definitions)
|
defs := maps.Clone(c.definitions)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue