summaryrefslogtreecommitdiff
path: root/japanese/grep/patches/patch-aa
diff options
context:
space:
mode:
Diffstat (limited to 'japanese/grep/patches/patch-aa')
-rw-r--r--japanese/grep/patches/patch-aa2842
1 files changed, 2842 insertions, 0 deletions
diff --git a/japanese/grep/patches/patch-aa b/japanese/grep/patches/patch-aa
new file mode 100644
index 00000000000..aeb97746864
--- /dev/null
+++ b/japanese/grep/patches/patch-aa
@@ -0,0 +1,2842 @@
+$B!|!|!|!|!|(B GNU grep version 2.0 + multi-byte extension 1.04 $B!|!|!|!|!|(B
+$B!|!|!|!|!|(B Jun. 2, 1994 by t^2 $B!|!|!|!|!|(B
+
+ $B$3$N%U%!%$%k$O(B GNU grep version 2.0 (grep-2.0) $B$N%=!<%9%3!<%I$+$i(B, $B$=(B
+ $B$N%^%k%A%P%$%HJ8;zBP1~HG(B grep-2.0+mb1.04 $B$N%=!<%9%3!<%I$r@8@.$9$k$?$a(B
+ $B$N:9J,$r4^$s$G$$$^$9(B. grep-2.0 $B$N%=!<%9$rE83+$7$F$"$k%G%#%l%/%H%j$G(B
+
+ % patch -p1 < $B$3$N%U%!%$%k(B
+
+ $B$J$I$H$7$F%Q%C%A$rEv$F$F$/$@$5$$(B. $B$=$N8e(B README.MB $B$rFI$s$G$/$@$5$$(B.
+
+$B")(B810 $BJ!2,;TCf1{6hG_8w1`CDCO(B 7-207
+TEL/FAX: 092-731-4025 (TEL/FAX $B<+F0@ZBX$((B)
+ 092-724-6342 (TEL $B$N$_(B)
+E-mail: NBC02362@niftyserve.or.jp t^2 ($BC+K\9'9@(B)
+
+diff -ru2N grep-2.0/ChangeLog.MB grep+mb1.04/ChangeLog.MB
+--- grep-2.0/ChangeLog.MB Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/ChangeLog.MB Thu Jun 2 17:01:42 1994
+@@ -0,0 +1,219 @@
++Thu Jun 2 16:58:03 1994 Takahiro Tanimoto (tt@isaac)
++
++ * Version 2.0 + multi-byte extension 1.04 released.
++
++Sat Mar 5 16:30:16 1994 Takahiro Tanimoto (tt@isaac)
++
++ * README.MSC: PC-9800 $B%7%j!<%:MQ(B MS-C 6.00A $B$N(B, $B%o%$%k%I%+!<%IE8(B
++ $B3+%k!<%A%s$N%P%0$KBP=h$7$?(B. $B0JA0$N(B stdargv.diff $B$r$3$l$KE}9g$7(B,
++ $B:o=|$7$?(B. (Thanks to $BJ!9@K.$5$s(B <GFE00522@niftyserve.or.jp>)
++
++Thu Aug 19 04:26:09 1993 Takahiro Tanimoto (tt@isaac)
++
++ * regex.c (re_compile_fastmap): charset_not $B$N(B fastmap $B$N:n@.=h(B
++ $BM}$,4V0c$C$F$$$F(B, regex $B$N(B fastmap $B$r;HMQ$9$k>l9g(B (e?grep $B$G$O(B
++ fastmap $B$r;HMQ$7$F$$$J$$$?$a(B, $B$3$NLdBj$OI=LL$K$O8=$l$J$$(B), $B@55,(B
++ $BI=8=$N@hF,$N(B [^$B#A(B] $B$d(B [^a] $B$KNc$($P(B $B#B(B $B$,%^%C%A$7$J$+$C$?(B.
++ (Thanks to $B>.20NIM4$5$s(B <JAE03716@niftyserve.or.jp>)
++
++Tue Aug 10 01:29:05 1993 Takahiro Tanimoto (tt@isaac)
++
++ * regex.c (set_list_bits): $BJ8;z%/%i%9Cf$N%^%k%A%P%$%HJ8;z$N:GE,(B
++ $B2=$G(B, $B6h4V=*E@$N99?7=hM}ItJ,$K%P%0$,$"$j(B, [$B#A(B-$B#C#E(B-$B#G#B(B-$B#D(B] $B$r:G(B
++ $BE,2=$9$k$H(B [$B#A(B-$B#G(B] $B$@$,(B, $B$3$l$,(B [$B#A(B-$B#E(B] $B$H$J$C$F$7$^$C$F$$$?(B.
++ $B$?$@$7(B, regex $B$G$O$J$/(B dfa $B$,;HMQ$5$l$k>l9g$K$O$3$N%P%0$OI=LL$K(B
++ $B$O8=$l$J$$(B.
++
++Fri Jul 23 03:22:13 1993 Takahiro Tanimoto (tt@isaac)
++
++ * Version 2.0 + multi-byte extension 1.03 released.
++
++ * DEFS.dos: strcmpi $B$r(B stricmp $B$KJQ99(B.
++
++ * grep.c (main): MS-DOS $B$N>l9g(B, argv[0] $B$r2C9)$7$?J8;zNs$X$N%]%$(B
++ $B%s%?$r(B argv[0] $B$X$b%;%C%H$9$k(B. getopt $B$,=PNO$9$k%a%C%;!<%8$b2C(B
++ $B9)$5$l$?J8;zNs$H$J$k(B.
++
++ * grep.c (main): MS-C 6.00A $B$N(B stdargv.asm $B$N%P%0$r%U%#%C%/%9$7(B
++ $B$?$?$a(B, argv[0] == "" $B$N$H$-$N=hM}$r:o=|$7$?(B.
++
++ * stdargv.diff: $BDI2C(B.
++
++Tue Jul 13 07:04:13 1993 Takahiro Tanimoto (tt@isaac)
++
++ * Version 2.0 + multi-byte extension 1.02 released.
++
++Mon Jul 12 00:20:36 1993 Takahiro Tanimoto (tt@isaac)
++
++ * grep.c: HAVE_STRCASECMP $B$,(B #define $B$5$l$F$$$J$$$H$-(B, $B0lJ}$NJ8(B
++ $B;zNs$@$1$r>.J8;z$K$7$F$+$iHf3S$9$k4X?t$rDj5A$7$F$$$?$,(B, $B;H$$J}$,(B
++ $B0-$+$C$?(B. $B$=$l$r(B strcasecmp() $B$HF1$8$b$N$KJQ99$7$?(B.
++
++ * DEFS.dos: HAVE_STRCMPI $B$r(B #define $B$9$kBe$o$j$K(B,
++ HAVE_STRCASECMP $B$r(B #define $B$7(B, strcasecmp $B$r(B strcmpi $B$K(B #define
++ $B$7$?(B.
++
++Sat Jul 10 01:05:04 1993 Takahiro Tanimoto (tt@isaac)
++
++ * Version 2.0 + multi-byte extension 1.01 released.
++
++ * grep.c (main): MSDOS $B$N>l9g(B, argv[0] $B$r>.J8;z$K$7$F(B prog $B$K%;%C(B
++ $B%H$9$k(B. $B$^$?(B, $B3HD%;R$O<h$j=|$/(B.
++
++ * obstack.h: chunk_size $B$N7?$r(B size_t $B$+$i(B unsigned $B$KJQ99(B.
++ old-C $B$N>l9g(B, size_t $B$,Dj5A$5$l$F$$$J$$>uBV$H$J$C$?$?$a(B.
++
++ * regex.h: $BDj?t$N8e$K(B U, UL $B$r$D$1$k$H(B old-C $B$G%3%s%Q%$%k$G$-$J(B
++ $B$$(B. $B$3$l$i$r%-%c%9%H$KJQ99$7$?(B.
++
++ * regex.h: RE_DUP_MAX $B$NDj5A$r(B 16 $B%S%C%H(B int $B$N%^%7%s$G$b%*!<%P(B
++ $B%U%m!<$7$J$$=q$-J}$K=$@5(B.
++
++ * obstack.h: struct obstack $B$N%a%s%P(B chunk_size $B$N7?$r(B size_t $B$H(B
++ $B$7$?(B. PTR_INT_TYPE $B$r30It$+$i(B #define $B$G$-$k$h$&$K$7$?(B. MSDOS
++ $B$G(B SMALL MODEL $B0J30$N>l9g(B, __PTR_TO_INT, __INT_TO_PTR $B$H$H$b$K(B,
++ $B%]%$%s%?$H(B long $B$rJQ49$9$k$h$&$K$7$?(B.
++
++ * grep.c (fillbuf, grep): read() $B$NJV$jCM$N@5Ii$K$h$k%(%i!<%A%'%C(B
++ $B%/$r(B, -1 $B$KEy$7$$$+$I$&$+$G9T$&$h$&$KJQ99(B.
++
++ * grep.c: totalcc, totalnl $B$r(B unsigned long $B$KJQ99$7(B, prline()
++ $BCf$N(B printf() $B$N=q<0$r9g$o$;$?(B.
++
++ * DEFS.dos: BUFSALLOC $B$r(B 4096 $B$K(B #define. (See reset() in
++ grep.c.)
++
++ * getpagesize.h: MSDOS $B$N>l9g(B, $B%Z!<%8%5%$%:$O(B 4096 $B$H$7$?(B.
++
++ * dfa.c: STDC_HEADERS $B$^$?$O(B HAVE_STRING_H $B$N$H$-(B, bcopy, bzero
++ $B$r%^%/%mE83+$9$k(B.
++
++Fri Jul 9 13:16:50 1993 Takahiro Tanimoto (tt@isaac)
++
++ * mbc.c, mbc.h, ...: ismbchar() $B$r%b%8%e!<%kKh$KFHN)$7$FDj5A$9$k(B
++ $B$N$r$d$a(B, $B%b%8%e!<%k$rDI2C$7$?(B.
++
++ * search.c (Fexecute): fgrep $B$r%^%k%A%P%$%HJ8;z$KBP1~$5$;$?(B.
++
++Wed Jul 7 17:02:33 1993 Takahiro Tanimoto (tt@isaac)
++
++ * kwset.c (bmexec): 8 $B%S%C%H%/%j!<%s$G$J$$$H$3$m$r=$@5(B.
++
++ * $B%Y!<%9$r(B grep-2.0 $B$XJQ99(B.
++
++Sun Jul 4 08:48:12 1993 Takahiro Tanimoto (tt@isaac)
++
++ * regex.c (re_match_2): $B%*%j%8%J%k$N%P%0(B. maybe_finalize_jump
++ $B$N=hM}Cf(B, start_memory/stop_memory $B$r%9%-%C%W$9$k$H$3$m$G(B, $B0z?t(B
++ $B$N%9%-%C%W$r$7$F$$$J$$%P%0$r=$@5(B. $BNc$($P(B "([a-n]+).*\1" $B$,@5$7(B
++ $B$/(B "abcxyzab" $B$K%^%C%A$9$k$h$&$K$J$C$?(B.
++
++Sat Jul 3 06:51:33 1993 Takahiro Tanimoto (tt@isaac)
++
++ * Version 1.6 + multi-byte extension 1.00 released.
++
++Sat Jul 3 04:29:14 1993 Takahiro Tanimoto (tt at pc98)
++
++ * grep.c (bufprev): -b $B%*%W%7%g%s$GI=<($9$k%P%$%H%*%U%;%C%H$r(B
++ long $B$K$9$k$?$a$K(B bufprev $B$r(B long $B$H$7$?(B. bufprev $B0J30$OJQ99$7(B
++ $B$F$$$J$$$?$a(B, 1 $B9T$N%5%$%:$,(B int $B$NHO0O$r1[$($k$H@5$7$/=hM}$5$l(B
++ $B$J$$(B. $B$^$?(B, DOS $B$G$O(B CR+LF $B$r(B 1 $B%P%$%H$H$7$F%+%&%s%H$7$F$7$^$&(B.
++ ($B<jH4$-(B)
++
++ * regex.c (re_match_2): $BJ8;z%/%i%9$N=hM}Cf$N(B 16 $B%S%C%H(B int $B$G@5(B
++ $B>oF0:n$7$J$$ItJ,$r=$@5(B.
++
++ * regex.c (re_exec): re_search() $B$X$N:G8e$N0z?t$r(B 0 $B$+$i(B NULL $B$X(B
++ $B=$@5(B.
++
++ * regex.c (re_match): re_match_2() $B$X$N#2HVL\$N0z?t$r(B 0 $B$+$i(B
++ NULL $B$X=$@5(B.
++
++ * regex.c (re_search): re_search_2() $B$X$N#2HVL\$N0z?t$r(B 0 $B$+$i(B
++ NULL $B$X=$@5(B.
++
++ * grep.c (main): MS-C $B$N(B setargv $B$N%P%0$N$;$$$G(B, grep "\\" foo
++ $B$H$9$k$H(B argv[0] == "" $B$H$J$C$F$7$^$&(B. argv[0] == "" $B$N$H$-$O6/(B
++ $B@)E*$K(B "grep" $B$^$?$O(B "egrep" $B$r%;%C%H$9$k$h$&$K$7$?(B.
++
++Fri Jul 2 19:25:58 1993 Takahiro Tanimoto (tt at pc98)
++
++ * grep.c (main): $BJQ?t(B prog $B$N@_Dj$r(B DOS $BMQ$K=$@5$7$?(B. $B$=$N:](B,
++ $B%*%j%8%J%k$N$d$jJ}$O$^$:$+$C$?$N$G=$@5$7$?(B.
++
++ * grep.c: MSDOS $B$N$H$-(B errno $B$H(B sys_errlist $B$N@k8@$r$7$J$$$h$&$K(B
++ $B=$@5$7$?(B.
++
++ * regex.c (set_list_bits): $B;HMQ$7$F$$$J$+$C$?JQ?t$r:o=|(B.
++
++ * Makefile.msc: DOS $B%5%]!<%H$N$?$aDI2C(B.
++
++Fri Jun 11 04:14:22 1993 Takahiro Tanimoto (tt@isaac)
++
++ * grep.c: version $BJ8;zNs$,8E$$$^$^$@$C$?(B.
++
++Tue May 25 00:10:49 1993 Takahiro Tanimoto (tt@isaac)
++
++ * Version 1.6 + multi-byte extension 0.02 released.
++
++Mon May 24 15:57:31 1993 Takahiro Tanimoto (tt@isaac)
++
++ * regex.c (re_search_2): $B8eJ}$X(B advance $B$9$k:]$N%P%0$r=$@5(B.
++
++Sat May 22 02:03:41 1993 Takahiro Tanimoto (tt@isaac)
++
++ * regex.c (re_compile_fastmap): exactn $B$G(B translate $B$9$k$N$r$d$a(B
++ $B$?(B. re_compile_pattern $B$G0lEY(B translate $B$5$l$F$$$k$O$:(B.
++
++ * regex.c (re_match_2): exactn $B$N=hM}ItJ,$G(B, #if 0 $B$r(B #if 1 $B$K$7(B
++ $B$?>l9g(B, $B@5$7$$=hM}$r9T$C$F$$$J$+$C$?$N$r=$@5(B.
++
++Fri May 21 20:04:07 1993 Takahiro Tanimoto (tt@isaac)
++
++ * regex.[ch]: mbcharset, mbcharset_not $B$rGQ;_(B. $BBe$o$j$K(B
++ charset, charset_not $B$,%^%k%A%P%$%HJ8;z$r$bJ];}$9$k(B.
++
++ * grep.c (main): $B2<5-$NJQ99$KH<$C$F(B, "^.*(" ... ")" $B$rIU2C$9$k=h(B
++ $BM}$r:o=|$7$?(B.
++
++ * dfa.c (regcompile): searchflag $B$,(B ON $B$N$H$-(B, $B@55,I=8=$r(B "^.*("
++ ... ")" $B$H$7$F%3%s%Q%$%k$9$k$h$&$K$7$?(B. $B0JA0$O(B grep.c $B$NCf$GF1(B
++ $B$8$3$H$r9T$C$F$$$?(B.
++
++ * dfa.c (lex): $BJ8;z%/%i%9$G%^%k%A%P%$%HJ8;z$N#1J8;zL\$N=89g$+$i(B,
++ $B%7%s%0%k%P%$%HJ8;z$r=|30$9$k=hM}$rDI2C$7$?(B.
++
++ * dfa.c (lex): $BJ8;z%/%i%9$G%7%s%0%k%P%$%HJ8;z$N>e8B$,4V0c$C$F$$(B
++ $B$?$N$r=$@5$7$?(B.
++
++Wed May 19 01:27:07 1993 Takahiro Tanimoto (tt@isaac)
++
++ * regex.c: !__STDC__ $B$N$H$-$K(B const $B$r(B #define.
++
++ * dfa.h: $B%*%j%8%J%k$G$O(B !STDC_HEADERS $B$N$H$-$K(B const $B$r(B #define
++ $B$7$F$$$?$,(B, $B$3$l$r(B !__STDC__ $B$N$H$-$K(B #define $B$9$k$h$&$KJQ99$7$?(B.
++
++ * configure.in: bcopy(), memmove() $B$N%A%'%C%/$rDI2C(B.
++
++ * dfa.c (reginit): cs_tok[] $B$N=i4|2=$rDI2C$7$?(B. -i $B%U%i%0$rIU$1(B
++ $B$?>l9g$NIT6q9g$r=$@5(B.
++
++Tue May 18 18:14:04 1993 Takahiro Tanimoto (tt@albert)
++
++ * dfa.h: regex.h $B$G$N(B RE_MBCTYPE_??? $B$NCM$H0lCW$5$;$?(B.
++
++ * regex.[ch] (RE_TRANSLATED_RANGE): mbsed-0.01 $B$G9T$C$?3HD%$rM"(B
++ $BF~$7$?(B.
++
++Sat May 15 04:27:32 1993 Takahiro Tanimoto (tt@isaac)
++
++ * $B%^%k%A%P%$%HJ8;zBP1~HG$,0lDL$j40@.$7$?(B.
++
++
++Local Variables:
++mode: indented-text
++left-margin: 8
++fill-column: 72
++fill-prefix: " "
++version-control: never
++End:
+diff -ru2N grep-2.0/DEFS.dos grep+mb1.04/DEFS.dos
+--- grep-2.0/DEFS.dos Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/DEFS.dos Fri Jul 23 03:23:31 1993
+@@ -0,0 +1,15 @@
++#define STDC_HEADERS 1
++#define HAVE_STRING_H 1
++#define HAVE_MEMCHR 1
++#define HAVE_STRERROR 1
++#define HAVE_MEMMOVE 1
++#define HAVE_STRCASECMP 1
++#define strcasecmp stricmp
++
++#define BUFSALLOC 4096
++
++#ifndef M_I86SM
++#define __PTR_TO_INT(P) ((long)(P))
++#define __INT_TO_PTR(P) ((char *)(P))
++#define PTR_INT_TYPE long
++#endif
+diff -ru2N grep-2.0/MANIFEST.MB grep+mb1.04/MANIFEST.MB
+--- grep-2.0/MANIFEST.MB Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/MANIFEST.MB Sat Mar 5 16:37:46 1994
+@@ -0,0 +1,11 @@
++ChangeLog.MB Revision history of multi-byte extension to grep.
++DEFS.dos Definitions for DOS.
++MANIFEST.MB This file.
++Makefile.msc Makefile for MS-C version 6.
++README.MB Documentation for multi-byte extension.
++README.MSC Patch for source/startup/... of MS-C 6.00A
++mbc.c Multi-byte char handler.
++mbc.h Interface to mbc.c.
++tests/batgen.awk DOS version of scriptgen.awk.
++tests/check.bat DOS version of check.sh
++tests/spencer.dos Input for batgen.
+diff -ru2N grep-2.0/Makefile.in grep+mb1.04/Makefile.in
+--- grep-2.0/Makefile.in Mon May 3 05:54:24 1993
++++ grep+mb1.04/Makefile.in Mon Jul 12 02:02:28 1993
+@@ -16,4 +16,7 @@
+ # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
++# Multi-byte extension added May, 1993 by t^2 (Takahiro Tanimoto)
++# Last change: Jul. 12, 1993 by t^2
++
+ SHELL = /bin/sh
+
+@@ -40,4 +43,11 @@
+ DEFS=-DGREP @DEFS@
+
++# Things you might set to MBCTYPE_DEF to spec. default multi-byte char type.
++# -DEUC will make default multi-byte char type EUC and
++# -DSJIS SJIS.
++# If you do not set EUC/SJIS, grep assumes no multi-byte
++# char as default.
++MBCTYPE_DEF=-DEUC
++
+ # Extra libraries.
+ LIBS=@LIBS@
+@@ -69,9 +79,9 @@
+ #### End of system configuration section. ####
+
+-SRCS=grep.c getopt.c regex.c dfa.c kwset.c obstack.c search.c
+-OBJS=grep.o getopt.o regex.o dfa.o kwset.o obstack.o search.o
++SRCS=grep.c getopt.c regex.c dfa.c kwset.c obstack.c search.c mbc.c
++OBJS=grep.o getopt.o regex.o dfa.o kwset.o obstack.o search.o mbc.o
+
+ .c.o:
+- $(CC) $(CFLAGS) $(DEFS) -I$(srcdir) -c $<
++ $(CC) $(CFLAGS) $(DEFS) $(MBCTYPE_DEF) -I$(srcdir) -c $<
+
+ all: grep check.done
+@@ -120,7 +130,9 @@
+ dist:
+ V=`sed -n '/version\\[/s/.*\\([0-9][0-9]*\\.[0-9]*\\).*/\\1/p' \
++ grep.c`+mb`sed -n '/^ + multi-byte/s/[^0-9]*\\([0-9.]*\\).*/\\1/p' \
+ grep.c`; \
+ mkdir grep-$$V; mkdir grep-$$V/tests; \
+- for f in `awk '{print $$1}' MANIFEST`; do ln $$f grep-$$V/$$f; done; \
++ for f in `awk '{print $$1}' MANIFEST MANIFEST.MB`; \
++ do ln $$f grep-$$V/$$f; done; \
+ tar cvhf - grep-$$V | gzip > grep-$$V.tar.z; \
+ rm -fr grep-$$V
+@@ -132,2 +144,3 @@
+ kwset.o obstack.o: obstack.h
+ regex.o search.o: regex.h
++grep.o regex.o dfa.o search.o mbc.o: mbc.h
+diff -ru2N grep-2.0/Makefile.msc grep+mb1.04/Makefile.msc
+--- grep-2.0/Makefile.msc Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/Makefile.msc Fri Jul 23 04:03:17 1993
+@@ -0,0 +1,138 @@
++# Generated automatically from Makefile.in by configure.
++# Makefile for GNU grep
++# Copyright (C) 1992 Free Software Foundation, Inc.
++
++# This program is free software; you can redistribute it and/or modify
++# it under the terms of the GNU General Public License as published by
++# the Free Software Foundation; either version 2, or (at your option)
++# any later version.
++
++# This program is distributed in the hope that it will be useful,
++# but WITHOUT ANY WARRANTY; without even the implied warranty of
++# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
++# GNU General Public License for more details.
++
++# You should have received a copy of the GNU General Public License
++# along with this program; if not, write to the Free Software
++# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
++
++# Multi-byte extension added May, 1993 by t^2 (Takahiro Tanimoto)
++# Last change: Jul. 23, 1993 by t^2
++
++#### Start of system configuration section. ####
++
++srcdir=.
++VPATH=.
++
++AWK=gawk
++INSTALL=cp
++INSTALL_PROGRAM=$(INSTALL)
++INSTALL_DATA=$(INSTALL)
++
++CC=cl -nologo -D__STDC__ -AL
++LINT=lint
++
++# Things you might add to DEFS:
++# -DSTDC_HEADERS If you have ANSI C headers and libraries.
++# -DHAVE_UNISTD_H If you have unistd.h.
++# -DUSG If you have System V/ANSI C string
++# and memory functions and headers.
++# -D__CHAR_UNSIGNED__ If type `char' is unsigned.
++# gcc defines this automatically.
++#
++# For DOS, add those to DEFS.dos.
++
++# Things you might set to MBCTYPE_DEF to spec. default multi-byte char type.
++# -DEUC will make default multi-byte char type EUC and
++# -DSJIS SJIS.
++# If you do not set EUC/SJIS, grep assumes no multi-byte
++# char as default.
++MBCTYPE_DEF=-DSJIS
++
++# Extra libraries.
++LIBS=setargv/noe/st:30000
++ALLOCA=
++
++CFLAGS=-Ox
++LDFLAGS=$(CFLAGS)
++
++prefix=
++exec_prefix=$(prefix)
++
++# Prefix for installed program, normally empty or `g'.
++binprefix=
++# Prefix for installed man page, normally empty or `g'.
++manprefix=
++
++# Where to install executables.
++bindir=$(exec_prefix)/bin
++
++# Where to install man pages.
++mandir=$(prefix)/man/man1
++
++# Extension for man pages.
++manext=1
++
++# How to make a hard link.
++LN=cp
++
++#### End of system configuration section. ####
++
++SRCS=grep.c getopt.c regex.c dfa.c kwset.c obstack.c search.c mbc.c
++OBJS=grep.obj getopt.obj regex.obj dfa.obj kwset.obj obstack.obj search.obj mbc.obj
++
++.c.obj:
++ cat DEFS.dos $< > $*_.c
++ $(CC) $(CFLAGS) $(MBCTYPE_DEF) -I$(srcdir) -c -Fo$@ $*_.c
++ rm $*_.c
++
++all: grep.exe check.don
++
++# For Saber C.
++grep.loa: $(SRCS)
++ #load $(CFLAGS) $(DEFS) -I$(srcdir) (SRCS)
++
++# For Lint.
++grep.lin: $(SRCS)
++ $(LINT) $(CFLAGS) $(DEFS) -I$(srcdir) $(SRCS)
++
++install: all
++ $(INSTALL_PROGRAM) grep.exe $(bindir)/$(binprefix)grep.exe
++ rm -f $(bindir)/$(binprefix)egrep.exe
++ $(LN) $(bindir)/$(binprefix)grep.exe $(bindir)/$(binprefix)egrep.exe
++ rm -f $(bindir)/$(binprefix)fgrep.exe
++ $(LN) $(bindir)/$(binprefix)grep.exe $(bindir)/$(binprefix)fgrep.exe
++
++check:
++ tests\check
++ echo done >check.don
++
++check.don: grep.exe
++ tests\check
++ echo done >check.don
++
++grep.exe: $(OBJS)
++ echo $(OBJS:.obj =.obj+)+>link.tmp
++ echo $(LIBS)>>link.tmp
++ echo $@/noi;>>link.tmp
++ link @link.tmp
++ rm link.tmp
++
++clean:
++ rm -f grep.exe *.obj check.don tmp.bat tmp.in khadafy.out
++
++mostlycl: clean
++
++distclea: clean
++ rm -f Makefile config.sta
++
++realclea: distclea
++ rm -f TAGS
++
++# Some header file dependencies that really ought to be automatically deduced.
++dfa.obj search.obj: dfa.h
++grep.obj search.obj: grep.h
++kwset.obj search.obj: kwset.h
++kwset.obj obstack.obj: obstack.h
++regex.obj search.obj: regex.h
++grep.obj regex.obj dfa.obj search.obj mbc.obj: mbc.h
+diff -ru2N grep-2.0/README.MB grep+mb1.04/README.MB
+--- grep-2.0/README.MB Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/README.MB Thu Jun 2 17:03:37 1994
+@@ -0,0 +1,327 @@
++$B!|!|!|!|!|(B GNU grep version 2.0 + multi-byte extension 1.04 $B!|!|!|!|!|(B
++$B!|!|!|!|!|(B Jun. 2, 1994 by t^2 $B!|!|!|!|!|(B
++
++ grep-2.0+mb1.04 -- $B%^%k%A%P%$%HJ8;zBP1~HG(B GNU grep
++
++$B!|35MW(B
++
++ GNU $B%W%m%8%'%/%H$K$h$k(B grep, egrep, fgrep ($B0J2<C1$K(B grep) $B$r%^%k%A%P(B
++ $B%$%HJ8;zBP1~2=$7$?$b$N$G$9(B.
++
++$B!|;HMQK!(B
++
++ grep $B$+$i$N3HD%ItJ,$@$1$r@bL@$7$^$9(B.
++
++ $BA}$($?%*%W%7%g%s$O0J2<$NDL$j$G$9(B.
++
++ -Wctype=ASCII
++ $B%^%k%A%P%$%HJ8;z$r9MN8$7$^$;$s(B. $B$3$N%*%W%7%g%s$r;HMQ$7$?>l(B
++ $B9g(B, grep $B$N%*%j%8%J%k$HF1$8F0:n$K$J$k$O$:$G$9(B.
++
++ -Wctype=EUC
++ $B%^%k%A%P%$%HJ8;z$H$7$F(B EUC $B$rG'<1$7$^$9(B.
++
++ -Wctype=SJIS
++ $B%^%k%A%P%$%HJ8;z$H$7$F(B Shift-JIS $B$rG'<1$7$^$9(B.
++
++ MS-DOS $B0J30$N%7%9%F%`$G(B, Makefile(.in)? $B$r=q$-49$($:$K%$%s%9%H!<(B
++ $B%k$7$?>l9g(B, $B%G%U%)%k%H$G$O(B EUC $B$rG'<1$7$^$9(B. MS-DOS $B$G$O%G%U%)(B
++ $B%k%H$G(B Shift-JIS $B$rG'<1$7$^$9(B.
++
++$B!|(B GREM104.LZH (MS-DOS $BHG<B9T7A<0$r4^$`%"!<%+%$%V(B) $B$K$D$$$F(B ($B$=$l0J30$N(B
++ $B7ABV$GF~<j$5$l$?J}$OL5;k$7$F$/$@$5$$(B)
++
++ 1. $B%"!<%+%$%V$K4^$^$l$F$$$k%U%!%$%k(B
++
++ $B%*%j%8%J%k$+$iA4$/<j$r2C$($F$$$J$$%U%!%$%k(B
++
++ AUTHORS $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k(B AUTHORS
++ CHANGELO $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k(B ChangeLog
++ COPYING $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k(B COPYING
++ MANIFEST $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k(B MANIFEST
++ NEWS $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k(B NEWS
++ PROJECTS $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k(B PROJECTS
++ README $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k(B README
++
++ grep+mb $BMQ$N%U%!%$%k(B
++
++ CHANGELO.MB grep+mb $B$NJQ99MzNr(B
++ README.MB $B$3$N%U%!%$%k(B
++
++ MS-DOS $BHG(B grep+mb $BMQ$N%U%!%$%k(B
++
++ GREP.CAT $B%*%j%8%J%k$N%=!<%9$K4^$^$l$F$$$k%^%K%e%"%k%Z!<%8(B.
++ grep.man $B$r(B GNU roff $B$G%U%)!<%^%C%H$7$?$b$N(B.
++ GREP.EXE MS-DOS $BHG(B grep-2.0+mb1.04 $B$N<B9T7A<0(B
++ READMAN.SED sed $B$r;}$C$F$$$k?M$X$*$^$1(B
++ (sed -f readman.sed grep.cat)
++
++ 2. GREP.EXE $B$K$D$$$F(B
++
++ grep-2.0+mb1.04 $B$r(B MS-C 6.00A $B$G%3%s%Q%$%k$7$?$b$N$G$9(B.
++
++ $B%G%U%)%k%H$G(B Shift-JIS $B4A;z%3!<%I$r4^$`%Q%?!<%s$d%F%-%9%H$r=hM}(B
++ $B$G$-$^$9(B.
++
++ setargv.obj $B$rAH$_9~$s$G$"$j$^$9$N$G(B, MS-DOS $B$G%]%T%e%i!<$J%?%$(B
++ $B%W$N%o%$%k%I%+!<%I$,;HMQ$G$-$^$9(B. UNIX $B$N(B csh $B%i%$%/$J%o%$%k%I(B
++ $B%+!<%IE83+%k!<%A%s$rMQ0U$7$h$&$+$H$b;W$C$?$N$G$9$,(B, MS-DOS $B$NB>(B
++ $B$N%3%^%s%I$H$N@09g@-$,<h$l$J$$$7(B, $B%*%j%8%J%k$r$J$k$Y$/B:=E$7$?$+$C(B
++ $B$?$N$GCGG0$7$^$7$?(B.
++
++ 3. $B%$%s%9%H!<%k(B
++
++ GREP.EXE $B$O(B, grep $B$O$b$A$m$s(B, egrep, fgrep $B$N5!G=$r4^$s$G$$$^$9(B.
++ grep $B$K(B -E $B%*%W%7%g%s$rM?$($k$H(B egrep $B$NF0:n(B, -F $B%*%W%7%g%s$rM?(B
++ $B$($k$H(B fgrep $B$NF0:n$r$7$^$9(B. $B$^$?(B, GREP.EXE $B$r(B EGREP.EXE,
++ FGREP.EXE $B$H$$$&L>A0$G%3%T!<$7$F(B egrep, fgrep $B$H$7$F5/F0$9$k$H(B,
++ $B$=$NL>A0$K$U$5$o$7$$F0:n$r$7$^$9(B. $B%O!<%I%G%#%9%/$KM>M5$N$J$$J}(B
++ $B0J30$O(B,
++
++ A>copy grep.exe a:\bin
++ A>copy grep.exe a:\bin\egrep.exe
++ A>copy grep.exe a:\bin\fgrep.exe
++
++ $B$J$I$H$7$F$4;HMQ$K$J$i$l$k$3$H$r$*4+$a$7$^$9(B. $B$I$&$7$F$b%O!<%I(B
++ $B%G%#%9%/$NL5BL;H$$$r$7$?$/$J$1$l$P(B,
++
++ @echo off
++ grep -E %1 %2 %3 %4 %5 %6 %7 %8 %9
++
++ $B$J$I$N%P%C%A%U%!%$%k$r:n@.$9$k$H$$$&<j$b$"$j$^$9(B.
++
++ 4. $B%3%^%s%I%i%$%s0z?t$K$D$$$F(B
++
++ $BA0=R$7$?$H$*$j(B MS-C $B$N(B setargv.obj $B$r%j%s%/$7$F$$$^$9$N$G(B, $B$=$N(B
++ $B;EMM$K=>$o$J$1$l$P$J$j$^$;$s(B.
++
++ $B#1$D#1$D$N0z?t$O6uGr$G6h@Z$j$^$9(B. $B0z?t$K6uGr(B, ", \, <, >, | $B$r(B
++ $B4^$`$H$-$O%/%)!<%F%#%s%0$,I,MW$G$9(B. $B$=$NJ}K!$O(B COMMAND.COM $B$N%P(B
++ $B%0=-$$;EMM$H(B, $B$5$i$K(B setargv.obj $B$K$bLdBj$,$"$j(B, $B$+$J$jFq$7$$$N(B
++ $B$G$3$3$G$O@bL@$r>J$-$^$9(B. $B3F<+8&5f$7$F$/$@$5$$(B. $B0lHV4JC1$J$N$O(B,
++ $B8!:w%Q%?!<%s$r%U%!%$%k$K$7$F(B
++
++ grep -f $B%U%!%$%kL>(B
++
++ $B$H$9$k$3$H$G$9(B.
++
++ 5. $B%^%K%e%"%k(B
++
++ roff $B7O$N%U%)!<%^%C%?$r;H$($J$$?M$N$?$a$K(B GNU roff $B$G%U%)!<%^%C(B
++ $B%H:Q$_$N%^%K%e%"%k$rMQ0U$7$^$7$?(B. $B%\!<%k%I%U%'!<%9(B, $B%"%s%@!<%i(B
++ $B%$%sBP1~$N(B less $B$J$I$G$*FI$_$/$@$5$$(B. $B%(%G%#%?$J$I$G$O(B ^H $B$,F~$C(B
++ $B$F$$$FFI$_$K$/$$$H;W$$$^$9(B.
++
++ s/.^H//g
++
++ $B$H$$$&(B sed $B$N%W%m%0%i%`$KDL$;$P(B, $BDL>o$N%F%-%9%H%U%!%$%k$,F@$i$l(B
++ $B$^$9(B. (^H $B$H$$$&$N$O%3%s%H%m!<%k%3!<%I$rD>@\Kd$a$3$`$H$$$&0UL#(B
++ $B$G$9(B.)
++
++$B!|%$%s%9%H!<%k(B (MS-DOS $B0J30(B)
++
++ $B%G%U%)%k%H$N%^%k%A%P%$%HJ8;z$N@_Dj$O(B, Makefile.in $B$NCf$G;XDj$7$^$9(B.
++ $B%G%U%)%k%H$r(B Shift-JIS $B$H$9$k>l9g$H(B, $B%G%U%)%k%H$G%^%k%A%P%$%HJ8;z$r(B
++ $B;HMQ$7$J$$>l9g$O(B Makefile.in $B$N(B MBCTYPE_DEF $B%^%/%m$NDj5A$r$=$l$>$l0J(B
++ $B2<$N$h$&$KJQ$($F$/$@$5$$(B.
++
++ MBCTYPE_DEF=-DSJIS ($B%G%U%)%k%H$G(B Shift-JIS $B$N>l9g(B)
++ MBCTYPE_DEF= ($B%G%U%)%k%H$G;HMQ$7$J$$>l9g(B)
++
++ $B$$$:$l$N>l9g$G$b5/F0;~$N%*%W%7%g%s$K$h$j%^%k%A%P%$%HJ8;z%3!<%I$NA*Br(B
++ $B$,2DG=$G$9(B.
++
++ $B$=$NB>$N:n6H$O(B, $B%*%j%8%J%k$N(B grep $B$HF1MM$G$9$N$G(B INSTALL $B$r$*FI$_$/(B
++ $B$@$5$$(B.
++
++$B!|%$%s%9%H!<%k(B (MS-DOS $BHG(B. $B$3$3$G$$$&%$%s%9%H!<%k$H$$$&$N$O(B, $B%=!<%9$+$i(B
++ $B$N%$%s%9%H!<%k$N$3$H$G$9(B)
++
++ MS-C 6.00A $B$r;HMQ$7$F(B, $B%G%U%)%k%H$G(B Shift-JIS $B$rG'<1$9$k(B grep $B$r:n@.(B
++ $B$9$k>l9g$O(B, README.MSC $B$KL\$rDL$7$F(B, $BI,MW$J$i%i%$%V%i%j$K%Q%C%A$rEv(B
++ $B$F$?8e(B,
++
++ A>nmake -f makefile.msc
++
++ $B$H$9$k$@$1$G#O#K$G$9(B. grep.exe $B$r:n@.8e(B, $B<+F0E*$K%F%9%H$r9T$$$^$9(B.
++ $B$=$N:](B, grep $B$+$i$N%(%i!<%a%C%;!<%8$,$$$/$D$+I=<($5$l$^$9$,(B, $B$=$l$O(B
++ $B0[>o$G$O$"$j$^$;$s(B. $B%(%i!<$r4^$`%Q%?!<%s$rEO$7$?;~$K(B, $B=*N;%9%F!<%?(B
++ $B%9$,(B 2 $B$H$J$k$3$H$r3NG'$7$F$$$k$@$1$G$9(B. $BK\Ev$K0[>o$,$"$C$?>l9g$O(B
++ "Spencer test #nn faild" (nn $B$O?t;z(B) $B$HI=<($5$l$^$9(B.
++
++ $B%F%9%H$K%Q%9$7$?$i(B, grep.exe $B$rE,Ev$J%G%#%l%/%H%j$K%3%T!<$7$F$/$@$5(B
++ $B$$(B. $B$=$N:](B, $BL>A0$r(B egrep.exe, fgrep.exe $B$HJQ$($k$@$1$G(B, $B$=$l$>$l(B
++ egrep, fgrep $B$NF0:n$r$7$^$9(B. $B$=$3$G(B, $BNc$($P(B a:\bin $B$X%$%s%9%H!<%k$9(B
++ $B$k>l9g(B,
++
++ A>copy grep.exe a:\bin
++ A>copy grep.exe a:\bin\egrep.exe
++ A>copy grep.exe a:\bin\fgrep.exe
++
++ $B$J$I$H$7$^$9(B.
++
++ $B$=$NB>$N=hM}7O$r;HMQ$9$k>l9g$d(B, $B%G%U%)%k%H$r(B Shift-JIS $B0J30$K$9$k>l(B
++ $B9g$O(B Makefile.msc $B$r;29M$K(B Makefile $B$r=q$$$F$/$@$5$$(B. $B$J$*(B, $B%F%9%H$K(B
++ $B$O(B awk (gawk) $B$,I,MW$G$9(B.
++
++$B!|%P%0(B
++
++ 1. $B$$$o$f$k(B JIS $B$K$OBP1~$7$F$$$^$;$s(B. $B>-MhBP1~$9$kM=Dj$b$"$j$^$;$s(B.
++
++ 2. $B%^%k%A%P%$%HJ8;z%3!<%I$O$"$^$j873J$K$O9M$($F$$$^$;$s(B.
++
++ EUC $B#1%P%$%HL\(B ... 0x80 - 0xff
++ EUC $B#2%P%$%HL\(B ... 0x01 - 0xff (0x0a $B$r=|$/(B)
++
++ Shift-JIS $B#1%P%$%HL\(B ... 0x80 - 0x9f, 0xe0 - 0xff
++ Shift-JIS $B#2%P%$%HL\(B ... 0x01 - 0xff (0x0a $B$r=|$/(B)
++
++ $B$H$7$F=hM}$7$F$$$^$9(B. $BH>3Q%+%J$b;H$($^$9(B. EUC $B$N(B SS3 (0x8f) $B$K(B
++ $B;O$^$k#3%P%$%H%3!<%I$O;H$($^$;$s(B. ($B;d$O$3$l$r%5%]!<%H$7$F$$$k%7(B
++ $B%9%F%`$r8+$?$3$H$,$J$$(B...)
++
++ 3. -b $B%*%W%7%g%s$GI=<($5$l$k%P%$%H%*%U%;%C%H$O(B DOS $B$N>l9g(B CR+LF $B$r(B 1
++ $B$H$7$F%+%&%s%H$7$?CM$K$J$j$^$9(B. ($B<jH4$-(B)
++
++$B!|%"%k%4%j%:%`(B (dfa.[ch] $B$N%^%k%A%P%$%HJ8;zBP1~2=(B)
++
++ $B0JA0$OGyA3$H(B, DFA $B$rD>@\(B EUC $B$d(B Shift-JIS $B$N$h$&$JJ8;z<o$NB?$$%3!<%I(B
++ $B%;%C%H$KBP1~$5$;$k$N$O(B, $BHs>o$KFq$7$$$H;W$C$F$$$^$7$?(B. $B$H$3$m$,$"$k(B
++ $BF|(B, $B<+:n%i%$%V%i%j$N%F%9%HMQ$K(B, $B@55,I=8=$r(B DFA $B$XJQ49$9$k4JC1$J%W%m(B
++ $B%0%i%`$r=q$$$?$H$-$K(B, $BFMA3$&$^$$%"%$%G%#%"$,A.$$$?$N$G$9(B. $B%^%k%A%P(B
++ $B%$%HJ8;z$H$$$($I$b7k6I$O%P%$%H$NJB$S$G$9(B. $B%^%k%A%P%$%HJ8;z$r(B, $B$9$Y(B
++ $B$F%P%$%HC10L$KJ,2r$7$F(B, $B@55,I=8=$r:n$C$F$7$^$($P$h$+$C$?$N$G$9(B.
++
++ $B8@MU$G$O$&$^$/I=8=$G$-$J$$$N$G(B, $B0J2<$N5-9f$r;HMQ$7(B, $B$I$&$$$&$U$&$K%P(B
++ $B%$%HC10L$KJ,2r$7$F$$$k$N$+(B, $BNc$r5s$2$^$9(B.
++
++ a, b, c ... $B%7%s%0%k%P%$%HJ8;z(B.
++ x, y, z ... $B%^%k%A%P%$%HJ8;z$N#1J8;zL\(B.
++
++ . ($BG$0U$N#1J8;z(B)
++ ==> [a-c]|[x-z][a-z]
++
++ ($B%7%s%0%k%P%$%HJ8;z$+(B, $B$^$?$O%^%k%A%P%$%HJ8;z$N#1J8;zL\$H(B
++ $BG$0U$N#1J8;z$NO"@\(B.)
++
++ [xb-zx] (xb $B$+$i(B zx $B$NHO0O$N%^%k%A%P%$%HJ8;z(B)
++ ==> x[b-z]|y[a-z]|z[a-x]
++
++ yb*
++ ==> (yb)*
++
++ $B<B:]$K$O@55,I=8=$r:n$j=P$9$N$G$O$J$/(B, $B@55,I=8=$rJ,2r$7$?%H!<%/%s$rD>(B
++ $B@\@8@.$7$F$$$^$9(B. $B$3$NJU(B, $B6=L#$,$"$kJ}$O%=!<%9$r8+$?$[$&$,Aa$$$H;W(B
++ $B$$$^$9(B. ($B$"$^$j%(%l%,%s%H$G$O$"$j$^$;$s$N$G%=!<%9$r$8$C$/$j8+$i$l$k(B
++ $B$N$OCQ$:$+$7$$5$$b$7$^$9$,(B...)
++
++ $B$3$l$@$1$G$O(B, $BNc$($P$"$k%F%-%9%H$+$i(B xy $B$H$$$&J8;z$rC5$=$&$H$9$k$H(B,
++ xxyy $B$N$h$&$JJ8;z$NJB$S$K$^$GH?1~$7$F$7$^$$$^$9(B. $B$=$3$G(B, $B%^%k%A%P%$(B
++ $B%H%b!<%I$N$H$-$K$OI,$:(B "^.*(" + $B%f!<%6%Q%?!<%s(B + ")" $B$H$7$F=hM}$7$^(B
++ $B$9(B. '.*' $B$K$h$j(B, '.' $B$O%^%k%A%P%$%HJ8;z$N0lIt$K$O%^%C%A$7$^$;$s$+$i(B,
++ $BF,=P$7$G$-$k$o$1$G$9(B.
++
++$B!|(B dfa.[ch], regex.[ch] $B$N3HD%;EMM(B
++
++ dfa.[ch], regex.[ch] $B%b%8%e!<%k$O(B mbc.[ch] $B%b%8%e!<%k$K0MB8$7$F$$$^(B
++ $B$9(B. $B$^$?(B, $B$3$l$O%*%j%8%J%k$N;EMM$G$9$,(B, dfa.[ch] $B$r;HMQ$9$k>l9g$O(B
++ regex.h $B$NDj5A$,I,MW$G$9(B.
++
++ $B%^%k%A%P%$%HJ8;z$N%?%$%W$O(B, mbc.[ch] $B$N(B mbcinit() $B$G@_Dj$7$^$9(B.
++ mbc.h $B$KDj5A$5$l$F$$$k%^%/%m(B MBCTYPE_ASCII, MBCTYPE_EUC,
++ MBCTYPE_SJIS $B$N$$$:$l$+$r(B mbcinit() $B$KEO$7$F$/$@$5$$(B.
++
++ dfa.[ch] $B$O(B, $B%Q%?!<%s$N%3%s%Q%$%k;~$K$@$1(B, $B$3$N(B mbc.[ch] $B$N@_Dj$r;2(B
++ $B>H$7$^$9(B. $B%Q%?!<%s%^%C%A%s%0$N:]$O(B, $B%3%s%Q%$%k;~$K@_Dj$5$l$F$$$?(B,
++ $B%^%k%A%P%$%HJ8;z$N%?%$%W$r8!:w$7$^$9(B.
++
++ $B0lJ}(B, regex.[ch] $B$O(B, $B%Q%?!<%s%3%s%Q%$%k;~(B, $B%^%C%A%s%0;~$NN>J}$G(B
++ mbc.[ch] $B$N@_Dj$r;2>H$7$^$9(B. $B$,(B, $B$3$NN><T$G(B mbc.[ch] $B$N@_Dj$rJQ99$9(B
++ $B$k$3$H$O$G$-$^$;$s(B. $B$D$^$j(B, Shift-JIS $B$G5-=R$5$l$?%Q%?!<%s$r(B, EUC
++ $B%F%-%9%H$+$i8!:w$9$k$H$$$C$?F0:n$O$G$-$^$;$s(B. $BCm0U$7$F$/$@$5$$(B.
++
++ $B%^%k%A%P%$%HJ8;zBP1~$KH<$C$FCm0U$9$Y$-@55,I=8=$r0J2<$K5-$7$^$9(B.
++
++ . $BG$0U$N#1%P%$%HJ8;z(B, $B@5Ev$J%^%k%A%P%$%HJ8;z$K%^%C%A$7$^$9(B.
++ $B!V@5Ev$J%^%k%A%P%$%HJ8;z!W$H$O(B, $B%^%k%A%P%$%HJ8;z$N#1J8;z(B
++ $BL\$K(B, '\0' $B$^$?$O(B '\n' $B0J30$,B3$/J8;z$N$3$H$G$9(B.
++
++ [x-y] $BJ8;z%3!<%I(B ($BFbItI=8=(B) $B$,(B x $B$+$i(B y $B$NHO0O$K$"$kG$0U$N#1J8(B
++ $B;z$K%^%C%A$7$^$9(B. $B$3$l$b(B . $B$HF1$8$/(B, $B@5Ev$G$J$$J8;z$K$O(B
++ $B%^%C%A$7$^$;$s(B.
++
++ [^x-y] $BJ8;z%3!<%I(B ($BFbItI=8=(B) $B$,(B x $B$+$i(B y $B$NHO0O$K$J$$G$0U$N#1J8(B
++ $B;z$K%^%C%A$7$^$9(B. $B@5Ev$G$J$$J8;z$K$b%^%C%A$7$^$9(B.
++
++ $B%^%k%A%P%$%HJ8;z$NFbItI=8=$OC1$K#1%P%$%HL\$r>e0L%P%$%H(B, $B#2%P%$%HL\$r(B
++ $B2<0L%P%$%H$H$7$?#1#6%S%C%HId9f$J$7@0?t$G$9(B. Shift-JIS $B$G$b(B EUC $B$G$b(B
++
++ $B#1%P%$%H(B ASCII $BJ8;z(B < $BH>3Q%+%JJ8;z(B < $BA43QJ8;z(B
++
++ $B$H$$$&Bg>.4X78$,@.$jN)$C$F$$$^$9(B.
++
++$B!|$=$NB>(B
++
++ 1. $B%*%j%8%J%k$N(B GNU grep $B$NCx:n8"$O(B Free Software Foundation, Inc.
++ $B$,M-$7$F$$$^$9(B. $B%Q%C%AItJ,(B (grep-mb.diff) $B$NCx:n8"$O;d(B (t^2) $B$,M-(B
++ $B$7$F$$$^$9(B.
++
++ 2. GNU grep $B$N%=!<%9%3!<%I$O3F=j$N(B ftp $B%5%$%H(B, $B$b$7$/$O(B Nifty-serve
++ $B$N(B FUNIX $B$N%G!<%?%i%$%V%i%j$+$iF~<j2DG=$G$9(B. GNU grep $B$+$i(B
++ grep+mb $B$X$N:9J,(B grep-mb.diff $B$O(B, $B;d$,(B FUNIX $B$XEPO?$7(B, $BF21`OBO:;a(B
++ (dohzono@sdsft.kme.mei.co.jp) $B$,(B fj.sources $B$X%]%9%H$7$F$/$@$5$C(B
++ $B$F$$$^$9(B.
++
++ 3. $B:9J,(B grep-mb.diff $B$N:FG[I[$O<+M3$G$9(B. $B$3$l$K4X$7$F$O(B FSF $B$N5,Dj$K(B
++ $B=>$&I,MW$b$"$j$^$;$s(B. $B$7$+$7:9J,$rE,MQ$7$?7k2L$N%=!<%9%3!<%I(B, $B$*(B
++ $B$h$S<B9T7A<0$G$N:FG[I[$N:]$O(B GNU GENERAL PUBLIC LICENSE (COPYING
++ $B;2>H(B) $B$K=>$C$F$/$@$5$$(B.
++
++ grep+mb $B$K2?$i$+$N2~JQ$r2C$($?$b$N$r:FG[I[$9$k:]$b(B, GNU GENERAL
++ PUBLIC LICENSE $B$K=>$&$h$&$KCm0U$7$F$/$@$5$$(B. $B$^$?(B grep+mb $B$K4^$^(B
++ $B$l$k%3!<%I(B (dfa.[ch] $B$d(B regex.[ch]) $B$rMxMQ$7$?%W%m%0%i%`$rG[I[$9(B
++ $B$k:]$b(B GNU GENERAL PUBLIC LICENSE $B$N3:EvItJ,$K=>$C$F$/$@$5$$(B.
++
++ $B$^$?5AL3$G$O$"$j$^$;$s$,:FG[I[$5$l$kJ}$O;v8e$K$G$bO"Mm$r$/$@$5$$(B.
++ $B$=$7$F2DG=$J8B$j(B, $B?7$7$$%P!<%8%g%s$X$N%"%C%W%G!<%H$KEX$a(B, $BMxMQ<T(B
++ $B$+$i$NO"Mm$,;d$KFO$/$h$&$KG[N8$7$F$/$@$5$$(B.
++
++ 4. $B$3$N%W%m%0%i%`$OL5J]>Z$G$9(B.
++
++ 5. grep+mb $B$K2?$i$+$NIT6q9g$,H/@8$7$?>l9g(B, (FSF $B$d(B, $B%*%j%8%J%k$N:n<T(B
++ $B$G$O$J$/(B) $B;d$KO"Mm$7$F$/$@$5$$(B. $BG[I[$7$??M$,4uK>$7$F$$$k>l9g$O(B,
++ $B$=$N?M$KO"Mm$7$F$/$@$5$$(B.
++
++ 6. $B$4<ALd(B/$B$4MWK>(B/$B$*<8$j(B, $B$=$NB>$bBg4?7^$G$9(B. $B$G$-$k$+$.$j%5%]!<%H$7(B
++ $B$^$9(B.
++
++$B!|<U<-(B
++
++ $B86:n<T$*$h$S(B FSF $B$K46<U$7$^$9(B.
++
++ $B%I%-%e%a%s%H:n@.$K4X$7$F=u8@$r$/$@$5$C$?F21`OBO:;a(B
++ (dohzono@sdsft.kme.mei.co.jp) $B$K46<U$7$^$9(B.
++
++ $B$3$l$^$GE>:\(B/$B%P%0Js9p$r$/$@$5$C$?J}!9$K46<U$7$^$9(B. $B<BL>$r5s$2$5$;$F(B
++ $BD:$-$?$+$C$?$N$G$9$,%O!<%I%G%#%9%/$N%H%i%V%k$G$[$H$s$I$N%a!<%k$r>C<:(B
++ $B$5$;$F$7$^$$$^$7$?(B.
++
++ $B:G8e$K(B, $B5.=E$J%G%#%9%/%9%Z!<%9$r(B grep+mb $B$N$?$a$K3d$$$F$4;HMQD:$$$F(B
++ $B$$$k$9$Y$F$NMxMQ<T$NJ}!9$K46<U$7$^$9(B.
++
++$B!|!V;d!W$NO"Mm@h(B
++
++ $B")(B810 $BJ!2,;TCf1{6hG_8w1`CDCO(B 7-207 ($BCm(B: $BE>5o$7$^$7$?(B)
++ TEL/FAX: 092-731-4025 (TEL/FAX $B<+F0@ZBX$((B)
++ 092-724-6342 (TEL $B$N$_(B)
++ E-mail: NBC02362@niftyserve.or.jp $BC+K\9'9@(B
++
++# Local variables:
++# mode: indented-text
++# indent-tabs-mode: nil
++# tab-stop-list: (4 8 16 24 32 40 48 56 64 72 80)
++# left-margin: 4
++# fill-column: 72
++# fill-prefix: " "
++# version-control: never
++# End:
+diff -ru2N grep-2.0/README.MSC grep+mb1.04/README.MSC
+--- grep-2.0/README.MSC Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/README.MSC Sat Mar 5 16:14:14 1994
+@@ -0,0 +1,99 @@
++PC-9801 $BMQ(B MS-C version 6.00A $B$N0z?t$N%;%C%H%"%C%W%k!<%A%s$K$O%P%0$,$"$j(B
++$B$^$9(B.
++
++#include <stdio.h>
++
++int
++main(int argc, char **argv)
++{
++ int i;
++
++ for (i = 0; i <= argc; i++)
++ printf("argv[%d] == %s\n", i, argv[i]);
++ return 0;
++}
++
++$B$r%3%s%Q%$%k(B, $B%j%s%/$7$?(B FOO.EXE $B$K(B
++
++ A>foo "\\" abc
++
++$B$J$I$N0z?t$rEO$7$F<B9T$9$k$H(B, $B%P%0$,3NG'$G$-$^$9(B. $B$^$?(B, $B%o%$%k%I%+!<%I(B
++$BE83+%k!<%A%s$K$b%P%0$,$"$j(B, $B>e5-$N%W%m%0%i%`$r(B SETARGV.OBJ $B$H$H$b$K%j%s(B
++$B%/$7$F(B
++
++ A>foo \DOS\*.com
++
++$B$J$I$N0z?t$G<B9T$9$k$H(B, $B$*$+$7$JE83+$N;EJ}$r$7$F$7$^$$$^$9(B.
++
++$B$3$N%P%0$O(B SOURCE/STARTUP $B2<$N(B DOS/STDARGV.ASM $B$*$h$S(B WILD.C $B$K0J2<$N%Q%C(B
++$B%A$rEv$F$k$H=$@5$G$-$k$h$&$G$9(B. $B%Q%C%A$rEv$F$F(B STARTUP.BAT $B$G%3%s%Q%$%k(B
++$B$7$F$/$@$5$$(B. $B$=$N8e(B, $BNc$($P%i!<%8%b%G%kMQ$N%i%$%V%i%j$r=$@5$9$k>l9g(B,
++L/DOS/STDARGV.OBJ, L/DOS/_SETARGV.OBJ, L/WILD.OBJ $B$r$=$l$>$l(B
++KSTDARGV.OBJ, _KSTARGV.OBJ, KWILD.OBJ $B$H%j%M!<%`$7(B,
++
++ lib \msc6\lib\llibce.lib-+dos\kstdargv.obj-+dos\_kstargv.obj-+kwild.obj;
++
++$B$J$I$H$7$F%b%8%e!<%k$r99?7$7$F$/$@$5$$(B. $BG0$N$?$a$3$N:n6H$r9T$&A0$K(B,
++
++ lib \msc6\lib\llibce.lib*kstdargv.obj*_kstargv.obj*kwild.obj;
++
++$B$J$I$G(B, kstdargv.obj, _kstargv.obj, kwild.obj $B$N%P%C%/%"%C%W$r$H$C$FCV$/(B
++$B$H$$$$$G$7$g$&(B.
++
++$B$J$*(B, $B$3$N%Q%C%A$OEvA3$N$3$H$J$,$iL5J]>Z$G$9(B.
++
++Mar. 5, 1994 t^2
++
++*** stdargv.org Mon Oct 8 19:50:46 1990
++--- stdargv.asm Thu Jul 22 17:50:44 1993
++***************
++*** 409,415 ****
++ shr cx,1
++ adc dx,cx ; add 1 for every pair of backslashes
++ test al,1 ; plus 1 for the " if odd number of \
++! jz arg310 ; [J1]
++ jmp arg210 ; [J1]
++ ;
++ ; Command line is fully parsed - compute number of bytes needed
++--- 409,415 ----
++ shr cx,1
++ adc dx,cx ; add 1 for every pair of backslashes
++ test al,1 ; plus 1 for the " if odd number of \
++! jnz arg310 ; ! Jul.21.93 t^2
++ jmp arg210 ; [J1]
++ ;
++ ; Command line is fully parsed - compute number of bytes needed
++
++*** wild.org Mon Oct 8 19:49:48 1990
++--- wild.c Sat Mar 5 00:42:12 1994
++***************
++*** 186,197 ****
++ char *ptr2 = arg; // [J1]
++
++ if(ptr != arg) { // [J1]
++! while(ptr2 + 1 != ptr && *ptr2 != SLASHCHAR && *ptr2 != FWDSLASHCHAR
++! && *ptr2 != ':') { // [J1]
++ if(iskanji(*ptr2)) ptr2++; // [J1]
++ ptr2++; // [J1]
++ } // [J1]
++! ptr = ptr2; // [J1]
++ } // [J1]
++
++ if (*ptr == ':' && ptr != arg+1) /* weird name, just add it as is */
++--- 186,201 ----
++ char *ptr2 = arg; // [J1]
++
++ if(ptr != arg) { // [J1]
++! char *ptr3 = arg;
++!
++! while (ptr2 < ptr) {
++! if (*ptr2 == SLASHCHAR || *ptr2 == FWDSLASHCHAR
++! || *ptr2 == ':')
++! ptr3 = ptr2;
++ if(iskanji(*ptr2)) ptr2++; // [J1]
++ ptr2++; // [J1]
++ } // [J1]
++! ptr = ptr3;
++ } // [J1]
++
++ if (*ptr == ':' && ptr != arg+1) /* weird name, just add it as is */
+diff -ru2N grep-2.0/configure grep+mb1.04/configure
+--- grep-2.0/configure Sat May 22 13:20:23 1993
++++ grep+mb1.04/configure Fri Jul 9 13:05:45 1993
+@@ -566,5 +566,5 @@
+ fi
+
+-for func in getpagesize memchr strerror valloc
++for func in getpagesize memchr strerror valloc bcopy memmove strcasecmp
+ do
+ trfunc=HAVE_`echo $func | tr '[a-z]' '[A-Z]'`
+diff -ru2N grep-2.0/configure.in grep+mb1.04/configure.in
+--- grep-2.0/configure.in Sat May 22 13:20:16 1993
++++ grep+mb1.04/configure.in Fri Jul 9 13:05:32 1993
+@@ -12,5 +12,5 @@
+ AC_SIZE_T
+ AC_ALLOCA
+-AC_HAVE_FUNCS(getpagesize memchr strerror valloc)
++AC_HAVE_FUNCS(getpagesize memchr strerror valloc bcopy memmove strcasecmp)
+ AC_CHAR_UNSIGNED
+ AC_CONST
+diff -ru2N grep-2.0/dfa.c grep+mb1.04/dfa.c
+--- grep-2.0/dfa.c Mon May 31 08:02:20 1993
++++ grep+mb1.04/dfa.c Sat Jul 10 01:17:14 1993
+@@ -18,4 +18,6 @@
+ /* Written June, 1988 by Mike Haertel
+ Modified July, 1988 by Arthur David Olson to assist BMG speedups */
++/* Multi-byte extension added May, 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 10, 1993 by t^2 */
+
+ #include <assert.h>
+@@ -35,4 +37,8 @@
+ #undef index
+ #define index strchr
++#undef bcopy
++#define bcopy(s, d, n) memcpy(d, s, n)
++#undef bzero
++#define bzero(d, n) memset(d, 0, n)
+ #else
+ #include <strings.h>
+@@ -71,4 +77,5 @@
+ #include "dfa.h"
+ #include "regex.h"
++#include "mbc.h"
+
+ #if __STDC__
+@@ -141,5 +148,8 @@
+ fprintf(stderr, "END");
+ else if (t < NOTCHAR)
+- fprintf(stderr, "%c", t);
++ if (t & 0x80)
++ fprintf(stderr, "0x%02x", (unsigned char)t);
++ else
++ fprintf(stderr, "%c", t);
+ else
+ {
+@@ -239,4 +249,16 @@
+ }
+
++static int
++isemptyset(s)
++ charclass s;
++{
++ int i;
++
++ for (i = 0; i < CHARCLASS_INTS; i++)
++ if (s[i])
++ return 0;
++ return 1;
++}
++
+ /* A pointer to the current dfa is kept here during parsing. */
+ static struct dfa *dfa;
+@@ -259,5 +281,6 @@
+
+ /* Syntax bits controlling the behavior of the lexical analyzer. */
+-static int syntax_bits, syntax_bits_set;
++static unsigned long syntax_bits;
++static int syntax_bits_set;
+
+ /* Flag for case-folding letters into sets. */
+@@ -267,5 +290,5 @@
+ void
+ dfasyntax(bits, fold)
+- int bits;
++ unsigned long bits;
+ int fold;
+ {
+@@ -289,4 +312,66 @@
+ static int minrep, maxrep; /* Repeat counts for {m,n}. */
+
++static charclass cs_cset[8];
++static token cs_tok[8] = {0, 0, 0, 0, 0, 0, 0, 0};
++
++static enum {
++ MBEXTTOK_NONE = -1,
++ MBEXTTOK_NOTCHAR = 256,
++ MBEXTTOK_ORMBC = MBEXTTOK_NOTCHAR,
++ MBEXTTOK_ORMBC_NL,
++ MBEXTTOK_CLASS,
++ MBEXTTOK_INVCLASS,
++} mbexttok = MBEXTTOK_NONE;
++
++static charclass mbcset_set;
++static charclass mbcset_all;
++static charclass mbcset[128]; /* 128*256/8 = 4 Kbytes */
++
++/* $BIQHK$K;HMQ$5$l$k(B ($B$H;W$o$l$k(B) $BJ8;z=89g$r%H!<%/%s$H$7$FJV$9(B.
++ n = 0 ... 1$B%P%$%HJ8;zA4BN$N=89g(B.
++ 1 ... 2$B%P%$%HJ8;z$N(B1$B%P%$%HL\A4BN$N=89g(B.
++ 2 ... 2$B%P%$%HJ8;z$N(B2$B%P%$%HL\A4BN$N=89g(B.
++ +4 ... '\n'$B$r=|30$7$J$$(B. */
++static token
++setcodeset(n)
++ int n;
++{
++ token c;
++
++ if (!cs_tok[n]) {
++ zeroset(cs_cset[n]);
++ switch (n) {
++ case 0:
++ case 4:
++ /* 1$B%P%$%HJ8;zA4BN$N=89g(B. */
++ for (c = 0; c < NOTCHAR; c++)
++ if (ismbchar(c))
++ setbit(c, cs_cset[n]);
++ notset(cs_cset[n]);
++ break;
++ case 1:
++ case 5:
++ /* 2$B%P%$%HJ8;z$N(B1$BJ8;zL\A4BN$N=89g(B. */
++ for (c = 0; c < NOTCHAR; c++)
++ if (ismbchar(c))
++ setbit(c, cs_cset[n]);
++ break;
++ case 2:
++ case 6:
++ /* 2$B%P%$%HJ8;z$N(B2$BJ8;zL\A4BN$N=89g(B. */
++ notset(cs_cset[n]);
++ break;
++ }
++ if (!(n & 4)) {
++ if (syntax_bits & RE_DOT_NOT_NULL || n != 0)
++ clrbit('\0', cs_cset[n]);
++ if (!(syntax_bits & RE_DOT_NEWLINE) || n != 0)
++ clrbit('\n', cs_cset[n]);
++ }
++ cs_tok[n] = CSET + charclass_index(cs_cset[n]);
++ }
++ return cs_tok[n];
++}
++
+ /* Note that characters become unsigned here. */
+ #define FETCH(c, eoferr) \
+@@ -362,4 +447,5 @@
+ it means that just about every case begins with
+ "if (backslash) ...". */
++ mbexttok = MBEXTTOK_NONE;
+ for (i = 0; i < 2; ++i)
+ {
+@@ -543,14 +629,19 @@
+ if (backslash)
+ goto normal_char;
++ if (current_mbctype != MBCTYPE_ASCII)
++ mbexttok = MBEXTTOK_ORMBC;
++ laststart = 0;
++ return setcodeset(0);
++
++ case 'w':
++ if (!backslash)
++ goto normal_char;
+ zeroset(ccl);
+- notset(ccl);
+- if (!(syntax_bits & RE_DOT_NEWLINE))
+- clrbit('\n', ccl);
+- if (syntax_bits & RE_DOT_NOT_NULL)
+- clrbit('\0', ccl);
++ for (c2 = 0; c2 < NOTCHAR; ++c2)
++ if (ISALNUM(c2))
++ setbit(c2, ccl);
+ laststart = 0;
+ return lasttok = CSET + charclass_index(ccl);
+
+- case 'w':
+ case 'W':
+ if (!backslash)
+@@ -558,8 +649,7 @@
+ zeroset(ccl);
+ for (c2 = 0; c2 < NOTCHAR; ++c2)
+- if (ISALNUM(c2))
++ if (!ISALNUM(c2) && !ismbchar(c2))
+ setbit(c2, ccl);
+- if (c == 'W')
+- notset(ccl);
++ mbexttok = MBEXTTOK_ORMBC_NL;
+ laststart = 0;
+ return lasttok = CSET + charclass_index(ccl);
+@@ -579,4 +669,6 @@
+ do
+ {
++ unsigned char ch = 0, c2h = 0;
++
+ /* Nobody ever said this had to be fast. :-)
+ Note that if we're looking at some other [:...:]
+@@ -599,4 +691,8 @@
+ if (c == '\\' && (syntax_bits & RE_BACKSLASH_ESCAPE_IN_LISTS))
+ FETCH(c, "Unbalanced [");
++ if (ismbchar(c)) {
++ ch = (unsigned char)c;
++ FETCH(c, "Multi-byte char incomplete");
++ }
+ FETCH(c1, "Unbalanced [");
+ if (c1 == '-')
+@@ -616,19 +712,83 @@
+ && (syntax_bits & RE_BACKSLASH_ESCAPE_IN_LISTS))
+ FETCH(c2, "Unbalanced [");
++ if (ismbchar(c2)) {
++ c2h = (unsigned char)c2;
++ FETCH(c2, "Multi-byte char incomplete");
++ }
+ FETCH(c1, "Unbalanced [");
+ }
+ }
+- else
++ else {
++ c2h = ch;
+ c2 = c;
+- while (c <= c2)
+- {
+- setbit(c, ccl);
+- if (case_fold)
+- if (ISUPPER(c))
+- setbit(tolower(c), ccl);
+- else if (ISLOWER(c))
+- setbit(toupper(c), ccl);
+- ++c;
++ }
++ if (ch < c2h || (ch == c2h && c <= c2)) {
++ if (ch == 0) {
++ ch = (unsigned char)c2;
++ if (c2h > 0)
++ ch = NOTCHAR - 1;
++ for (; (unsigned char)c <= ch; c++) {
++ setbit(c, ccl);
++ if (case_fold) {
++ if (ISUPPER(c))
++ setbit(tolower(c), ccl);
++ else if (ISLOWER(c))
++ setbit(toupper(c), ccl);
++ }
++ }
++ ch = 0x80;
++ c = 0x00;
+ }
++ if (ch <= c2h) {
++ if (mbexttok < 0) {
++ mbexttok = MBEXTTOK_CLASS;
++ zeroset(mbcset_set);
++ zeroset(mbcset_all);
++ }
++ if (ch < c2h && c != 0x00) { /* $B:G=i$NH>C<(B */
++ int t;
++
++ if (ismbchar(ch)
++ && ((t = tstbit(ch, mbcset_set))
++ || !tstbit(ch, mbcset_all))) {
++ if (!t) {
++ setbit(ch, mbcset_set);
++ zeroset(mbcset[ch - 0x80]);
++ }
++ for (; c < NOTCHAR; c++)
++ setbit(c, mbcset[ch - 0x80]);
++ }
++ ch++;
++ c = 0x00;
++ }
++ if (ch < c2h || (ch == c2h && c == 0x00 && c2 == 0xff)) {
++ if (c == 0x00 && c2 == 0xff)
++ c2h++;
++ for (; ch < c2h; ch++)
++ if (ismbchar(ch)) {
++ clrbit(ch, mbcset_set);
++ setbit(ch, mbcset_all);
++ }
++ if (c == 0x00 && c2 == 0xff)
++ c2h--;
++ c = 0x00;
++ }
++ if (ch <= c2h) {
++ int t;
++
++ /* $B$3$3$G$OI,$:(B c <= c2 $B$H$J$C$F$$$k(B. */
++ if (ismbchar(ch)
++ && ((t = tstbit(ch, mbcset_set))
++ || !tstbit(ch, mbcset_all))) {
++ if (!t) {
++ setbit(ch, mbcset_set);
++ zeroset(mbcset[ch - 0x80]);
++ }
++ for (; c <= c2; c++)
++ setbit(c, mbcset[ch - 0x80]);
++ }
++ }
++ }
++ }
+ skip:
+ ;
+@@ -640,5 +800,20 @@
+ if (syntax_bits & RE_HAT_LISTS_NOT_NEWLINE)
+ clrbit('\n', ccl);
++ if (mbexttok == MBEXTTOK_CLASS) {
++ mbexttok = MBEXTTOK_INVCLASS;
++ if (!isemptyset(mbcset_set)) {
++ for (c = 0x80; c <= 0xff; c++)
++ if (tstbit(c, mbcset_set))
++ notset(mbcset[c - 0x80]);
++ }
++ notset(mbcset_all);
++ }
++ else
++ mbexttok = MBEXTTOK_ORMBC_NL;
+ }
++ if (current_mbctype != MBCTYPE_ASCII)
++ for (c = 0x80; c <= 0xff; c++)
++ if (ismbchar(c))
++ clrbit(c, ccl);
+ laststart = 0;
+ return lasttok = CSET + charclass_index(ccl);
+@@ -647,4 +822,8 @@
+ normal_char:
+ laststart = 0;
++ if (ismbchar(c)) {
++ FETCH(mbexttok, "Multi-byte char incomplete");
++ return c;
++ }
+ if (case_fold && ISALPHA(c))
+ {
+@@ -746,5 +925,67 @@
+ atom()
+ {
+- if ((tok >= 0 && tok < NOTCHAR) || tok >= CSET || tok == BACKREF
++ if (mbexttok >= 0) {
++ if (mbexttok < MBEXTTOK_NOTCHAR) {
++ addtok(tok);
++ addtok(mbexttok);
++ addtok(CAT);
++ }
++ else
++ switch (mbexttok) {
++ case MBEXTTOK_ORMBC:
++ case MBEXTTOK_ORMBC_NL:
++ addtok(tok);
++ if (mbexttok == MBEXTTOK_ORMBC) {
++ addtok(setcodeset(1));
++ addtok(setcodeset(2));
++ }
++ else {
++ addtok(setcodeset(5));
++ addtok(setcodeset(6));
++ }
++ addtok(CAT);
++ addtok(OR);
++ break;
++ case MBEXTTOK_CLASS:
++ case MBEXTTOK_INVCLASS:
++ {
++ token c;
++
++ addtok(tok);
++ if (!isemptyset(mbcset_set))
++ for (c = 0x80; c <= 0xff; c++)
++ if (tstbit(c, mbcset_set)) {
++ /* Make sure all bits in mbcset_all valid. */
++ clrbit(c, mbcset_all);
++ addtok(c);
++ if (mbexttok == MBEXTTOK_CLASS) {
++ clrbit('\n', mbcset[c - 0x80]);
++ clrbit('\0', mbcset[c - 0x80]);
++ }
++ else {
++ setbit('\n', mbcset[c - 0x80]);
++ setbit('\0', mbcset[c - 0x80]);
++ }
++ addtok(CSET + charclass_index(mbcset[c - 0x80]));
++ addtok(CAT);
++ addtok(OR);
++ }
++ if (!isemptyset(mbcset_all)) {
++ addtok(CSET + charclass_index(mbcset_all));
++ if (mbexttok == MBEXTTOK_CLASS)
++ addtok(setcodeset(2));
++ else
++ addtok(setcodeset(6));
++ addtok(CAT);
++ addtok(OR);
++ }
++ }
++ break;
++ default:
++ break;
++ }
++ tok = lex();
++ }
++ else if ((tok >= 0 && tok < NOTCHAR) || tok >= CSET || tok == BACKREF
+ || tok == BEGLINE || tok == ENDLINE || tok == BEGWORD
+ || tok == ENDWORD || tok == LIMWORD || tok == NOTLIMWORD)
+@@ -1904,4 +2145,6 @@
+
+ d->musts = 0;
++
++ bzero(cs_tok, sizeof cs_tok);
+ }
+
+@@ -1916,8 +2159,8 @@
+ if (case_fold) /* dummy folding in service of dfamust() */
+ {
+- char *copy;
++ char *copy, *p;
+ int i;
+
+- copy = malloc(len);
++ p = copy = malloc(len + 7);
+ if (!copy)
+ dfaerror("out of memory");
+@@ -1925,23 +2168,61 @@
+ /* This is a kludge. */
+ case_fold = 0;
++ if (current_mbctype != MBCTYPE_ASCII && searchflag) {
++ *p++ = '^';
++ *p++ = '.';
++ *p++ = '*';
++ if (!(syntax_bits & RE_NO_BK_PARENS))
++ *p++ = '\\';
++ *p++ = '(';
++ }
+ for (i = 0; i < len; ++i)
+ if (ISUPPER(s[i]))
+- copy[i] = tolower(s[i]);
++ *p++ = tolower((unsigned char)s[i]);
+ else
+- copy[i] = s[i];
++ *p++ = s[i];
++ if (current_mbctype != MBCTYPE_ASCII && searchflag) {
++ if (!(syntax_bits & RE_NO_BK_PARENS))
++ *p++ = '\\';
++ *p++ = ')';
++ }
+
+ dfainit(d);
+- dfaparse(copy, len, d);
+- free(copy);
++ dfaparse(copy, p - copy, d);
+ dfamust(d);
+ d->cindex = d->tindex = d->depth = d->nleaves = d->nregexps = 0;
++ bzero(cs_tok, sizeof cs_tok);
+ case_fold = 1;
+- dfaparse(s, len, d);
++ if (current_mbctype != MBCTYPE_ASCII && searchflag) {
++ bcopy(s, copy + (syntax_bits & RE_NO_BK_PARENS ? 4 : 5), len);
++ dfaparse(copy, p - copy, d);
++ }
++ else
++ dfaparse(s, len, d);
+ dfaanalyze(d, searchflag);
++ free(copy);
+ }
+ else
+ {
+ dfainit(d);
+- dfaparse(s, len, d);
++ if (current_mbctype != MBCTYPE_ASCII && searchflag) {
++ char *copy, *p;
++
++ p = copy = malloc(len + 7);
++ *p++ = '^';
++ *p++ = '.';
++ *p++ = '*';
++ if (!(syntax_bits & RE_NO_BK_PARENS))
++ *p++ = '\\';
++ *p++ = '(';
++ bcopy(s, p, len);
++ p += len;
++ if (!(syntax_bits & RE_NO_BK_PARENS))
++ *p++ = '\\';
++ *p++ = ')';
++ dfaparse(copy, p - copy, d);
++ free(copy);
++ }
++ else
++ dfaparse(s, len, d);
+ dfamust(d);
+ dfaanalyze(d, searchflag);
+diff -ru2N grep-2.0/dfa.h grep+mb1.04/dfa.h
+--- grep-2.0/dfa.h Mon Apr 12 06:17:22 1993
++++ grep+mb1.04/dfa.h Wed Jul 7 17:02:13 1993
+@@ -15,4 +15,6 @@
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
++/* Multi-byte extension added May, 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 7, 1993 by t^2 */
+
+ /* Written June, 1988 by Mike Haertel */
+@@ -306,5 +308,5 @@
+ /* dfasyntax() takes two arguments; the first sets the syntax bits described
+ earlier in this file, and the second sets the case-folding flag. */
+-extern void dfasyntax(int, int);
++extern void dfasyntax(unsigned long, int);
+
+ /* Compile the given string of the given length into the given struct dfa.
+diff -ru2N grep-2.0/getpagesize.h grep+mb1.04/getpagesize.h
+--- grep-2.0/getpagesize.h Fri May 21 14:18:58 1993
++++ grep+mb1.04/getpagesize.h Sat Jul 10 02:19:10 1993
+@@ -1,2 +1,4 @@
++/* Multi-byte extension added Jul., 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 10, 1993 by t^2 */
+ #ifdef BSD
+ #ifndef BSD4_1
+@@ -35,5 +37,9 @@
+ #endif /* no EXEC_PAGESIZE */
+ #else /* !HAVE_SYS_PARAM_H */
++#ifndef MSDOS
+ #define getpagesize() 8192 /* punt totally */
++#else
++#define getpagesize() 4096
++#endif
+ #endif /* !HAVE_SYS_PARAM_H */
+ #endif /* no _SC_PAGESIZE */
+diff -ru2N grep-2.0/grep.c grep+mb1.04/grep.c
+--- grep-2.0/grep.c Sun May 23 14:52:52 1993
++++ grep+mb1.04/grep.c Thu Jun 2 17:01:53 1994
+@@ -17,4 +17,6 @@
+
+ Written July 1992 by Mike Haertel. */
++/* Multi-byte extension added May, 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jun. 2, 1994 by t^2 */
+
+ #include <errno.h>
+@@ -22,6 +24,8 @@
+
+ #ifndef errno
++#ifndef MSDOS
+ extern int errno;
+ #endif
++#endif
+
+ #ifdef STDC_HEADERS
+@@ -59,4 +63,5 @@
+ #include "getpagesize.h"
+ #include "grep.h"
++#include "mbc.h"
+
+ #undef MAX
+@@ -315,6 +320,6 @@
+ cc = read(bufdesc, buffer + bufsalloc, bufalloc - bufsalloc);
+ #endif
+- if (cc > 0)
+- buflim = buffer + bufsalloc + cc;
++ if (cc != -1)
++ buflim = buffer + bufsalloc + (unsigned)cc;
+ else
+ buflim = buffer + bufsalloc;
+@@ -332,10 +337,10 @@
+
+ /* Internal variables to keep track of byte count, context, etc. */
+-static size_t totalcc; /* Total character count before bufbeg. */
++static unsigned long totalcc; /* Total character count before bufbeg. */
+ static char *lastnl; /* Pointer after last newline counted. */
+ static char *lastout; /* Pointer after last character output;
+ NULL if no character has been output
+ or if it's conceptually before bufbeg. */
+-static size_t totalnl; /* Total newline count before lastnl. */
++static unsigned long totalnl; /* Total newline count before lastnl. */
+ static int pending; /* Pending lines of output. */
+
+@@ -363,5 +368,5 @@
+ {
+ nlscan(beg);
+- printf("%d%c", ++totalnl, sep);
++ printf("%lu%c", ++totalnl, sep);
+ lastnl = lim;
+ }
+@@ -519,5 +524,5 @@
+ for (;;)
+ {
+- if (fillbuf(save) < 0)
++ if (fillbuf(save) == -1)
+ {
+ error(filename, errno);
+@@ -564,8 +569,10 @@
+ }
+
+-static char version[] = "GNU grep version 2.0";
++static char version[] = "GNU grep version 2.0\
++ + multi-byte extension 1.04";
+
+ #define USAGE \
+- "usage: %s [-[[AB] ]<num>] [-[CEFGVchilnqsvwx]] [-[ef]] <expr> [<files...>]\n"
++ "usage: %s [-[[AB] ]<num>] [-[CEFGVchilnqsvwx]] [-W ctype=...]\n\
++ [-[ef]] <expr> [<files...>]\n"
+
+ static void
+@@ -594,4 +601,32 @@
+ }
+
++#ifndef HAVE_STRCASECMP
++
++static int
++#ifdef __STDC__
++strcasecmp(const char *s1, const char *s2)
++#else
++strcasecmp(s1, s2)
++ char *s1, *s2;
++#endif
++{
++ unsigned char c1, c2;
++
++ while ((c1 = *s1++)) {
++ if ((unsigned char)(c1 - 'A') <= (unsigned char)('Z' - 'A'))
++ c1 += 'a' - 'A';
++ c2 = *s2++;
++ if ((unsigned char)(c2 - 'A') <= (unsigned char)('Z' - 'A'))
++ c2 += 'a' - 'A';
++ if (c1 != c2) {
++ --s2;
++ break;
++ }
++ }
++ return c1 - (unsigned char)*s2;
++}
++
++#endif
++
+ int
+ main(argc, argv)
+@@ -607,7 +642,27 @@
+ extern int optind;
+
+- prog = argv[0];
+- if (prog && strrchr(prog, '/'))
+- prog = strrchr(prog, '/') + 1;
++ if ((prog = argv[0]) && prog[0]) {
++ char c, *p;
++#ifdef MSDOS
++ static char progname[8 + 1];
++#endif
++
++ for (p = prog; (c = *p++); )
++ if (c == '/'
++#ifdef MSDOS
++ || c == '\\' || c == ':'
++#endif
++ )
++ prog = p;
++#ifdef MSDOS
++ for (p = progname; p < &progname[8] && (c = *prog++) && c != '.'; ) {
++ if ((unsigned char)(c - 'A') <= (unsigned char)('Z' - 'A'))
++ c += 'a' - 'A';
++ *p++ = c;
++ }
++ *p++ = '\0';
++ prog = argv[0] = progname;
++#endif
++ }
+
+ keys = NULL;
+@@ -620,5 +675,5 @@
+ matcher = NULL;
+
+- while ((opt = getopt(argc, argv, "0123456789A:B:CEFGVX:bce:f:hiLlnqsvwxy"))
++ while ((opt = getopt(argc, argv, "0123456789A:B:CEFGVX:bce:f:hiLlnqsvwxyW:"))
+ != EOF)
+ switch (opt)
+@@ -747,4 +802,19 @@
+ case 'x':
+ match_lines = 1;
++ break;
++ case 'W':
++ if (strcasecmp(optarg, "ctype=ASCII") == 0) {
++ mbcinit(MBCTYPE_ASCII);
++ break;
++ }
++ if (strcasecmp(optarg, "ctype=EUC") == 0) {
++ mbcinit(MBCTYPE_EUC);
++ break;
++ }
++ if (strcasecmp(optarg, "ctype=SJIS") == 0) {
++ mbcinit(MBCTYPE_SJIS);
++ break;
++ }
++ fatal("unknown argument to -Wctype", 0);
+ break;
+ default:
+diff -ru2N grep-2.0/kwset.c grep+mb1.04/kwset.c
+--- grep-2.0/kwset.c Mon May 3 04:26:20 1993
++++ grep+mb1.04/kwset.c Fri Jul 9 14:54:46 1993
+@@ -19,4 +19,6 @@
+ The author may be reached (Email) at the address mike@ai.mit.edu,
+ or (US mail) as Mike Haertel c/o Free Software Foundation. */
++/* Multi-byte extension added Jul, 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 9, 1993 by t^2 */
+
+ /* The algorithm implemented by these routines bears a startling resemblence
+@@ -592,5 +594,5 @@
+ if (d != 0)
+ continue;
+- if (tp[-2] == gc)
++ if (U(tp[-2]) == gc)
+ {
+ for (i = 3; i <= len && U(tp[-i]) == U(sp[-i]); ++i)
+diff -ru2N grep-2.0/mbc.c grep+mb1.04/mbc.c
+--- grep-2.0/mbc.c Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/mbc.c Fri Jul 9 14:38:28 1993
+@@ -0,0 +1,98 @@
++/* Functions for multi-byte support.
++ Created for grep multi-byte extension Jul., 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 9, 1993 by t^2 */
++#include "mbc.h"
++
++static const unsigned char mbctab_ascii[] = {
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
++};
++
++static const unsigned char mbctab_euc[] = {
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1
++};
++
++static const unsigned char mbctab_sjis[] = {
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1
++};
++
++#ifdef EUC
++const unsigned char *mbctab = mbctab_euc;
++int current_mbctype = MBCTYPE_EUC;
++#else
++#ifdef SJIS
++const unsigned char *mbctab = mbctab_sjis;
++int current_mbctype = MBCTYPE_SJIS;
++#else
++const unsigned char *mbctab = mbctab_ascii;
++int current_mbctype = MBCTYPE_ASCII;
++#endif
++#endif
++
++void
++#ifdef __STDC__
++mbcinit(int mbctype)
++#else
++mbcinit(mbctype)
++ int mbctype;
++#endif
++{
++ switch (mbctype) {
++ case MBCTYPE_ASCII:
++ mbctab = mbctab_ascii;
++ current_mbctype = MBCTYPE_ASCII;
++ break;
++ case MBCTYPE_EUC:
++ mbctab = mbctab_euc;
++ current_mbctype = MBCTYPE_EUC;
++ break;
++ case MBCTYPE_SJIS:
++ mbctab = mbctab_sjis;
++ current_mbctype = MBCTYPE_SJIS;
++ break;
++ }
++}
+diff -ru2N grep-2.0/mbc.h grep+mb1.04/mbc.h
+--- grep-2.0/mbc.h Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/mbc.h Fri Jul 9 14:40:03 1993
+@@ -0,0 +1,38 @@
++#ifndef MBC_H
++#define MBC_H 1
++/* Definitions for multi-byte support.
++ Created for grep multi-byte extension Jul., 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 9, 1993 by t^2 */
++
++#ifndef const
++#ifndef __STDC__
++#ifdef __GNUC__
++#define const __const__
++#define volatile __volatile__
++#else
++#define const
++#define volatile
++#endif
++#endif
++#endif
++
++#ifndef _
++#ifdef __STDC__
++#define _(x) x
++#else
++#define _(x) ()
++#endif
++#endif
++
++#define MBCTYPE_ASCII 0
++#define MBCTYPE_EUC 1
++#define MBCTYPE_SJIS 2
++
++extern const unsigned char *mbctab;
++extern int current_mbctype;
++
++void mbcinit _((int));
++
++#define ismbchar(c) mbctab[(unsigned char)c]
++
++#endif /* !MBC_H */
+diff -ru2N grep-2.0/obstack.h grep+mb1.04/obstack.h
+--- grep-2.0/obstack.h Sat May 22 11:55:23 1993
++++ grep+mb1.04/obstack.h Sat Jul 10 04:47:06 1993
+@@ -15,4 +15,6 @@
+ along with this program; if not, write to the Free Software
+ Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
++/* Multi-byte extension added Jul., 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 10, 1993 by t^2 */
+
+ /* Summary:
+@@ -136,4 +138,5 @@
+ #endif
+
++#ifndef PTR_INT_TYPE
+ #ifdef __STDC__
+ #define PTR_INT_TYPE ptrdiff_t
+@@ -141,4 +144,5 @@
+ #define PTR_INT_TYPE long
+ #endif
++#endif
+
+ struct _obstack_chunk /* Lives at front of each chunk. */
+@@ -151,5 +155,5 @@
+ struct obstack /* control current object in current chunk */
+ {
+- long chunk_size; /* preferred size to allocate chunks in */
++ unsigned chunk_size; /* preferred size to allocate chunks in */
+ struct _obstack_chunk* chunk; /* address of current struct obstack_chunk */
+ char *object_base; /* address of object we are building */
+diff -ru2N grep-2.0/regex.c grep+mb1.04/regex.c
+--- grep-2.0/regex.c Fri May 21 14:11:40 1993
++++ grep+mb1.04/regex.c Thu Aug 19 04:37:03 1993
+@@ -19,4 +19,6 @@
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
++/* Multi-byte extension added May, 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Aug. 19, 1993 by t^2 */
+
+ /* AIX requires this to be the first thing in the file. */
+@@ -54,6 +56,33 @@
+ #define bcmp(s1, s2, n) memcmp ((s1), (s2), (n))
+ #endif
++#ifdef HAVE_MEMMOVE
+ #ifndef bcopy
+-#define bcopy(s, d, n) memcpy ((d), (s), (n))
++#define bcopy(s, d, n) memmove ((d), (s), (n))
++#endif
++#else
++#ifndef HAVE_BCOPY
++static void
++#ifdef __STDC__
++bcopy (const void *s0, void *d0, size_t n)
++#else
++bcopy (s, d, n)
++ const void *s0;
++ void *d;
++ size_t n;
++#endif
++{
++ const char *s = s0;
++ char *d = d0;
++
++ if (s < d) {
++ s += n, d += n;
++ while (n--)
++ *--d = *--s;
++ }
++ else
++ while (n--)
++ *d++ = *s++;
++}
++#endif
+ #endif
+ #ifndef bzero
+@@ -124,4 +153,5 @@
+ /* Get the interface, including the syntax bits. */
+ #include "regex.h"
++#include "mbc.h"
+
+ /* isalpha etc. are used for the character classes. */
+@@ -462,4 +492,19 @@
+
+ #endif /* DEBUG */
++
++#define STORE_MBC(p, c) \
++ ((p)[0] = (unsigned char) ((c) >> 8), (p)[1] = (unsigned char) (c))
++#define STORE_MBC_AND_INCR(p, c) \
++ (*(p)++ = (unsigned char) ((c) >> 8), *(p)++ = (unsigned char) (c))
++
++#define EXTRACT_MBC(p) \
++ ((unsigned char) (p)[0] << 8 | (unsigned char) (p)[1])
++#define EXTRACT_MBC_AND_INCR(p) \
++ ((p) += 2, (unsigned char) (p)[-2] << 8 | (unsigned char) (p)[-1])
++
++#define EXTRACT_UNSIGNED(p) \
++ ((unsigned char) (p)[0] | (unsigned char) (p)[1] << 8)
++#define EXTRACT_UNSIGNED_AND_INCR(p) \
++ ((p) += 2, (unsigned char) (p)[-2] | (unsigned char) (p)[-1] << 8)
+
+ /* If DEBUG is defined, Regex prints many voluminous messages about what
+@@ -558,4 +603,8 @@
+ {
+ putchar ('/');
++ if (ismbchar (*p) && 2 <= mcnt) {
++ printf ("/%.2s", (char *) p), p += 2, --mcnt;
++ continue;
++ }
+ printchar (*p++);
+ }
+@@ -618,7 +667,14 @@
+ printchar (last);
+
+- putchar (']');
+-
+ p += 1 + *p;
++ {
++ unsigned short i, size;
++
++ size = EXTRACT_UNSIGNED_AND_INCR (p);
++ for (i = 0; i < size; i++)
++ printf ("%.2s-%.2s", (char *) p, (char *) p + 2),
++ p += 4;
++ }
++ putchar (']');
+ }
+ break;
+@@ -779,5 +835,5 @@
+ printf ("not_bol: %d\t", bufp->not_bol);
+ printf ("not_eol: %d\t", bufp->not_eol);
+- printf ("syntax: %d\n", bufp->syntax);
++ printf ("syntax: %lu\n", bufp->syntax);
+ /* Perhaps we should print the translate table? */
+ }
+@@ -878,5 +934,7 @@
+ static boolean at_begline_loc_p (), at_endline_loc_p ();
+ static boolean group_in_compile_stack ();
++#if 0
+ static reg_errcode_t compile_range ();
++#endif
+
+ /* Fetch the next character in the uncompiled pattern---translating it
+@@ -887,5 +945,6 @@
+ do {if (p == pend) return REG_EEND; \
+ c = (unsigned char) *p++; \
+- if (translate) c = translate[c]; \
++ if (translate && !ismbchar (c)) \
++ c = (unsigned char) translate[(unsigned char) c]; \
+ } while (0)
+
+@@ -905,5 +964,7 @@
+ `char *', to avoid warnings when a string constant is passed. But
+ when we use a character as a subscript we must make it unsigned. */
+-#define TRANSLATE(d) (translate ? translate[(unsigned char) (d)] : (d))
++#define TRANSLATE(d) (translate \
++ ? (unsigned char) translate[(unsigned char) (d)] \
++ : (d))
+
+
+@@ -1075,4 +1136,159 @@
+ || STREQ (string, "cntrl") || STREQ (string, "blank"))
+
++/* Handle charset(_not)?.
++
++ Structure of charset(_not)? in compiled pattern.
++
++ struct {
++ unsinged char id; charset(_not)?
++ unsigned char sbc_size;
++ unsigned char sbc_map[sbc_size]; same as original up to here.
++ unsigned short mbc_size; number of intervals.
++ struct {
++ unsigned short beg; beginning of interval.
++ unsigned short end; end of interval.
++ } intervals[mbc_size];
++ }; */
++
++static reg_errcode_t
++#ifdef __STDC__
++set_list_bits (unsigned short c1, unsigned short c2,
++ reg_syntax_t syntax, unsigned char *b, const char *translate)
++#else
++set_list_bits (c1, c2, syntax, b, translate)
++ unsigned short c1, c2;
++ reg_syntax_t syntax;
++ unsigned char *b;
++ const char *translate;
++#endif
++{
++ unsigned char sbc_size = b[-1];
++ unsigned short mbc_size = EXTRACT_UNSIGNED (&b[sbc_size]);
++ unsigned short beg, end, upb;
++
++ if (c1 > c2)
++ return syntax & RE_NO_EMPTY_RANGES ? REG_ERANGE : REG_NOERROR;
++ if (c1 < 1 << BYTEWIDTH) {
++ upb = c2;
++ if (1 << BYTEWIDTH <= upb)
++ upb = (1 << BYTEWIDTH) - 1; /* The last single-byte char */
++ if (sbc_size <= upb / BYTEWIDTH) {
++ /* Allocate maximum size so it never happens again. */
++ /* NOTE: memcpy() would not work here. */
++ bcopy (&b[sbc_size], &b[(1 << BYTEWIDTH) / BYTEWIDTH], 2 + mbc_size*4);
++ bzero (&b[sbc_size], (1 << BYTEWIDTH) / BYTEWIDTH - sbc_size);
++ b[-1] = sbc_size = (1 << BYTEWIDTH) / BYTEWIDTH;
++ }
++ if (!translate) {
++ for (; c1 <= upb; c1++)
++ if (!ismbchar (c1))
++ SET_LIST_BIT (c1);
++ }
++ else
++ for (; c1 <= upb; c1++)
++ if (!ismbchar (c1))
++ SET_LIST_BIT (TRANSLATE (c1));
++ if (c2 < 1 << BYTEWIDTH)
++ return REG_NOERROR;
++ c1 = 0x8000; /* The first wide char */
++ }
++ b = &b[sbc_size + 2];
++
++ /* intervals[beg]
++ $B!|(B----------$B!|(B $B!|(B----------$B!|(B
++ c1
++ $B!{(B----------------------$B!|(B
++
++ $B>e?^$N$h$&$J6h4V$N%$%s%G%C%/%9(B beg $B$r7hDj$9$k(B. */
++ for (beg = 0, upb = mbc_size; beg < upb; ) {
++ unsigned short mid = (beg + upb) >> 1;
++
++ if (c1 - 1 > EXTRACT_MBC (&b[mid*4 + 2]))
++ beg = mid + 1;
++ else
++ upb = mid;
++ }
++
++ /* intervals[end]
++ $B!|(B-------$B!|(B $B!|(B----------$B!|(B
++ c2
++ $B!|(B---------------$B!{(B
++
++ $B>e?^$N$h$&$J6h4V$N%$%s%G%C%/%9(B end $B$r7hDj$9$k(B. */
++ for (end = beg, upb = mbc_size; end < upb; ) {
++ unsigned short mid = (end + upb) >> 1;
++
++ if (c2 >= EXTRACT_MBC (&b[mid*4]) - 1)
++ end = mid + 1;
++ else
++ upb = mid;
++ }
++
++ if (beg != end) {
++ /* $B4{B8$N6h4V$r>/$J$/$H$b(B1$B$DE}9g$9$k>l9g(B,
++ $B6h4V$N;OE@(B, $B=*E@$r=$@5$9$k(B. */
++ if (c1 > EXTRACT_MBC (&b[beg*4]))
++ c1 = EXTRACT_MBC (&b[beg*4]);
++ if (c2 < EXTRACT_MBC (&b[end*4 - 2]))
++ c2 = EXTRACT_MBC (&b[end*4 - 2]);
++ }
++ if (end < mbc_size && end != beg + 1)
++ /* $BDI2C$5$l$k6h4V$N8e$m$K4{B8$N6h4V$r0\F0$9$k(B. */
++ /* NOTE: memcpy() would not work here. */
++ bcopy (&b[end*4], &b[(beg + 1)*4], (mbc_size - end)*4);
++ STORE_MBC (&b[beg*4 + 0], c1);
++ STORE_MBC (&b[beg*4 + 2], c2);
++ mbc_size += beg + 1 - end;
++ STORE_NUMBER (&b[-2], mbc_size);
++ return REG_NOERROR;
++}
++
++static int
++#ifdef __STDC__
++is_in_list (unsigned short c, const unsigned char *b)
++#else
++is_in_list (c, b)
++ unsigned short c;
++ const unsigned char *b;
++#endif
++{
++ unsigned short size;
++ int in = (re_opcode_t) b[-1] == charset_not;
++
++ size = *b++;
++ if (c < 1 << BYTEWIDTH) {
++ if (c / BYTEWIDTH < size && b[c / BYTEWIDTH] & 1 << c % BYTEWIDTH)
++ in = !in;
++ }
++ else {
++ unsigned short i, j;
++
++ b += size + 2;
++ size = EXTRACT_UNSIGNED (&b[-2]);
++
++ /* intervals[i]
++ $B!|(B-------$B!|(B $B!|(B--------$B!|(B
++ c
++ $B!{(B----------------$B!|(B
++
++ $B>e?^$N$h$&$J6h4V$N%$%s%G%C%/%9(B i $B$r7hDj$9$k(B. */
++ for (i = 0, j = size; i < j; ) {
++ unsigned short k = (i + j) >> 1;
++
++ if (c > EXTRACT_MBC (&b[k*4 + 2]))
++ i = k + 1;
++ else
++ j = k;
++ }
++ if (i < size && EXTRACT_MBC (&b[i*4]) <= c
++ /* [...] $B$+$i(B, $BL58z$J%^%k%A%P%$%HJ8;z$r=|30$9$k(B. $B$3$3$G$O4JC1$N(B
++ $B$?$a#2%P%$%HL\$,(B '\n' $B$^$?$O(B '\0' $B$@$1$rL58z$H$7$?(B. [^...]
++ $B$N>l9g$O(B, $B5U$KL58z$J%^%k%A%P%$%HJ8;z$r%^%C%A$5$;$k(B. */
++ && ((unsigned char) c != '\n' && (unsigned char) c != '\0'))
++ in = !in;
++ }
++ return in;
++}
++
+ /* `regex_compile' compiles PATTERN (of length SIZE) according to SYNTAX.
+ Returns one of error codes defined in `regex.h', or zero for success.
+@@ -1385,4 +1601,6 @@
+ {
+ boolean had_char_class = false;
++ unsigned short c, c1;
++ int last_char = -1;
+
+ if (p == pend) return REG_EBRACK;
+@@ -1390,5 +1608,6 @@
+ /* Ensure that we have enough space to push a charset: the
+ opcode, the length count, and the bitset; 34 bytes in all. */
+- GET_BUFFER_SPACE (34);
++ /* + 2 + 4 for mbcharset(_not)? with just one interval. */
++ GET_BUFFER_SPACE (34 + 2 + 4);
+
+ laststart = b;
+@@ -1407,5 +1626,5 @@
+
+ /* Clear the whole map. */
+- bzero (b, (1 << BYTEWIDTH) / BYTEWIDTH);
++ bzero (b, (1 << BYTEWIDTH) / BYTEWIDTH + 2);
+
+ /* charset_not matches newline according to a syntax bit. */
+@@ -1417,7 +1636,14 @@
+ for (;;)
+ {
++ int size;
++
+ if (p == pend) return REG_EBRACK;
+
+- PATFETCH (c);
++ if ((size = EXTRACT_UNSIGNED (&b[(1 << BYTEWIDTH) / BYTEWIDTH])))
++ /* Ensure the space is enough to hold another interval
++ of multi-byte chars in charset(_not)?. */
++ GET_BUFFER_SPACE (32 + 2 + size*4 + 4);
++
++ PATFETCH_RAW (c);
+
+ /* \ might escape characters inside [...] and [^...]. */
+@@ -1426,6 +1652,16 @@
+ if (p == pend) return REG_EESCAPE;
+
+- PATFETCH (c1);
+- SET_LIST_BIT (c1);
++ PATFETCH_RAW (c1);
++ if (ismbchar (c1)) {
++ unsigned char c2;
++
++ PATFETCH_RAW (c2);
++ c1 = c1 << 8 | c2;
++ (void) set_list_bits (c1, c1, syntax, b, translate);
++ last_char = c1;
++ continue;
++ }
++ SET_LIST_BIT (TRANSLATE (c1));
++ last_char = c1;
+ continue;
+ }
+@@ -1442,4 +1678,11 @@
+ return REG_ERANGE;
+
++ if (ismbchar (c)) {
++ unsigned char c2;
++
++ PATFETCH_RAW (c2);
++ c = c << 8 | c2;
++ }
++
+ /* Look ahead to see if it's a range when the last thing
+ was a character: if this is a hyphen not at the
+@@ -1447,10 +1690,25 @@
+ operator. */
+ if (c == '-'
++#if 0 /* The original was: */
+ && !(p - 2 >= pattern && p[-2] == '[')
+ && !(p - 3 >= pattern && p[-3] == '[' && p[-2] == '^')
++#else /* I wonder why he did not write like this.
++ Have we got any problems? */
++ && p != p1 + 1
++#endif
+ && *p != ']')
+ {
+- reg_errcode_t ret
+- = compile_range (&p, pend, translate, syntax, b);
++ reg_errcode_t ret;
++
++ assert (last_char >= 0);
++ PATFETCH_RAW (c1);
++ if (ismbchar (c1)) {
++ unsigned char c2;
++
++ PATFETCH_RAW (c2);
++ c1 = c1 << 8 | c2;
++ }
++ ret = set_list_bits (last_char, c1, syntax, b, translate);
++ last_char = c1;
+ if (ret != REG_NOERROR) return ret;
+ }
+@@ -1461,7 +1719,15 @@
+
+ /* Move past the `-'. */
+- PATFETCH (c1);
+-
+- ret = compile_range (&p, pend, translate, syntax, b);
++ PATFETCH_RAW (c1);
++
++ PATFETCH_RAW (c1);
++ if (ismbchar (c1)) {
++ unsigned char c2;
++
++ PATFETCH_RAW (c2);
++ c1 = c1 << 8 | c2;
++ }
++ ret = set_list_bits (c, c1, syntax, b, translate);
++ last_char = c1;
+ if (ret != REG_NOERROR) return ret;
+ }
+@@ -1474,5 +1740,5 @@
+ char str[CHAR_CLASS_MAX_LENGTH + 1];
+
+- PATFETCH (c);
++ PATFETCH_RAW (c);
+ c1 = 0;
+
+@@ -1534,4 +1800,7 @@
+ }
+ had_char_class = true;
++#ifdef DEBUG
++ last_char = -1;
++#endif
+ }
+ else
+@@ -1540,7 +1809,13 @@
+ while (c1--)
+ PATUNFETCH;
++#if 0 /* The original was: */
+ SET_LIST_BIT ('[');
+ SET_LIST_BIT (':');
++#else /* I think this is the right way. */
++ SET_LIST_BIT (TRANSLATE ('['));
++ SET_LIST_BIT (TRANSLATE (':'));
++#endif
+ had_char_class = false;
++ last_char = ':';
+ }
+ }
+@@ -1548,5 +1823,6 @@
+ {
+ had_char_class = false;
+- SET_LIST_BIT (c);
++ (void) set_list_bits (c, c, syntax, b, translate);
++ last_char = c;
+ }
+ }
+@@ -1556,5 +1832,9 @@
+ while ((int) b[-1] > 0 && b[b[-1] - 1] == 0)
+ b[-1]--;
+- b += b[-1];
++ if (b[-1] != (1 << BYTEWIDTH) / BYTEWIDTH)
++ bcopy (&b[(1 << BYTEWIDTH) / BYTEWIDTH], &b[b[-1]],
++ 2 + EXTRACT_UNSIGNED (&b[(1 << BYTEWIDTH) / BYTEWIDTH])*4);
++ b += b[-1] + 2 + EXTRACT_UNSIGNED (&b[b[-1]])*4;
++ break;
+ }
+ break;
+@@ -2023,5 +2303,6 @@
+ not to translate; but if we don't translate it
+ it will never match anything. */
+- c = TRANSLATE (c);
++ if (!ismbchar (c))
++ c = TRANSLATE (c);
+ goto normal_char;
+ }
+@@ -2032,4 +2313,11 @@
+ /* Expects the character in `c'. */
+ normal_char:
++
++ c1 = 0;
++ if (ismbchar (c)) {
++ c1 = c;
++ PATFETCH_RAW (c);
++ }
++
+ /* If no exactn currently being built. */
+ if (!pending_exact
+@@ -2039,5 +2327,6 @@
+
+ /* We have only one byte following the exactn for the count. */
+- || *pending_exact == (1 << BYTEWIDTH) - 1
++ || *pending_exact >= (c1 ? (1 << BYTEWIDTH) - 2
++ : (1 << BYTEWIDTH) - 1)
+
+ /* If followed by a repetition operator. */
+@@ -2059,4 +2348,8 @@
+ }
+
++ if (c1) {
++ BUF_PUSH (c1);
++ (*pending_exact)++;
++ }
+ BUF_PUSH (c);
+ (*pending_exact)++;
+@@ -2184,5 +2477,5 @@
+ at_endline_loc_p (p, pend, syntax)
+ const char *p, *pend;
+- int syntax;
++ reg_syntax_t syntax;
+ {
+ const char *next = p;
+@@ -2220,4 +2513,5 @@
+
+
++#if 0 /* We use set_list_bits() now. */
+ /* Read the ending character of a range (in a bracket expression) from the
+ uncompiled pattern *P_PTR (which ends at PEND). We assume the
+@@ -2275,4 +2569,5 @@
+ return REG_NOERROR;
+ }
++#endif
+
+ /* Failure stack declarations and macros; both re_compile_fastmap and
+@@ -2638,18 +2933,65 @@
+
+ case charset:
++ /* NOTE: Charset for single-byte chars never contain
++ multi-byte char. See set_list_bits(). */
+ for (j = *p++ * BYTEWIDTH - 1; j >= 0; j--)
+ if (p[j / BYTEWIDTH] & (1 << (j % BYTEWIDTH)))
+ fastmap[j] = 1;
++ {
++ unsigned short size;
++ unsigned char c, end;
++
++ p += p[-1] + 2;
++ size = EXTRACT_UNSIGNED (&p[-2]);
++ for (j = 0; j < size; j++)
++ /* set bits for 1st bytes of multi-byte chars. */
++ for (c = (unsigned char) p[j*4],
++ end = (unsigned char) p[j*4 + 2];
++ c <= end; c++)
++ /* NOTE: Charset for multi-byte chars might contain
++ single-byte chars. We must reject them. */
++ if (ismbchar (c))
++ fastmap[c] = 1;
++ }
+ break;
+
+
+ case charset_not:
++ /* S: set of all single-byte chars.
++ M: set of all first bytes that can start multi-byte chars.
++ s: any set of single-byte chars.
++ m: any set of first bytes that can start multi-byte chars.
++
++ We assume S+M = U.
++ ___ _ _
++ s+m = (S*s+M*m). */
+ /* Chars beyond end of map must be allowed. */
++ /* NOTE: Charset_not for single-byte chars might contain
++ multi-byte chars. See set_list_bits(). */
+ for (j = *p * BYTEWIDTH; j < (1 << BYTEWIDTH); j++)
+- fastmap[j] = 1;
++ if (!ismbchar (j))
++ fastmap[j] = 1;
+
+ for (j = *p++ * BYTEWIDTH - 1; j >= 0; j--)
+ if (!(p[j / BYTEWIDTH] & (1 << (j % BYTEWIDTH))))
+- fastmap[j] = 1;
++ if (!ismbchar (j))
++ fastmap[j] = 1;
++ {
++ unsigned short size;
++ unsigned short c, beg;
++
++ p += p[-1] + 2;
++ size = EXTRACT_UNSIGNED (&p[-2]);
++ c = 0x00;
++ for (j = 0; j < size; j++) {
++ for (beg = (unsigned char) p[j*4 + 0]; c <= beg; c++)
++ if (ismbchar (c))
++ fastmap[c] = 1;
++ c = (unsigned char) p[j*4 + 2];
++ }
++ for (beg = 0xff; c <= beg; c++)
++ if (ismbchar (c))
++ fastmap[c] = 1;
++ }
+ break;
+
+@@ -2964,4 +3306,5 @@
+ register int lim = 0;
+ int irange = range;
++ unsigned char c;
+
+ if (startpos < size1 && startpos + range >= size1)
+@@ -2973,11 +3316,23 @@
+ inside the loop. */
+ if (translate)
+- while (range > lim
+- && !fastmap[(unsigned char)
+- translate[(unsigned char) *d++]])
++ while (range > lim) {
++ c = *d++;
++ if (ismbchar (c)) {
++ if (fastmap[c])
++ break;
++ d++;
++ range -= 2;
++ continue;
++ }
++ if (fastmap[(unsigned char) translate[c]])
++ break;
+ range--;
++ }
+ else
+- while (range > lim && !fastmap[(unsigned char) *d++])
++ while (range > lim && (c = *d++, !fastmap[c])) {
++ if (ismbchar (c))
++ d++, range--;
+ range--;
++ }
+
+ startpos += irange - range;
+@@ -3012,11 +3367,34 @@
+ else if (range > 0)
+ {
+- range--;
+- startpos++;
++ const char *d = ((startpos >= size1 ? string2 - size1 : string1)
++ + startpos);
++
++ if (ismbchar (*d)) {
++ range--, startpos++;
++ if (!range)
++ break;
++ }
++ range--, startpos++;
+ }
+ else
+ {
+- range++;
+- startpos--;
++ range++, startpos--;
++ {
++ const char *s, *d, *p;
++
++ if (startpos < size1)
++ s = string1, d = string1 + startpos;
++ else
++ s = string2, d = string2 + startpos - size1;
++ for (p = d; p-- > s && ismbchar(*p); )
++ /* --p >= s $B$@$H(B 80[12]?86 $B$GF0$+$J$$2DG=@-$,$"$k(B. (huge
++ model $B0J30$G(B, s $B$N%*%U%;%C%H$,(B 0 $B$@$C$?>l9g(B.) */
++ ;
++ if (!((d - p) & 1)) {
++ if (!range)
++ break;
++ range++, startpos--;
++ }
++ }
+ }
+ }
+@@ -3578,6 +3956,19 @@
+ do
+ {
++ unsigned char c;
++
+ PREFETCH ();
+- if (translate[(unsigned char) *d++] != (char) *p++)
++ c = *d++;
++ if (ismbchar (c)) {
++ if (c != (unsigned char) *p++
++ || !--mcnt /* $B%Q%?!<%s$,@5$7$/%3%s%Q%$%k$5(B
++ $B$l$F$$$k8B$j(B, $B$3$N%A%'%C%/$O(B
++ $B>iD9$@$,G0$N$?$a(B. */
++ || d == dend
++ || (unsigned char) *d++ != (unsigned char) *p++)
++ goto fail;
++ continue;
++ }
++ if ((unsigned char) translate[c] != (unsigned char) *p++)
+ goto fail;
+ }
+@@ -3588,6 +3979,26 @@
+ do
+ {
++#if 0
++ /* $BB>$NItJ,$G$O(B, string1 $B$H(B string2 $B$K%^%k%A%P%$%HJ8;z(B
++ $B$,8Y$k$N$r5v$7$F$$$J$$(B. $B$3$N$3$H$rB.EY$r5>@7$K$7$F(B
++ $B$b%A%'%C%/$9$k>l9g$O(B, $B$3$3$H<!$N(B `#if 0' $B$r(B `#if 1'
++ $B$KJQ$($k$3$H(B. */
++ unsigned char c;
++
++#endif
+ PREFETCH ();
++#if 0
++ c = *d++;
++ if (ismbchar (c)) {
++ if (c != (unsigned char) *p++
++ || !--mcnt
++ || d == dend)
++ goto fail;
++ c = *d++;
++ }
++ if (c != (unsigned char) *p++) goto fail;
++#else
+ if (*d++ != (char) *p++) goto fail;
++#endif
+ }
+ while (--mcnt);
+@@ -3602,4 +4013,14 @@
+
+ PREFETCH ();
++ if (ismbchar (*d)) {
++ if (d + 1 == dend || d[1] == '\n' || d[1] == '\0')
++ /* $BL58z$J%^%k%A%P%$%HJ8;z$K$O%^%C%A$5$;$J$$(B. $B$3$3$G$O(B, $B4J(B
++ $BC1$N$?$a#2%P%$%HL\$,(B '\n', '\0' $B$N$b$N$@$1$rL58z$H$9$k(B. */
++ goto fail;
++ SET_REGS_MATCHED ();
++ DEBUG_PRINT2 (" Matched `%d'.\n", EXTRACT_MBC (&d[0]));
++ d += 2;
++ break;
++ }
+
+ if ((!(bufp->syntax & RE_DOT_NEWLINE) && TRANSLATE (*d) == '\n')
+@@ -3616,19 +4037,23 @@
+ case charset_not:
+ {
+- register unsigned char c;
+- boolean not = (re_opcode_t) *(p - 1) == charset_not;
++ register unsigned short c;
++ boolean not;
+
+- DEBUG_PRINT2 ("EXECUTING charset%s.\n", not ? "_not" : "");
++ DEBUG_PRINT2 ("EXECUTING charset%s.\n",
++ (re_opcode_t) *(p - 1) == charset_not ? "_not" : "");
+
+ PREFETCH ();
+- c = TRANSLATE (*d); /* The character to match. */
++ c = (unsigned char) *d;
++ if (ismbchar (c)) {
++ c <<= 8;
++ if (d + 1 != dend)
++ c |= (unsigned char) d[1];
++ }
++ else
++ c = TRANSLATE (c); /* The character to match. */
+
+- /* Cast to `unsigned' instead of `unsigned char' in case the
+- bit list is a full 32 bytes long. */
+- if (c < (unsigned) (*p * BYTEWIDTH)
+- && p[1 + c / BYTEWIDTH] & (1 << (c % BYTEWIDTH)))
+- not = !not;
++ not = is_in_list (c, p);
+
+- p += 1 + *p;
++ p += 1 + *p + 2 + EXTRACT_UNSIGNED (&p[1 + *p])*4;
+
+ if (!not) goto fail;
+@@ -3636,4 +4061,6 @@
+ SET_REGS_MATCHED ();
+ d++;
++ if (d != dend && c >= 1 << BYTEWIDTH)
++ d++;
+ break;
+ }
+@@ -3801,5 +4228,5 @@
+
+ /* xx why this test? */
+- if ((int) old_regend[r] >= (int) regstart[r])
++ if (old_regend[r] >= regstart[r])
+ regend[r] = old_regend[r];
+ }
+@@ -4052,5 +4479,5 @@
+ || (bufp->newline_anchor && (re_opcode_t) *p2 == endline))
+ {
+- register unsigned char c
++ register unsigned short c
+ = *p2 == (unsigned char) endline ? '\n' : p2[2];
+ p1 = p + mcnt;
+@@ -4069,13 +4496,10 @@
+ || (re_opcode_t) p1[3] == charset_not)
+ {
+- int not = (re_opcode_t) p1[3] == charset_not;
+-
+- if (c < (unsigned char) (p1[4] * BYTEWIDTH)
+- && p1[5 + c / BYTEWIDTH] & (1 << (c % BYTEWIDTH)))
+- not = !not;
++ if (ismbchar (c))
++ c = c << 8 | p2[3];
+
+- /* `not' is equal to 1 if c would match, which means
++ /* `is_in_list()' is TRUE if c would match, which means
+ that we can't change to pop_failure_jump. */
+- if (!not)
++ if (!is_in_list (c, p1 + 4))
+ {
+ p[-3] = (unsigned char) pop_failure_jump;
+@@ -4632,8 +5056,15 @@
+ char *translate;
+ {
+- register unsigned char *p1 = s1, *p2 = s2;
++ register unsigned char *p1 = s1, *p2 = s2, c;
+ while (len)
+ {
+- if (translate[*p1++] != translate[*p2++]) return 1;
++ c = *p1++;
++ if (ismbchar(c)) {
++ if (c != *p2++ || !--len || *p1++ != *p2++)
++ return 1;
++ }
++ else
++ if (translate[c] != translate[*p2++])
++ return 1;
+ len--;
+ }
+@@ -4778,5 +5209,5 @@
+ {
+ reg_errcode_t ret;
+- unsigned syntax
++ reg_syntax_t syntax
+ = (cflags & REG_EXTENDED) ?
+ RE_SYNTAX_POSIX_EXTENDED : RE_SYNTAX_POSIX_BASIC;
+diff -ru2N grep-2.0/regex.h grep+mb1.04/regex.h
+--- grep-2.0/regex.h Fri May 21 14:11:43 1993
++++ grep+mb1.04/regex.h Sat Jul 10 04:38:03 1993
+@@ -17,4 +17,6 @@
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
++/* Multi-byte extension added May, 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 10, 1993 by t^2 */
+
+ #ifndef __REGEXP_LIBRARY_H__
+@@ -36,9 +38,9 @@
+ the definitions shifted by one from the previous bit; thus, when we
+ add or remove a bit, only one other definition need change. */
+-typedef unsigned reg_syntax_t;
++typedef unsigned long reg_syntax_t;
+
+ /* If this bit is not set, then \ inside a bracket expression is literal.
+ If set, then such a \ quotes the following character. */
+-#define RE_BACKSLASH_ESCAPE_IN_LISTS (1)
++#define RE_BACKSLASH_ESCAPE_IN_LISTS ((unsigned long)1)
+
+ /* If this bit is not set, then + and ? are operators, and \+ and \? are
+@@ -206,5 +208,5 @@
+ #undef RE_DUP_MAX
+ #endif
+-#define RE_DUP_MAX ((1 << 15) - 1)
++#define RE_DUP_MAX ((int)(((unsigned)1 << 15) - 1))
+
+
+@@ -397,4 +399,10 @@
+
+ #define _RE_ARGS(args) ()
++
++#ifdef __GNUC__
++#define const __const__
++#else
++#define const
++#endif
+
+ #endif /* not __STDC__ */
+diff -ru2N grep-2.0/search.c grep+mb1.04/search.c
+--- grep-2.0/search.c Mon May 3 06:02:00 1993
++++ grep+mb1.04/search.c Fri Jul 9 14:55:21 1993
+@@ -17,4 +17,6 @@
+
+ Written August 1992 by Mike Haertel. */
++/* Multi-byte extension added Jul., 1993 by t^2 (Takahiro Tanimoto)
++ Last change: Jul. 9, 1993 by t^2 */
+
+ #include <ctype.h>
+@@ -61,4 +63,5 @@
+ #include "kwset.h"
+ #include "regex.h"
++#include "mbc.h"
+
+ #define NCHAR (UCHAR_MAX + 1)
+@@ -434,8 +437,9 @@
+ char **endp;
+ {
+- register char *beg, *try, *end;
++ register char *beg, *try, *end, *p, *lim;
+ register size_t len;
+ struct kwsmatch kwsmatch;
+
++ lim = buf;
+ for (beg = buf; beg <= buf + size; ++beg)
+ {
+@@ -456,4 +460,8 @@
+ if (try > buf && WCHAR((unsigned char) try[-1]))
+ break;
++ for (p = try; p-- > lim && ismbchar(*p); )
++ ;
++ if (!((try - p) & 1))
++ break;
+ if (try + len < buf + size && WCHAR((unsigned char) try[len]))
+ {
+@@ -464,6 +472,12 @@
+ goto success;
+ }
+- else
+- goto success;
++ else {
++ for (p = beg; p-- > lim && ismbchar(*p); )
++ ;
++ if ((beg - p) & 1)
++ goto success;
++ if (lim + 1 < beg)
++ lim = beg - 1;
++ }
+ }
+
+diff -ru2N grep-2.0/tests/batgen.awk grep+mb1.04/tests/batgen.awk
+--- grep-2.0/tests/batgen.awk Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/tests/batgen.awk Sat Jul 10 02:10:24 1993
+@@ -0,0 +1,10 @@
++BEGIN { print "@echo off"; }
++$0 !~ /^#/ && NF == 3 {
++ printf "echo #%d --\n", ++n
++ print "set R=0";
++ print "echo " $3 ">tmp.in";
++ print "grep -E -e \"" $2 "\" tmp.in >nul";
++ print "if errorlevel 1 set R=1";
++ print "if errorlevel 2 set R=2";
++ printf "if not %R% == " $1 " echo Spencer test #%d failed\n", n
++}
+diff -ru2N grep-2.0/tests/check.bat grep+mb1.04/tests/check.bat
+--- grep-2.0/tests/check.bat Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/tests/check.bat Fri Jul 9 17:05:30 1993
+@@ -0,0 +1,14 @@
++@echo off
++rem
++rem Regression test for GNU e?grep.
++rem
++
++rem The Khadafy test is brought to you by Scott Anderson . . .
++grep -E -f tests/khadafy.reg tests/khadafy.lin > khadafy.out
++fc tests\khadafy.lin khadafy.out
++
++rem . . . and the following by Henry Spencer.
++
++gawk -F: -f tests/batgen.awk tests/spencer.dos > tmp.bat
++
++tmp
+diff -ru2N grep-2.0/tests/spencer.dos grep+mb1.04/tests/spencer.dos
+--- grep-2.0/tests/spencer.dos Thu Jan 1 09:00:00 1970
++++ grep+mb1.04/tests/spencer.dos Sat Jul 10 02:12:59 1993
+@@ -0,0 +1,122 @@
++0:abc:abc
++1:abc:xbc
++1:abc:axc
++1:abc:abx
++0:abc:xabcy
++0:abc:ababc
++0:ab*c:abc
++0:ab*bc:abc
++0:ab*bc:abbc
++0:ab*bc:abbbbc
++0:ab+bc:abbc
++1:ab+bc:abc
++1:ab+bc:abq
++0:ab+bc:abbbbc
++0:ab?bc:abbc
++0:ab?bc:abc
++1:ab?bc:abbbbc
++0:ab?c:abc
++0:^abc$:abc
++1:^abc$:abcc
++0:^abc:abcc
++1:^abc$:aabc
++0:abc$:aabc
++0:^:abc
++0:$:abc
++0:a.c:abc
++0:a.c:axc
++0:a.*c:axyzc
++1:a.*c:axyzd
++1:a[bc]d:abc
++0:a[bc]d:abd
++1:a[b-d]e:abd
++0:a[b-d]e:ace
++0:a[b-d]:aac
++0:a[-b]:a-
++0:a[b-]:a-
++1:a[b-a]:-
++2:a[]b:-
++2:a[:-
++0:a]:a]
++0:a[]]b:a]b
++0:a[^bc]d:aed
++1:a[^bc]d:abd
++0:a[^-b]c:adc
++1:a[^-b]c:a-c
++1:a[^]b]c:a]c
++0:a[^]b]c:adc
++0:ab|cd:abc
++0:ab|cd:abcd
++0:()ef:def
++0:()*:-
++1:*a:-
++0:^*:-
++0:$*:-
++1:(*)b:-
++1:$b:b
++2:a\\:-
++0:a\(b:a(b
++0:a\(*b:ab
++0:a\(*b:a((b
++1:a\x:a\x
++2:abc):-
++2:(abc:-
++0:((a)):abc
++0:(a)b(c):abc
++0:a+b+c:aabbabc
++0:a**:-
++0:a*?:-
++0:(a*)*:-
++0:(a*)+:-
++0:(a|)*:-
++0:(a*|b)*:-
++0:(a+|b)*:ab
++0:(a+|b)+:ab
++0:(a+|b)?:ab
++0:[^ab]*:cde
++0:(^)*:-
++0:(ab|)*:-
++2:)(:-
++1:abc:
++1:abc:
++0:a*:
++0:([abc])*d:abbbcd
++0:([abc])*bcd:abcd
++0:a|b|c|d|e:e
++0:(a|b|c|d|e)f:ef
++0:((a*|b))*:-
++0:abcd*efg:abcdefg
++0:ab*:xabyabbbz
++0:ab*:xayabbbz
++0:(ab|cd)e:abcde
++0:[abhgefdc]ij:hij
++1:^(ab|cd)e:abcde
++0:(abc|)ef:abcdef
++0:(a|b)c*d:abcd
++0:(ab|ab*)bc:abc
++0:a([bc]*)c*:abc
++0:a([bc]*)(c*d):abcd
++0:a([bc]+)(c*d):abcd
++0:a([bc]*)(c+d):abcd
++0:a[bcd]*dcdcde:adcdcde
++1:a[bcd]+dcdcde:adcdcde
++0:(ab|a)b*c:abc
++0:((a)(b)c)(d):abcd
++0:[A-Za-z_][A-Za-z0-9_]*:alpha
++0:^a(bc+|b[eh])g|.h$:abh
++0:(bc+d$|ef*g.|h?i(j|k)):effgz
++0:(bc+d$|ef*g.|h?i(j|k)):ij
++1:(bc+d$|ef*g.|h?i(j|k)):effg
++1:(bc+d$|ef*g.|h?i(j|k)):bcdd
++0:(bc+d$|ef*g.|h?i(j|k)):reffgz
++1:((((((((((a)))))))))):-
++0:(((((((((a))))))))):a
++1:multiple words of text:uh-uh
++0:multiple words:multiple words, yeah
++0:(.*)c(.*):abcde
++1:\((.*),:(.*)\)
++1:[k]:ab
++0:abcd:abcd
++0:a(bc)d:abcd
++0:a[-]?c:ac
++0:(....).*\1:beriberi