extended_yaml 0.4.1 copy "extended_yaml: ^0.4.1" to clipboard
extended_yaml: ^0.4.1 copied to clipboard

YAML parser with extra non-standard features

Extended features for YAML parsing.

Features #

Map merging

Maps can be merged from anchors using the map merge key. Explicitly provided keys take precedence.

base_map: &base
  a: 1
  b: 2
  c: 7

other_map:
 <<: *base
 c: 3

The resulting structure of other_map is equivalent to

other_map:
  a: 1
  b: 2
  c: 3

When maps merge using this syntax, the deep is merge rather than shallow.

i_have_a_pet: &ref
  dog:
    name: 'Buttercup'
    age: 7
    breed: 'beagle'

i_have_one_too:
  <<: ref
  dog:
    name: 'Snoopy'
    sex: 'male'

Equivalent yaml:

i_have_one_too:
  <<: ref
  dog:
    name: 'Snoopy'
    age: 7
    breed: 'beagle'
    sex: 'male'

Including files

External definitions can be included using an include key defining a string or list of strings.

include: path/to/file.yaml

Limitations

At least to start off, this is a wrapper around the yaml package to add additional functionality. There are limits to the performance this package can provide. Eventually, this may get its own parser; but until then, if you're certain your yaml definition doesn't need extended features, we recommend using the yaml packages parsing directly.

Usage #

Pass the string-encoded yaml into loadExtendedYaml.


Future<String> fileContents = File('file.yaml').readAsString();
dynamic parsed = await loadExtendedYaml(await fileContents);

0
likes
140
points
4.11k
downloads

Publisher

unverified uploader

Weekly Downloads

YAML parser with extra non-standard features

Repository (GitHub)

Documentation

API reference

License

MIT (license)

Dependencies

yaml

More

Packages that depend on extended_yaml