summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlastair Tse <liquidx@gentoo.org>2003-05-25 15:11:27 +0000
committerAlastair Tse <liquidx@gentoo.org>2003-05-25 15:11:27 +0000
commit6582b4fbef4ad3cb7d6bab9861251b0a8e1bc988 (patch)
tree74e399acc6c9ccf23187c7b26715d42cd38d77db /app-i18n/unicon
parent*** empty log message *** (diff)
downloadhistorical-6582b4fbef4ad3cb7d6bab9861251b0a8e1bc988.tar.gz
historical-6582b4fbef4ad3cb7d6bab9861251b0a8e1bc988.tar.bz2
historical-6582b4fbef4ad3cb7d6bab9861251b0a8e1bc988.zip
massive chinese input support addition! watch out debian, here we come!
Diffstat (limited to 'app-i18n/unicon')
-rw-r--r--app-i18n/unicon/Manifest3
-rw-r--r--app-i18n/unicon/files/digest-unicon-3.0.41
-rw-r--r--app-i18n/unicon/files/unicon-3.0.4-debian.patch2087
-rw-r--r--app-i18n/unicon/files/unicon-3.0.4-gentoo.patch11
-rw-r--r--app-i18n/unicon/unicon-3.0.4.ebuild63
5 files changed, 2164 insertions, 1 deletions
diff --git a/app-i18n/unicon/Manifest b/app-i18n/unicon/Manifest
index a8388139a533..471755c86117 100644
--- a/app-i18n/unicon/Manifest
+++ b/app-i18n/unicon/Manifest
@@ -1,4 +1,5 @@
-MD5 6deeec9300fbdd3f0d0267938730c3ac unicon-3.0.4.ebuild 1362
+MD5 e9c00930ce6c6190c0b74f748387042f unicon-3.0.4.ebuild 1505
+MD5 e738bbb245fc3ce2b399dbe13481cdb0 ChangeLog 437
MD5 e69f90a124ed00f574cc5ae111df1bd7 files/digest-unicon-3.0.4 66
MD5 cc6f3b807859a0d79f19b3f649de45b5 files/unicon-3.0.4-debian.patch 59606
MD5 31b30bcac54f35d0a41f969075a136de files/unicon-3.0.4-gentoo.patch 302
diff --git a/app-i18n/unicon/files/digest-unicon-3.0.4 b/app-i18n/unicon/files/digest-unicon-3.0.4
new file mode 100644
index 000000000000..bf0cbd907c9b
--- /dev/null
+++ b/app-i18n/unicon/files/digest-unicon-3.0.4
@@ -0,0 +1 @@
+MD5 b8c9a0aa908c4be8108578f5d4a19fe5 unicon-3.0.4.tar.bz2 5300843
diff --git a/app-i18n/unicon/files/unicon-3.0.4-debian.patch b/app-i18n/unicon/files/unicon-3.0.4-debian.patch
new file mode 100644
index 000000000000..fbbf2f498158
--- /dev/null
+++ b/app-i18n/unicon/files/unicon-3.0.4-debian.patch
@@ -0,0 +1,2087 @@
+--- unicon-3.0.4.orig/fonts/gb/Makefile.in
++++ unicon-3.0.4/fonts/gb/Makefile.in
+@@ -2,6 +2,7 @@
+ CFLAGS = @CFLAGS@
+ CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
+ PROG = encode-gb.o
++DESTDIR =
+
+ CC=gcc $(CFLAGS)
+ MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
+--- unicon-3.0.4.orig/fonts/gb/Makefile
++++ unicon-3.0.4/fonts/gb/Makefile
+@@ -0,0 +1,25 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
++PROG = encode-gb.o
++DESTDIR =
++
++CC=gcc $(CFLAGS)
++MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
++
++all: $(PROG)
++
++$(PROG): encode-gb.mo
++ ld -m elf_i386 -r encode-gb.mo -o $(PROG)
++encode-gb.mo: font_gb16.h encode-gb.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c encode-gb.c -o encode-gb.mo
++
++clean:
++ rm -f a.out *.bak *.o *~ core encode-gb.mo $(PROG)
++
++distclean: clean
++ rm -f Makefile tags TAGS
++
++install: all
++ sh install_module.sh $(PROG)
+--- unicon-3.0.4.orig/fonts/gbk/Makefile.in
++++ unicon-3.0.4/fonts/gbk/Makefile.in
+@@ -2,6 +2,7 @@
+ CFLAGS = @CFLAGS@
+ CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
+ PROG = encode-gbk.o
++DESTDIR =
+
+ CC=gcc $(CFLAGS)
+ MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
+--- unicon-3.0.4.orig/fonts/gbk/Makefile
++++ unicon-3.0.4/fonts/gbk/Makefile
+@@ -0,0 +1,25 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
++PROG = encode-gbk.o
++DESTDIR =
++
++CC=gcc $(CFLAGS)
++MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
++
++all: $(PROG)
++
++$(PROG): encode-gbk.mo
++ ld -m elf_i386 -r encode-gbk.mo -o $(PROG)
++encode-gbk.mo: font_gbk16.h encode-gbk.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c encode-gbk.c -o encode-gbk.mo
++
++clean:
++ rm -f a.out *.bak *.o *.mo *~ core encode-gb.mo $(PROG)
++
++distclean: clean
++ rm -f Makefile tags TAGS
++
++install: all
++ sh install_module.sh $(PROG)
+--- unicon-3.0.4.orig/fonts/jis/Makefile.in
++++ unicon-3.0.4/fonts/jis/Makefile.in
+@@ -2,6 +2,7 @@
+ CFLAGS = @CFLAGS@
+ CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
+ PROG = encode-jis.o
++DESTDIR =
+
+ CC=gcc $(CFLAGS)
+ MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
+--- unicon-3.0.4.orig/fonts/jis/Makefile
++++ unicon-3.0.4/fonts/jis/Makefile
+@@ -0,0 +1,25 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
++PROG = encode-jis.o
++DESTDIR =
++
++CC=gcc $(CFLAGS)
++MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
++
++all: $(PROG)
++
++$(PROG): encode-jis.mo
++ ld -m elf_i386 -r encode-jis.mo -o $(PROG)
++encode-jis.mo: font_jis16.h encode-jis.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c encode-jis.c -o encode-jis.mo
++
++clean:
++ rm -f a.out core *.bak *.o *~ *.mo $(PROG)
++
++distclean: clean
++ rm -f Makefile tags TAGS
++
++install: all
++ sh install_module.sh $(PROG)
+--- unicon-3.0.4.orig/fonts/big5/Makefile.in
++++ unicon-3.0.4/fonts/big5/Makefile.in
+@@ -2,6 +2,7 @@
+ CFLAGS = @CFLAGS@
+ CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
+ PROG = encode-big5.o
++DESTDIR=
+
+ KERNELRELEASE=$(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION)
+
+--- unicon-3.0.4.orig/fonts/big5/Makefile
++++ unicon-3.0.4/fonts/big5/Makefile
+@@ -0,0 +1,27 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
++PROG = encode-big5.o
++DESTDIR=
++
++KERNELRELEASE=$(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION)
++
++CC=gcc $(CFLAGS)
++MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
++
++all: $(PROG)
++
++$(PROG): encode-big5.mo
++ ld -m elf_i386 -r encode-big5.mo -o $(PROG)
++encode-big5.mo: font_big5_16.h encode-big5.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c encode-big5.c -o encode-big5.mo
++
++clean:
++ rm -f a.out *.bak *.o *.mo core *~ $(PROG)
++
++distclean: clean
++ rm -f Makefile tags TAGS
++
++install: all
++ sh install_module.sh $(PROG)
+--- unicon-3.0.4.orig/fonts/kscm/Makefile.in
++++ unicon-3.0.4/fonts/kscm/Makefile.in
+@@ -2,6 +2,7 @@
+ CFLAGS = @CFLAGS@
+ CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
+ PROG = encode-kscm.o
++DESTDIR =
+
+ CC=gcc $(CFLAGS)
+ MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
+--- unicon-3.0.4.orig/fonts/kscm/Makefile
++++ unicon-3.0.4/fonts/kscm/Makefile
+@@ -0,0 +1,26 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++CFLAGS += -I/usr/src/linux/include -I. -include /usr/src/linux/include/linux/modversions.h
++PROG = encode-kscm.o
++DESTDIR =
++
++CC=gcc $(CFLAGS)
++MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
++
++all: $(PROG)
++
++$(PROG): encode-kscm.mo
++ ld -m elf_i386 -r encode-kscm.mo -o $(PROG)
++encode-kscm.mo: font_kscm16.h encode-kscm.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c encode-kscm.c -o encode-kscm.mo
++
++clean:
++ rm -f a.out *.bak *.o core *~ *.mo $(PROG)
++
++distclean: clean
++ rm -f Makefile tags TAGS
++
++install: all
++ sh install_module.sh $(PROG)
++
+--- unicon-3.0.4.orig/fonts/Makefile
++++ unicon-3.0.4/fonts/Makefile
+@@ -0,0 +1,33 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++all:
++ cd big5; make
++ cd gb; make
++ cd gbk; make
++ cd kscm; make
++ cd jis; make
++
++install: all
++ cd big5; make install
++ cd gb; make install
++ cd gbk; make install
++ cd kscm; make install
++ cd jis; make install
++
++clean:
++ cd big5; make clean
++ cd gb; make clean
++ cd gbk; make clean
++ cd jis; make clean
++ cd kscm; make clean
++ rm -f *.bak core *~
++
++distclean: clean
++ rm -f config.status config.log config.cache Makefile
++ cd big5; make distclean
++ cd gb; make distclean
++ cd gbk; make distclean
++ cd jis; make distclean
++ cd kscm; make distclean
++ rm -f *.bak core tags TAGS
++
+--- unicon-3.0.4.orig/tools/Makefile
++++ unicon-3.0.4/tools/Makefile
+@@ -0,0 +1,26 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++LIBDIR=$(prefix)/lib/unicon
++CFLAGS = -g -O2
++CFLAGS += -I. -I../include
++PROG = uniconcfg uniconctrl
++
++CC=gcc $(CFLAGS)
++
++all: $(PROG)
++uniconcfg:
++ $(CC) -lnewt uniconcfg.c -o uniconcfg
++uniconctrl:
++ $(CC) uniconctrl.c -o uniconctrl
++clean:
++ rm -f a.out *.bak *.o core *~ $(PROG)
++
++install: all
++ mkdir -p $(prefix)/bin $(LIBDIR)/bin
++ install -o root -g root -m755 uniconcfg $(LIBDIR)/bin/uniconcfg
++ install -o root -g root -m755 uniconctrl $(LIBDIR)/bin/uniconctrl
++ ln -sf $(prefix)/lib/unicon/bin/uniconctrl /usr/bin/uniconctrl
++ ln -sf $(prefix)/lib/unicon/bin/uniconcfg /usr/bin/uniconcfg
++
++distclean: clean
++ rm -f Makefile tags TAGS
+--- unicon-3.0.4.orig/Makefile.in
++++ unicon-3.0.4/Makefile.in
+@@ -1,10 +1,10 @@
+ prefix=@prefix@
+ all:
+- cd unikey; make
+- cd fonts; make
++# cd unikey; make
++# cd fonts; make
+ cd unicon; make
+- cd tools; make
+- cd unimap; make
++# cd tools; make
++# cd unimap; make
+
+ data:
+ cd unicon; make data
+@@ -17,26 +17,26 @@
+ if [ ! -d $(prefix)/lib/unicon ] ; then mkdir -p $(prefix)/lib/unicon; fi
+ if [ ! -d $(prefix)/bin ] ; then mkdir -p $(prefix)/bin; fi
+ cd unicon; make install
+- cd unikey; make install
+- cd fonts; make install
+- cd tools; make install
+- cd unimap; make install
++# cd unikey; make install
++# cd fonts; make install
++# cd tools; make install
++# cd unimap; make install
+
+ clean:
+ cd unicon; make clean
+- cd unikey; make clean
+- cd fonts; make clean
+- cd tools; make clean
+- cd unimap; make clean
++# cd unikey; make clean
++# cd fonts; make clean
++# cd tools; make clean
++# cd unimap; make clean
+ rm -f core *.bak *~
+
+ distclean: clean
+ rm -f config.status config.log config.cache Makefile
+ cd unicon; make distclean
+- cd unikey; make distclean
+- cd fonts; make distclean
+- cd tools; make distclean
+- cd sfonts; make distclean
+- cd unimap; make distclean
++# cd unikey; make distclean
++# cd fonts; make distclean
++# cd tools; make distclean
++# cd sfonts; make distclean
++# cd unimap; make distclean
+ rm -f *.bak
+
+--- unicon-3.0.4.orig/sfonts/tools/Makefile
++++ unicon-3.0.4/sfonts/tools/Makefile
+@@ -0,0 +1,36 @@
++# Generated automatically from Makefile.in by configure.
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++PROG = sfont
++OBJS = main.o sfont.o filter.o encode-gb.o encode-gbk.o \
++ encode-big5.o encode-jis.o encode-kscm.o
++FONT_PATH=../../fonts
++CC=gcc -g $(CFLAGS) -I. -I../../include
++
++all: $(PROG)
++
++$(PROG): $(OBJS)
++ $(CC) $(OBJS) -o $(PROG)
++main.o: main.cpp
++ $(CC) -c main.cpp -o main.o
++filter.o: filter.cpp filter.hpp
++ $(CC) -c filter.cpp -o filter.o
++sfont.o: sfont.cpp sfont.hpp
++ $(CC) -c sfont.cpp -o sfont.o
++encode-gb.o : $(FONT_PATH)/gb/encode-gb.c $(FONT_PATH)/gb/font_gb16.h
++ $(CC) -c -I$(FONT_PATH)/gb $(FONT_PATH)/gb/encode-gb.c -o encode-gb.o
++encode-gbk.o : $(FONT_PATH)/gbk/encode-gbk.c $(FONT_PATH)/gbk/font_gbk16.h
++ $(CC) -c -I$(FONT_PATH)/gbk $(FONT_PATH)/gbk/encode-gbk.c -o encode-gbk.o
++encode-big5.o : $(FONT_PATH)/big5/encode-big5.c $(FONT_PATH)/big5/font_big5_16.h
++ $(CC) -c -I$(FONT_PATH)/big5 $(FONT_PATH)/big5/encode-big5.c -o encode-big5.o
++encode-jis.o : $(FONT_PATH)/jis/encode-jis.c $(FONT_PATH)/jis/font_jis16.h
++ $(CC) -c -I$(FONT_PATH)/jis $(FONT_PATH)/jis/encode-jis.c -o encode-jis.o
++encode-kscm.o : $(FONT_PATH)/kscm/encode-kscm.c $(FONT_PATH)/kscm/font_kscm16.h
++ $(CC) -c -I$(FONT_PATH)/kscm $(FONT_PATH)/kscm/encode-kscm.c -o encode-kscm.o
++
++clean:
++ rm -f a.out *.bak *.o core *~ $(PROG)
++
++distclean: clean
++ rm -f Makefile
+--- unicon-3.0.4.orig/sfonts/genfont/Makefile
++++ unicon-3.0.4/sfonts/genfont/Makefile
+@@ -0,0 +1,52 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++CFLAGS += -I.
++
++CC=gcc $(CFLAGS)
++MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
++PROG = gb gbk big5 jis kscm
++
++all: $(PROG)
++
++# GB
++gb: sencode-gb.mo
++ ld -m elf_i386 -r sencode-gb.mo -o sencode-gb.o
++sencode-gb.mo: sencode-gb.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c sencode-gb.c -o sencode-gb.mo
++
++# GBK
++gbk: sencode-gbk.mo
++ ld -m elf_i386 -r sencode-gbk.mo -o sencode-gbk.o
++sencode-gbk.mo: sencode-gbk.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c sencode-gbk.c -o sencode-gbk.mo
++
++# Big5
++big5: sencode-big5.mo
++ ld -m elf_i386 -r sencode-big5.mo -o sencode-big5.o
++sencode-big5.mo: sencode-big5.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c sencode-big5.c -o sencode-big5.mo
++
++# JIS
++jis: sencode-jis.mo
++ ld -m elf_i386 -r sencode-jis.mo -o sencode-jis.o
++sencode-jis.mo: sencode-jis.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c sencode-jis.c -o sencode-jis.mo
++
++# JIS
++kscm: sencode-kscm.mo
++ ld -m elf_i386 -r sencode-kscm.mo -o sencode-kscm.o
++sencode-kscm.mo: sencode-jis.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c sencode-kscm.c -o sencode-kscm.mo
++
++clean:
++ rm -f a.out *.bak *.o core *~ sencode-gb.mo $(PROG)
++
++distclean: clean
++ rm -f Makefile
++ rm -f *.h
++
++install: all
++ mkdir -p /lib/modules/`uname -a|awk '{print $$3}'`/misc
++ cp -f $(PROG) /lib/modules/`uname -a|awk '{print $$3}'`/misc
++
+--- unicon-3.0.4.orig/sfonts/Makefile
++++ unicon-3.0.4/sfonts/Makefile
+@@ -0,0 +1,29 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CC=gcc $(CFLAGS)
++PROG = tools
++
++all: $(PROG)
++
++tools:
++ cd tools; make
++
++# run genfont manual
++genfont:
++ cd genfont; make
++
++clean:
++ rm -f *.bak *.o *~ core
++ cd tools; make clean
++ cd genfont; make clean
++
++
++distclean: clean
++ rm -f Makefile tags TAGS
++ cd tools; make distclean
++ cd genfont; make distclean
++
++install: all
++ cd tools; make install
++ cd genfont; make install
++
+--- unicon-3.0.4.orig/unicon/client/Makefile.in
++++ unicon-3.0.4/unicon/client/Makefile.in
+@@ -34,8 +34,8 @@
+ g++ $(CFLAGS) -D__DLL_SUPPORT__ -ldl -lpth test.cpp $(PROG_LIB) $(SERVER_LIB) -o test
+
+ install: all
+- mkdir -p $(prefix)/lib/unicon
+- cp -f $(PROG_LIB) $(prefix)/lib/unicon
++# mkdir -p $(prefix)/lib
++ cp -f $(PROG_LIB) $(prefix)/lib
+ clean:
+ rm -f *.o a.out core *~ *.bak $(PROG_LIB) $(PROG)
+
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/Makefile.in
++++ unicon-3.0.4/unicon/ImmModules/cce/Makefile.in
+@@ -6,7 +6,7 @@
+ CCE_OBJS = xl_hzinput.o CCE_hzinput.o intcode.o \
+ xl_pinyin.o CCE_pinyin.o
+
+-CFLAGS = -g -O2 -fomit-frame-pointer -W -Wall -I. -I../../include
++CFLAGS = -fPIC -g -O2 -fomit-frame-pointer -W -Wall -I. -I../../include
+
+ all: cce_hzinput.so cce_pinyin.so gb18030_intcode.so
+
+@@ -15,14 +15,14 @@
+ xl_hzinput.o : xl_hzinput.c
+ gcc $(CFLAGS) -c xl_hzinput.c -o xl_hzinput.o
+ cce_hzinput.so: CCE_hzinput.o xl_hzinput.o
+- gcc CCE_hzinput.o xl_hzinput.o -shared -o cce_hzinput.so
++ gcc CCE_hzinput.o xl_hzinput.o -fPIC -shared -o cce_hzinput.so
+
+ xl_pinyin.o : xl_pinyin.c xl_pinyin.h
+ gcc $(CFLAGS) -c xl_pinyin.c -o xl_pinyin.o
+ CCE_pinyin.o : CCE_pinyin.c
+ gcc $(CFLAGS) -c CCE_pinyin.c -o CCE_pinyin.o
+ cce_pinyin.so : xl_pinyin.o CCE_pinyin.o
+- gcc CCE_pinyin.o xl_pinyin.o -shared -o cce_pinyin.so
++ gcc CCE_pinyin.o xl_pinyin.o -fPIC -shared -o cce_pinyin.so
+
+ intcode.o : xl_intcode.c
+ gcc $(CFLAGS) -c xl_intcode.c -o intcode.o
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/inputs/Makefile.in
++++ unicon-3.0.4/unicon/ImmModules/cce/inputs/Makefile.in
+@@ -2,7 +2,7 @@
+ prefix=@prefix@
+ CFLAGS = @CFLAGS@
+
+-CFLAGS += -I. -I..
++CFLAGS += -O2 -I. -I..
+
+ LIBDIR = $(prefix)/lib/unicon
+ LD = gcc $(CFLAGS)
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/inputs/cin2dat.c
++++ unicon-3.0.4/unicon/ImmModules/cce/inputs/cin2dat.c
+@@ -114,7 +114,7 @@
+
+ /* qcmp2 compare two ITEM2 structure, according to its key1/key2/ch */
+ int
+-qcmp2 (ITEM2 * a, ITEM2 * b)
++qcmp2 (const ITEM2 * a, const ITEM2 * b)
+ {
+ if (a->key1 > b->key1)
+ return 1;
+@@ -134,7 +134,7 @@
+
+ /* qcmp compare two ITEM2 structure, according to its key1/key2/occur_seq */
+ int
+-qcmp (ITEM2 * a, ITEM2 * b)
++qcmp (const ITEM2 * a, const ITEM2 * b)
+ {
+ if (a->key1 > b->key1)
+ return 1;
+@@ -148,7 +148,7 @@
+ }
+
+ int
+-qcmp_ser (ITEM * a, ITEM * b)
++qcmp_ser (const ITEM * a, const ITEM * b)
+ {
+ if (a->ch > b->ch)
+ return 1;
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/inputs/cin2tab.c
++++ unicon-3.0.4/unicon/ImmModules/cce/inputs/cin2tab.c
+@@ -3,6 +3,7 @@
+ #include <stdarg.h>
+ #include <sys/types.h>
+ #include <string.h>
++#include <stdlib.h>
+ #include "xl_hzinput.h"
+
+ FILE *fr, *fw;
+@@ -114,7 +115,7 @@
+
+ /* qcmp2 compare two ITEM2 structure, according to its key1/key2/ch */
+ int
+-qcmp2 (ITEM2 * a, ITEM2 * b)
++qcmp2 (const ITEM2 * a, const ITEM2 * b)
+ {
+ if (a->key1 > b->key1)
+ return 1;
+@@ -152,7 +153,7 @@
+ }
+
+ int
+-qcmp_ser (ITEM * a, ITEM * b)
++qcmp_ser (const ITEM * a, const ITEM * b)
+ {
+ if (a->ch > b->ch)
+ return 1;
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/inputs/tab2txt.c
++++ unicon-3.0.4/unicon/ImmModules/cce/inputs/tab2txt.c
+@@ -71,7 +71,7 @@
+ exit (1);
+ }
+
+- if (fseek (in, -4, SEEK_END) == -1 ||
++ if (fseek (in, -sizeof(int), SEEK_END) == -1 ||
+ fread (&fsize, sizeof (int), 1, in) != 1 || fsize != ftell (in) - sizeof (int)) // error!!
+ {
+ fprintf (stderr, "%s is not a valid pinyin phrase file.\n", infile);
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/CCE_pinyin.c
++++ unicon-3.0.4/unicon/ImmModules/cce/CCE_pinyin.c
+@@ -44,6 +44,8 @@
+ extern void CCE_ClosePinyin (InputModule * p);
+ extern InputModule *pCCE_OpenPinyin (char *szPath);
+ extern void Pinyin_SaveAllPyUsrPhrase ();
++extern int SaveUsrPhrase(char *pathname);
++extern int SavePhraseFrequencyi(char *pathname);
+
+ static void
+ SetPhraseBuffer (PhraseItem * p, char *buf, int buflen)
+@@ -156,6 +158,12 @@
+ static int
+ IMM_Flush ()
+ {
++ char name[256];
++ sprintf(name,"%s/.pyinput/usrphrase.tab",getenv("HOME"));
++ SaveUsrPhrase(name);
++ sprintf(name,"%s/.pyinput/sysfrequency.tab",getenv("HOME"));
++ SavePhraseFrequency(name);
++
+ return 1;
+ }
+
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/xl_pinyin.c
++++ unicon-3.0.4/unicon/ImmModules/cce/xl_pinyin.c
+@@ -43,7 +43,8 @@
+
+ static int LoadPinyinTable (char *pathname);
+ static int SaveSysPhrase (char *pathname, int remove);
+-static int SaveUsrPhrase (char *pathname);
++//static int SaveUsrPhrase (char *pathname);
++int SaveUsrPhrase (char *pathname);
+ static int LoadUsrPhrase (char *pathname);
+ static int LoadSysPhrase (char *pathname);
+ static void FindMatchPhrase (InputModule * inmd, PYString pinyin[],
+@@ -59,11 +60,13 @@
+ // MAX_EACH_PY = 38 a[], b[], c[] ....
+ // map the pinyin to keys
+ static SysPhrase *sysph[MAX_PY_NUM]; // system phrases
+-static int sys_size;
++static int sys_size,sys_num;
+
+-static int FuzzyPinyin; // zh-ch-sh z-c-s
++static int FuzzyPinyin =0 ; // zh-ch-sh z-c-s
+ static UsrPhrase *usrph[MAX_PY_NUM]; //user defined phrase
+
++static int LoadPhraseFrequency(char *pathname);
++
+ /**************************************************************************
+ * Structure of the Char/Phrases *
+ * u_char len; // char/phrase len *
+@@ -134,7 +137,7 @@
+
+ //Rat: modified for processing user-defined dictionaries
+ if ((usrhome = getenv ("HOME")) != NULL)
+- {
++ {
+ sprintf (buf, "%s/%s", usrhome, ".pyinput");
+ retval = stat (buf, &statbuf);
+
+@@ -148,24 +151,24 @@
+ {
+ if ( statbuf.st_size < MIN_USRPHR_SIZE || LoadUsrPhrase (buf) == -1)
+ {
+- printf ("Couldn't load %s. Please fix it.\n", buf);
+- sprintf (buf, "%s/%s", szPath, "usrphrase.tab");
+- if ((retval = access (buf, R_OK)) == 0)
+- {
+- if (LoadUsrPhrase (buf) == -1)
+- printf ("Couldn't load %s. Please fix it.\n",
+- buf);
++ printf ("Couldn't load %s. Please fix it. size or load error\n", buf);
++ sprintf (buf, "%s/%s", szPath, "usrphrase.tab");
++ if ((retval = access (buf, R_OK)) == 0)
++ {
++ if (LoadUsrPhrase (buf) == -1)
++ printf ("Couldn't load %s. Please fix it. sysfile\n",
++ buf);
++ }
++ }
+ }
+- }
+- }
+- else
+- {
+- creat (buf, 0600);
+- sprintf (buf, "%s/%s", szPath, "usrphrase.tab");
++ else
++ {
++ creat (buf, 0600);
++ sprintf (buf, "%s/%s", szPath, "usrphrase.tab");
+ if ((retval = access (buf, R_OK)) == 0)
+ {
+ if (LoadUsrPhrase (buf) == -1)
+- printf ("Couldn't load %s. Please fix it.\n", buf);
++ printf ("Couldn't load %s. Please fix it. couldn't access\n", buf);
+ }
+ }
+ }
+@@ -186,7 +189,7 @@
+ {
+ if (LoadUsrPhrase (buf) == -1)
+ {
+- printf ("Couldn't load %s. Please fix it.\n", buf);
++ printf ("Couldn't load %s. Please fix it. create\n", buf);
+ }
+ }
+ }
+@@ -207,6 +210,13 @@
+
+ }
+
++ sprintf(buf,"%s/%s/%s",usrhome,".pyinput","sysfrequency.tab");
++ if(LoadPhraseFrequency(buf) == -1)
++ {
++ creat(buf,0700);
++ SavePhraseFrequency(buf);
++ }
++
+ return 1;
+ }
+
+@@ -265,7 +275,8 @@
+ }
+
+ /* need to combine the same pinyin/phrases */
+-static int
++//static int
++int
+ SaveUsrPhrase (char *pathname)
+ {
+ int i, tmpcount;
+@@ -340,6 +351,53 @@
+ return 0;
+ }
+
++int SavePhraseFrequency(char *pathname)
++{
++ FILE *stream;
++ Phrase *sph;
++ SysPhrase *sysph_tmp;
++ char *f;
++ char *p;
++ int i,j,k,index,pcount;
++
++ if ( (stream = fopen(pathname , "wb" )) == NULL )
++ {
++ fatal("%s file can't open\n",pathname);
++ return -1;
++ }
++
++ f = (char *) malloc (sys_num);
++ memset (f, 0, sys_num);
++ pcount=0;
++
++ for(i = 1; i < MAX_PY_NUM; i++)
++ {
++ sysph_tmp = sysph[i];
++ assert (sysph_tmp != NULL);
++ p = (char*)sysph_tmp->phrase; // count = total pinyin number
++ for(j = 0; j < sysph_tmp->count; j++)
++ {
++ sph = (Phrase *)p;
++ assert (sph != NULL);
++ for(k = 0; k < sph->count; k++)
++ {
++ index = sph->len+1 + (2*sph->len+1)*k + 2*sph->len;
++ f[pcount]=sph->key[index];
++ pcount++;
++ }
++ p += SizeOfPhrase(sph->len,sph->count);
++ }
++ }
++ assert (pcount==sys_num);
++ fseek(stream,0,SEEK_SET);
++ fwrite(f, sys_num, 1, stream);
++ fwrite(&(sys_size),sizeof(int),1,stream);
++ fwrite(&(sys_num),sizeof(int),1,stream);
++ free(f);
++ fclose(stream);
++ return 0;
++}
++
+ // don't save the frequency information, all lost?
+ static int
+ SaveSysPhrase (char *pathname, int remove)
+@@ -483,6 +541,7 @@
+ fseek (stream, 0, SEEK_SET);
+ p = (char *) malloc (sys_size);
+ memset (p, 0, sys_size);
++ sys_num = 0;
+ /* Attach the shared segment to local address space */
+ if (fread (p, sys_size, 1, stream) != 1)
+ {
+@@ -494,15 +553,74 @@
+ sysph[i] = sysph_tmp = (SysPhrase *) p;
+ p = (char *) sysph_tmp->phrase;
+ for (j = 0; j < sysph_tmp->count; j++)
+- {
++ {
+ kph = (Phrase *) p;
+ p += SizeOfPhrase (kph->len, kph->count); // skip the string
+- }
++ sys_num += kph->count;
++ }
+ }
+ fclose (stream);
+ return 0;
+ }
+
++static int LoadPhraseFrequency(char *pathname)
++{
++ FILE *stream;
++ Phrase *sph;
++ SysPhrase *sysph_tmp;
++ char *f;
++ char *p;
++ int i,j,k,index,sys_size_tmp,sys_num_tmp,pcount;
++
++ if ( (stream = fopen(pathname , "rb" )) == NULL )
++ {
++ fatal("%s file can't open\n",pathname);
++ return -1;
++ }
++
++ if (fseek(stream,-sizeof(int)*2,SEEK_END) == -1 ||
++ fread(&(sys_size_tmp),sizeof(int),1,stream) != 1 ||
++ fread(&(sys_num_tmp),sizeof(int),1,stream) != 1 ||
++ sys_size != sys_size_tmp||
++ sys_num_tmp != ftell(stream)-sizeof(int)*2 ||
++ sys_num != sys_num_tmp) // error!!
++ {
++ fatal("%s is not a valid pinyin phrase freqency file.\n",pathname);
++ return -1;
++ }
++ fseek(stream,0,SEEK_SET);
++ f = (char *) malloc (sys_num);
++ memset (f, 0, sys_num);
++ if (fread(f, sys_num, 1, stream) != 1)
++ {
++ fatal("Load File %s Error.\n", pathname);
++ return -1;
++ }
++ //
++ pcount=0;
++ for(i = 1; i < MAX_PY_NUM; i++)
++ {
++ sysph_tmp = sysph[i];
++ assert (sysph_tmp != NULL);
++ p = (char*)sysph_tmp->phrase; // count = total pinyin number
++ for(j = 0; j < sysph_tmp->count; j++)
++ {
++ sph = (Phrase *)p;
++ assert (sph != NULL);
++ for(k = 0; k < sph->count; k++)
++ {
++ index = sph->len+1 + (2*sph->len+1)*k + 2*sph->len;
++ sph->key[index] = f[pcount];
++ pcount++;
++ }
++ p += SizeOfPhrase(sph->len,sph->count);
++ }
++ }
++ free(f);
++ fclose(stream);
++ return 0;
++}
++
+ // When loading the phrase library, save it in memory
+ // structure, dynamic linklist
+ /* str, hanzi codes, key: pinyin codes, len: length, pass: system/user */
+@@ -676,6 +794,7 @@
+ inmd->lenkey = 0;
+ inmd->key[0] = '\0';
+ inmd->nTotalCurSel = 0;
++ inmd->flg_english = 0;
+ }
+
+ // pinyin[0]-pinyin[len-1], parsed pinyin chars
+@@ -710,6 +829,7 @@
+
+ if (!inmd->len)
+ return NULL;
++ printf("szGetSelectPhrase called\n");
+
+ idx = inmd->startpos + n;
+
+@@ -735,6 +855,15 @@
+ char strhz[MAX_PHRASE_LEN * 2 + 1];
+ int pos, idx;
+
++
++ if (ch == '\n')
++ {
++ strcpy(strbuf,inmd->inbuf);
++ ResetPinyinInput(inmd);
++ return 2;
++ }
++
++
+ if (!inmd->len)
+ return 1;
+
+@@ -782,12 +911,16 @@
+ }
+ else // not yet, some unselected pinyin exist
+ {
++ inmd->flg_english = 0;
+ // forward the pinyinpos pointer
+ for (pos = strlen (strhz) / 2; pos > 0; inmd->pinyinpos++)
+ {
+ ch = inmd->pinyin[inmd->pinyinpos][0];
+ if (ch == 'i' || ch == 'u' || ch == 'v' || ch < 'a' || ch > 'z')
++ {
++ inmd->flg_english = 1;
+ continue;
++ }
+ pos--;
+ }
+
+@@ -820,21 +953,26 @@
+
+ char chtmp;
+ int count;
++ int i;
++ char tmpbuf[128];
+
+ /* \010 = Ctrl+H, \177 = BackSpace */
+ if (ch == '\010' || ch == '\177') // BackSpace
+ {
+ if (!strlen (inbuf))
+- return 0;
++ return 0;
+ else if (!strlen (inbuftmp))
+ {
+ strcpy (inbuftmp, inbuf);
++ inbuf[strlen(inbuf)-1] = '\0';
+ *pybuftmp = '\0'; // clear all the selected chars, reparse
+ }
+ else
+ {
+ inbuf[strlen (inbuf) - 1] = '\0';
+- inbuftmp[strlen (inbuftmp) - 1] = '\0'; // cut one pinyin-char off
++ if(inmd->flg_english) strcpy(inbuftmp,inbuf);
++ else inbuftmp[strlen (inbuftmp) - 1] = '\0'; // cut one pinyin-char off
++
+ if (!strlen (inbuf))
+ {
+ ResetPinyinInput (inmd);
+@@ -862,7 +1000,8 @@
+ chtmp = inmd->pinyin[inmd->lenpy - 1][0];
+ if (chtmp == 'i' || chtmp == 'u' || chtmp == 'v')
+ {
+- inbuf[strlen (inbuf) - 1] = '\0';
++// inbuf[strlen (inbuf) - 1] = '\0';
++ inmd->flg_english = 1;
+ inbuftmp[strlen (inbuftmp) - 1] = '\0';
+ inmd->lenpy--;
+ return 1;
+@@ -871,7 +1010,7 @@
+ /* Too many chars now */
+ if (EffectPyNum (inmd->pinyin, inmd->lenpy) > MAX_PHRASE_LEN)
+ {
+- inbuf[strlen (inbuf) - 1] = '\0';
++// inbuf[strlen (inbuf) - 1] = '\0';
+ inbuftmp[strlen (inbuftmp) - 1] = '\0';
+ inmd->lenpy--;
+ return 1;
+@@ -881,6 +1020,14 @@
+ FillForwardSelection (inmd, 0);
+ CreatePyMsg (inmd);
+
++ tmpbuf[0] = '\0';
++ for(i = 0;i < inmd->lenpy; i++)
++ {
++ strcat(tmpbuf,inmd->pinyin[i]);
++ }
++ if(strcmp(inmd->inbuf,tmpbuf)) inmd->flg_english = 1;
++ else inmd->flg_english = 0;
++
+ return 1;
+ }
+
+@@ -921,8 +1068,8 @@
+ break;
+
+ default: // select some keys
+- if ((ch >= '1' && ch <= '9') || ch == '0' || ch == ' ')
+- return SelectKeyPressed (inmd, ch, strbuf);
++ if ((ch >= '1' && ch <= '9') || ch == '0' || ch == ' ' || ch == '\n')
++ return SelectKeyPressed (inmd, ch, strbuf);
+ break;
+ }
+ return 0;
+@@ -952,6 +1099,12 @@
+ continue;
+ }
+
++ if (pybuf[offset] == 'v' || pybuf[offset] == 'i' || pybuf[offset] == 'u')
++ {
++ offset++; count = 2;
++ continue;
++ }
++
+ ahead = pybuf[offset] - 'a';
+ if (ahead < 0 || ahead > 25)
+ return 0;
+@@ -1004,13 +1157,13 @@
+ // temporary array, 500 items
+
+ int lenarr[MAX_PHRASE_LEN], result;
+- char ch;
++ char ch, ch2='\0';
+
+ if (!lenpy)
+- {
++ {
+ inmd->len = 0;
+ return;
+- }
++ }
+
+ /* first of all, fill the pykey array */
+ for (i = 0; i < lenpy; i++)
+@@ -1022,9 +1175,14 @@
+ ahead = pinyin[i][0] - 'a';
+ lenkey = 0;
+ tmplen = strlen (pinyin[i]);
++ if(tmplen > 1)
++ ch2 = pinyin[i][1];
+ for (j = 0; (keytmp = pytab[ahead][j].key); j++)
+ {
+- if (tmplen == 1 || !strncmp (pinyin[i], pytab[ahead][j].py, tmplen))
++// if (tmplen == 1 || !strncmp (pinyin[i], pytab[ahead][j].py, tmplen))
++ if (tmplen == 1 || !strcmp (pinyin[i], pytab[ahead][j].py)
++ || ((tmplen == 2) && (!FuzzyPinyin)&&(ch=='z'||ch=='c'||ch=='s')
++ &&(ch2=='h')))
+ // prefix match
+ {
+ pykey[count][lenkey++] = keytmp;
+@@ -1048,7 +1206,7 @@
+ }
+ }
+ pykey[count++][lenkey] = 0;
+- } // for i = 1 to lenpy, pykey array filled
++ } // for i = 1 to lenpy, pykey array filled
+
+ for (i = 0; i < MAX_PHRASE_LEN; i++)
+ lenarr[i] = 0;
+@@ -1334,13 +1492,17 @@
+ int
+ CCE_GetInputDisplay (InputModule * p, char *buf)
+ {
+- strcpy (buf, p->iapybuf);
++// strcpy (buf, p->iapybuf);
++ if(p->flg_english) strcpy(buf, p->inbuf);
++ else strcpy(buf, p->iapybuf);
+ return 1;
+ }
+
+ int
+ CCE_GetSelectDisplay (InputModule * p, char *buf)
+ {
+- strcpy (buf, p->iahzbuf);
++// strcpy (buf, p->iahzbuf);
++ if(p->flg_english) strcpy(buf, p->inbuf);
++ else strcpy(buf, p->iahzbuf);
+ return p->nTotalCurSel;
+ }
+--- unicon-3.0.4.orig/unicon/ImmModules/cce/xl_pinyin.h
++++ unicon-3.0.4/unicon/ImmModules/cce/xl_pinyin.h
+@@ -137,6 +137,7 @@
+ // MAX_HZ_BUF = 250
+ int nTotalCurSel; /* Total Selection */
+ int SelectionLen;
++ int flg_english;
+ }
+ InputModule; // about 30KB
+
+@@ -149,6 +150,8 @@
+ int Pinyin_KeyFilter (InputModule * inmd, u_char key, char *buf, int *len);
+ int Pinyin_KeyPressed (InputModule * inmd, u_char key);
+ void RefreshPYInputArea (InputModule * inmd);
++int SaveUsrPhrase(char *pathname);
++int SavePhraseFrequency(char *pathname);
+ int UnloadSysPhrase ();
+ int UnloadUserPhrase ();
+
+--- unicon-3.0.4.orig/unicon/ImmModules/turbo/Makefile.in
++++ unicon-3.0.4/unicon/ImmModules/turbo/Makefile.in
+@@ -1,11 +1,11 @@
+ prefix=@prefix@
+ CFLAGS=@CFLAGS@
+ # CFLAGS += -V2.7.2.3 -I.
+-CFLAGS += -I.
++CFLAGS += -I. -O2
+ PROG = TL_hzinput.so
+ TL_OBJS = xl_hzinput.o TL_hzinput.o xl_phrase.o xl_sysphrase.o xl_mfile.o
+
+-CFLAGS = -g -Wall -I../../include -I.
++CFLAGS = -fPIC -g -Wall -I../../include -I.
+
+ all:dlib
+ dlib: $(PROG)
+@@ -21,7 +21,7 @@
+ xl_sysphrase.o : xl_sysphrase.c
+ gcc $(CFLAGS) -c xl_sysphrase.c -o xl_sysphrase.o
+ $(PROG): $(TL_OBJS)
+- gcc $(TL_OBJS) -shared -o $(PROG)
++ gcc $(TL_OBJS) -fPIC -shared -o $(PROG)
+
+ # GB Support
+ gbdata: cin2tab addphrase levelphrase
+@@ -62,7 +62,8 @@
+ install: all
+ mkdir -p $(prefix)/lib/unicon/modules/turbo
+ cp -f *.so $(prefix)/lib/unicon/modules/turbo
+-data-install: big5data gbdata
++#data-install: big5data gbdata
++data-install:
+ mkdir -p $(prefix)/lib/unicon/modules/turbo/dict/{gb,gbk,big5}
+ cp -f tl_sysphrase.*.bin $(prefix)/lib/unicon/modules/turbo
+ cp -f gb/*.tab $(prefix)/lib/unicon/modules/turbo/dict/gb
+--- unicon-3.0.4.orig/unicon/ImmModules/turbo/xl_phrase.c
++++ unicon-3.0.4/unicon/ImmModules/turbo/xl_phrase.c
+@@ -413,11 +413,11 @@
+ }
+
+ static TL_SysPhrase_T *pDefaultSysPhrase = NULL;
+-static int qcmp (void *t1, void *t2)
++static int qcmp (const void *t1, const void *t2)
+ {
+ u_long c1, c2;
+- ITEM *a = (ITEM *) t1,
+- *b = (ITEM*) t2;
++ const ITEM *a = (ITEM *) t1,
++ *b = (ITEM*) t2;
+
+ if (a->key1 > b->key1)
+ return 1;
+--- unicon-3.0.4.orig/unicon/ImmModules/turbo/xl_hzinput.c
++++ unicon-3.0.4/unicon/ImmModules/turbo/xl_hzinput.c
+@@ -239,11 +239,11 @@
+ }
+
+ static HzInputTable_T *pDefaultClient = NULL;
+-static int qcmp (void *t1, void *t2)
++static int qcmp (const void *t1, const void *t2)
+ {
+ long c1, c2, k1, k2;
+- long *a = (long *) t1,
+- *b = (long *) t2;
++ const long *a = (long *) t1,
++ *b = (long *) t2;
+ int n1, n2, m1, m2;
+ static char p1[256], p2[256];
+ n1 = pDefaultClient->cur_table->item[*a].nPhrase;
+--- unicon-3.0.4.orig/unicon/ImmModules/turbo/xl_mfile.c
++++ unicon-3.0.4/unicon/ImmModules/turbo/xl_mfile.c
+@@ -26,6 +26,7 @@
+
+ #include <stdlib.h>
+ #include <stdio.h>
++#include <string.h>
+
+ typedef struct MemFile_handle
+ {
+--- unicon-3.0.4.orig/unicon/ImmModules/cxterm/dict/Makefile
++++ unicon-3.0.4/unicon/ImmModules/cxterm/dict/Makefile
+@@ -0,0 +1,34 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++dictdir=$(prefix)/lib/unicon/modules/cxterm/dict
++
++SUBDIRS = gb big5 jis ks
++all::
++ for i in $(SUBDIRS) ;\
++ do \
++ echo "making" all "in $(CURRENT_DIR)/$$i..."; \
++ $(MAKE) -C $$i all; \
++ done
++
++clean:
++ $(RM) *.CKP *.ln *.BAK *.bak *.o core errs ,* *~ *.a .emacs_* make.log MakeOut core "#"*
++ @for flag in ${MAKEFLAGS} ''; do \
++ case "$$flag" in *=*) ;; *[ik]*) set +e;; esac; done; \
++ for i in $(SUBDIRS) ;\
++ do \
++ echo "cleaning" "in $(CURRENT_DIR)/$$i..."; \
++ $(MAKE) -C $$i $(MFLAGS) $(PARALLELMFLAGS) clean; \
++ done
++distclean:
++ $(RM) Makefile tags TAGS
++
++install: all
++ for i in $(SUBDIRS) ;\
++ do \
++ echo "installing" "in $$i..."; \
++ mkdir -p $(dictdir)/$$i; \
++ install -o root -g root -m644 $$i/*.cit $(dictdir)/$$i/; \
++ done
++
++
++
+--- unicon-3.0.4.orig/unicon/ImmModules/cxterm/utils/Makefile
++++ unicon-3.0.4/unicon/ImmModules/cxterm/utils/Makefile
+@@ -0,0 +1,37 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++
++CFLAGS += -I. -I..
++
++LIBDIR = $(prefix)/lib/unicon
++LD = gcc $(CFLAGS)
++INSTALL = install -c
++
++GROUP = root
++
++PROGS = cit2tit tit2cit
++
++all: $(PROGS)
++
++cit2tit:
++ $(LD) -o cit2tit cit2tit.c HZutil.c
++
++tit2cit:
++ $(LD) -o tit2cit tit2cit.c HZutil.c
++
++clean:
++ rm -f $(PROGS)
++ rm -f *.o core *~ *.bak
++
++distclean:clean
++ rm -f Makefile tags TAGS
++
++install: all
++ mkdir -p $(LIBDIR)/bin
++ $(INSTALL) -o root -g $(GROUP) -m 755 -d $(LIBDIR)/bin
++ $(INSTALL) -s -o root -g $(GROUP) -m 755 tit2cit $(LIBDIR)/bin
++ $(INSTALL) -s -o root -g $(GROUP) -m 755 cit2tit $(LIBDIR)/bin
++
++
++
+--- unicon-3.0.4.orig/unicon/ImmModules/cxterm/Makefile.in
++++ unicon-3.0.4/unicon/ImmModules/cxterm/Makefile.in
+@@ -5,13 +5,13 @@
+ PROG = cxterm_hzinput.so
+ OBJS = hzinput.o Cxterm_hzinput.o
+
+-CFLAGS = -g -Wall -I../../include -I.
++CFLAGS = -fPIC -g -Wall -I../../include -I.
+
+ all: $(PROG)
+ cd utils && make
+ cd dict && make
+ $(PROG) : $(OBJS)
+- gcc $(OBJS) -shared -o $(PROG)
++ gcc $(OBJS) -fPIC -shared -o $(PROG)
+ Cxterm_hzinput.o : Cxterm_hzinput.c
+ gcc $(CFLAGS) -c Cxterm_hzinput.c -o Cxterm_hzinput.o
+ hzinput.o : hzinput.c
+--- unicon-3.0.4.orig/unicon/ImmModules/cxterm/Makefile
++++ unicon-3.0.4/unicon/ImmModules/cxterm/Makefile
+@@ -0,0 +1,34 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++# CFLAGS += -V2.7.2.3 -I.
++CFLAGS += -I.
++PROG = cxterm_hzinput.so
++OBJS = hzinput.o Cxterm_hzinput.o
++
++CFLAGS = -fPIC -g -Wall -I../../include -I.
++
++all: $(PROG)
++ cd utils && make
++ cd dict && make
++$(PROG) : $(OBJS)
++ gcc $(OBJS) -fPIC -shared -o $(PROG)
++Cxterm_hzinput.o : Cxterm_hzinput.c
++ gcc $(CFLAGS) -c Cxterm_hzinput.c -o Cxterm_hzinput.o
++hzinput.o : hzinput.c
++ gcc $(CFLAGS) -c hzinput.c -o hzinput.o
++install: all
++ mkdir -p $(prefix)/lib/unicon/modules/cxterm
++ cp *.so $(prefix)/lib/unicon/modules/cxterm
++ cd utils && make install
++ cd dict && make install
++clean:
++ rm -f *.o core a.out *.bak test *.so *~
++ cd utils && make clean
++ cd dict && make clean
++
++distclean: clean
++ rm -f Makefile tags TAGS
++ cd utils && make distclean
++ cd dict && make distclean
++
+--- unicon-3.0.4.orig/unicon/Makefile.in
++++ unicon-3.0.4/unicon/Makefile.in
+@@ -2,9 +2,9 @@
+ all:
+ cd server; make
+ cd client; make
+- cd unicon; make
++# cd unicon; make
+ cd ImmModules/cce && make
+- cd ImmModules/cxterm && make
++# cd ImmModules/cxterm && make
+ cd ImmModules/turbo && make
+ ccedata:
+ cd ImmModules/cce/inputs && make
+@@ -19,23 +19,25 @@
+ if [ ! -d $(prefix) ] ; then mkdir -p $(prefix); fi
+ if [ ! -d $(prefix)/lib/unicon ] ; then mkdir -p $(prefix)/lib/unicon; fi
+ if [ ! -d $(prefix)/bin ] ; then mkdir -p $(prefix)/bin; fi
+- cd ImmModules/cce/inputs; make install
+- cd ImmModules/turbo; make data-install
++ cd ImmModules/cce/inputs; make install prefix=$(prefix)
++ cd ImmModules/turbo; make data-install prefix=$(prefix)
+ install: all
+ if [ ! -d $(prefix) ] ; then mkdir -p $(prefix); fi
+ if [ ! -d $(prefix)/lib/unicon ] ; then mkdir -p $(prefix)/lib/unicon; fi
+ if [ ! -d $(prefix)/bin ] ; then mkdir -p $(prefix)/bin; fi
+ cd server; make install
+ cd client; make install
+- cd unicon; make install
++# cd unicon; make install
+ cd ImmModules/cce; make install
+- cd ImmModules/cxterm; make install
++# cd ImmModules/cxterm; make install
+ cd ImmModules/turbo; make install
++ cp -f unicon/sys-gb.tab $(prefix)/lib/unicon
++ cp -f unicon/sys-big5.tab $(prefix)/lib/unicon
+
+ clean:
+ cd server; make clean
+ cd client; make clean
+- cd unicon; make clean
++# cd unicon; make clean
+ cd ImmModules/cce; make clean
+ cd ImmModules/cce/inputs; make clean
+ cd ImmModules/cxterm; make clean
+@@ -47,10 +49,10 @@
+ distclean: clean
+ rm -f config.status config.log config.cache Makefile tags TAGS
+ cd server; make distclean
+- cd unicon; make distclean
++# cd unicon; make distclean
+ cd client; make distclean
+ cd ImmModules/cce; make distclean
+ cd ImmModules/cce/inputs; make distclean
+- cd ImmModules/cxterm; make distclean
++# cd ImmModules/cxterm; make distclean
+ cd ImmModules/turbo; make distclean
+
+--- unicon-3.0.4.orig/unicon/server/TLS_Debug.cpp
++++ unicon-3.0.4/unicon/server/TLS_Debug.cpp
+@@ -32,8 +32,10 @@
+ #include <stdlib.h>
+ #include <assert.h>
+ #include <string.h>
++#include <stdarg.h>
+ #include <TLS_Debug.hpp>
+-TLS_CDebug::TLS_CDebug (char *szFileName, int mode = 0)
++
++TLS_CDebug::TLS_CDebug (char *szFileName, int mode)
+ {
+ if (szFileName == NULL)
+ {
+--- unicon-3.0.4.orig/unicon/server/Makefile.in
++++ unicon-3.0.4/unicon/server/Makefile.in
+@@ -1,7 +1,7 @@
+ prefix=@prefix@
+ CFLAGS = @CFLAGS@
+ APP_PROG = imm_server
+-DLIB_PROG = libimm_server.so
++DLIB_PROG = libimm_server.so.0.0
+
+ APP_OBJS = TLS_HzInput.o TLS_ImmOp.o TLS_TcpipMain.o TLS_MemFile.o \
+ TLS_PthSocket.o TLS_Debug.o \
+@@ -14,13 +14,13 @@
+ LIBS = /usr/lib/libpth.so -ldl
+
+ # CFLAGS = -g -D__IMM_DEBUG__ -Wall -I. -I/usr/include -I../include
+-CFLAGS = -g -Wall -I. -I/usr/include -I../include
++CFLAGS = -fPIC -g -Wall -I. -I../include
+ CC=g++
+
+ all: $(DLIB_PROG)
+
+-libimm_server.so: $(DLIB_OBJS)
+- $(CC) $(DLIB_OBJS) -shared -o $(DLIB_PROG)
++libimm_server.so.0.0: $(DLIB_OBJS)
++ $(CC) $(DLIB_OBJS) -fPIC -Wl,-soname,libimm_server.so.0 -shared -o $(DLIB_PROG) -ldl
+
+ TLS_LibMain.o : TLS_LibMain.cpp
+ $(CC) $(CFLAGS) -DUNICON_LIB=\"$(prefix)/lib/unicon\" -c TLS_LibMain.cpp -o TLS_LibMain.o
+@@ -46,9 +46,10 @@
+
+ install: all
+ mkdir -p $(prefix)/bin
+- mkdir -p $(prefix)/lib/unicon
++ mkdir -p $(prefix)/lib
+ if [ -f $(APP_PROG) ]; then cp -f $(APP_PROG) $(prefix)/bin; fi
+- if [ -f $(DLIB_PROG) ]; then cp -f $(DLIB_PROG) $(prefix)/lib/unicon; fi
++ if [ -f $(DLIB_PROG) ]; then cp -f $(DLIB_PROG) $(prefix)/lib; fi
++ cd $(prefix)/lib;ln -s libimm_server.so.0.0 libimm_server.so.0;ln -s libimm_server.so.0 libimm_server.so
+
+ clean:
+ if test -e $(PROG); then rm -f $(PROG); fi
+--- unicon-3.0.4.orig/unicon/unicon/unicon.ini.in
++++ unicon-3.0.4/unicon/unicon/unicon.ini.in
+@@ -49,8 +49,8 @@
+ MethodModule7=@PREFIX@/lib/unicon/modules/turbo/TL_hzinput.so
+ MethodTable7=@PREFIX@/lib/unicon/modules/turbo/dict/gb/CangJie.tab
+ MethodName7=苍颉输入
+-MethodModule8=@PREFIX@/lib/unicon/modules/turbo/TL_hzinput.so
+-MethodTable8=@PREFIX@/lib/unicon/modules/turbo/dict/gb/WuBi.tab
++MethodModule8=@PREFIX@/lib/unicon/modules/cce/cce_hzinput.so
++MethodTable8=@PREFIX@/lib/unicon/modules/cce/dict/wubi.tab
+ MethodName8=五笔字型
+ MethodModule9=@PREFIX@/lib/unicon/modules/turbo/TL_hzinput.so
+ MethodTable9=@PREFIX@/lib/unicon/modules/turbo/dict/gb/QianMa.tab
+@@ -110,8 +110,8 @@
+ MethodModule7=@PREFIX@/lib/unicon/modules/turbo/TL_hzinput.so
+ MethodTable7=@PREFIX@/lib/unicon/modules/turbo/dict/gb/CangJie.tab
+ MethodName7=苍颉输入
+-MethodModule8=@PREFIX@/lib/unicon/modules/turbo/TL_hzinput.so
+-MethodTable8=@PREFIX@/lib/unicon/modules/turbo/dict/gb/WuBi.tab
++MethodModule8=@PREFIX@/lib/unicon/modules/cce/cce_hzinput.so
++MethodTable8=@PREFIX@/lib/unicon/modules/cce/dict/wubi.tab
+ MethodName8=五笔字型
+ MethodModule9=@PREFIX@/lib/unicon/modules/turbo/TL_hzinput.so
+ MethodTable9=@PREFIX@/lib/unicon/modules/turbo/dict/gb/QianMa.tab
+--- unicon-3.0.4.orig/unicon/unicon/Makefile
++++ unicon-3.0.4/unicon/unicon/Makefile
+@@ -0,0 +1,52 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++PROG = unicon
++OBJS = ImmHzInput.o AImmHzInput.o Main.o UniKey.o \
++ MyInputArea.o SysConfig.o MyConfig.o ConfigManager.o
++S_IMM_LIB = ../client/libimmclient.a
++D_IMM_LIB = ../client/libimmclient.a -lpth -ldl -L../server -Wl,-rpath=$(prefix)/lib/unicon -limm_server
++
++# CFLAGS = -g -Wall -I. -DSIMULATE_OS_KEY -DSIMULATE_OS_VIDEO
++# __CLIB24_SUPPORT__
++CFLAGS = -g -Wall -I. -I../include -I../../include -I../unikey
++CC = g++ -g
++all: $(PROG) unicon.ini
++
++unicon: $(OBJS) $(S_IMM_LIB)
++ $(CC) -ldl $(OBJS) $(D_IMM_LIB) -o $(PROG)
++
++slib: $(OBJS) $(S_IMM_LIB)
++ $(CC) $(OBJS) $(S_IMM_LIB) -o $(PROG)
++ImmHzInput.o: ImmHzInput.cpp ImmHzInput.hpp
++ $(CC) $(CFLAGS) -c ImmHzInput.cpp -o ImmHzInput.o
++AImmHzInput.o: AImmHzInput.cpp AImmHzInput.hpp
++ $(CC) $(CFLAGS) -c AImmHzInput.cpp -o AImmHzInput.o
++MyInputArea.o: MyInputArea.cpp MyInputArea.hpp
++ $(CC) $(CFLAGS) -c MyInputArea.cpp -o MyInputArea.o
++SysConfig.o : SysConfig.cpp SysConfig.hpp
++ $(CC) $(CFLAGS) -c SysConfig.cpp -o SysConfig.o
++MyConfig.o : MyConfig.cpp MyConfig.hpp SysConfig.hpp
++ $(CC) $(CFLAGS) -DUNICON_LIB=\"$(prefix)/lib/unicon\" -c MyConfig.cpp -o MyConfig.o
++UniKey.o : UniKey.hpp UniKey.cpp
++ $(CC) $(CFLAGS) -c UniKey.cpp -o UniKey.o
++Main.o: Main.cpp
++ $(CC) $(CFLAGS) -D__DLL_SUPPORT__ -DUNICON_LIB=\"$(prefix)/lib/unicon\" -c Main.cpp -o Main.o
++ConfigManager.o: ConfigManager.cpp
++ $(CC) $(CFLAGS) -DUNICON_LIB=\"$(prefix)/lib/unicon\" -c ConfigManager.cpp -o ConfigManager.o
++
++unicon.ini: unicon.ini.in
++ sed -e "s.@PREFIX@.$(prefix).g" unicon.ini.in > unicon.ini
++
++install: all
++ mkdir -p $(prefix)/bin $(prefix)/lib/unicon
++ install -o root -g root -m755 unicon $(prefix)/bin
++ install -o root -g root -m644 unicon.ini $(prefix)/lib/unicon
++ install -o root -g root -m644 sys-gb.tab $(prefix)/lib/unicon
++ install -o root -g root -m644 sys-big5.tab $(prefix)/lib/unicon
++
++clean:
++ rm -f *.o core *.bak a.out unicon.ini *~ $(PROG)
++
++distclean: clean
++ rm -f Makefile tags TAGS
+--- unicon-3.0.4.orig/unikey/Makefile.in
++++ unicon-3.0.4/unikey/Makefile.in
+@@ -3,6 +3,7 @@
+ CFLAGS += -I. -I./include -I../include -I/usr/src/linux/include -include /usr/src/linux/include/linux/modversions.h
+ PROG = unikey.o
+ CC=gcc $(CFLAGS)
++DESTDIR =
+
+ MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
+
+--- unicon-3.0.4.orig/unikey/Makefile
++++ unicon-3.0.4/unikey/Makefile
+@@ -0,0 +1,40 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++CFLAGS = -g -O2
++CFLAGS += -I. -I./include -I../include -I/usr/src/linux/include -include /usr/src/linux/include/linux/modversions.h
++PROG = unikey.o
++CC=gcc $(CFLAGS)
++DESTDIR =
++
++MODCFLAGS = -Wall -O2 -DMODULE -D__KERNEL__ -DLINUX
++
++all: $(PROG)
++
++unikey.o: xl_keyhooks.o xl_unikey.o xl_keymasks.o xl_hzfb.o xl_fontmgr.o
++ ld -m elf_i386 -r xl_keyhooks.o xl_unikey.o xl_keymasks.o xl_hzfb.o \
++ xl_fontmgr.o -o unikey.o
++
++xl_unikey.o: xl_unikey.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c xl_unikey.c -o xl_unikey.o
++
++xl_keyhooks.o: xl_keyhooks.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c xl_keyhooks.c -o xl_keyhooks.o
++
++xl_keymasks.o: xl_keymasks.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c xl_keymasks.c -o xl_keymasks.o
++
++xl_hzfb.o: xl_hzfb.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c xl_hzfb.c -o xl_hzfb.o
++xl_fontmgr.o: xl_fontmgr.c /usr/include/linux/version.h
++ $(CC) $(MODCFLAGS) -c xl_fontmgr.c -o xl_fontmgr.o
++
++clean:
++ rm -f *.bak *.o xl_unikey.o *~ core $(PROG)
++
++install: all
++ rm -f /dev/unikey ; \
++ mknod /dev/unikey c 10 202 ; \
++ sh install_module.sh $(PROG)
++
++distclean: clean
++ rm -f Makefile tags TAGS
+--- unicon-3.0.4.orig/unimap/Makefile
++++ unicon-3.0.4/unimap/Makefile
+@@ -0,0 +1,14 @@
++# Generated automatically from Makefile.in by configure.
++prefix=/usr
++all: unimapsh
++unimapsh:
++ echo "#!/bin/bash" > load-unimap.sh
++ echo "loadunimap $(prefix)/lib/unicon/direct.uni" >> load-unimap.sh
++install: all
++ install -m 644 direct.uni $(prefix)/lib/unicon
++ install -m 644 load-unimap.sh $(prefix)/lib/unicon
++clean:
++ rm -f *.bak core *~ load-unimap.sh
++
++distclean: clean
++ rm -f Makefile
+--- unicon-3.0.4.orig/debian/README.Debian
++++ unicon-3.0.4/debian/README.Debian
+@@ -0,0 +1,5 @@
++unicon for Debian
++----------------------
++
++
++ -- Yu Guanghui <ygh@debian.org>, Thu, 16 Nov 2000 08:48:37 +0800
+--- unicon-3.0.4.orig/debian/changelog
++++ unicon-3.0.4/debian/changelog
+@@ -0,0 +1,183 @@
++unicon (3.0.4-9) unstable; urgency=low
++
++ * Fix gcc-3.2 compile errors. (closes:Bug#188909)
++
++ -- Yu Guanghui <ygh@debian.org> Thu, 8 May 2003 13:17:08 +0800
++
++unicon (3.0.4-8) unstable; urgency=low
++
++ * minor fixes.
++
++ -- Yu Guanghui <ygh@debian.org> Mon, 19 Aug 2002 18:31:39 +0800
++
++unicon (3.0.4-7) unstable; urgency=low
++
++ * Changed WuBi input method from turbo to cce.
++
++ -- Yu Guanghui <ygh@debian.org> Sat, 11 May 2002 21:33:28 +0800
++
++unicon (3.0.4-6) unstable; urgency=low
++
++ * This patch is from John R. Daily [jdaily@progeny.com].
++ Thank you very much. (closes:Bug#119877)
++ * Added ia64 to the "Architecture" line in debian/control
++ (change arch to any)
++ * Critical: Added stdlib.h include to cin2tab.c so that
++ realloc(3) returns a valid pointer. Without the function
++ prototype, the 64-bit pointer was being truncated to a
++ 32-bit int, and unlike on alpha, ia64 uses the entire
++ 64-bit space for pointer values.
++ * Added string.h to xl_mfile.c to provide a prototype for
++ memcpy(3).
++ * Minor: Changed functions passed to qsort to declare const
++ arguments, to better comply with qsort's prototype. There
++ are still warnings because the parameters are not void *
++ in two files.
++
++ -- Yu Guanghui <ygh@debian.org> Sat, 17 Nov 2001 08:32:49 +0800
++
++unicon (3.0.4-5) unstable; urgency=low
++
++ * Removed IA64 from the support listing. It will be added
++ in future if the new versoin supports IA64.
++
++ -- Yu Guanghui <ygh@debian.org> Wed, 24 Oct 2001 15:33:08 +0800
++
++unicon (3.0.4-4) unstable; urgency=low
++
++ * Fixed a memory leak. Got the patch from www.linuxforum.com.
++
++ -- Yu Guanghui <ygh@debian.org> Sun, 21 Oct 2001 17:41:11 +0800
++
++unicon (3.0.4-3) unstable; urgency=low
++
++ * Compiled cce module with -fPIC. (closes:Bug#114784)
++
++ -- Yu Guanghui <ygh@debian.org> Mon, 8 Oct 2001 22:03:54 +0800
++
++unicon (3.0.4-2) unstable; urgency=low
++
++ * Fixed exact match.
++
++ -- Yu Guanghui <ygh@debian.org> Sun, 7 Oct 2001 21:57:49 +0800
++
++unicon (3.0.4-1) unstable; urgency=low
++
++ * New upstream release
++ * Merged with old patches.
++
++ -- Yu Guanghui <ygh@debian.org> Mon, 17 Sep 2001 20:08:09 +0800
++
++unicon (3.0.3-7) unstable; urgency=low
++
++ * Fixed tab2txt bug. Get from miniChinput-0.0.2-alpha2.
++
++ -- Yu Guanghui <ygh@debian.org> Wed, 18 Jul 2001 00:12:56 +0800
++
++unicon (3.0.3-6) unstable; urgency=low
++
++ * Fixed the include path, in order to let gcc 3.0 work.
++ (closes: Bug#104618, Bug#104759)
++ * Need more than 150 mins build time under m68k. (closes: Bug#103802)
++
++ -- Yu Guanghui <ygh@debian.org> Sat, 14 Jul 2001 10:27:19 +0800
++
++unicon (3.0.3-5) unstable; urgency=low
++
++ * New excat match patch, get from miniChinput.
++
++ -- Yu Guanghui <ygh@debian.org> Sun, 8 Jul 2001 18:55:02 +0800
++
++unicon (3.0.3-4) unstable; urgency=low
++
++ * Megred with minichinput.
++
++ -- Yu Guanghui <ygh@debian.org> Fri, 6 Jul 2001 15:44:40 +0800
++
++unicon (3.0.3-3) unstable; urgency=low
++
++ * Merged patch from huyou (www.linuxforum.net). The ZNPY input method
++ supports user phrase.
++
++ -- Yu Guanghui <ygh@debian.org> Thu, 5 Jul 2001 22:54:00 +0800
++
++unicon (3.0.3-2) unstable; urgency=low
++
++ * Apply patch for ZNPY input. If it's an exact match, break out now.
++ Thank althea.bbs@bbs.smth.org.
++
++ -- Yu Guanghui <ygh@debian.org> Fri, 29 Jun 2001 18:19:56 +0800
++
++unicon (3.0.3-1) unstable; urgency=low
++
++ * New upstream release
++
++ -- Yu Guanghui <ygh@debian.org> Sun, 17 Jun 2001 11:35:33 +0800
++
++unicon (3.0.2-3) unstable; urgency=low
++
++ * Marked conflics with chinput <= 3.0.1-3.
++ * Close again.(closes: Bug#99670)
++
++ -- Yu Guanghui <ygh@debian.org> Thu, 10 May 2001 00:59:30 +0800
++
++unicon (3.0.2-2) unstable; urgency=low
++
++ * Removed cxterm dict build, we don't need it. (closes: #Bug96670)
++
++ -- Yu Guanghui <ygh@debian.org> Tue, 8 May 2001 00:21:51 +0800
++
++unicon (3.0.2-1) unstable; urgency=low
++
++ * New upstream release
++
++ -- Yu Guanghui <ygh@debian.org> Wed, 2 May 2001 00:07:39 +0800
++
++unicon (3.0-7) unstable; urgency=low
++
++ * Added Build-Depends: xlibs-dev
++
++ -- Yu Guanghui <ygh@debian.org> Tue, 13 Mar 2001 21:02:59 +0800
++
++unicon (3.0-6) unstable; urgency=low
++
++ * Fixed alpha build fails. (closes:Bug#87981)
++ I Have sended the patch to the upstream author.
++
++ -- Yu Guanghui <ygh@debian.org> Wed, 28 Feb 2001 23:11:55 +0800
++
++unicon (3.0-5) unstable; urgency=low
++
++ * Added Build-Depends: debhelper,libpth-dev (closes:Bug#87268)
++
++ -- Yu Guanghui <ygh@debian.org> Sat, 24 Feb 2001 09:13:44 +0800
++
++unicon (3.0-4) unstable; urgency=low
++
++ *Add lintian override file for unicon-im, make lintian happy.
++
++ -- Yu Guanghui <ygh@debian.org> Tue, 20 Feb 2001 23:04:43 +0800
++
++unicon (3.0-3) unstable; urgency=low
++
++ *Fixed the shared library install: libimm_server.so.0.0 is installed correctly now.
++ *Add lost file sys-gb.tab, sys-big5.tab to /usr/lib/unicon
++ *Applyed pinyin input method patch from Liang Changtai<linuxrat@gnuchina.org>.
++
++ -- Yu Guanghui <ygh@debian.org> Mon, 19 Feb 2001 22:25:46 +0800
++
++unicon (3.0-2) unstable; urgency=low
++
++ * add gcc compile flag -fPIC for the shared libraries.
++
++ -- Yu Guanghui <ygh@debian.org> Sun, 18 Feb 2001 21:21:08 +0800
++
++unicon (3.0-1) unstable; urgency=low
++
++ * Initial Release.
++
++ -- Yu Guanghui <ygh@debian.org> Thu, 16 Nov 2000 08:48:37 +0800
++
++Local variables:
++mode: debian-changelog
++End:
+--- unicon-3.0.4.orig/debian/copyright
++++ unicon-3.0.4/debian/copyright
+@@ -0,0 +1,19 @@
++This package was debianized by Yu Guanghui <ygh@debian.org> on
++Thu, 16 Nov 2000 08:48:37 +0800.
++
++It was downloaded from ftp.turbolinux.com.cn
++
++Upstream Author(s): Arthur Ma <arthur.ma@turbolinux.com.cn>
++
++Copyright:
++
++This is UNICON
++
++The programs in this package may be copied under the terms of the GNU Lesser
++General Public Licence, version 2.1 (see below).
++
++They were written by several people, and integrate work from many many
++others. See the CREDITS file for details.
++
++On Debian systems, you can find the complete GNU GPL v2 at
++/usr/share/common-licenses/GPL.
+--- unicon-3.0.4.orig/debian/unicon-im.files
++++ unicon-3.0.4/debian/unicon-im.files
+@@ -0,0 +1 @@
++usr
+--- unicon-3.0.4.orig/debian/postinst
++++ unicon-3.0.4/debian/postinst
+@@ -0,0 +1,45 @@
++#! /bin/sh
++# postinst script for unicon
++#
++# see: dh_installdeb(1)
++
++set -e
++
++# summary of how this script can be called:
++# * <postinst> `configure' <most-recently-configured-version>
++# * <old-postinst> `abort-upgrade' <new version>
++# * <conflictor's-postinst> `abort-remove' `in-favour' <package>
++# <new-version>
++# * <deconfigured's-postinst> `abort-deconfigure' `in-favour'
++# <failed-install-package> <version> `removing'
++# <conflicting-package> <version>
++# for details, see /usr/doc/packaging-manual/
++#
++# quoting from the policy:
++# Any necessary prompting should almost always be confined to the
++# post-installation script, and should be protected with a conditional
++# so that unnecessary prompting doesn't happen if a package's
++# installation fails and the `postinst' is called with `abort-upgrade',
++# `abort-remove' or `abort-deconfigure'.
++
++case "$1" in
++ configure)
++ ;;
++
++ abort-upgrade|abort-remove|abort-deconfigure)
++ ;;
++
++ *)
++ echo "postinst called with unknown argument \`$1'" >&2
++ exit 0
++ ;;
++esac
++
++# dh_installdeb will replace this with shell code automatically
++# generated by other debhelper scripts.
++
++#DEBHELPER#
++
++exit 0
++
++
+--- unicon-3.0.4.orig/debian/postrm
++++ unicon-3.0.4/debian/postrm
+@@ -0,0 +1,37 @@
++#! /bin/sh
++# postrm script for unicon
++#
++# see: dh_installdeb(1)
++
++set -e
++
++# summary of how this script can be called:
++# * <postrm> `remove'
++# * <postrm> `purge'
++# * <old-postrm> `upgrade' <new-version>
++# * <new-postrm> `failed-upgrade' <old-version>
++# * <new-postrm> `abort-install'
++# * <new-postrm> `abort-install' <old-version>
++# * <new-postrm> `abort-upgrade' <old-version>
++# * <disappearer's-postrm> `disappear' <r>overwrit>r> <new-version>
++# for details, see /usr/doc/packaging-manual/
++
++case "$1" in
++ purge|remove|upgrade|failed-upgrade|abort-install|abort-upgrade|disappear)
++
++ # update the menu system
++# if [ -x /usr/bin/update-menus ]; then update-menus; fi
++ ;;
++
++ *)
++ echo "postrm called with unknown argument \`$1'" >&2
++ exit 0
++
++esac
++
++# dh_installdeb will replace this with shell code automatically
++# generated by other debhelper scripts.
++
++#DEBHELPER#
++
++
+--- unicon-3.0.4.orig/debian/TODO.Debian
++++ unicon-3.0.4/debian/TODO.Debian
+@@ -0,0 +1,4 @@
++Only the input method library has been packged now. The unicon package will finish
++soon.
++ Yu Guanghui<ygh@debian.org>
++ 2001.2.18
+--- unicon-3.0.4.orig/debian/control
++++ unicon-3.0.4/debian/control
+@@ -0,0 +1,14 @@
++Source: unicon
++Section: utils
++Build-Depends: debhelper (>= 2.0.72), libpth-dev, xlibs-dev
++Priority: optional
++Maintainer: Yu Guanghui <ygh@debian.org>
++Standards-Version: 3.5.0
++
++Package: unicon-im
++Architecture: any
++Depends: ${shlibs:Depends}
++Conflicts: chinput (<= 3.0.1-3)
++Description: Chinese Input Method Libaray
++ General Chinese Input method interface and API. It is using by chinput and
++ unicon now.
+--- unicon-3.0.4.orig/debian/unicon-im.override
++++ unicon-3.0.4/debian/unicon-im.override
+@@ -0,0 +1,3 @@
++unicon-im: shlib-with-non-pic-code usr/lib/unicon/modules/turbo/TL_hzinput.so
++unicon-im: non-dev-pkg-with-shlib-symlink usr/lib/libimm_server.so.0.0 usr/lib/libimm_server.so
++unicon-im: postinst-must-call-ldconfig usr/lib/libimm_server.so.0.0
+--- unicon-3.0.4.orig/debian/rules
++++ unicon-3.0.4/debian/rules
+@@ -0,0 +1,93 @@
++#!/usr/bin/make -f
++# Sample debian/rules that uses debhelper.
++# GNU copyright 1997 by Joey Hess.
++#
++# This version is for a hypothetical package that builds an
++# architecture-dependant package, as well as an architecture-independent
++# package.
++
++# Uncomment this to turn on verbose mode.
++#export DH_VERBOSE=1
++
++# This is the debhelper compatability version to use.
++export DH_COMPAT=3
++
++# This has to be exported to make some magic below work.
++
++# shared library versions, option 1
++version=0.0
++major=0
++
++
++build: build-stamp
++build-stamp:
++ dh_testdir
++
++ ./configure --prefix=/usr --mandir=\$${prefix}/share/man --infodir=\$${prefix}/share/info
++ # Add here commands to compile the package.
++ $(MAKE)
++ $(MAKE) data
++
++ touch build-stamp
++
++clean:
++ dh_testdir
++ dh_testroot
++ rm -f build-stamp
++
++ # Add here commands to clean up after the build process.
++ -$(MAKE) distclean
++
++ dh_clean
++
++install: build
++ dh_testdir
++ dh_testroot
++ dh_clean -k
++ dh_installdirs
++
++ $(MAKE) install prefix=`pwd`/debian/unicon-im/usr DESTDIR=`pwd`/debian/unicon-im/usr
++ $(MAKE) data-install prefix=`pwd`/debian/unicon-im/usr
++ cp -f debian/unicon-im.override `pwd`/debian/unicon-im/usr/share/lintian/overrides/unicon-im
++
++# dh_movefiles
++
++# Build architecture-independent files here.
++# Pass -i to all debhelper commands in this target to reduce clutter.
++binary-indep: build install
++
++# Build architecture-dependent files here.
++# Pass -a to all debhelper commands in this target to reduce clutter.
++binary-arch: build install
++# Need this version of debhelper for DH_OPTIONS to work.
++# dh_testversion 1.1.17
++ dh_testdir
++ dh_testroot
++# dh_installdebconf
++ dh_installdocs
++ dh_installexamples
++ dh_installmenu
++# dh_installemacsen
++# dh_installpam
++# dh_installinit
++ dh_installcron
++# dh_installmanpages
++ dh_installinfo
++# dh_undocumented
++ dh_installchangelogs ChangeLog
++ dh_strip
++ dh_link
++ dh_compress
++ dh_fixperms
++ # You may want to make some executables suid here.
++# dh_suidregister
++ dh_installdeb
++ dh_makeshlibs
++# dh_perl
++ dh_shlibdeps
++ dh_gencontrol
++ dh_md5sums
++ dh_builddeb
++
++binary: binary-indep binary-arch
++.PHONY: build clean binary-indep binary-arch binary install
+--- unicon-3.0.4.orig/debian/unicon-im.docs
++++ unicon-3.0.4/debian/unicon-im.docs
+@@ -0,0 +1,13 @@
++BUGS
++README
++README_cn
++THANKS
++RELEASE
++RELEASE_cn
++CREDITS
++debian/TODO.Debian
++doc/faq_en.txt
++doc/smallfont.txt
++doc/tech_unicon.txt
++doc/unicon_font_header.txt
++doc/whitepaper_unicon.txt
+--- unicon-3.0.4.orig/debian/patches/ia64.patch
++++ unicon-3.0.4/debian/patches/ia64.patch
+@@ -0,0 +1,106 @@
++diff -Naur unicon.orig/unicon/ImmModules/cce/inputs/cin2dat.c unicon-3.0.4/unicon/ImmModules/cce/inputs/cin2dat.c
++--- unicon.orig/unicon/ImmModules/cce/inputs/cin2dat.c Tue Sep 11 02:12:10 2001
+++++ unicon-3.0.4/unicon/ImmModules/cce/inputs/cin2dat.c Fri Nov 16 14:41:36 2001
++@@ -114,7 +114,7 @@
++
++ /* qcmp2 compare two ITEM2 structure, according to its key1/key2/ch */
++ int
++-qcmp2 (ITEM2 * a, ITEM2 * b)
+++qcmp2 (const ITEM2 * a, const ITEM2 * b)
++ {
++ if (a->key1 > b->key1)
++ return 1;
++@@ -134,7 +134,7 @@
++
++ /* qcmp compare two ITEM2 structure, according to its key1/key2/occur_seq */
++ int
++-qcmp (ITEM2 * a, ITEM2 * b)
+++qcmp (const ITEM2 * a, const ITEM2 * b)
++ {
++ if (a->key1 > b->key1)
++ return 1;
++@@ -148,7 +148,7 @@
++ }
++
++ int
++-qcmp_ser (ITEM * a, ITEM * b)
+++qcmp_ser (const ITEM * a, const ITEM * b)
++ {
++ if (a->ch > b->ch)
++ return 1;
++diff -Naur unicon.orig/unicon/ImmModules/cce/inputs/cin2tab.c unicon-3.0.4/unicon/ImmModules/cce/inputs/cin2tab.c
++--- unicon.orig/unicon/ImmModules/cce/inputs/cin2tab.c Tue Sep 11 02:12:10 2001
+++++ unicon-3.0.4/unicon/ImmModules/cce/inputs/cin2tab.c Fri Nov 16 14:41:16 2001
++@@ -3,6 +3,7 @@
++ #include <stdarg.h>
++ #include <sys/types.h>
++ #include <string.h>
+++#include <stdlib.h>
++ #include "xl_hzinput.h"
++
++ FILE *fr, *fw;
++@@ -114,7 +115,7 @@
++
++ /* qcmp2 compare two ITEM2 structure, according to its key1/key2/ch */
++ int
++-qcmp2 (ITEM2 * a, ITEM2 * b)
+++qcmp2 (const ITEM2 * a, const ITEM2 * b)
++ {
++ if (a->key1 > b->key1)
++ return 1;
++@@ -152,7 +153,7 @@
++ }
++
++ int
++-qcmp_ser (ITEM * a, ITEM * b)
+++qcmp_ser (const ITEM * a, const ITEM * b)
++ {
++ if (a->ch > b->ch)
++ return 1;
++diff -Naur unicon.orig/unicon/ImmModules/turbo/xl_hzinput.c unicon-3.0.4/unicon/ImmModules/turbo/xl_hzinput.c
++--- unicon.orig/unicon/ImmModules/turbo/xl_hzinput.c Wed Aug 8 09:32:38 2001
+++++ unicon-3.0.4/unicon/ImmModules/turbo/xl_hzinput.c Fri Nov 16 14:35:47 2001
++@@ -239,11 +239,11 @@
++ }
++
++ static HzInputTable_T *pDefaultClient = NULL;
++-static int qcmp (void *t1, void *t2)
+++static int qcmp (const void *t1, const void *t2)
++ {
++ long c1, c2, k1, k2;
++- long *a = (long *) t1,
++- *b = (long *) t2;
+++ const long *a = (long *) t1,
+++ *b = (long *) t2;
++ int n1, n2, m1, m2;
++ static char p1[256], p2[256];
++ n1 = pDefaultClient->cur_table->item[*a].nPhrase;
++diff -Naur unicon.orig/unicon/ImmModules/turbo/xl_mfile.c unicon-3.0.4/unicon/ImmModules/turbo/xl_mfile.c
++--- unicon.orig/unicon/ImmModules/turbo/xl_mfile.c Wed Aug 8 09:32:38 2001
+++++ unicon-3.0.4/unicon/ImmModules/turbo/xl_mfile.c Fri Nov 16 14:36:15 2001
++@@ -26,6 +26,7 @@
++
++ #include <stdlib.h>
++ #include <stdio.h>
+++#include <string.h>
++
++ typedef struct MemFile_handle
++ {
++diff -Naur unicon.orig/unicon/ImmModules/turbo/xl_phrase.c unicon-3.0.4/unicon/ImmModules/turbo/xl_phrase.c
++--- unicon.orig/unicon/ImmModules/turbo/xl_phrase.c Wed Aug 8 09:32:38 2001
+++++ unicon-3.0.4/unicon/ImmModules/turbo/xl_phrase.c Fri Nov 16 14:38:43 2001
++@@ -413,11 +413,11 @@
++ }
++
++ static TL_SysPhrase_T *pDefaultSysPhrase = NULL;
++-static int qcmp (void *t1, void *t2)
+++static int qcmp (const void *t1, const void *t2)
++ {
++ u_long c1, c2;
++- ITEM *a = (ITEM *) t1,
++- *b = (ITEM*) t2;
+++ const ITEM *a = (ITEM *) t1,
+++ *b = (ITEM*) t2;
++
++ if (a->key1 > b->key1)
++ return 1;
+--- unicon-3.0.4.orig/debian/unicon-im.dirs
++++ unicon-3.0.4/debian/unicon-im.dirs
+@@ -0,0 +1,2 @@
++usr/share/lintian/overrides
++usr/lib/unicon
diff --git a/app-i18n/unicon/files/unicon-3.0.4-gentoo.patch b/app-i18n/unicon/files/unicon-3.0.4-gentoo.patch
new file mode 100644
index 000000000000..7be821844d8f
--- /dev/null
+++ b/app-i18n/unicon/files/unicon-3.0.4-gentoo.patch
@@ -0,0 +1,11 @@
+--- unicon-3.0.4/sfonts/tools/main.cpp 2001-08-08 15:32:33.000000000 +0100
++++ unicon-3.0.4/sfonts/tools/main.cpp 2003-05-25 03:10:59.000000000 +0100
+@@ -29,7 +29,7 @@
+ #include <mytype.h>
+ #include <filter.hpp>
+ #include <sfont.hpp>
+-
++#include <string.h>
+
+ /* font_type */
+ #define XL_DB_GB 0
diff --git a/app-i18n/unicon/unicon-3.0.4.ebuild b/app-i18n/unicon/unicon-3.0.4.ebuild
new file mode 100644
index 000000000000..39beb757469c
--- /dev/null
+++ b/app-i18n/unicon/unicon-3.0.4.ebuild
@@ -0,0 +1,63 @@
+# Copyright 1999-2003 Gentoo Technologies, Inc.
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/app-i18n/unicon/unicon-3.0.4.ebuild,v 1.1 2003/05/25 15:10:52 liquidx Exp $
+
+inherit eutils
+
+# This release was taken from debian sources. For some reason I can't
+# find this release on turbolinux's site. Even Mandrake is using the
+# older 3.0.3.
+
+# TODO: Figure out how to build the kernel-modules.
+
+DESCRIPTION="CJK (Chinese/Japanese/Korean) console input, display system and input modules."
+HOMEPAGE="http://www.gnu.org/directory/UNICON.html"
+SRC_URI="mirror://gentoo/${P}.tar.bz2"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~x86"
+IUSE=""
+
+DEPEND="virtual/kernel
+ dev-libs/newt
+ dev-libs/pth"
+
+S=${WORKDIR}/${P}
+
+MAKEOPTS="${MAKEOPTS} -j1"
+
+src_unpack() {
+ unpack ${A}
+ cd ${S}
+ einfo "Applying unicon-3.0.4-debian.patch"
+ patch -p1 < ${FILESDIR}/unicon-3.0.4-debian.patch || die "Failed applying debian patch"
+ epatch ${FILESDIR}/unicon-3.0.4-gentoo.patch
+}
+
+src_compile() {
+ econf
+
+ make || die "make failed"
+ make data || die "make data failed"
+
+ cd ${S}/tools
+ make || die "make tools failed"
+
+ # still has gcc-3.2 issues
+ # make -C sfonts/tools || die "make tools failed"
+}
+
+src_install() {
+ make prefix=${D}/usr install || die "install failed"
+
+ # still has gcc-3.2 issues
+ # dobin sfonts/tools/sfont
+ dobin tools/uniconcfg
+ dobin tools/uniconctrl
+
+ make prefix=${D}/usr data-install || die "install data failed"
+
+ dobin scripts/unicon-start
+
+}