Monkey configuration files are unique on it's schema, they have been designed to force the user to keep a simple and readable format, if for some reason some of the Schema rules are broken, the Server will not start up and will raise an error.
HTTP Server configuration files tends to grow with the time when new Virtual Hosts are added or just because some rules are added. It's not a surprise to find spaghetti configuration files when playing with well known HTTP servers.
Monkey implements three basic concepts that aims to address the spaghetti problem:
A simple example of a configuration file is as follows:
[SERVER]
# This is a commented line
Port 2001
KeepAlive on
A section is defined by a name or title inside brackets. Looking at the example above a Server section have been set using [SERVER] definition. Section rules:
A section may contain Entries, an entry is defined by a line of text that contains a Key and a Value, using the above example, the [SERVER] section contains two entries, one is the key Port with value 2001 and the other the key KeepAlive with the value on. Entries rules:
Also commented lines are set prefixing the # character, those lines are not processed but they must be indented too.
Monkey configuration files are based in a strict Indented Mode, that means that each configuration file must follow the same pattern of alignment from left to right when writing text. Monkey by default suggest an indentation level of four spaces from left to right. Example:
[FIRST_SECTION]
# This is a commented line
Key1 some value
Key2 another value
# more comments
[SECOND_SECTION]
KeyN 3.14
As you can see there are two sections with multiple entries and comments, note also that empty lines are allowed and they do not need to be indented.