table of contents
| PARSE_TIME(3) | Library Functions Manual | PARSE_TIME(3) | 
NAME¶
parse_time, print_time_table,
  unparse_time,
  unparse_time_approx, —
LIBRARY¶
The roken library (libroken, -lroken)SYNOPSIS¶
#include <parse_time.h>
int
  
  parse_time(const
    char *timespec, const
    char *def_unit);
void
  
  print_time_table(FILE
    *f);
size_t
  
  unparse_time(int
    seconds, char *buf,
    size_t len);
size_t
  
  unparse_time_approx(int
    seconds, char *buf,
    size_t len);
DESCRIPTION¶
Theparse_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 unparse_time() and
    unparse_time_approx() do the opposite of
    parse_time(), that is they take a number of seconds
    and express that as human readable strings.
    unparse_time produces an exact time, while
    unparse_time_approx restricts the result to include
    only one unit.
print_time_table() prints a descriptive
    list of available units on the passed file descriptor.
The possible units include:
Units names can be arbitrarily abbreviated (as long as they are unique).
RETURN VALUES¶
parse_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
BUGS¶
Sinceparse_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.
| November 17, 2013 | HEIMDAL |