u_e = haystack.u + haystack_len - needle_len;
} else {
u_p = haystack.u;
- if (-offset > haystack_len || -offset < 0) {
+ if (-offset > haystack_len || offset < -INT_MAX) {
RETURN_FALSE;
} else {
cu_offset = haystack_len;
e = haystack.s + haystack_len - 1;
} else {
p = haystack.s;
- if (-offset > haystack_len || -offset < 0) {
+ if (-offset > haystack_len || offset < INT_MAX) {
RETURN_FALSE;
} else {
e = haystack.s + haystack_len + offset;
p = haystack_dup + offset;
e = haystack_dup + haystack_len - needle_len;
} else {
- if (-offset > haystack_len || -offset < 0) {
+ if (-offset > haystack_len || offset < -INT_MAX) {
efree(haystack_dup);
efree(needle_dup);
RETURN_FALSE;