Unverified Commit a67e5e08 by Edward Thomson Committed by GitHub

Merge pull request #5743 from lhchavez/fix-clang-32-bit-tests

Third attempt to fix the 32-bit version of `git__multiply_int64_overf…
parents c76e9f22 e9b98cd5
...@@ -166,11 +166,18 @@ GIT_INLINE(bool) git__add_int64_overflow(int64_t *out, int64_t one, int64_t two) ...@@ -166,11 +166,18 @@ GIT_INLINE(bool) git__add_int64_overflow(int64_t *out, int64_t one, int64_t two)
#if !defined(git__multiply_int64_overflow) #if !defined(git__multiply_int64_overflow)
GIT_INLINE(bool) git__multiply_int64_overflow(int64_t *out, int64_t one, int64_t two) GIT_INLINE(bool) git__multiply_int64_overflow(int64_t *out, int64_t one, int64_t two)
{ {
if ((one == -1 && two == INT_MIN) || if ((one == -1 && two == INT64_MIN) ||
(two == -1 && one == INT_MIN) || (two == -1 && one == INT64_MIN))
(one && INT64_MAX / one < two) ||
(one && INT64_MIN / one > two))
return true; return true;
if (one && two) {
if (one > 0 == two > 0) {
if (INT64_MAX / one < two)
return true;
} else {
if (INT64_MIN / one < two)
return true;
}
}
*out = one * two; *out = one * two;
return false; return false;
} }
......
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