"Kotlin Object Notation" (Pronounced like "cotton") is Kotlin DSL to create a JSON document
In order to use this library include in your build.gradle.kts
file follow
repositories {
jcenter()
}
dependencies {
compile("com.helpchoice.kotlin:koton:1.1.6")
}
<dependency>
<groupId>com.helpchoice.kotlin</groupId>
<artifactId>koton</artifactId>
<version>1.1.6</version>
</dependency>
This library was inspired by KTON. Unlike later KotON doesn't allocate both array and map for each instance. Instead it create instances of different classes to hold different type of data.
Also KotON provides the toJson() method to convert the whole structure into valid JSON string.
KotON object with parentheses returns the internal value. Depend on the instance that value may be simple Kotlin instance, array or map (see examples below). The expected type might be provided as generics before parentheses.
To create the root object call the kotON(...)
function. Depend on provided parameters
it will return instance of the different type.
For examples of different ways to define KotON instances check the kotlintest unit test in the project. Thous tests create instances of KotON and then validate them by comparing JSON output to expected String value.
Function kotON(...)
with simple parameter like Int
, Long
, Boolean
, etc. will create
an instance which will be represented in JSON as the value of that parameter.
Same function taking String
parameter get represented in JSON as double-quoted string.
For example:
kotON(42)<Int>() == 42
kotON(42).toJson() == "42"
kotON(3.14)<Float>() == 3.14
kotON(3.14).toJson() == "3.14"
kotON(true)<Boolean>() == true
kotON(true).toJson() == "true"
kotON("any text")<String>() == "any text"
kotON(true).toJson() == "\"any text\""
In order to create the array object call the function kotON(...)
with elements describing lambdas
separated with commas.
kotON(
{ "start" to 10; "stop" to 100; "step" to 10 },
{
"pattern" to "[a-zA-Z0-9]+"
"skip" to false
},
{ "validate" to false }
)
Function toJson()
on such instance will return follow String:
[{"start": 10, "stop": 100, "step": 10}, {"pattern": "[a-zA-Z0-9]+", "skip" to false}, {"validate": false}]
Overloaded function taking single lambda creates the instance defined in that lambda.
Each element inside lambda could be one of:
- a map from String to simple value (using
to
keyword) - a lambda defining compound value with String prefix
- an Array value prefixed by String
all these elements can appear in any order. For example:
kotON {
"number" to 25
"text" to "The text content"
"subElement" {
"subNumber" to 625
"subBool" to false
}
"subArray"[
{ "start" to 10; "stop" to 100; "step" to 10 },
{
"pattern" to "[a-zA-Z0-9]+"
"skip" to false
},
{ "validate" to false }
]
}
For other examples see Unit Tests.
KotON instant allows to access its content. Depend on specific type there are 3 ways to access content of the instance:
- empty parenthesis with generics type prefix -- returns the value holt by the instance.
- KotONElement holds a Map
- KotONArray holds an array
- KotVal holds an instance of type T
- instance of base class KotON holds
null
as a value
- square brackets with String inside returns the value from KotONElement by key
- square brackets with comma-separated Strings inside equivalent to applying indexes one-by-one in order
- square brackets with Int inside returns the value from KotONArray by index
- if provided index (String or Int) is not applicable to the type of the instance function throws IllegalAccessException
Once the instant get created one can convert it into JSON as a String
or by writing it into provided Writer object.
KotON class defines function toJson()
without Writer parameter to create a new String containing a JSON.
Both function can take 2 additional parameters (empty by default). First of them defines the string separating
elements and last one get appended to the separator for each inner object. Calling function with these 2
parameters allows to produce the "pretty" JSON if separator is a "new line" character string and increment is
a string with 2 or 4 spaces or TAB character. See unit test for example.