Created an informative README, fixed issues with boolean, made the

serialization slightly more efficient.
This commit is contained in:
jsrobson10 2019-07-09 21:53:05 +10:00
parent 42a1818a5c
commit a5619d0f16
5 changed files with 299 additions and 31 deletions

226
README.md
View File

@ -0,0 +1,226 @@
#Binary Data Format
###Overview:
Binary Data Format (or BDF) is designed to store data in a tag-like binary structure,
like Notch's NBT format, but also open source and free like JSON. The format is
fast and allows multiple data types, it uses 32-bit integers, so BDF files can
be fast and work well on 32-bit systems, but have a maximum size of 2 GB.
BDF allows human readable serialization to see what is going on for debugging
purposes, but it currently can't parse the result to an object.
###Datatypes:
- Boolean
- Integer
- Long
- Short
- Byte
- Double
- Float
- String
- Array
- Named List
- Empty
###Creating an object
You will need to create a new object to store any data, use a `BdfObject` instance.
You can input serialized data into `BdfObject` via a `BdfDatabase`.
```java
// New BDF object
BdfObject bdf = new BdfObject();
// Get an integer
int v = bdf.getInteger();
// Set an integer
bdf.setInteger(5);
// Get the type of variable of the object
int type = bdf.getType();
// Compare the type with a type from BdfTypes
if(type == BdfTypes.INTEGER)
{
}
// Serialize the BDF object
byte[] data = bdf.serialize().getBytes();
// Load another BDF object with the serialized bytes
BdfObject bdf2 = new BdfObject(new BdfDatabase(data));
```
A `BdfFileManager`
instance can be used in the same way as a `BdfObject`, but it also needs a String parameter
for the path of the file. The file can be written with `BdfFileManager.saveDatabase()`.
A `BdfFileManager` is an instance of `BdfObject`, a `BdfFileManager` can be casted to
a `BdfObject`.
```java
// Open a file
BdfFileManager bdf = new BdfFileManager("file.bdf");
// Save the database
bdf.saveDatabase();
// The file can be casted to a BdfObject
BdfObject bdf2 = (BdfObject) bdf;
// Bdf
System.out.println(bdf instanceof BdfObject); // true
```
###Arrays
Arrays can be used to store lists of information, they hold `BdfObject`.
The array is called with `new BdfArray()`. It can hold information, get
the size of the array with `BdfArray.size()`, remove elements with
`BdfArray.remove(index)`, set indexes with `BdfArray.set(index, BdfObject)`,
and add elements with `BdfArray.add(BdfObject)`. Arrays also
have support for Iterators and are an instance of `Iterable`.
```java
// New BDF Object
BdfObject bdf = new BdfObject();
// New BDF Array
BdfArray array = new BdfArray();
// Size
int size = array.size();
// Remove
array.remove(3); // Could be any number
// Set - Could be any number with any object
array.set(4, BdfObject.with("A String"));
// Add - Could be any object
array.add(BdfObject.with(53));
// Set the array to the bdf object
bdf.setArray(array);
// Iterate over an array
for(BdfObject o : array)
{
}
```
###Named Lists
Named lists can be used to store data under strings,
to be used like variables in a program. A named list
can be created with `new BdfNamedList()` and it
has the ability to set with `BdfNamedList.set(String, BdfObject)`,
remove with `BdfNamedList.remove(String)`, and check
for a key with `BdfNamedList.contains(String)`. It also has
features to get all the keys with `BdfNamedList.getKeys()`.
Named lists also have Iterator support and are an instance of
`Iterable`.
```java
// New bdf named list
BdfNamedList list = new BdfNamedList();
// Set an element with a value
list.set("key1", BdfObject.with(5));
// Get an elements value
int v = list.get("key1").getInteger();
// Check if an element exists
boolean has_key = list.contains("key1");
// Get the lists keys
String[] keys = list.getKeys();
// Iterate over the lists keys
for(String key : list)
{
}
```
###Example BDF program
```java
// Create a new BdfObject instance
BdfObject bdf = new BdfObject();
// Create a named list
BdfNamedList bdf_nl = new BdfNamedList();
// Add some variables to the named list
bdf_nl.set("boolean", BdfObject.with(true));
bdf_nl.set("an_int", BdfObject.with((int)53));
bdf_nl.set("double", new BdfObject().setDouble(632.5));
// Output some checks on BdfNamedList
System.out.println(bdf_nl.contains("an_int")); // true
System.out.println(bdf_nl.contains("this_dosn't_exist")); // false
// Create an array
BdfArray bdf_array = new BdfArray();
// Add some values to the array
bdf_array.add(BdfObject.with("Hello, World!"));
bdf_array.add(BdfObject.with(1234567890L));
bdf_array.set(1, BdfObject.with((short)432));
// Output the size of the array
System.out.println(bdf_array.size()); // 2
// Output the type of the 2nd item in the array, value types are in BdfTypes
System.out.println(bdf_array.get(1).getType()); // 3 (BdfTypes.SHORT)
// Save the array to the named list
bdf_nl.set("array", BdfObject.with(bdf_array));
// Set the named list to the bdf object
bdf.setNamedList(bdf_nl);
// Serialize the data
byte[] bdf_data = bdf.serialize().getBytes();
// Load the serialized data
BdfObject bdf2 = new BdfObject(new BdfDatabase(bdf_data));
// Show the human readable serialized data
System.out.println(bdf2.serializeHumanReadable()); // {"boolean": true, "an_int": 53I, "double": 632.5D, "array": ["Hello, World!", 432S]}
// Show the value of the boolean in the named list
System.out.println(bdf2.getNamedList().get("boolean").getBoolean()); // true
// Show the value of item 0 in the array
System.out.println(bdf2.getNamedList().get("array").getArray().get(0).getString()); // Hello, World!
// Check if the double exists
System.out.println(bdf2.getNamedList().contains("double")); // true
// Remove the double from the named list
bdf2.getNamedList().remove("double");
// Check if the double exists
System.out.println(bdf2.getNamedList().contains("double")); // false
```

