diff options
author | Jim Meyering <jim@meyering.net> | 1999-05-22 02:47:45 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 1999-05-22 02:47:45 +0000 |
commit | 7bac5533d78cad33650ea275a37cf06d7295f3c9 (patch) | |
tree | 55ac519dd17f3694289be425b97ed49ea3a3fa5f | |
parent | 28c635adb2d06818e66d5848e91d3a115259d168 (diff) | |
download | coreutils-7bac5533d78cad33650ea275a37cf06d7295f3c9.tar.xz |
(strtod): Declare if STDC_HEADERS is not defined.
(general_numcompare): Use strtod, not xstrtod.
Do not consider partial conversions to be errors.
Put -infinity at the start, and +infinity at the end;
follow +infinity with NaNs (sorted by bit pattern),
and finally by conversion errors.
-rw-r--r-- | src/sort.c | 36 |
1 files changed, 25 insertions, 11 deletions
diff --git a/src/sort.c b/src/sort.c index a9ea5c867..7dd0ac6ef 100644 --- a/src/sort.c +++ b/src/sort.c @@ -30,7 +30,6 @@ #include "system.h" #include "long-options.h" #include "error.h" -#include "xstrtod.h" #include "xalloc.h" /* The official name of this program (e.g., no `g' prefix). */ @@ -48,6 +47,10 @@ # define NAME_MAX_IN_DIR(Dir) 255 #endif +#ifndef STDC_HEADERS +double strtod (); +#endif + char *xstrdup (); /* Undefine, to avoid warning about redefinition on some systems. */ @@ -1064,19 +1067,30 @@ numcompare (register const char *a, register const char *b) static int general_numcompare (const char *sa, const char *sb) { - double a, b; /* FIXME: add option to warn about failed conversions. */ /* FIXME: maybe add option to try expensive FP conversion only if A and B can't be compared more cheaply/accurately. */ - if (xstrtod (sa, NULL, &a)) - { - a = 0; - } - if (xstrtod (sb, NULL, &b)) - { - b = 0; - } - return a == b ? 0 : a < b ? -1 : 1; + + char *ea; + char *eb; + double a = strtod (sa, &ea); + double b = strtod (sb, &eb); + + /* Put conversion errors at the end of the collating sequence. */ + if (sa == ea) + return eb - sb; + if (sb == eb) + return -1; + + /* Put NaNs after numbers but before conversion errors; sort them by + internal bit-pattern, for lack of a more portable alternative. + Don't test specially for the case where a is a NaN but b is not, + since the conditional at the end of this function does the right + thing for that case. */ + if (b != b) + return a == a ? -1 : memcmp ((char *) &a, (char *) &b, sizeof a); + + return a < b ? -1 : a != b; } /* Return an integer in 1..12 of the month name S with length LEN. |