Skip to content

C06A/KotON

Repository files navigation

KotON

"Kotlin Object Notation" (Pronounced like "cotton") is Kotlin DSL to create a JSON document

license Download Latest

In order to use this library include in your build.gradle.kts file follow

Gradle

repositories {
    jcenter()
}

dependencies {
    compile("com.helpchoice.kotlin:koton:1.1.6")
}

Maven

<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.

Simple values

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\""

Array value

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}]

Compound value

Overloaded function taking single lambda creates the instance defined in that lambda.

Each element inside lambda could be one of:

  1. a map from String to simple value (using to keyword)
  2. a lambda defining compound value with String prefix
  3. 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.

Using KotON instance

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.

About

Kotlin DSL to create a JSON document

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages