aboutsummaryrefslogtreecommitdiffstats
path: root/shells/tcsh
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>1996-08-12 10:56:37 +0800
committerache <ache@FreeBSD.org>1996-08-12 10:56:37 +0800
commit49ad7e8929c29bde775f8e960a6afff1c069a872 (patch)
tree34660943a6cd1f7775eced3e9020c0a10755c625 /shells/tcsh
parenta93c95713bf0ba2d869be862c4429b4817e8ab22 (diff)
downloadfreebsd-ports-graphics-49ad7e8929c29bde775f8e960a6afff1c069a872.tar.gz
freebsd-ports-graphics-49ad7e8929c29bde775f8e960a6afff1c069a872.tar.zst
freebsd-ports-graphics-49ad7e8929c29bde775f8e960a6afff1c069a872.zip
Use collate for alpha character ranges
Diffstat (limited to 'shells/tcsh')
-rw-r--r--shells/tcsh/files/patch-ad93
1 files changed, 93 insertions, 0 deletions
diff --git a/shells/tcsh/files/patch-ad b/shells/tcsh/files/patch-ad
new file mode 100644
index 00000000000..61d4e999f20
--- /dev/null
+++ b/shells/tcsh/files/patch-ad
@@ -0,0 +1,93 @@
+*** sh.glob.c.orig Sun May 14 00:49:17 1995
+--- sh.glob.c Mon Aug 12 06:36:22 1996
+***************
+*** 1038,1045 ****
+ if (match)
+ continue;
+ if (rangec == '-' && *(pattern-2) != '[' && *pattern != ']') {
+! match = (stringc <= (*pattern & TRIM) &&
+! (*(pattern-2) & TRIM) <= stringc);
+ pattern++;
+ }
+ else
+--- 1038,1046 ----
+ if (match)
+ continue;
+ if (rangec == '-' && *(pattern-2) != '[' && *pattern != ']') {
+! match = ( collcmp(stringc, *pattern & TRIM) <= 0
+! && collcmp(*(pattern-2) & TRIM, stringc) <= 0
+! );
+ pattern++;
+ }
+ else
+*** glob.c.orig Sun May 14 00:49:21 1995
+--- glob.c Mon Aug 12 06:35:03 1996
+***************
+*** 610,615 ****
+--- 610,645 ----
+ return ((copy == NULL) ? GLOB_NOSPACE : 0);
+ }
+
++ int collcmp (c1, c2)
++ int c1, c2;
++ {
++ static char s1[2], s2[2];
++
++ if (c1 == c2)
++ return (0);
++ if ( (isascii(c1) && isascii(c2))
++ || (!isalpha(c1) && !isalpha(c2))
++ )
++ return (c1 - c2);
++ if (isalpha(c1) && !isalpha(c2)) {
++ if (isupper(c1))
++ return ('A' - c2);
++ else
++ return ('a' - c2);
++ } else if (isalpha(c2) && !isalpha(c1)) {
++ if (isupper(c2))
++ return (c1 - 'A');
++ else
++ return (c1 - 'a');
++ }
++ if (isupper(c1) && islower(c2))
++ return (-1);
++ else if (islower(c1) && isupper(c2))
++ return (1);
++ s1[0] = c1;
++ s2[0] = c2;
++ return strcoll(s1, s2);
++ }
+
+ /*
+ * pattern matching function for filenames. Each occurrence of the *
+***************
+*** 646,652 ****
+ ++pat;
+ while (((c = *pat++) & M_MASK) != M_END) {
+ if ((*pat & M_MASK) == M_RNG) {
+! if (c <= k && k <= pat[1])
+ ok = 1;
+ pat += 2;
+ }
+--- 676,684 ----
+ ++pat;
+ while (((c = *pat++) & M_MASK) != M_END) {
+ if ((*pat & M_MASK) == M_RNG) {
+! if ( collcmp(CHAR(c), CHAR(k)) <= 0
+! && collcmp(CHAR(k), CHAR(pat[1])) <= 0
+! )
+ ok = 1;
+ pat += 2;
+ }
+*** glob.h.orig Sun May 14 00:49:21 1995
+--- glob.h Mon Aug 12 06:35:03 1996
+***************
+*** 65,69 ****
+--- 65,70 ----
+
+ int glob __P((const char *, int, int (*)(char *, int), glob_t *));
+ void globfree __P((glob_t *));
++ int collcmp __P((int, int));
+
+ #endif /* !_GLOB_H_ */