-
Notifications
You must be signed in to change notification settings - Fork 88
helper: Serialization
pepej edited this page Apr 20, 2021
·
2 revisions
helper provides a few classes with are useful when trying to serialize plugin data. It makes use of Google's GSON to convert from Java Objects to JSON.
-
Position
- similar to Bukkit's location, but without pitch/yaw -
BlockPosition
- the location of a block within a world -
ChunkPosition
- the location of a chunk within a world -
Region
- the area bounded by two Positions -
BlockRegion
- the area bounded by two BlockPositions -
ChunkRegion
- the area bounded by two ChunkPositions -
Direction
- the yaw and pitch -
Point
- a position + a direction
And finally, Serializers
, containing serializers for ItemStacks and Inventories.
There is also an abstraction for conducting file I/O. FileStorageHandler
is capable of handling the initial creation of storage files, as well as automatically creating backups and saving when the server stops.
It's as simple as creating a class to handle serialization/deserialization, and then calling a method when you want to load/save data.
public class DemoStorageHandler extends FileStorageHandler<Map<String, String>> {
private static final Splitter SPLITTER = Splitter.on('=');
public DemoStorageHandler(JavaPlugin plugin) {
super("demo", ".json", plugin.getDataFolder());
}
@Override
protected Map<String, String> readFromFile(Path path) {
Map<String, String> data = new HashMap<>();
try (BufferedReader reader = Files.newBufferedReader(path, StandardCharsets.UTF_8)) {
// read all the data from the file.
reader.lines().forEach(line -> {
Iterator<String> it = SPLITTER.split(line).iterator();
data.put(it.next(), it.next());
});
} catch (IOException e) {
e.printStackTrace();
}
return data;
}
@Override
protected void saveToFile(Path path, Map<String, String> data) {
try (BufferedWriter writer = Files.newBufferedWriter(path, StandardCharsets.UTF_8)) {
for (Map.Entry<String, String> e : data.entrySet()) {
writer.write(e.getKey() + "=" + e.getValue());
writer.newLine();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
Then, to save/load, just create an instance of the handler, and use the provided methods.
DemoStorageHandler handler = new DemoStorageHandler(this);
handler.save(ImmutableMap.of("some key", "some value"));
// or, to save a backup of the previous file too
handler.saveAndBackup(ImmutableMap.of("some key", "some value"));
helper also provides a handler which uses Gson to serialize the data.
GsonStorageHandler<List<String>> gsonHandler = new GsonStorageHandler<>("data", ".json", getDataFolder(), new TypeToken<List<String>>(){});
gsonHandler.save(ImmutableList.of("some key", "some value"));
- Events
- Scheduler
- Promise
- Metadata
- Commands
- Terminables
- Messenger
- Extended Plugin
- Serialization
- Menu