summaryrefslogtreecommitdiff
path: root/prism/util/pm_buffer.h
diff options
context:
space:
mode:
Diffstat (limited to 'prism/util/pm_buffer.h')
-rw-r--r--prism/util/pm_buffer.h105
1 files changed, 89 insertions, 16 deletions
diff --git a/prism/util/pm_buffer.h b/prism/util/pm_buffer.h
index 69edb1525a..a2bccb3d00 100644
--- a/prism/util/pm_buffer.h
+++ b/prism/util/pm_buffer.h
@@ -9,52 +9,125 @@
#include <stdlib.h>
#include <string.h>
-// A pm_buffer_t is a simple memory buffer that stores data in a contiguous
-// block of memory. It is used to store the serialized representation of a
-// prism tree.
+/**
+ * A pm_buffer_t is a simple memory buffer that stores data in a contiguous
+ * block of memory.
+ */
typedef struct {
+ /** The length of the buffer in bytes. */
size_t length;
+
+ /** The capacity of the buffer in bytes that has been allocated. */
size_t capacity;
+
+ /** A pointer to the start of the buffer. */
char *value;
} pm_buffer_t;
-// Return the size of the pm_buffer_t struct.
+/**
+ * Return the size of the pm_buffer_t struct.
+ *
+ * @returns The size of the pm_buffer_t struct.
+ */
PRISM_EXPORTED_FUNCTION size_t pm_buffer_sizeof(void);
-// Initialize a pm_buffer_t with the given capacity.
+/**
+ * Initialize a pm_buffer_t with the given capacity.
+ *
+ * @param buffer The buffer to initialize.
+ * @param capacity The capacity of the buffer.
+ * @returns True if the buffer was initialized successfully, false otherwise.
+ */
bool pm_buffer_init_capacity(pm_buffer_t *buffer, size_t capacity);
-// Initialize a pm_buffer_t with its default values.
+/**
+ * Initialize a pm_buffer_t with its default values.
+ *
+ * @param buffer The buffer to initialize.
+ * @returns True if the buffer was initialized successfully, false otherwise.
+ */
PRISM_EXPORTED_FUNCTION bool pm_buffer_init(pm_buffer_t *buffer);
-// Return the value of the buffer.
+/**
+ * Return the value of the buffer.
+ *
+ * @param buffer The buffer to get the value of.
+ * @returns The value of the buffer.
+ */
PRISM_EXPORTED_FUNCTION char * pm_buffer_value(pm_buffer_t *buffer);
-// Return the length of the buffer.
+/**
+ * Return the length of the buffer.
+ *
+ * @param buffer The buffer to get the length of.
+ * @returns The length of the buffer.
+ */
PRISM_EXPORTED_FUNCTION size_t pm_buffer_length(pm_buffer_t *buffer);
-// Append the given amount of space as zeroes to the buffer.
+/**
+ * Append the given amount of space as zeroes to the buffer.
+ *
+ * @param buffer The buffer to append to.
+ * @param length The amount of space to append and zero.
+ */
void pm_buffer_append_zeroes(pm_buffer_t *buffer, size_t length);
-// Append a formatted string to the buffer.
+/**
+ * Append a formatted string to the buffer.
+ *
+ * @param buffer The buffer to append to.
+ * @param format The format string to append.
+ * @param ... The arguments to the format string.
+ */
void pm_buffer_append_format(pm_buffer_t *buffer, const char *format, ...) PRISM_ATTRIBUTE_FORMAT(2, 3);
-// Append a string to the buffer.
+/**
+ * Append a string to the buffer.
+ *
+ * @param buffer The buffer to append to.
+ * @param value The string to append.
+ * @param length The length of the string to append.
+ */
void pm_buffer_append_string(pm_buffer_t *buffer, const char *value, size_t length);
-// Append a list of bytes to the buffer.
+/**
+ * Append a list of bytes to the buffer.
+ *
+ * @param buffer The buffer to append to.
+ * @param value The bytes to append.
+ * @param length The length of the bytes to append.
+ */
void pm_buffer_append_bytes(pm_buffer_t *buffer, const uint8_t *value, size_t length);
-// Append a single byte to the buffer.
+/**
+ * Append a single byte to the buffer.
+ *
+ * @param buffer The buffer to append to.
+ * @param value The byte to append.
+ */
void pm_buffer_append_byte(pm_buffer_t *buffer, uint8_t value);
-// Append a 32-bit unsigned integer to the buffer.
+/**
+ * Append a 32-bit unsigned integer to the buffer as a variable-length integer.
+ *
+ * @param buffer The buffer to append to.
+ * @param value The integer to append.
+ */
void pm_buffer_append_varint(pm_buffer_t *buffer, uint32_t value);
-// Append one buffer onto another.
+/**
+ * Concatenate one buffer onto another.
+ *
+ * @param destination The buffer to concatenate onto.
+ * @param source The buffer to concatenate.
+ */
void pm_buffer_concat(pm_buffer_t *destination, const pm_buffer_t *source);
-// Free the memory associated with the buffer.
+/**
+ * Free the memory associated with the buffer.
+ *
+ * @param buffer The buffer to free.
+ */
PRISM_EXPORTED_FUNCTION void pm_buffer_free(pm_buffer_t *buffer);
#endif