107 lines
3.5 KiB
107 lines
3.5 KiB
<h1>STF - Simple Tree Format</h1>
|
|
<p>
|
|
STF is a new file format to store a tree of values, just like XML and JSON can do. It has support for only 2 types: values and nodes. A node can have values and other nodes, allowing the creation of a tree format. A STF file itself is a node (the virtual root node). Nodes are a collection of other values and (child)nodes.
|
|
</p>
|
|
|
|
<h2>Usage</h2>
|
|
<p>
|
|
Nodes and values are named, the smallest name being "". We refer to the nodes with "" as name as unnamed nodes/values, but the same rules apply for the syntax; examples will follow, don't worry. Each name is followed by a ':' which signifies the end of the name (the name-terminator). The ':' is followed by either a '{' or a '"', which signifies the type of the name (the type-specifier): '{' are lists, '"' are values. The parser will extract and ignore anything in between the name-terminator and the type-specifier.
|
|
</p>
|
|
|
|
<h2>Examples</h2>
|
|
<h3>Starting easy</h3>
|
|
<p>
|
|
Here's an example of a very small STF file. It shows values and nodes and their syntax, without fancy stuff.
|
|
<pre>
|
|
name: "First value in the file"
|
|
childnode: {
|
|
value: "This is another value, inside a child node with the name "childnode"
|
|
}
|
|
</pre>
|
|
</p>
|
|
|
|
<h3>Comments</h3>
|
|
<p>
|
|
Don't want to have a very long descriptive name, but do want a bit of extra info? Comments (or anything really) can be place in between the name-terminator and the type-specifier.
|
|
<pre>
|
|
name: This text will be ignore by the parser "First value in the file."
|
|
childnode: This text will too, be ignored {
|
|
value: You probably already guessed it
|
|
|
|
But this text will to be ignored. Anything here is allowed, except for a type-specifier of course! ;-)
|
|
|
|
"This is another value, inside a child node with the name ""childnode""."
|
|
}
|
|
|
|
<h3>Getting more interesting</h3>
|
|
<p>
|
|
This example shows what characters are allowed inside names and values.
|
|
<pre>
|
|
firstnode: {
|
|
subnode: {
|
|
blah: "xyz"
|
|
blah: "names of values/childs don't have to be unique!"
|
|
}
|
|
}
|
|
secondnode: {
|
|
name with space: "names can contain spaces"
|
|
name
|
|
with
|
|
newlines: "names can contain newlines"
|
|
blah: "values can contain
|
|
newlines too!"
|
|
}
|
|
</pre>
|
|
</p>
|
|
<p>
|
|
NOTE: Take a look at the other .stf files included with this project for more examples.
|
|
</p>
|
|
|
|
<h1>STFU - Simple Tree Format Utility</h1>
|
|
<p>
|
|
STFU is the first C++ implementation for STF.
|
|
</p>
|
|
<p>
|
|
This example will show you some of the basic features of STFU:
|
|
<pre>
|
|
#include <iostream>
|
|
#include "stf.hpp"
|
|
using namespace std;
|
|
using stfu::node;
|
|
|
|
int main(){
|
|
node n,f;
|
|
if (n.read("blah.stf")){ //could also do: 'if ("blah.stf" >> n){'
|
|
cout << n.value("test"); // Read a value
|
|
|
|
cout << n.child("subnode").value("hi",0); //Read the first value
|
|
cout << n.child("subnode").value("hi",1); //Read the second value
|
|
|
|
n.child("subnode").value("test") = "blah"; //Add a value
|
|
|
|
if (f.read("another_file.stf")){
|
|
n.child("secondnode") = f; //add a child
|
|
}
|
|
|
|
n.write("blah.stf"); //Write changes back to the file
|
|
// "blah.stf" << n; would also be valid.
|
|
|
|
cout << n; //output the file to the console instead of a file.
|
|
|
|
} else {
|
|
cout << "ERROR!" << endl;
|
|
}
|
|
}
|
|
//NOTE: For more detailed examples, please take a look at the 'main.cpp' file of this project.
|
|
</pre>
|
|
</p>
|
|
<p>
|
|
As you see, the .child() and .value() functions can be used to read, create and change values/childs. More advanced functions are available, 'main.cpp' contains examples to explain all of them.
|
|
</p>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|