diff options
Diffstat (limited to '')
-rw-r--r-- | include/slibc-human.h | 40 |
1 files changed, 33 insertions, 7 deletions
diff --git a/include/slibc-human.h b/include/slibc-human.h index de505a1..e56a78d 100644 --- a/include/slibc-human.h +++ b/include/slibc-human.h @@ -148,6 +148,9 @@ enum machinesize_mode /** * 'k' and 'K' is 1000. * + * 'i'-affix for 'K' = 1024 is still + * supported. + * * If `MACHINESIZE_IEC` is also used, * 1000-base is used if 'B' is explicitly * included, otherwise 1024-base is used. @@ -311,11 +314,34 @@ char* humansize(char*, size_t, size_t, enum humansize_mode, int, const char* res const char* restrict, const char* restrict) __GCC_ONLY(__attribute__((__warn_unused_result__))); -/* TODO machinesize */ -/* @etymology Convert to (machine)-representation: `(size)_t`. */ -/* @since Always. */ -int machinesize(size_t* restrict size, const char* restrict str, enum machinesize_mode mode, - const char* restrict space, const char* restrict point); +/** + * Parses a human representation of storage size or file offset. + * + * If no unit is used, bytes are assumed. If you rather it be + * (for example) kilobytes, you can multiply it if + * `strpbrk(str, "qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM") == NULL`. + * + * @etymology Convert to (machine)-representation: `(size)_t`. + * + * @param size Output parameter for the value, must not be `NULL`. + * @param str The value to parse, must not `NULL`. + * @param mode How to parse ambiguous strings, 0 for default. + * @param space Characters to ignore (thousand-group delimiters). + * Supports UTF-8. `NULL` for default. Default value + * is " '". + * @param point Decimal pointer chracters. Supports UTF-8. `NULL` + * for default. Default value is ",.". + * @return Zero on success, -1 on error. + * + * @throws EINVAL If `mode` is invalid. + * @throws EINVAL If `str` is not parseable. + * @throws ERANGE If the value is too range to fit in a `size_t`. + * + * @since Always. + */ +int machinesize(size_t* restrict, const char* restrict, enum machinesize_mode, + const char* restrict, const char* restrict) + __GCC_ONLY(__attribute__((__nonnull__(1, 2)))); #ifdef __C99__ @@ -354,8 +380,8 @@ char* machineuint(uintmax_t* restrict r, const char* restrict str) /* TODO machinefloat */ /* @etymology Convert to (machine)-representation: (float)ing-point number. */ /* @since Always. */ -int machinefloat(long double* restrict r, const char* restrict str, - const char* restrict space, const char* restrict comma); +char* machinefloat(long double* restrict r, const char* restrict str, + const char* restrict space, const char* restrict point); #ifdef __CONST_CORRECT # define machinefloat(...) (__const_correct_2(machinefloat, __VA_ARGS__)) #endif |