View File

@ -1,6 +1,6 @@
package bdf; package bdf;
import bdf.file.BdfFileManager; import bdf.data.BdfDatabase;
import bdf.types.BdfArray; import bdf.types.BdfArray;
import bdf.types.BdfNamedList; import bdf.types.BdfNamedList;
import bdf.types.BdfObject; import bdf.types.BdfObject;
@ -9,28 +9,67 @@ public class Tests {
public static void main(String[] args) public static void main(String[] args)
{ {
BdfFileManager bdf = new BdfFileManager("db/file.db"); // Create a new BdfObject instance
BdfObject bdf = new BdfObject();
// Create a named list
BdfNamedList bdf_nl = new BdfNamedList(); BdfNamedList bdf_nl = new BdfNamedList();
bdf_nl.set("greeting", BdfObject.getNew("Hello, World!"));
bdf_nl.set("integer", BdfObject.getNew(21)); // Add some variables to the named list
bdf_nl.set("integer", BdfObject.getNew(52)); bdf_nl.set("boolean", BdfObject.with(true));
bdf_nl.set("\"test\"", BdfObject.getNew((byte) 69)); bdf_nl.set("an_int", BdfObject.with((int)53));
bdf_nl.set("double", new BdfObject().setDouble(632.5));
// Output some checks on BdfNamedList
System.out.println(bdf_nl.contains("an_int")); // true
System.out.println(bdf_nl.contains("this_dosn't_exist")); // false
// Create an array
BdfArray bdf_array = new BdfArray(); BdfArray bdf_array = new BdfArray();
bdf_array.add(BdfObject.getNew(61));
bdf_array.add(BdfObject.getNew(42.0d)); // Add some values to the array
bdf_array.add(BdfObject.getNew(67F)); bdf_array.add(BdfObject.with("Hello, World!"));
bdf_array.add(BdfObject.getNew("hello!")); bdf_array.add(BdfObject.with(1234567890L));
bdf_array.add(BdfObject.getNew()); bdf_array.set(1, BdfObject.with((short)432));
bdf_array.add(BdfObject.getNew("\"hi\""));
bdf_nl.set("array", BdfObject.getNew(bdf_array)); // Output the size of the array
System.out.println(bdf_array.size()); // 2
// Output the type of the 2nd item in the array, value types are in BdfTypes
System.out.println(bdf_array.get(1).getType()); // 3 (BdfTypes.SHORT)
// Save the array to the named list
bdf_nl.set("array", BdfObject.with(bdf_array));
// Set the named list to the bdf object
bdf.setNamedList(bdf_nl); bdf.setNamedList(bdf_nl);
bdf.saveDatabase(); // Serialize the data
byte[] bdf_data = bdf.serialize().getBytes();
// Load the serialized data
BdfObject bdf2 = new BdfObject(new BdfDatabase(bdf_data));
// Show the human readable serialized data
System.out.println(bdf2.serializeHumanReadable()); // {"boolean": true, "an_int": 53I, "double": 632.5D, "array": ["Hello, World!", 432S]}
// Show the value of the boolean in the named list
System.out.println(bdf2.getNamedList().get("boolean").getBoolean()); // true
// Show the value of item 0 in the array
System.out.println(bdf2.getNamedList().get("array").getArray().get(0).getString()); // Hello, World!
// Check if the double exists
System.out.println(bdf2.getNamedList().contains("double")); // true
// Remove the double from the named list
bdf2.getNamedList().remove("double");
// Check if the double exists
System.out.println(bdf2.getNamedList().contains("double")); // false
System.out.println(bdf.serializeHumanReadable());
} }
} }

