Skip to content
This repository has been archived by the owner on Oct 24, 2023. It is now read-only.

Commit

Permalink
cc_bstring simplify and fix (twitter#207)
Browse files Browse the repository at this point in the history
* Use isdigit instead of manual check for digit

* Fix integer overflow in expression (-INT64_MIN)
  • Loading branch information
michalbiesek authored and Yao Yue committed Sep 7, 2019
1 parent 8737d99 commit 683bc1a
Showing 1 changed file with 5 additions and 3 deletions.
8 changes: 5 additions & 3 deletions src/cc_bstring.c
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@
#include <cc_debug.h>
#include <cc_mm.h>

#include <ctype.h>

/*
* Byte string (struct bstring) is a sequence of unsigned char
* The length of the string is pre-computed and explicitly available.
Expand Down Expand Up @@ -131,14 +133,14 @@ bstring_atoi64(int64_t *i64, struct bstring *str)

for (*i64 = 0LL; offset < str->len; offset++) {
c = *(str->data + offset);
if (c < '0' || c > '9') {
if (isdigit(c) == 0) {
return CC_ERROR;
}

// overflow check
if (offset == CC_INT64_MAXLEN - 2) {
if (sign < 0 && *i64 == INT64_MIN / 10 &&
c - '0' > (uint64_t)(-INT64_MIN) % 10) {
c - '0' > -(INT64_MIN % 10)) {
return CC_ERROR;
}
if (sign > 0 && *i64 == INT64_MAX / 10 &&
Expand Down Expand Up @@ -167,7 +169,7 @@ bstring_atou64(uint64_t *u64, struct bstring *str)

for (offset = 0; offset < str->len; offset++) {
c = *(str->data + offset);
if (c < '0' || c > '9') {
if (isdigit(c) == 0) {
return CC_ERROR;
}

Expand Down

0 comments on commit 683bc1a

Please sign in to comment.