Commit 1edbfa1f by Krishna Ram Prakash R Committed by Carlos Martín Nieto

Fixed bug while parsing INT64_MIN

parent a200dc9e
...@@ -122,8 +122,8 @@ int git__strtol64(int64_t *result, const char *nptr, const char **endptr, int ba ...@@ -122,8 +122,8 @@ int git__strtol64(int64_t *result, const char *nptr, const char **endptr, int ba
v = c - 'A' + 10; v = c - 'A' + 10;
if (v >= base) if (v >= base)
break; break;
nn = n*base + v; nn = n * base + (neg ? -v : v);
if (nn < n) if ((!neg && nn < n) || (neg && nn > n))
ovfl = 1; ovfl = 1;
n = nn; n = nn;
} }
...@@ -142,7 +142,7 @@ Return: ...@@ -142,7 +142,7 @@ Return:
return -1; return -1;
} }
*result = neg ? -n : n; *result = n;
return 0; return 0;
} }
......
...@@ -33,5 +33,13 @@ void test_core_strtol__int64(void) ...@@ -33,5 +33,13 @@ void test_core_strtol__int64(void)
cl_assert(i == 2147483657LL); cl_assert(i == 2147483657LL);
cl_git_pass(git__strtol64(&i, " -2147483657 ", NULL, 10)); cl_git_pass(git__strtol64(&i, " -2147483657 ", NULL, 10));
cl_assert(i == -2147483657LL); cl_assert(i == -2147483657LL);
cl_git_pass(git__strtol64(&i, " 9223372036854775807 ", NULL, 10));
cl_assert(i == INT64_MAX);
cl_git_pass(git__strtol64(&i, " -9223372036854775808 ", NULL, 10));
cl_assert(i == INT64_MIN);
cl_git_pass(git__strtol64(&i, " 0x7fffffffffffffff ", NULL, 16));
cl_assert(i == INT64_MAX);
cl_git_pass(git__strtol64(&i, " -0x8000000000000000 ", NULL, 16));
cl_assert(i == INT64_MIN);
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment