Skip to content

Commit

Permalink
Don't use buf_size as input and output in encode
Browse files Browse the repository at this point in the history
  • Loading branch information
a-veitch committed Jan 22, 2016
1 parent c45d088 commit ff14b44
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 23 deletions.
17 changes: 9 additions & 8 deletions include/grpc/census.h
Original file line number Diff line number Diff line change
Expand Up @@ -438,19 +438,20 @@ int census_tag_set_get_tag_by_key(const census_tag_set *tags, const char *key,
@param tags tag set to be encoded
@param buffer pointer to buffer. This address will be used to encode the
printable tags.
@param buf_size On input, will be a pointer to total buffer size. On output,
will be set to total number of bytes consumed by printable
tags.
@param bin_buf_size on output, will be set to the number of bytes used to
encode the binary tags.
@param buf_size number of available bytes in buffer.
@param print_buf_size Will be set to the number of bytes consumed by
printable tags.
@param bin_buf_size Will be set to the number of bytes used to encode the
binary tags.
@return A pointer to the binary tag's encoded, or NULL if the buffer was
insufficiently large to hold the encoded tags. Thus, if successful,
printable tags are encoded into
[buffer, buffer + *buf_size) and binary tags into
[buffer, buffer + *print_buf_size) and binary tags into
[returned-ptr, returned-ptr + *bin_buf_size) (and the return value
should be buffer + *buf_size) */
should be buffer + *print_buf_size) */
char *census_tag_set_encode(const census_tag_set *tags, char *buffer,
size_t *buf_size, size_t *bin_buf_size);
size_t buf_size, size_t *print_buf_size,
size_t *bin_buf_size);

/* Decode tag set buffers encoded with census_tag_set_encode_*(). Returns NULL
if there is an error in parsing either buffer. */
Expand Down
14 changes: 7 additions & 7 deletions src/core/census/tag_set.c
Original file line number Diff line number Diff line change
Expand Up @@ -454,19 +454,19 @@ static size_t tag_set_encode(const struct tag_set *tags, char *buffer,
}

char *census_tag_set_encode(const census_tag_set *tags, char *buffer,
size_t *buf_size, size_t *bin_buf_size) {
size_t p_buf_size =
tag_set_encode(&tags->tags[PROPAGATED_TAGS], buffer, *buf_size);
if (p_buf_size == 0) {
size_t buf_size, size_t *print_buf_size,
size_t *bin_buf_size) {
*print_buf_size =
tag_set_encode(&tags->tags[PROPAGATED_TAGS], buffer, buf_size);
if (*print_buf_size == 0) {
return NULL;
}
char *b_buffer = buffer + p_buf_size;
char *b_buffer = buffer + *print_buf_size;
*bin_buf_size = tag_set_encode(&tags->tags[PROPAGATED_BINARY_TAGS], b_buffer,
*buf_size - p_buf_size);
buf_size - *print_buf_size);
if (*bin_buf_size == 0) {
return NULL;
}
*buf_size = p_buf_size;
return b_buffer;
}

Expand Down
19 changes: 11 additions & 8 deletions test/core/census/tag_set_test.c
Original file line number Diff line number Diff line change
Expand Up @@ -325,15 +325,18 @@ static void encode_decode_test(void) {
char buffer[BUF_SIZE];
struct census_tag_set *cts =
census_tag_set_create(NULL, basic_tags, BASIC_TAG_COUNT, NULL);
size_t bsize = 2; // buffer size too small
size_t bin_bsize = 0;
GPR_ASSERT(census_tag_set_encode(cts, buffer, &bsize, &bin_bsize) == NULL);
bsize = BUF_SIZE;
char *b_buffer = census_tag_set_encode(cts, buffer, &bsize, &bin_bsize);
GPR_ASSERT(b_buffer != NULL && bsize > 0 && bin_bsize > 0 &&
bsize + bin_bsize <= BUF_SIZE && b_buffer == buffer + bsize);
size_t print_bsize;
size_t bin_bsize;
// Test with too small a buffer
GPR_ASSERT(census_tag_set_encode(cts, buffer, 2, &print_bsize, &bin_bsize) ==
NULL);
char *b_buffer =
census_tag_set_encode(cts, buffer, BUF_SIZE, &print_bsize, &bin_bsize);
GPR_ASSERT(b_buffer != NULL && print_bsize > 0 && bin_bsize > 0 &&
print_bsize + bin_bsize <= BUF_SIZE &&
b_buffer == buffer + print_bsize);
census_tag_set *cts2 =
census_tag_set_decode(buffer, bsize, b_buffer, bin_bsize);
census_tag_set_decode(buffer, print_bsize, b_buffer, bin_bsize);
GPR_ASSERT(cts2 != NULL);
const census_tag_set_create_status *status =
census_tag_set_get_create_status(cts2);
Expand Down

0 comments on commit ff14b44

Please sign in to comment.