From b3f04cedf49fe13b5a88060bf4d2a41638cdb208 Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Tue, 18 Dec 2001 22:50:26 +0000 Subject: [PATCH] (scmp): Function moved from minibuf.c. Delete multibyte handling--used only on encoded strings. --- src/dired.c | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/dired.c b/src/dired.c index fe1d8098c77..d21cb65c9d3 100644 --- a/src/dired.c +++ b/src/dired.c @@ -117,6 +117,8 @@ Lisp_Object Qfile_name_completion; Lisp_Object Qfile_name_all_completions; Lisp_Object Qfile_attributes; Lisp_Object Qfile_attributes_lessp; + +static int scmp P_ ((unsigned char *, unsigned char *, int)); Lisp_Object @@ -734,6 +736,34 @@ file_name_completion (file, dirname, all_flag, ver_flag) return Fsignal (Qquit, Qnil); } +/* Compare exactly LEN chars of strings at S1 and S2, + ignoring case if appropriate. + Return -1 if strings match, + else number of chars that match at the beginning. */ + +static int +scmp (s1, s2, len) + register unsigned char *s1, *s2; + int len; +{ + register int l = len; + + if (completion_ignore_case) + { + while (l && DOWNCASE (*s1++) == DOWNCASE (*s2++)) + l--; + } + else + { + while (l && *s1++ == *s2++) + l--; + } + if (l == 0) + return -1; + else + return len - l; +} + static int file_name_completion_stat (dirname, dp, st_addr) Lisp_Object dirname; -- 2.39.2