Structure SilcBuffer
NAME
typedef struct { ... } *SilcBuffer, SilcBufferStruct;
DESCRIPTION
SILC Buffer object. Following short description of the fields
of the buffer.
EXAMPLE
unsiged char *head;
Head of the allocated buffer. This is the start of the allocated
data area and remains as same throughout the lifetime of the buffer.
However, the end of the head area or the start of the currently valid
data area is variable.
--------------------------------
| head | data | tail |
--------------------------------
^ ^
Current head section in the buffer is sb->data - sb->head.
unsigned char *data;
Currently valid data area. This is the start of the currently valid
main data area. The data area is variable in all directions.
--------------------------------
| head | data | tail |
--------------------------------
^ ^
Current valid data area in the buffer is sb->tail - sb->data.
unsigned char *tail;
Tail of the buffer. This is the end of the currently valid data area
or start of the tail area. The start of the tail area is variable.
--------------------------------
| head | data | tail |
--------------------------------
^ ^
Current tail section in the buffer is sb->end - sb->tail.
unsigned char *end;
End of the allocated buffer. This is the end of the allocated data
area and remains as same throughout the lifetime of the buffer.
Usually this field is not needed except when checking the size
of the buffer.
--------------------------------
| head | data | tail |
--------------------------------
^
Length of the entire buffer is (ie. truelen) sb->end - sb->head.
Currently valid data area is considered to be the main data area in
the buffer. However, the entire buffer is of course valid data and can
be used as such. Usually head section of the buffer includes different
kind of headers or similar. Data section includes the main data of
the buffer. Tail section can be seen as a reserve space of the data
section. Tail section can be pulled towards end, and thus the data
section becomes larger.
SILC Buffer is not thread-safe. If the same SilcBuffer context must be
used in multithreaded environment concurrency control must be employed.
SOURCE
typedef struct SilcBufferObject {
unsigned char *head;
unsigned char *data;
unsigned char *tail;
unsigned char *end;
} *SilcBuffer, SilcBufferStruct;
|