diff options
author | ShadowNinja <shadowninja@minetest.net> | 2014-10-24 15:01:46 -0400 |
---|---|---|
committer | ShadowNinja <shadowninja@minetest.net> | 2014-10-24 16:45:10 -0400 |
commit | 796aa3870d5cd45696cb253024aa75e8bbc2b462 (patch) | |
tree | ea17e9c6e87af555427f1ec9c8ce9bce2be66c57 /WorldEdit API.md | |
parent | 70c24c9501c691d85bbe267ee79547fb490e6c00 (diff) |
Clean up serialization
* Adds a header to serialized data (to make version checking sane).
* Removes the duplicate deserialization for `worldedit.deserialize` and `worldedit.allocate`.
* Optimizes `worldedit.deserialize` by only deserializing the data once.
* Makes some fields optional.
* Cleans up the comments and a little of the code style.
Diffstat (limited to 'WorldEdit API.md')
-rw-r--r-- | WorldEdit API.md | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/WorldEdit API.md b/WorldEdit API.md index 8f4b7d2..af7138b 100644 --- a/WorldEdit API.md +++ b/WorldEdit API.md @@ -195,29 +195,30 @@ Serialization -------------
Contained in serialization.lua, this module allows regions of nodes to be serialized and deserialized to formats suitable for use outside MineTest.
-### version = worldedit.valueversion(value)
+### version, extra_fields, content = worldedit.read_header(value)
-Determines the version of serialized data `value`.
+Reads the header from serialized data `value`.
-Returns the version as a positive integer or 0 for unknown versions.
+Returns the version as a positive integer (nil for unknown versions),
+extra header fields (nil if not supported), and the content after the header.
### data, count = worldedit.serialize(pos1, pos2)
Converts the region defined by positions `pos1` and `pos2` into a single string.
-Returns the serialized data and the number of nodes serialized.
+Returns the serialized data and the number of nodes serialized, or nil.
-### pos1, pos2, count = worldedit.allocate(originpos, value)
+### pos1, pos2, count = worldedit.allocate(origin_pos, value)
-Determines the volume the nodes represented by string `value` would occupy if deserialized at `originpos`.
+Determines the volume the nodes represented by string `value` would occupy if deserialized at `origin_pos`.
-Returns the two corner positions and the number of nodes.
+Returns the two corner positions and the number of nodes, or nil.
-### count = worldedit.deserialize(originpos, value)
+### count = worldedit.deserialize(origin_pos, value)
-Loads the nodes represented by string `value` at position `originpos`.
+Loads the nodes represented by string `value` at position `origin_pos`.
-Returns the number of nodes deserialized.
+Returns the number of nodes deserialized or nil.
Code
----
@@ -233,4 +234,4 @@ Returns an error if the code fails or nil otherwise. Executes `code` as a Lua chunk in the global namespace with the variable `pos` available, for each node in a region defined by positions `pos1` and `pos2`.
-Returns an error if the code fails or nil otherwise.
\ No newline at end of file +Returns an error if the code fails or nil otherwise.
|