1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
/* Routines for formatting time
Copyright (C) 1995, 1996 Free Software Foundation, Inc.
Written by Miles Bader <miles@gnu.ai.mit.edu>
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2, or (at
your option) any later version.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
#ifndef __TIMEFMT_H__
#define __TIMEFMT_H__
struct timeval;
/* Format into BUF & BUF_LEN the time interval represented by TV, trying to
make the result less than WIDTH characters wide. The number of characters
used is returned. */
size_t fmt_named_interval (struct timeval *tv, size_t width,
char *buf, size_t buf_len);
/* Format into BUF & BUF_LEN the time interval represented by TV, using
HH:MM:SS notation where possible, with FRAC_PLACES digits after the
decimal point, and trying to make the result less than WIDTH characters
wide. If LEADING_ZEROS is true, then any fields that are zero-valued, but
would fit in the given width are printed. If FRAC_PLACES is negative,
then any space remaining after printing the time, up to WIDTH, is used for
the fraction. The number of characters used is returned. */
size_t fmt_seconds (struct timeval *tv, int leading_zeros, int frac_places,
size_t width, char *buf, size_t buf_len);
/* Format into BUF & BUF_LEN the time interval represented by TV, using HH:MM
notation where possible, and trying to make the result less than WIDTH
characters wide. If LEADING_ZEROS is true, then any fields that are
zero-valued, but would fit in the given width are printed. The number of
characters used is returned. */
size_t fmt_minutes (struct timeval *tv, int leading_zeros,
size_t width, char *buf, size_t buf_len);
/* Format into BUF & BUF_LEN the absolute time represented by TV. An attempt
is made to fit the result in less than WIDTH characters, by omitting
fields implied by the current time, NOW (if NOW is 0, then no assumptions
are made, so the resulting times will be somewhat long). The number of
characters used is returned. */
size_t fmt_past_time (struct timeval *tv, struct timeval *now,
size_t width, char *buf, size_t buf_len);
#endif /* __TIMEFMT_H__ */
|