Int32Buffer¶
Inherits: RefCounted
Namespace: TauPlot
Ring buffer that stores int values (32-bit) with a fixed capacity.
Description¶
Int32Buffer stores a sequence of int values (32-bit) in a ring buffer of fixed capacity. When the buffer is full, appending a new value drops the oldest one.
All read and write operations use logical indices. Index 0 refers to the oldest value currently in the buffer. Index size()- 1 refers to the most recently appended one. Logical indices shift when the buffer wraps: after a new value is appended into a full buffer, every index decreases by one.
The buffer is pre-allocated at construction and does not resize unless set_capacity() is called explicitly.
Example¶
# Ring buffer with a capacity of 128 integers (32-bit).
var shapes := TauPlot.Int32Buffer.new(128)
# Append one integer
shapes.append_value(42)
Notes¶
-
Default value fills unused slots. At construction and after
clear(), every slot is filled withp_default_value. Default:-1, which is the conventional sentinel meaning "unset" in contexts such asScatterVisualAttributes.shape_buffer. -
Out-of-range access logs an error.
get_value(),set_value(), andset_values()log an error and return early when the buffer is empty or the index is out of range. -
append_value()andappend_values()always succeed. They never reject input. When the buffer is full, the oldest value is silently overwritten. The return value indicates how many existing values were overwritten.
Constructor¶
new()¶
Creates an empty buffer with the given capacity. The buffer is ready to use immediately after construction.
Parameters
p_capacity: intMaximum number ofintvalues the buffer can hold. Values below1are clamped to1.p_default_value: intValue used to fill unused slots at construction and afterclear(). Default:-1.
Methods¶
Introspection¶
get_capacity()¶
Returns the maximum number of values the buffer can hold.
size()¶
Returns the number of values currently stored. Always between 0 and get_capacity().
Reading and writing individual values¶
get_value()¶
Returns the int at the given logical index. Index 0 is the oldest value in the buffer, size()- 1 is the most recent. Logs an error and returns -1 if the buffer is empty or the index is out of range.
Parameters
p_logical_index: intLogical index in the range[0,size()- 1].
set_value()¶
Overwrites the int at the given logical index. Index 0 is the oldest value, size()- 1 is the most recent. Logs an error and does nothing if the buffer is empty or the index is out of range.
Parameters
p_logical_index: intLogical index in the range[0,size()- 1].p_value: intReplacement value.
set_values()¶
Overwrites a contiguous range of values starting at p_start_index. Writes as many values as fit from p_start_index to the end of the currently stored range. Returns the number of values actually written. Returns 0 without writing if p_values is empty, the buffer is empty, or p_start_index is out of range. Logs an error in the latter two cases.
Parameters
p_start_index: intLogical index of the first slot to overwrite. Must be in the range[0,size()- 1].p_values: PackedInt32ArrayReplacement values. Values beyondsize()- p_start_indexare ignored.
Appending values¶
append_value()¶
Appends one int to the buffer. If the buffer is full, the oldest value is overwritten. Returns 1 if an existing value was overwritten, 0 otherwise.
Parameters
p_value: intValue to append.
append_values()¶
Appends multiple int values to the buffer. If the buffer does not have enough free slots, the oldest values are overwritten. Returns the number of existing values overwritten. Returns 0 immediately if p_values is empty.
Parameters
p_values: PackedInt32ArrayValues to append, in order from oldest to newest.
Capacity¶
set_capacity()¶
Resizes the buffer to the new capacity. Values below 1 are clamped to 1. If the new capacity is smaller than the current sample count, the oldest values are dropped. If the new capacity is greater, existing values are preserved, new slots are pre-filled with the default value set at construction, and size() is unchanged. Does nothing if the new capacity equals the current one.
Parameters
p_capacity: intNew maximum number of values the buffer can hold.
Clearing data¶
clear()¶
Removes all stored values. The buffer capacity is unchanged. All slots are refilled with the p_default_value set at construction.
Related Classes¶
ColorBufferSibling ring buffer storingColorvalues.Float32BufferSibling ring buffer storingfloatvalues (32-bit).Float64BufferSibling ring buffer storingfloatvalues (64-bit).StringBufferSibling ring buffer storingStringvalues.