|
NAMEparse_time , print_time_table ,
unparse_time ,
unparse_time_approx , —
parse and unparse time intervals
LIBRARYThe roken library (libroken, -lroken)SYNOPSIS#include <parse_time.h>
int
void
size_t
size_t
DESCRIPTIONTheparse_time () function converts the period of time
specified into a number of seconds. The timespec can be
any number of ⟨number unit⟩ pairs separated by comma and
whitespace. The number can be negative. Numbers without explicit units are
taken as being def_unit.
The
The possible units include: Units names can be arbitrarily abbreviated (as long as they are unique). RETURN VALUESparse_time () returns the number of seconds that
represents the expression in timespec or -1 on error.
unparse_time () and
unparse_time_approx () return the number of characters
written to buf. if the return value is greater than or
equal to the len argument, the string was too short and
some of the printed characters were discarded.
EXAMPLES#include <stdio.h> #include <parse_time.h> int main(int argc, char **argv) { int i; int result; char buf[128]; print_time_table(stdout); for (i = 1; i < argc; i++) { result = parse_time(argv[i], "second"); if(result == -1) { fprintf(stderr, "%s: parse error\n", argv[i]); continue; } printf("--\n"); printf("parse_time = %d\n", result); unparse_time(result, buf, sizeof(buf)); printf("unparse_time = %s\n", buf); unparse_time_approx(result, buf, sizeof(buf)); printf("unparse_time_approx = %s\n", buf); } return 0; } $ ./a.out "1 minute 30 seconds" "90 s" "1 y -1 s" 1 year = 365 days 1 month = 30 days 1 week = 7 days 1 day = 24 hours 1 hour = 60 minutes 1 minute = 60 seconds 1 second -- parse_time = 90 unparse_time = 1 minute 30 seconds unparse_time_approx = 1 minute -- parse_time = 90 unparse_time = 1 minute 30 seconds unparse_time_approx = 1 minute -- parse_time = 31535999 unparse_time = 12 months 4 days 23 hours 59 minutes 59 seconds unparse_time_approx = 12 months BUGSSinceparse_time () returns -1 on error there is no way
to parse "minus one second". Currently "s" at the end of
units is ignored. This is a hack for English plural forms. If these functions
are ever localised, this scheme will have to change.
Visit the GSP FreeBSD Man Page Interface. |