Commit 0f44398b by Christian Brauner Committed by Stéphane Graber

utils: add lxc_safe_long()

parent c453697f
...@@ -2007,7 +2007,7 @@ int lxc_safe_uint(const char *numstr, unsigned int *converted) ...@@ -2007,7 +2007,7 @@ int lxc_safe_uint(const char *numstr, unsigned int *converted)
if (uli > UINT_MAX) if (uli > UINT_MAX)
return -ERANGE; return -ERANGE;
*converted = (unsigned)uli; *converted = (unsigned int)uli;
return 0; return 0;
} }
...@@ -2030,3 +2030,23 @@ int lxc_safe_int(const char *numstr, int *converted) ...@@ -2030,3 +2030,23 @@ int lxc_safe_int(const char *numstr, int *converted)
*converted = (int)sli; *converted = (int)sli;
return 0; return 0;
} }
int lxc_safe_long(const char *numstr, long int *converted)
{
char *err = NULL;
signed long int sli;
errno = 0;
sli = strtol(numstr, &err, 0);
if (errno > 0)
return -errno;
if (!err || err == numstr || *err != '\0')
return -EINVAL;
if (sli > LONG_MAX)
return -ERANGE;
*converted = sli;
return 0;
}
...@@ -320,5 +320,6 @@ bool task_blocking_signal(pid_t pid, int signal); ...@@ -320,5 +320,6 @@ bool task_blocking_signal(pid_t pid, int signal);
/* Helper functions to parse numbers. */ /* Helper functions to parse numbers. */
int lxc_safe_uint(const char *numstr, unsigned int *converted); int lxc_safe_uint(const char *numstr, unsigned int *converted);
int lxc_safe_int(const char *numstr, int *converted); int lxc_safe_int(const char *numstr, int *converted);
int lxc_safe_long(const char *numstr, long int *converted);
#endif /* __LXC_UTILS_H */ #endif /* __LXC_UTILS_H */
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