View File

@ -101,6 +101,11 @@ public class BdfArray implements IBdfType
return elements.get(index); return elements.get(index);
} }
public BdfArray set(int index, BdfObject element) {
elements.set(index, element);
return this;
}
public int size() { public int size() {
return elements.size(); return elements.size();
} }

View File

@ -15,7 +15,7 @@ public class BdfNamedList implements IBdfType
public BdfObject object; public BdfObject object;
} }
ArrayList<Element> elements = new ArrayList<Element>(); protected ArrayList<Element> elements = new ArrayList<Element>();
public BdfNamedList() { public BdfNamedList() {
} }

View File

@ -73,43 +73,43 @@ public class BdfObject implements IBdfType
database = new BdfDatabase(); database = new BdfDatabase();
} }
public static BdfObject getNew(int v) { public static BdfObject with(int v) {
return (new BdfObject()).setInteger(v); return (new BdfObject()).setInteger(v);
} }
public static BdfObject getNew(byte v) { public static BdfObject with(byte v) {
return (new BdfObject()).setByte(v); return (new BdfObject()).setByte(v);
} }
public static BdfObject getNew(boolean v) { public static BdfObject with(boolean v) {
return (new BdfObject()).setBoolean(v); return (new BdfObject()).setBoolean(v);
} }
public static BdfObject getNew(float v) { public static BdfObject with(float v) {
return (new BdfObject()).setFloat(v); return (new BdfObject()).setFloat(v);
} }
public static BdfObject getNew(double v) { public static BdfObject with(double v) {
return (new BdfObject()).setDouble(v); return (new BdfObject()).setDouble(v);
} }
public static BdfObject getNew(long v) { public static BdfObject with(long v) {
return (new BdfObject()).setLong(v); return (new BdfObject()).setLong(v);
} }
public static BdfObject getNew(short v) { public static BdfObject with(short v) {
return (new BdfObject()).setShort(v); return (new BdfObject()).setShort(v);
} }
public static BdfObject getNew(String v) { public static BdfObject with(String v) {
return (new BdfObject()).setString(v); return (new BdfObject()).setString(v);
} }
public static BdfObject getNew(BdfArray v) { public static BdfObject with(BdfArray v) {
return (new BdfObject()).setArray(v); return (new BdfObject()).setArray(v);
} }
public static BdfObject getNew(BdfNamedList v) { public static BdfObject with(BdfNamedList v) {
return (new BdfObject()).setNamedList(v); return (new BdfObject()).setNamedList(v);
} }
@ -126,7 +126,7 @@ public class BdfObject implements IBdfType
} }
public boolean getBoolean() { public boolean getBoolean() {
return database.getByte(0) == 0x00; return database.getByte(0) == 0x01;
} }
public double getDouble() { public double getDouble() {
@ -219,14 +219,12 @@ public class BdfObject implements IBdfType
public BdfObject setArray(BdfArray value) { public BdfObject setArray(BdfArray value) {
this.type = BdfTypes.ARRAY; this.type = BdfTypes.ARRAY;
this.database = value.serialize();
this.object = value; this.object = value;
return this; return this;
} }
public BdfObject setNamedList(BdfNamedList value) { public BdfObject setNamedList(BdfNamedList value) {
this.type = BdfTypes.NAMED_LIST; this.type = BdfTypes.NAMED_LIST;
this.database = value.serialize();
this.object = value; this.object = value;
return this; return this;
} }