summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2002-04-30 09:29:45 +0000
committerJim Meyering <jim@meyering.net>2002-04-30 09:29:45 +0000
commit0c4c74218919c3d36a4ea58c5d06a1014879d644 (patch)
treecd851a07d4a9158947b549d57177d0f5fdaf80b7
parent9d64f63aaaee974b26d74fed7e1524ef4464cc97 (diff)
downloadcoreutils-0c4c74218919c3d36a4ea58c5d06a1014879d644.tar.xz
(keycompare, compare): Replace #ifdef ENABLE_NLS with if (HAVE_SETLOCALE).
(hard_LC_COLLATE): Define even if ! ENABLE_NLS. (main): Always initialize hard_LC_COLLATE. Put initialization next to other locale-related stuff. Include <langinfo.h> even if ! ENABLE_NLS. (decimal_point, th_sep): Depend on HAVE_SETLOCALE, not ENABLE_NLS. (main): Likewise. (MONTHTAB_CONST): Remove; all uses removed. (struct_month_cmp, inittables): Do not depend on ENABLE_NLS. (main): hard_LC_TIME locale does not depend on ENABLE_NLS.
-rw-r--r--src/sort.c36
1 files changed, 12 insertions, 24 deletions
diff --git a/src/sort.c b/src/sort.c
index a2b0ef16d..999de4015 100644
--- a/src/sort.c
+++ b/src/sort.c
@@ -52,7 +52,7 @@ struct rlimit { size_t rlim_cur; };
#define AUTHORS N_ ("Mike Haertel and Paul Eggert")
-#if defined ENABLE_NLS && HAVE_LANGINFO_H
+#if HAVE_LANGINFO_H
# include <langinfo.h>
#endif
@@ -91,7 +91,7 @@ double strtod ();
#define NEGATION_SIGN '-'
#define NUMERIC_ZERO '0'
-#ifdef ENABLE_NLS
+#if HAVE_SETLOCALE
static char decimal_point;
static int th_sep; /* if CHAR_MAX + 1, then there is no thousands separator */
@@ -194,15 +194,9 @@ static char fold_toupper[UCHAR_LIM];
#define MONTHS_PER_YEAR 12
-#if defined ENABLE_NLS && HAVE_NL_LANGINFO
-# define MONTHTAB_CONST /* empty */
-#else
-# define MONTHTAB_CONST const
-#endif
-
/* Table mapping month names to integers.
Alphabetic order allows binary search. */
-static MONTHTAB_CONST struct month monthtab[] =
+static struct month monthtab[] =
{
{"APR", 4},
{"AUG", 8},
@@ -536,7 +530,7 @@ zaptemp (const char *name)
}
}
-#if defined ENABLE_NLS && HAVE_NL_LANGINFO
+#if HAVE_NL_LANGINFO
static int
struct_month_cmp (const void *m1, const void *m2)
@@ -568,7 +562,7 @@ inittables (void)
fold_toupper[i] = i;
}
-#if defined ENABLE_NLS && HAVE_NL_LANGINFO
+#if HAVE_NL_LANGINFO
/* If we're not in the "C" locale, read different names for months. */
if (hard_LC_TIME)
{
@@ -591,7 +585,7 @@ inittables (void)
qsort ((void *) monthtab, MONTHS_PER_YEAR,
sizeof (struct month), struct_month_cmp);
}
-#endif /* NLS */
+#endif
}
/* Specify the amount of main memory to use when sorting. */
@@ -1366,10 +1360,9 @@ keycompare (const struct line *a, const struct line *b)
}
else if (key->month)
diff = getmonth (texta, lena) - getmonth (textb, lenb);
-#ifdef ENABLE_NLS
/* Sorting like this may become slow, so in a simple locale the user
can select a faster sort that is similar to ascii sort */
- else if (hard_LC_COLLATE)
+ else if (HAVE_SETLOCALE && hard_LC_COLLATE)
{
if (ignore || translate)
{
@@ -1407,7 +1400,6 @@ keycompare (const struct line *a, const struct line *b)
else
diff = xmemcoll (texta, lena, textb, lenb);
}
-#endif
else if (ignore)
{
#define CMP_WITH_IGNORE(A, B) \
@@ -1527,10 +1519,8 @@ compare (register const struct line *a, register const struct line *b)
diff = - NONZERO (blen);
else if (blen == 0)
diff = NONZERO (alen);
-#ifdef ENABLE_NLS
- else if (hard_LC_COLLATE)
+ else if (HAVE_SETLOCALE && hard_LC_COLLATE)
diff = xmemcoll (a->text, alen, b->text, blen);
-#endif
else if (! (diff = memcmp (a->text, b->text, min (alen, blen))))
diff = alen < blen ? -1 : alen != blen;
@@ -2187,13 +2177,12 @@ main (int argc, char **argv)
atexit (cleanup);
-#ifdef ENABLE_NLS
-
hard_LC_COLLATE = hard_locale (LC_COLLATE);
-# if HAVE_NL_LANGINFO
+#if HAVE_NL_LANGINFO
hard_LC_TIME = hard_locale (LC_TIME);
-# endif
+#endif
+#if HAVE_SETLOCALE
/* Let's get locale's representation of the decimal point */
{
struct lconv *lconvp = localeconv ();
@@ -2210,8 +2199,7 @@ main (int argc, char **argv)
if (! th_sep || lconvp->thousands_sep[1])
th_sep = CHAR_MAX + 1;
}
-
-#endif /* NLS */
+#endif
have_read_stdin = 0;
inittables ();