Xinqi Bao's Git
fc8b72aa5ac91bb180cc525faf5f1241b4e93e83
1 /* See LICENSE file for copyright and license details. */
13 verr(const char *fmt
, va_list ap
)
15 if (argv0
&& strncmp(fmt
, "usage", sizeof("usage") - 1)) {
16 fprintf(stderr
, "%s: ", argv0
);
19 vfprintf(stderr
, fmt
, ap
);
21 if (fmt
[0] && fmt
[strlen(fmt
) - 1] == ':') {
30 warn(const char *fmt
, ...)
40 die(const char *fmt
, ...)
52 esnprintf(char *str
, size_t size
, const char *fmt
, ...)
58 ret
= vsnprintf(str
, size
, fmt
, ap
);
64 } else if ((size_t)ret
>= size
) {
65 warn("snprintf: Output truncated");
73 bprintf(const char *fmt
, ...)
79 if ((ret
= vsnprintf(buf
, sizeof(buf
), fmt
, ap
)) < 0) {
81 } else if ((size_t)ret
>= sizeof(buf
)) {
82 warn("vsnprintf: Output truncated");
90 fmt_human(size_t num
, int base
)
94 const char *siprefix
[] = { "", "k", "M", "G", "T", "P", "E", "Z", "Y" };
95 const char *iecprefix
[] = { "", "Ki", "Mi", "Gi", "Ti", "Pi", "Ei",
100 memcpy(prefix
, siprefix
, sizeof(prefix
));
101 } else if (base
== 1024) {
102 memcpy(prefix
, iecprefix
, sizeof(prefix
));
106 for (i
= 0; i
< LEN(prefix
) && scaled
>= 1024; i
++) {
110 return bprintf("%.1f%s", scaled
, prefix
[i
]);
114 pscanf(const char *path
, const char *fmt
, ...)
120 if (!(fp
= fopen(path
, "r"))) {
121 warn("fopen '%s':", path
);
125 n
= vfscanf(fp
, fmt
, ap
);
129 return (n
== EOF
) ? -1 : n
;