libfreerdp-core/transport: add stream_seal when a packet is received.
This commit is contained in:
parent
eea404e977
commit
8387380035
@ -35,8 +35,7 @@ typedef struct _STREAM STREAM;
|
|||||||
STREAM* stream_new(int size);
|
STREAM* stream_new(int size);
|
||||||
void stream_free(STREAM* stream);
|
void stream_free(STREAM* stream);
|
||||||
|
|
||||||
void
|
void stream_extend(STREAM* stream);
|
||||||
stream_extend(STREAM* stream);
|
|
||||||
#define stream_check_size(_s,_n) \
|
#define stream_check_size(_s,_n) \
|
||||||
while (_s->p - _s->data + (_n) > _s->size) \
|
while (_s->p - _s->data + (_n) > _s->size) \
|
||||||
stream_extend(_s)
|
stream_extend(_s)
|
||||||
@ -45,6 +44,7 @@ stream_extend(STREAM* stream);
|
|||||||
#define stream_set_pos(_s,_m) _s->p = _s->data + (_m)
|
#define stream_set_pos(_s,_m) _s->p = _s->data + (_m)
|
||||||
#define stream_seek(_s,_offset) _s->p += (_offset)
|
#define stream_seek(_s,_offset) _s->p += (_offset)
|
||||||
#define stream_rewind(_s,_offset) _s->p -= (_offset)
|
#define stream_rewind(_s,_offset) _s->p -= (_offset)
|
||||||
|
#define stream_seal(_s) _s->size = (_s->p - _s->data)
|
||||||
#define stream_get_mark(_s,_mark) _mark = _s->p
|
#define stream_get_mark(_s,_mark) _mark = _s->p
|
||||||
#define stream_set_mark(_s,_mark) _s->p = _mark
|
#define stream_set_mark(_s,_mark) _s->p = _mark
|
||||||
#define stream_get_head(_s) _s->data
|
#define stream_get_head(_s) _s->data
|
||||||
@ -52,6 +52,7 @@ stream_extend(STREAM* stream);
|
|||||||
#define stream_get_length(_s) (_s->p - _s->data)
|
#define stream_get_length(_s) (_s->p - _s->data)
|
||||||
#define stream_get_data(_s) (_s->data)
|
#define stream_get_data(_s) (_s->data)
|
||||||
#define stream_get_size(_s) (_s->size)
|
#define stream_get_size(_s) (_s->size)
|
||||||
|
#define stream_get_left(_s) (_s->size - (_s->p - _s->data))
|
||||||
|
|
||||||
#define stream_read_uint8(_s, _v) do { _v = *_s->p++; } while (0)
|
#define stream_read_uint8(_s, _v) do { _v = *_s->p++; } while (0)
|
||||||
#define stream_read_uint16(_s, _v) do { _v = \
|
#define stream_read_uint16(_s, _v) do { _v = \
|
||||||
|
@ -263,6 +263,8 @@ int transport_check_fds(rdpTransport* transport)
|
|||||||
stream_copy(transport->recv_buffer, received, pos - length);
|
stream_copy(transport->recv_buffer, received, pos - length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stream_set_pos(received, length);
|
||||||
|
stream_seal(received);
|
||||||
stream_set_pos(received, 0);
|
stream_set_pos(received, 0);
|
||||||
status = transport->recv_callback(transport, received, transport->recv_extra);
|
status = transport->recv_callback(transport, received, transport->recv_extra);
|
||||||
stream_free(received);
|
stream_free(received);
|
||||||
|
Loading…
Reference in New Issue
Block a user