2013-02-26 07:57:26 +00:00
|
|
|
# toml4j
|
|
|
|
|
2014-04-06 19:56:14 +00:00
|
|
|
toml4j is a [TOML 0.1.0](https://github.com/mojombo/toml) parser for Java that uses the [Parboiled](http://www.parboiled.org) PEG parser.
|
2013-02-26 07:57:26 +00:00
|
|
|
|
2013-02-26 19:49:57 +00:00
|
|
|
## Installation
|
|
|
|
|
2014-04-06 19:56:14 +00:00
|
|
|
Add the following dependency to your POM:
|
2013-02-26 19:49:57 +00:00
|
|
|
|
|
|
|
````xml
|
|
|
|
<dependency>
|
|
|
|
<groupId>com.moandjiezana.toml</groupId>
|
|
|
|
<artifactId>toml4j</artifactId>
|
2014-04-06 19:56:14 +00:00
|
|
|
<version>0.1.0</version>
|
2013-02-26 19:49:57 +00:00
|
|
|
</dependency>
|
|
|
|
````
|
|
|
|
|
2013-02-26 07:57:26 +00:00
|
|
|
## Usage
|
|
|
|
|
2013-02-28 10:53:46 +00:00
|
|
|
### Custom classes
|
|
|
|
|
|
|
|
A Toml object can be mapped to a custom class with the `Toml#to(Class<T>)` method.
|
|
|
|
|
|
|
|
Any keys not found in both the TOML and the class are ignored.
|
|
|
|
|
2014-04-06 19:56:14 +00:00
|
|
|
Key groups can be mapped to other custom classes. Fields may be private.
|
2013-02-28 10:53:46 +00:00
|
|
|
|
|
|
|
````
|
|
|
|
name = "Mwanji Ezana"
|
|
|
|
|
|
|
|
[address]
|
|
|
|
street = "123 A Street"
|
|
|
|
city = "AnyVille"
|
|
|
|
````
|
|
|
|
|
|
|
|
````java
|
2014-04-06 19:56:14 +00:00
|
|
|
class Address {
|
|
|
|
String street;
|
|
|
|
String city;
|
2013-02-28 10:53:46 +00:00
|
|
|
}
|
|
|
|
|
2014-04-06 19:56:14 +00:00
|
|
|
class User {
|
|
|
|
String name;
|
|
|
|
Address address;
|
2013-02-28 10:53:46 +00:00
|
|
|
}
|
|
|
|
````
|
|
|
|
|
|
|
|
````java
|
|
|
|
Toml toml = new Toml().parse(tomlFile);
|
|
|
|
User user = toml.to(User.class);
|
2014-04-06 19:56:14 +00:00
|
|
|
|
|
|
|
assert user.name.equals("Mwanji Ezana");
|
|
|
|
assert user.address.street.equals("123 A Street");
|
2013-02-28 10:53:46 +00:00
|
|
|
````
|
|
|
|
|
|
|
|
When defaults are present, a shallow merge is performed.
|
|
|
|
|
2014-04-06 19:56:14 +00:00
|
|
|
### Key names
|
|
|
|
|
|
|
|
1. Create a `com.moandjiezana.toml.Toml` instance
|
|
|
|
2. Call the `parse` method of your choice
|
|
|
|
3. Use the getters to retrieve the data
|
|
|
|
|
|
|
|
````java
|
|
|
|
Toml toml = new Toml().parse(getTomlFile()); // throws an Exception if the TOML is incorrect
|
|
|
|
|
|
|
|
String title = toml.getString("title"); // if a key doesn't exist, returns null
|
|
|
|
Boolean enabled = toml.getBoolean("database.enabled"); // gets the value of enabled from the database key group
|
|
|
|
Toml servers = toml.getKeyGroup("servers"); // returns a new Toml instance containing only the key group's values
|
|
|
|
````
|
|
|
|
|
|
|
|
### Defaults
|
|
|
|
|
|
|
|
The constructor can be given a set of default values that will be used if necessary.
|
|
|
|
|
|
|
|
````java
|
|
|
|
Toml defaults = new Toml().parse("a = 2\nb = 3");
|
|
|
|
Toml toml = new Toml(defaults).parse("a = 1");
|
|
|
|
|
|
|
|
Long a = toml.getLong("a"); // returns 1, not 2
|
|
|
|
Long b = toml.getLong("b"); // returns 3
|
|
|
|
Long c = toml.getLong("c"); // returns null
|
|
|
|
````
|
|
|
|
|
2013-02-26 19:57:29 +00:00
|
|
|
## TODO
|
|
|
|
|
2013-03-22 08:00:37 +00:00
|
|
|
* Fail on invalid definitions
|
2013-02-26 19:57:29 +00:00
|
|
|
|
2014-04-07 11:10:44 +00:00
|
|
|
## Coming in 0.2.0
|
|
|
|
|
|
|
|
### Table arrays
|
|
|
|
|
2014-04-07 12:38:34 +00:00
|
|
|
Table arrays are mapped to `List`s with `Toml#getTables(String)`. Custom classes and nested table arrays are supported.
|
2014-04-07 11:10:44 +00:00
|
|
|
|
|
|
|
````
|
|
|
|
[[products]]
|
|
|
|
name = "Hammer"
|
|
|
|
sku = 738594937
|
|
|
|
|
|
|
|
[[products]]
|
|
|
|
name = "Nail"
|
|
|
|
sku = 284758393
|
|
|
|
color = "gray"
|
|
|
|
````
|
|
|
|
|
|
|
|
````java
|
|
|
|
Toml toml = new Toml().parse(getTomlFile());
|
|
|
|
|
|
|
|
List<Toml> tables = toml.getTables("products");
|
|
|
|
tables.get(1).getLong("sku"); // returns 284758393
|
|
|
|
````
|
|
|
|
|
2013-02-26 19:49:57 +00:00
|
|
|
## License
|
|
|
|
|
2013-02-26 19:57:29 +00:00
|
|
|
toml4j is copyright of Moandji Ezana and is licensed under the [MIT License](http://www.opensource.org/licenses/mit-license.php)
|
2013-02-26 19:49:57 +00:00
|
|
|
|