Comments
Patch
@@ -291,34 +291,52 @@ int fcntl_setfl(int fd, int flag)
*/
ssize_t strtosz(const char *nptr, char **end)
{
- int64_t value;
+ ssize_t retval = -1;
char *endptr;
+ int mul_required = 0;
+ double val, mul = 1;
+
+ endptr = (char *)nptr + strspn(nptr, " 0123456789");
+ if (*endptr == '.') {
+ mul_required = 1;
+ }
+
+ val = strtod(nptr, &endptr);
+
+ if (val < 0)
+ goto fail;
- value = strtoll(nptr, &endptr, 0);
switch (*endptr++) {
case 'K':
case 'k':
- value <<= 10;
+ mul = 1 << 10;
break;
case 0:
+ case ' ':
+ if (mul_required) {
+ goto fail;
+ }
case 'M':
case 'm':
- value <<= 20;
+ mul = 1ULL << 20;
break;
case 'G':
case 'g':
- value <<= 30;
+ mul = 1ULL << 30;
break;
case 'T':
case 't':
- value <<= 40;
+ mul = 1ULL << 40;
break;
default:
- value = -1;
+ goto fail;
}
+ retval = (ssize_t)(val * mul);
+
if (end)
*end = endptr;
- return value;
+fail:
+ return retval;
}