libfreerdp-core/transport: add stream_seal when a packet is received.

This commit is contained in:
Vic Lee 2011-08-03 09:46:04 +08:00
parent eea404e977
commit 8387380035
2 changed files with 5 additions and 2 deletions

View File

@ -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 = \

View File

@ -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);