libyaml VS skylark

Compare libyaml vs skylark and see what are their differences.

libyaml

Canonical source repository for LibYAML (by yaml)

skylark

Skylark in Go: the Skylark configuration language, implemented in Go [MOVED to go.starlark.net] (by google)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
libyaml skylark
1 1
893 1,184
2.0% -
3.6 0.0
19 days ago about 5 years ago
C Go
MIT License BSD 3-clause "New" or "Revised" License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

libyaml

Posts with mentions or reviews of libyaml. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-08-14.
  • YAML and Configuration Files
    12 projects | news.ycombinator.com | 14 Aug 2021
    Currently, my main concern with YAML is that, by the spec, comments are not attached to a particular node (see https://yaml.org/spec/1.2/spec.html#id2767100). As a result, a lot of YAML parsers (like https://github.com/yaml/libyaml and https://github.com/chyh1990/yaml-rust) only filter out the comments during the parsing phase. This makes it less than ideal for a use-case where the configuration file is expected to be modified by both programs and humans.

    TOML makes it more trivial to associate comments with a node. This is mainly because the language is simpler though, as the spec is not explicit about that (https://github.com/chyh1990/yaml-rust).

skylark

Posts with mentions or reviews of skylark. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-08-14.
  • YAML and Configuration Files
    12 projects | news.ycombinator.com | 14 Aug 2021
    My stance is that YAML is a good format for configuration management and generation -- it's wonderful at filling gaps as your deployment model increases in complexity to provide a mechanism to "render" your configuration -- much like Skylark [1] does (derived from Google's internal GCL).

    YAML ends up being a powerfully declarative model [2] for the state of a data structure, rather than a straight representation, ironically often enough being used in turn for an imperative model like in Ansible [3]. Definitely friendlier than JSON. But personally, I really like YAML because it lets me compose using a traits/mixins-like model using & and , which allows for verbose, structured configuration inputs but concise configuration files.

    docker-compose YAML files extension fields [4], imo, are a great example of this type of model in action. When you leave this much pre-deserialization flexibility in your configuration representation, it makes building cool stuff like docker-compose ECS support x-aws- extension keys [5] and other plugin system-type capabilities much more straightforward than, for example, adding a new language feature to HCL.

    [1]: https://github.com/google/skylark

What are some alternatives?

When comparing libyaml and skylark you can also consider the following projects:

yaml-rust - A pure rust YAML implementation.

hjson-js - Hjson for JavaScript

ytt - YAML templating tool that works on YAML structure instead of text

KeenWrite - Free, open-source, cross-platform desktop Markdown text editor with live preview, string interpolation, and math.

cue - The home of the CUE language! Validate and define text-based and dynamic configuration

cue - CUE has moved to https://github.com/cue-lang/cue

strictyaml - Type-safe YAML parser and validator.

json5 - JSON5 — JSON for Humans