Add SerializeBuffered function
Add a SerializeBuffered function to provide full tree serialization support to non-seeking writers.
This commit is contained in:
parent
54d958d480
commit
b2cc3359a8
3 changed files with 36 additions and 22 deletions
33
SBHPFv1/buffered_serializer.go
Normal file
33
SBHPFv1/buffered_serializer.go
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
package sbhpfv1
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
|
||||||
|
"git.zervo.org/FLUX/GoSBHPF/pkg/seekablebuffer"
|
||||||
|
)
|
||||||
|
|
||||||
|
// SerializeNodeBuffered serializes a node object into a SBHPF node.
|
||||||
|
// It is a wrapper around SerializeNode that temporarily stores the serialized nodes in a seekable memory buffer.
|
||||||
|
// This provides serialization compatibility with non-seekable writers, at the cost of increased memory usage.
|
||||||
|
func SerializeNodeBuffered(w io.Writer, node *Node) error {
|
||||||
|
buf := &seekablebuffer.Buffer{}
|
||||||
|
if err := SerializeNode(buf, node); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := io.Copy(w, buf)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// SerializeBuffered serializes a root node object into a complete SBHPF tree.
|
||||||
|
// It is a wrapper around Serialize that temporarily stores the serialized data in a seekable memory buffer.
|
||||||
|
// This provides serialization compatibility with non-seekable writers, at the cost of increased memory usage.
|
||||||
|
func SerializeBuffered(w io.Writer, node *Node) error {
|
||||||
|
buf := &seekablebuffer.Buffer{}
|
||||||
|
if err := Serialize(buf, node); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := io.Copy(w, buf)
|
||||||
|
return err
|
||||||
|
}
|
|
@ -6,8 +6,9 @@ import (
|
||||||
"io"
|
"io"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Serialize writes a full binary property file from a root node object.
|
// Serialize serializes a root node object into a complete SBHPF tree.
|
||||||
// This includes the start headers necessary for proper deserialization of raw files.
|
// This includes the start headers necessary for proper deserialization of raw files.
|
||||||
|
// NOTE: Writer must support seeking. If this is not possible, use the SerializeBuffered wrapper.
|
||||||
func Serialize(w io.Writer, root *Node) error {
|
func Serialize(w io.Writer, root *Node) error {
|
||||||
// Write file header (version + feature flag).
|
// Write file header (version + feature flag).
|
||||||
if err := binary.Write(w, binary.LittleEndian, uint8(FormatVersion)); err != nil {
|
if err := binary.Write(w, binary.LittleEndian, uint8(FormatVersion)); err != nil {
|
||||||
|
@ -22,7 +23,7 @@ func Serialize(w io.Writer, root *Node) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// SerializeNode serializes a node object into a SBHPF node.
|
// SerializeNode serializes a node object into a SBHPF node.
|
||||||
// NOTE: Writer must support seeking. If this is not possible, use SerializeNodeStream.
|
// NOTE: Writer must support seeking. If this is not possible, use the SerializeNodeBuffered wrapper.
|
||||||
func SerializeNode(w io.Writer, node *Node) error {
|
func SerializeNode(w io.Writer, node *Node) error {
|
||||||
// Reserve space for node size ("Node Size" node header).
|
// Reserve space for node size ("Node Size" node header).
|
||||||
sizePos := getWriterPosition(w) // Save current position.
|
sizePos := getWriterPosition(w) // Save current position.
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
package sbhpfv1
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
|
|
||||||
"git.zervo.org/FLUX/GoSBHPF/pkg/seekablebuffer"
|
|
||||||
)
|
|
||||||
|
|
||||||
// SerializeNodeStream serializes a node object into a SBHPF node.
|
|
||||||
// It is a wrapper around SerializeNode that temporarily stores the serialized nodes in a seekable memory buffer.
|
|
||||||
// This is less efficient, but provides compatibility with writers that lack seeking support.
|
|
||||||
func SerializeNodeStream(w io.Writer, node *Node) error {
|
|
||||||
buf := &seekablebuffer.Buffer{}
|
|
||||||
if err := SerializeNode(buf, node); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
_, err := io.Copy(w, buf)
|
|
||||||
return err
|
|
||||||
}
|
|
Loading…
Add table
Reference in a new issue