Mercurial > hg > octave-kai > gnulib-hg
annotate lib/human.c @ 2593:3ebe28cfe9b4
(adjust_value): New function.
(human_readable_inexact): Apply rounding style even when
printing approximate values.
author | Jim Meyering <jim@meyering.net> |
---|---|
date | Fri, 16 Jun 2000 12:51:28 +0000 |
parents | a3c74265aa47 |
children | 0cd372c853e5 |
rev | line source |
---|---|
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
1 /* human.c -- print human readable file size |
2288
ae987539432e
Use `#if !HAVE_DECL...' instead of `#ifndef HAVE_DECL..'
Jim Meyering <jim@meyering.net>
parents:
2008
diff
changeset
|
2 Copyright (C) 1996, 1997, 1998, 1999, 2000 Free Software Foundation, Inc. |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
3 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
4 This program is free software; you can redistribute it and/or modify |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
5 it under the terms of the GNU General Public License as published by |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
6 the Free Software Foundation; either version 2, or (at your option) |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
7 any later version. |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
8 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
9 This program is distributed in the hope that it will be useful, |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
10 but WITHOUT ANY WARRANTY; without even the implied warranty of |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
12 GNU General Public License for more details. |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
13 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
14 You should have received a copy of the GNU General Public License |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
15 along with this program; if not, write to the Free Software Foundation, |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
16 Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
17 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
18 /* Originally contributed by lm@sgi.com; |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
19 --si, output block size selection, and large file support |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
20 added by eggert@twinsun.com. */ |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
21 |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
22 #if HAVE_CONFIG_H |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
23 # include <config.h> |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
24 #endif |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
25 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
26 #include <sys/types.h> |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
27 #include <stdio.h> |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
28 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
29 #if HAVE_LIMITS_H |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
30 # include <limits.h> |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
31 #endif |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
32 |
1841
29f0e78db379
Include <string.h> or <strings.h> for strlen prototype.
Jim Meyering <jim@meyering.net>
parents:
1812
diff
changeset
|
33 #if HAVE_STRING_H |
29f0e78db379
Include <string.h> or <strings.h> for strlen prototype.
Jim Meyering <jim@meyering.net>
parents:
1812
diff
changeset
|
34 # include <string.h> |
29f0e78db379
Include <string.h> or <strings.h> for strlen prototype.
Jim Meyering <jim@meyering.net>
parents:
1812
diff
changeset
|
35 #else |
29f0e78db379
Include <string.h> or <strings.h> for strlen prototype.
Jim Meyering <jim@meyering.net>
parents:
1812
diff
changeset
|
36 # include <strings.h> |
29f0e78db379
Include <string.h> or <strings.h> for strlen prototype.
Jim Meyering <jim@meyering.net>
parents:
1812
diff
changeset
|
37 #endif |
29f0e78db379
Include <string.h> or <strings.h> for strlen prototype.
Jim Meyering <jim@meyering.net>
parents:
1812
diff
changeset
|
38 |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
39 #ifndef CHAR_BIT |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
40 # define CHAR_BIT 8 |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
41 #endif |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
42 #if HAVE_STDLIB_H |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
43 # include <stdlib.h> |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
44 #endif |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
45 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
46 #ifndef HAVE_DECL_GETENV |
2293
d68da7d92089
use double quotes, not single quotes around syntax-error-evoking string
Jim Meyering <jim@meyering.net>
parents:
2288
diff
changeset
|
47 "this configure-time declaration test was not run" |
2288
ae987539432e
Use `#if !HAVE_DECL...' instead of `#ifndef HAVE_DECL..'
Jim Meyering <jim@meyering.net>
parents:
2008
diff
changeset
|
48 #endif |
ae987539432e
Use `#if !HAVE_DECL...' instead of `#ifndef HAVE_DECL..'
Jim Meyering <jim@meyering.net>
parents:
2008
diff
changeset
|
49 #if !HAVE_DECL_GETENV |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
50 char *getenv (); |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
51 #endif |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
52 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
53 #if ENABLE_NLS |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
54 # include <libintl.h> |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
55 # define _(Text) gettext (Text) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
56 #else |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
57 # define _(Text) Text |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
58 #endif |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
59 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
60 #include <argmatch.h> |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
61 #include <error.h> |
1786
027e08403b18
Include xstrtol.h, not xstrtoul.h, since xstrtol.h now defines all the
Jim Meyering <jim@meyering.net>
parents:
1596
diff
changeset
|
62 #include <xstrtol.h> |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
63 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
64 #include "human.h" |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
65 |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
66 static const char suffixes[] = |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
67 { |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
68 0, /* not used */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
69 'k', /* kilo */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
70 'M', /* Mega */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
71 'G', /* Giga */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
72 'T', /* Tera */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
73 'P', /* Peta */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
74 'E', /* Exa */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
75 'Z', /* Zetta */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
76 'Y' /* Yotta */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
77 }; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
78 |
2593
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
79 /* If INEXACT_STYLE is not human_round_to_even, and if easily |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
80 possible, adjust VALUE according to the style. */ |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
81 static double |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
82 adjust_value (enum human_inexact_style inexact_style, double value) |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
83 { |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
84 /* Do not use the floor or ceil functions, as that would mean |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
85 linking with the standard math library, which is a porting pain. |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
86 So leave the value alone if it is too large to easily round. */ |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
87 if (inexact_style != human_round_to_even && value < (uintmax_t) -1) |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
88 { |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
89 uintmax_t u = value; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
90 value = u + (inexact_style == human_ceiling && u != value); |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
91 } |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
92 |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
93 return value; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
94 } |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
95 |
1863
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
96 /* Like human_readable_inexact, except always round to even. */ |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
97 char * |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
98 human_readable (uintmax_t n, char *buf, |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
99 int from_block_size, int output_block_size) |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
100 { |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
101 return human_readable_inexact (n, buf, from_block_size, output_block_size, |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
102 human_round_to_even); |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
103 } |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
104 |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
105 /* Convert N to a human readable format in BUF. |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
106 |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
107 N is expressed in units of FROM_BLOCK_SIZE. FROM_BLOCK_SIZE must |
1848
afab915d3e18
(human_readable): Allow from_block_size to be zero.
Jim Meyering <jim@meyering.net>
parents:
1841
diff
changeset
|
108 be nonnegative. |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
109 |
2590
a3c74265aa47
(human_readable_inexact): Allow an input block
Jim Meyering <jim@meyering.net>
parents:
2293
diff
changeset
|
110 OUTPUT_BLOCK_SIZE must be nonzero. If it is positive, use units of |
a3c74265aa47
(human_readable_inexact): Allow an input block
Jim Meyering <jim@meyering.net>
parents:
2293
diff
changeset
|
111 OUTPUT_BLOCK_SIZE in the output number. |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
112 |
1863
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
113 Use INEXACT_STYLE to determine whether to take the ceiling or floor |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
114 of any result that cannot be expressed exactly. |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
115 |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
116 If OUTPUT_BLOCK_SIZE is negative, use a format like "127k" if |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
117 possible, using powers of -OUTPUT_BLOCK_SIZE; otherwise, use |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
118 ordinary decimal format. Normally -OUTPUT_BLOCK_SIZE is either |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
119 1000 or 1024; it must be at least 2. Most people visually process |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
120 strings of 3-4 digits effectively, but longer strings of digits are |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
121 more prone to misinterpretation. Hence, converting to an |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
122 abbreviated form usually improves readability. Use a suffix |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
123 indicating which power is being used. For example, assuming |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
124 -OUTPUT_BLOCK_SIZE is 1024, 8500 would be converted to 8.3k, |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
125 133456345 to 127M, 56990456345 to 53G, and so on. Numbers smaller |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
126 than -OUTPUT_BLOCK_SIZE aren't modified. */ |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
127 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
128 char * |
1863
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
129 human_readable_inexact (uintmax_t n, char *buf, |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
130 int from_block_size, int output_block_size, |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
131 enum human_inexact_style inexact_style) |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
132 { |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
133 uintmax_t amt; |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
134 int base; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
135 int to_block_size; |
1848
afab915d3e18
(human_readable): Allow from_block_size to be zero.
Jim Meyering <jim@meyering.net>
parents:
1841
diff
changeset
|
136 int tenths = 0; |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
137 int power; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
138 char *p; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
139 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
140 /* 0 means adjusted N == AMT.TENTHS; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
141 1 means AMT.TENTHS < adjusted N < AMT.TENTHS + 0.05; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
142 2 means adjusted N == AMT.TENTHS + 0.05; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
143 3 means AMT.TENTHS + 0.05 < adjusted N < AMT.TENTHS + 0.1. */ |
1848
afab915d3e18
(human_readable): Allow from_block_size to be zero.
Jim Meyering <jim@meyering.net>
parents:
1841
diff
changeset
|
144 int rounding = 0; |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
145 |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
146 if (output_block_size < 0) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
147 { |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
148 base = -output_block_size; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
149 to_block_size = 1; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
150 } |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
151 else |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
152 { |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
153 base = 0; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
154 to_block_size = output_block_size; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
155 } |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
156 |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
157 p = buf + LONGEST_HUMAN_READABLE; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
158 *p = '\0'; |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
159 |
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
160 #ifdef lint |
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
161 /* Suppress `used before initialized' warning. */ |
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
162 power = 0; |
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
163 #endif |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
164 |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
165 /* Adjust AMT out of FROM_BLOCK_SIZE units and into TO_BLOCK_SIZE units. */ |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
166 |
2593
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
167 { |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
168 int multiplier; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
169 int divisor; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
170 int r2; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
171 int r10; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
172 if (to_block_size <= from_block_size |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
173 ? (from_block_size % to_block_size != 0 |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
174 || (multiplier = from_block_size / to_block_size, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
175 (amt = n * multiplier) / multiplier != n)) |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
176 : (from_block_size == 0 |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
177 || to_block_size % from_block_size != 0 |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
178 || (divisor = to_block_size / from_block_size, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
179 r10 = (n % divisor) * 10, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
180 r2 = (r10 % divisor) * 2, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
181 amt = n / divisor, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
182 tenths = r10 / divisor, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
183 rounding = r2 < divisor ? 0 < r2 : 2 + (divisor < r2), |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
184 0))) |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
185 { |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
186 /* Either the result cannot be computed easily using uintmax_t, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
187 or from_block_size is zero. Fall back on floating point. |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
188 FIXME: This can yield answers that are slightly off. */ |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
189 |
2593
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
190 double damt = n * (from_block_size / (double) to_block_size); |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
191 |
2593
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
192 if (! base) |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
193 sprintf (buf, "%.0f", adjust_value (inexact_style, damt)); |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
194 else |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
195 { |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
196 double e = 1; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
197 power = 0; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
198 |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
199 do |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
200 { |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
201 e *= base; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
202 power++; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
203 } |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
204 while (e * base <= damt && power < sizeof suffixes - 1); |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
205 |
2593
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
206 damt /= e; |
2590
a3c74265aa47
(human_readable_inexact): Allow an input block
Jim Meyering <jim@meyering.net>
parents:
2293
diff
changeset
|
207 |
2593
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
208 sprintf (buf, "%.1f%c", adjust_value (inexact_style, damt), |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
209 suffixes[power]); |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
210 if (4 < strlen (buf)) |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
211 sprintf (buf, "%.0f%c", |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
212 adjust_value (inexact_style, damt * 10) / 10, |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
213 suffixes[power]); |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
214 } |
2590
a3c74265aa47
(human_readable_inexact): Allow an input block
Jim Meyering <jim@meyering.net>
parents:
2293
diff
changeset
|
215 |
2593
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
216 return buf; |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
217 } |
3ebe28cfe9b4
(adjust_value): New function.
Jim Meyering <jim@meyering.net>
parents:
2590
diff
changeset
|
218 } |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
219 |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
220 /* Use power of BASE notation if adjusted AMT is large enough. */ |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
221 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
222 if (base && base <= amt) |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
223 { |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
224 power = 0; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
225 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
226 do |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
227 { |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
228 int r10 = (amt % base) * 10 + tenths; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
229 int r2 = (r10 % base) * 2 + (rounding >> 1); |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
230 amt /= base; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
231 tenths = r10 / base; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
232 rounding = (r2 < base |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
233 ? 0 < r2 + rounding |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
234 : 2 + (base < r2 + rounding)); |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
235 power++; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
236 } |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
237 while (base <= amt && power < sizeof suffixes - 1); |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
238 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
239 *--p = suffixes[power]; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
240 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
241 if (amt < 10) |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
242 { |
1863
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
243 if (2 * (1 - (int) inexact_style) |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
244 < rounding + (tenths & (inexact_style == human_round_to_even))) |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
245 { |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
246 tenths++; |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
247 rounding = 0; |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
248 |
1863
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
249 if (tenths == 10) |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
250 { |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
251 amt++; |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
252 tenths = 0; |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
253 } |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
254 } |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
255 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
256 if (amt < 10) |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
257 { |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
258 *--p = '0' + tenths; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
259 *--p = '.'; |
1863
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
260 tenths = rounding = 0; |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
261 } |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
262 } |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
263 } |
1142
ff40370aead6
(human_readable): Convert to ANSI-style definition.
Jim Meyering <jim@meyering.net>
parents:
1137
diff
changeset
|
264 |
1863
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
265 if (inexact_style == human_ceiling |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
266 ? 0 < tenths + rounding |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
267 : inexact_style == human_round_to_even |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
268 ? 5 < tenths + (2 < rounding + (amt & 1)) |
e6b535c4a46e
(human_readable): New function.
Jim Meyering <jim@meyering.net>
parents:
1848
diff
changeset
|
269 : /* inexact_style == human_floor */ 0) |
1137
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
270 { |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
271 amt++; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
272 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
273 if (amt == base && power < sizeof suffixes - 1) |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
274 { |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
275 *p = suffixes[power + 1]; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
276 *--p = '0'; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
277 *--p = '.'; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
278 amt = 1; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
279 } |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
280 } |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
281 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
282 do |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
283 *--p = '0' + (int) (amt % 10); |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
284 while ((amt /= 10) != 0); |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
285 |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
286 return p; |
2c9059ccc457
New file. The interface is inspired
Jim Meyering <jim@meyering.net>
parents:
diff
changeset
|
287 } |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
288 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
289 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
290 /* The default block size used for output. This number may change in |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
291 the future as disks get larger. */ |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
292 #ifndef DEFAULT_BLOCK_SIZE |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
293 # define DEFAULT_BLOCK_SIZE 1024 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
294 #endif |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
295 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
296 static char const *const block_size_args[] = { "human-readable", "si", 0 }; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
297 static int const block_size_types[] = { -1024, -1000 }; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
298 |
2008
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
299 static int |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
300 default_block_size (void) |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
301 { |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
302 return getenv ("POSIXLY_CORRECT") ? 512 : DEFAULT_BLOCK_SIZE; |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
303 } |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
304 |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
305 static strtol_error |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
306 humblock (char const *spec, int *block_size) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
307 { |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
308 int i; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
309 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
310 if (! spec && ! (spec = getenv ("BLOCK_SIZE"))) |
2008
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
311 *block_size = default_block_size (); |
1596
ca73757a0183
(humblock): Use ARGMATCH in place of argmatch.
Jim Meyering <jim@meyering.net>
parents:
1439
diff
changeset
|
312 else if (0 <= (i = ARGMATCH (spec, block_size_args, block_size_types))) |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
313 *block_size = block_size_types[i]; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
314 else |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
315 { |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
316 char *ptr; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
317 unsigned long val; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
318 strtol_error e = xstrtoul (spec, &ptr, 0, &val, "eEgGkKmMpPtTyYzZ0"); |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
319 if (e != LONGINT_OK) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
320 return e; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
321 if (*ptr) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
322 return LONGINT_INVALID_SUFFIX_CHAR; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
323 if ((int) val < 0 || val != (int) val) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
324 return LONGINT_OVERFLOW; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
325 *block_size = (int) val; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
326 } |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
327 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
328 return LONGINT_OK; |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
329 } |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
330 |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
331 void |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
332 human_block_size (char const *spec, int report_errors, int *block_size) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
333 { |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
334 strtol_error e = humblock (spec, block_size); |
2008
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
335 if (*block_size == 0) |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
336 { |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
337 *block_size = default_block_size (); |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
338 e = LONGINT_INVALID; |
2d8ab27e705c
(default_block_size): New function.
Jim Meyering <jim@meyering.net>
parents:
1863
diff
changeset
|
339 } |
1391
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
340 if (e != LONGINT_OK && report_errors) |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
341 STRTOL_FATAL_ERROR (spec, _("block size"), e); |
c9a7b76bd443
* lib/human.c, lib/human.h (human_readable): Coalesce last two args
Jim Meyering <jim@meyering.net>
parents:
1142
diff
changeset
|
342 } |