Awesome
eo-yaml
<img alt="eo-yaml-logo" src="http://www.amihaiemil.com/images/camila2.png" width="120" height="70"/> <a href="https://www.yegor256.com/2019/11/03/award-2020.html"> <img src="https://www.yegor256.com/images/award/2020/winner-amihaiemil.png" height="45" alt='winner'/> </a>YAML for Java 8 and above. Based on spec 1.2.
From the specification: YAML™ is a human-friendly, cross language, Unicode based data serialization language.
To get the latest release from Maven Central, simply add the following to your pom.xml
:
<dependency>
<groupId>com.amihaiemil.web</groupId>
<artifactId>eo-yaml</artifactId>
<version>8.0.6</version>
</dependency>
or download the <a href="https://oss.sonatype.org/service/local/repositories/releases/content/com/amihaiemil/web/eo-yaml/8.0.6/eo-yaml-8.0.6-jar-with-dependencies.jar">fat</a> jar.
If you use Gradle, add this to your dependencies:
implementation group: 'com.amihaiemil.web', name: 'eo-yaml', version: '8.0.6'
The releases are also available on Github Packages!
Usage
The API of this library is clean, intuitive and generally close to the javax.json
API that most developers are used to.
Just start from the com.amihaiemil.eoyaml.Yaml
class, it offers all the builders and readers you may need.
See the Block Style Yaml wiki for a first glance.
Features detailed (ongoing work!)
Here is what we have so far:
- Building and Reading Block YAML (wiki);
- Flow-style/JSON-Like representation (wiki);
- Support for Folded and Literal Block Scalars (wiki);
- Convenience Type-Casting Methods (wiki);
- Support for Comments (wiki);
- Convenient
YamlPrinter
(wiki); - Easy Extension Thanks to Interfaces (wiki);
- Building and Reading YAML Streams, integrated with Java 8's Stream API (wiki);
- Java Beans to YAML (wiki);
- JSON to/from YAML (wiki);
- YAML Visitor (wiki);
- Others:
- Clear and detailed Exceptions. For instance, in the case of bad indentation, it will tell you exactly which line is problematic and why.
- Fully encapsulated. The user works only with a few Java Interfaces.
- All objects are immutable and thread-safe.
- It can be used as a Java Module (if you're on JDK 9+).
- It is lightweight! It has 0 dependencies.
Here is what we're still missing and working on:
- Aliases, anchors and tags
- YAML to Java Bean
Keep in mind that the library is based on interfaces and OOP best practices, so you can probably extend/decorate the objects in order to create the functionality you need, if it's not yet implemented.
If you have some time and like the library, please consider contributing.
Contribute
Contributors are welcome!
- Open an issue regarding an improvement you thought of, or a bug you noticed, or ask to be assigned to an existing one.
- If the issue is confirmed, fork the repository, do the changes on a separate branch and make a Pull Request.
- After review and acceptance, the PR is merged and closed.
Make sure the maven build
$ mvn clean install -Pcheckstyle,itcases
passes before making a PR.