mirror of
https://git.FreeBSD.org/ports.git
synced 2024-12-29 05:38:00 +00:00
1: sync with irc/irssi.
2: most big5 patch already move to irc/irssi, maybe we should remove this slave ports soon.
This commit is contained in:
parent
01faf1934e
commit
cf5980a259
Notes:
svn2git
2021-03-31 03:12:20 +00:00
svn path=/head/; revision=150950
@ -5,7 +5,7 @@
|
||||
# $FreeBSD$
|
||||
#
|
||||
|
||||
PORTREVISION= 5
|
||||
PORTREVISION= 0
|
||||
CATEGORIES= chinese
|
||||
|
||||
MAINTAINER= vanilla@FreeBSD.org
|
||||
@ -13,14 +13,6 @@ COMMENT= A zh-tw cursor movement friendly, wrapping clean irssi
|
||||
|
||||
MASTERDIR= ${.CURDIR}/../../irc/irssi
|
||||
|
||||
EXTRA_PATCHES= ${.CURDIR}/files/patch-irssi.conf \
|
||||
${.CURDIR}/files/patch-src::fe-text::gui-entry.c \
|
||||
${.CURDIR}/files/patch-src::fe-text::gui-entry.h \
|
||||
${.CURDIR}/files/patch-src::fe-text::gui-printtext.c \
|
||||
${.CURDIR}/files/patch-src::fe-text::gui-readline.c \
|
||||
${.CURDIR}/files/patch-src::fe-text::term-terminfo.c \
|
||||
${.CURDIR}/files/patch-src::fe-text::textbuffer-view.c \
|
||||
${.CURDIR}/files/patch-src::fe-text::utf8.c \
|
||||
${.CURDIR}/files/patch-src::fe-text::utf8.h
|
||||
EXTRA_PATCHES= ${.CURDIR}/files/patch-irssi.conf
|
||||
|
||||
.include "${MASTERDIR}/Makefile"
|
||||
|
@ -1,6 +1,6 @@
|
||||
--- irssi.conf.orig Sun Dec 7 16:25:52 2003
|
||||
+++ irssi.conf Sun Dec 7 16:29:49 2003
|
||||
@@ -1,115 +1,17 @@
|
||||
--- irssi.conf.orig Fri Dec 9 01:32:50 2005
|
||||
+++ irssi.conf Mon Dec 12 13:50:14 2005
|
||||
@@ -1,54 +1,15 @@
|
||||
servers = (
|
||||
- { address = "irc.stealth.net"; chatnet = "IRCnet"; port = "6668"; },
|
||||
- { address = "irc.efnet.net"; chatnet = "EFNet"; port = "6667"; },
|
||||
@ -9,24 +9,9 @@
|
||||
- chatnet = "Undernet";
|
||||
- port = "6667";
|
||||
- },
|
||||
- { address = "irc.dal.net"; chatnet = "DALnet"; port = "6667"; },
|
||||
- { address = "irc.freenode.net"; chatnet = "freenode"; port = "6667"; },
|
||||
- { address = "irc.gnome.org"; chatnet = "GIMPNet"; port = "6667"; },
|
||||
- { address = "irc.ptlink.net"; chatnet = "PTlink"; port = "6667"; },
|
||||
- {
|
||||
- address = "irc.sorcery.net";
|
||||
- chatnet = "SorceryNet";
|
||||
- port = "6667";
|
||||
- },
|
||||
- {
|
||||
- address = "irc.hashmark.net";
|
||||
- chatnet = "Hashmark";
|
||||
- port = "6667";
|
||||
- },
|
||||
- { address = "irc.ptnet.org"; chatnet = "PTnet"; port = "6667"; },
|
||||
- { address = "irc.azzurra.org"; chatnet = "AzzurraNET"; port = "6667"; },
|
||||
- { address = "irc.dal.net"; chatnet = "DALnet"; port = "6667"; },
|
||||
- { address = "irc.quakenet.org"; chatnet = "QuakeNet"; port = "6667"; },
|
||||
- { address = "silc.silcnet.org"; chatnet = "SILC"; port = "706"; }
|
||||
+ { address = "irc.hinet.net"; chatnet = "Hinet"; port = "6667"; },
|
||||
+ { address = "irc.seed.net.tw"; chatnet = "BSDChat"; port = "6667"; },
|
||||
+ { address = "irc.csie.nctu.edu.tw"; chatnet = "BSDChat"; port = "6667"; },
|
||||
+ { address = "irc.tw.freebsd.org"; chatnet = "BSDChat"; port = "6667"; }
|
||||
@ -36,7 +21,6 @@
|
||||
- IRCnet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "3";
|
||||
- max_msgs = "5";
|
||||
- max_whois = "4";
|
||||
- max_query_chans = "5";
|
||||
@ -44,80 +28,33 @@
|
||||
- EFNet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "4";
|
||||
- max_msgs = "3";
|
||||
- max_whois = "1";
|
||||
- };
|
||||
- Undernet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "3";
|
||||
- max_kicks = "1";
|
||||
- max_msgs = "3";
|
||||
- max_whois = "30";
|
||||
- };
|
||||
- DALnet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "6";
|
||||
- max_msgs = "3";
|
||||
- max_whois = "30";
|
||||
- };
|
||||
- freenode = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "4";
|
||||
- max_msgs = "1";
|
||||
- max_whois = "1";
|
||||
- };
|
||||
- GIMPNet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "4";
|
||||
- max_msgs = "3";
|
||||
- max_whois = "1";
|
||||
- };
|
||||
- PTlink = {
|
||||
- };
|
||||
- QuakeNet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "1";
|
||||
- max_modes = "6";
|
||||
- max_msgs = "30";
|
||||
- max_whois = "1";
|
||||
- };
|
||||
- SorceryNet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "30";
|
||||
- max_modes = "6";
|
||||
- max_msgs = "30";
|
||||
- max_whois = "30";
|
||||
- };
|
||||
- Hashmark = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "3";
|
||||
- max_msgs = "3";
|
||||
- max_whois = "30";
|
||||
- };
|
||||
- PTnet = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "30";
|
||||
- max_modes = "13";
|
||||
- max_msgs = "10";
|
||||
- max_whois = "30";
|
||||
- };
|
||||
- AzzurraNET = {
|
||||
- type = "IRC";
|
||||
- max_kicks = "4";
|
||||
- max_modes = "6";
|
||||
- max_msgs = "3";
|
||||
- };
|
||||
- SILC = { type = "SILC"; };
|
||||
+ Hinet = { type = "IRC"; max_kicks = "3"; max_modes = "3"; max_msgs = "3"; };
|
||||
+ BSDChat = { type = "IRC"; max_kicks = 4; max_modes = 6; max_msgs = 3; };
|
||||
};
|
||||
|
||||
channels = (
|
||||
- { name = "#irssi"; chatnet = "ircnet"; autojoin = "No"; },
|
||||
- { name = "#irssi"; chatnet = "freenode"; autojoin = "No"; },
|
||||
- { name = "silc"; chatnet = "silc"; autojoin = "No"; }
|
||||
+ { name = "#bsdchat"; chatnet = "BSDChat"; autojoin = "No"; }
|
||||
);
|
||||
|
@ -1,355 +0,0 @@
|
||||
--- src/fe-text/gui-entry.c.orig Sun Oct 26 13:45:02 2003
|
||||
+++ src/fe-text/gui-entry.c Thu Apr 29 14:33:53 2004
|
||||
@@ -68,28 +68,107 @@
|
||||
g_free(entry);
|
||||
}
|
||||
|
||||
-/* Fixes the cursor position if it at big5_lo .
|
||||
- Direct: -1 , left shift 1 byte.
|
||||
- Direct: 0, +1 , right shift 1 byte.
|
||||
-*/
|
||||
-static int _fix_big5_pos(unichar *p, int pos, int direct)
|
||||
-{
|
||||
- int newpos;
|
||||
-
|
||||
- if (term_type != TERM_TYPE_BIG5)
|
||||
- return pos;
|
||||
-
|
||||
- for (newpos = 0; newpos < pos && p[newpos] != 0; ) {
|
||||
- if (is_big5(p[newpos], p[newpos+1]))
|
||||
- newpos += 2;
|
||||
- else
|
||||
- newpos++;
|
||||
+/* big5 functions */
|
||||
+#define big5_width(ch) ((ch)>0xff ? 2:1)
|
||||
+
|
||||
+void unichars_to_big5(const unichar *str, char *out)
|
||||
+{
|
||||
+ for (; *str != '\0'; str++) {
|
||||
+ if(*str>0xff)
|
||||
+ *out++ = (*str>>8)&0xff;
|
||||
+ *out++ = *str&0xff;
|
||||
}
|
||||
+ *out = '\0';
|
||||
+}
|
||||
+
|
||||
+void unichars_to_big5_with_pos(const unichar *str, int spos, char *out, int *opos)
|
||||
+{
|
||||
+ const unichar *sstart = str;
|
||||
+ char *ostart = out;
|
||||
|
||||
- if (newpos != pos)
|
||||
- pos += direct > 0 ? 1 : -1;
|
||||
+ *opos = 0;
|
||||
+ while(*str != '\0')
|
||||
+ {
|
||||
+ if(*str > 0xff)
|
||||
+ *out ++ = (*str >> 8) & 0xff;
|
||||
+ *out ++ = *str & 0xff;
|
||||
+ str ++;
|
||||
+ if(str - sstart == spos)
|
||||
+ *opos = out - ostart;
|
||||
+ }
|
||||
+ *out = '\0';
|
||||
+}
|
||||
|
||||
- return pos;
|
||||
+int strlen_big5(const unsigned char *str)
|
||||
+{
|
||||
+ int len=0;
|
||||
+
|
||||
+ if(term_type!=TERM_TYPE_BIG5)
|
||||
+ return strlen(str);
|
||||
+ while(*str != '\0') {
|
||||
+ if(is_big5(str[0],str[1]))
|
||||
+ str++;
|
||||
+ len++;
|
||||
+ str++;
|
||||
+ }
|
||||
+ return len;
|
||||
+}
|
||||
+
|
||||
+void big5_to_unichars(const char *str, unichar *out)
|
||||
+{
|
||||
+ const unsigned char *p = (const unsigned char *) str;
|
||||
+
|
||||
+ while(*p != '\0')
|
||||
+ if (is_big5(p[0], p[1])) {
|
||||
+ *out++ = p[0] << 8 | p[1];
|
||||
+ p += 2;
|
||||
+ } else
|
||||
+ *out++ = *p++;
|
||||
+ *out = '\0';
|
||||
+}
|
||||
+
|
||||
+/* ----------------------------- */
|
||||
+
|
||||
+static int pos2scrpos(GUI_ENTRY_REC *entry, int pos)
|
||||
+{
|
||||
+ unichar *p;
|
||||
+ int xpos=0;
|
||||
+
|
||||
+ for (p=entry->text;p-entry->text<pos;p++)
|
||||
+ if (term_type == TERM_TYPE_BIG5)
|
||||
+ xpos += big5_width(*p);
|
||||
+ else if(entry->utf8)
|
||||
+ xpos += utf8_width(*p);
|
||||
+ else
|
||||
+ xpos ++;
|
||||
+
|
||||
+ return xpos;
|
||||
+}
|
||||
+
|
||||
+static int scrpos2pos(GUI_ENTRY_REC *entry, int pos)
|
||||
+{
|
||||
+ int i;
|
||||
+ int xpos=0;
|
||||
+
|
||||
+ for(i=0; entry->text[i]; i++) {
|
||||
+ int width;
|
||||
+ unichar *p=entry->text+i;
|
||||
+
|
||||
+ if(term_type == TERM_TYPE_BIG5)
|
||||
+ width = big5_width(*p);
|
||||
+ else if(entry->utf8)
|
||||
+ width = utf8_width(*p);
|
||||
+ else
|
||||
+ width = 1;
|
||||
+ if(xpos+width>pos)
|
||||
+ break;
|
||||
+ xpos+=width;
|
||||
+ }
|
||||
+
|
||||
+ if(xpos==pos)
|
||||
+ return i;
|
||||
+ else
|
||||
+ return i-1;
|
||||
}
|
||||
|
||||
/* Fixes the cursor position in screen */
|
||||
@@ -97,20 +176,23 @@
|
||||
{
|
||||
int old_scrstart;
|
||||
|
||||
- old_scrstart = entry->scrstart;
|
||||
- if (entry->pos - entry->scrstart < entry->width-2 - entry->promptlen &&
|
||||
- entry->pos - entry->scrstart > 0) {
|
||||
- entry->scrpos = entry->pos - entry->scrstart;
|
||||
- } else if (entry->pos < entry->width-1 - entry->promptlen) {
|
||||
+ /* assume prompt len == prompt scrlen */
|
||||
+ int start=pos2scrpos(entry,entry->scrstart);
|
||||
+ int now=pos2scrpos(entry,entry->pos);
|
||||
+
|
||||
+ old_scrstart = entry->scrstart;
|
||||
+ if (now-start < entry->width-2-entry->promptlen &&
|
||||
+ now-start > 0)
|
||||
+ entry->scrpos=now-start;
|
||||
+ else if(now < entry->width-1-entry->promptlen) {
|
||||
entry->scrstart = 0;
|
||||
- entry->scrpos = entry->pos;
|
||||
+ entry->scrpos=now;
|
||||
} else {
|
||||
- entry->scrpos = (entry->width - entry->promptlen)*2/3;
|
||||
- entry->scrstart = entry->pos - entry->scrpos;
|
||||
+ entry->scrstart = scrpos2pos(entry,now-(entry->width - entry->promptlen)*2/3);
|
||||
+ start=pos2scrpos(entry,entry->scrstart);
|
||||
+ entry->scrpos=now-start;
|
||||
}
|
||||
|
||||
- entry->scrstart = _fix_big5_pos(entry->text, entry->scrstart, -1);
|
||||
-
|
||||
if (old_scrstart != entry->scrstart)
|
||||
entry->redraw_needed_from = 0;
|
||||
}
|
||||
@@ -120,7 +202,9 @@
|
||||
const unichar *p;
|
||||
int xpos, end_xpos;
|
||||
|
||||
- xpos = entry->xpos + entry->promptlen + pos;
|
||||
+ xpos = entry->xpos + entry->promptlen +
|
||||
+ pos2scrpos(entry, pos + entry->scrstart) -
|
||||
+ pos2scrpos(entry, entry->scrstart);
|
||||
end_xpos = entry->xpos + entry->width;
|
||||
if (xpos > end_xpos)
|
||||
return;
|
||||
@@ -131,8 +215,16 @@
|
||||
p = entry->scrstart + pos < entry->text_len ?
|
||||
entry->text + entry->scrstart + pos : empty_str;
|
||||
for (; *p != '\0'; p++) {
|
||||
- xpos += utf8_width(*p);
|
||||
- if (xpos > end_xpos)
|
||||
+ if (entry->hidden)
|
||||
+ xpos++;
|
||||
+ else if(term_type == TERM_TYPE_BIG5)
|
||||
+ xpos += big5_width(*p);
|
||||
+ else if(entry->utf8)
|
||||
+ xpos += utf8_width(*p);
|
||||
+ else
|
||||
+ xpos++;
|
||||
+
|
||||
+ if (xpos >= end_xpos)
|
||||
break;
|
||||
|
||||
if (entry->hidden)
|
||||
@@ -285,8 +377,34 @@
|
||||
if (entry->utf8)
|
||||
utf16_to_utf8(entry->text, buf);
|
||||
else {
|
||||
- for (i = 0; i <= entry->text_len; i++)
|
||||
- buf[i] = entry->text[i];
|
||||
+ if(term_type==TERM_TYPE_BIG5)
|
||||
+ unichars_to_big5(entry->text, buf);
|
||||
+ else
|
||||
+ for (i = 0; i <= entry->text_len; i++)
|
||||
+ buf[i] = entry->text[i];
|
||||
+ }
|
||||
+ return buf;
|
||||
+}
|
||||
+
|
||||
+char *gui_entry_get_text_and_pos(GUI_ENTRY_REC *entry, int *pos)
|
||||
+{
|
||||
+ char *buf;
|
||||
+ int i;
|
||||
+
|
||||
+ g_return_val_if_fail(entry != NULL, NULL);
|
||||
+
|
||||
+ buf = g_malloc(entry->text_len*6 + 1);
|
||||
+ if (entry->utf8)
|
||||
+ utf16_to_utf8_with_pos(entry->text, entry->pos, buf, pos);
|
||||
+ else {
|
||||
+ if(term_type==TERM_TYPE_BIG5)
|
||||
+ unichars_to_big5_with_pos(entry->text, entry->pos, buf, pos);
|
||||
+ else
|
||||
+ {
|
||||
+ for (i = 0; i <= entry->text_len; i++)
|
||||
+ buf[i] = entry->text[i];
|
||||
+ *pos = entry->pos;
|
||||
+ }
|
||||
}
|
||||
return buf;
|
||||
}
|
||||
@@ -301,7 +419,7 @@
|
||||
|
||||
gui_entry_redraw_from(entry, entry->pos);
|
||||
|
||||
- len = !entry->utf8 ? strlen(str) : strlen_utf8(str);
|
||||
+ len = !entry->utf8 ? strlen_big5(str) : strlen_utf8(str);
|
||||
entry_text_grow(entry, len);
|
||||
|
||||
/* make space for the string */
|
||||
@@ -309,8 +427,13 @@
|
||||
(entry->text_len-entry->pos + 1) * sizeof(unichar));
|
||||
|
||||
if (!entry->utf8) {
|
||||
- for (i = 0; i < len; i++)
|
||||
- entry->text[entry->pos+i] = str[i];
|
||||
+ if (term_type == TERM_TYPE_BIG5) {
|
||||
+ chr = entry->text[entry->pos+len];
|
||||
+ big5_to_unichars(str, entry->text+entry->pos);
|
||||
+ entry->text[entry->pos+len] = chr;
|
||||
+ } else
|
||||
+ for (i = 0; i < len; i++)
|
||||
+ entry->text[entry->pos + i] = str[i];
|
||||
} else {
|
||||
chr = entry->text[entry->pos+len];
|
||||
utf8_to_utf16(str, entry->text+entry->pos);
|
||||
@@ -361,8 +484,12 @@
|
||||
if (entry->utf8)
|
||||
utf16_to_utf8(entry->cutbuffer, buf);
|
||||
else {
|
||||
- for (i = 0; i <= entry->cutbuffer_len; i++)
|
||||
- buf[i] = entry->cutbuffer[i];
|
||||
+ if(term_type==TERM_TYPE_BIG5) {
|
||||
+ unichars_to_big5(entry->cutbuffer, buf);
|
||||
+ } else
|
||||
+ for (i = 0; i <= entry->cutbuffer_len; i++) {
|
||||
+ buf[i] = entry->cutbuffer[i];
|
||||
+ }
|
||||
}
|
||||
return buf;
|
||||
}
|
||||
@@ -374,24 +501,17 @@
|
||||
g_return_if_fail(entry != NULL);
|
||||
|
||||
for (newpos = gui_entry_get_pos(entry); newpos > pos; size++)
|
||||
- newpos = _fix_big5_pos(entry->text, newpos - 1, -1);
|
||||
+ newpos = newpos - 1;
|
||||
gui_entry_erase(entry, size, update_cutbuffer);
|
||||
}
|
||||
|
||||
void gui_entry_erase(GUI_ENTRY_REC *entry, int size, int update_cutbuffer)
|
||||
{
|
||||
- int newpos;
|
||||
-
|
||||
g_return_if_fail(entry != NULL);
|
||||
|
||||
if (entry->pos < size)
|
||||
return;
|
||||
|
||||
- /* recount the erase size with big5 charsets */
|
||||
- for (newpos = entry->pos; newpos > 0 && size > 0; size--)
|
||||
- newpos = _fix_big5_pos(entry->text, newpos-1, -1);
|
||||
- size = entry->pos - newpos;
|
||||
-
|
||||
if (update_cutbuffer) {
|
||||
/* put erased text to cutbuffer */
|
||||
if (entry->cutbuffer == NULL || entry->cutbuffer_len < size) {
|
||||
@@ -513,26 +633,42 @@
|
||||
gui_entry_draw(entry);
|
||||
}
|
||||
|
||||
-void gui_entry_move_pos(GUI_ENTRY_REC *entry, int pos)
|
||||
+int gui_entry_linepos_to_pos(GUI_ENTRY_REC *entry, int linepos)
|
||||
{
|
||||
- int newpos;
|
||||
-
|
||||
- g_return_if_fail(entry != NULL);
|
||||
+ int pos, len;
|
||||
|
||||
- /* move cursor with big5 charset */
|
||||
- newpos = _fix_big5_pos(entry->text, entry->pos, -1);
|
||||
- if (pos > 0) {
|
||||
- while (pos > 0 && newpos < entry->text_len) {
|
||||
- newpos = _fix_big5_pos(entry->text, newpos+1, 1);
|
||||
- pos--;
|
||||
- }
|
||||
- } else {
|
||||
- while (pos < 0 && newpos > 0) {
|
||||
- newpos = _fix_big5_pos(entry->text, newpos-1, -1);
|
||||
- pos++;
|
||||
+ for(pos = 0, len = 0; len < linepos; pos++)
|
||||
+ {
|
||||
+ if(entry->utf8)
|
||||
+ len += utf16_char_to_utf8(entry->text[pos], NULL);
|
||||
+ else if(term_type == TERM_TYPE_BIG5)
|
||||
+ {
|
||||
+ len += (entry->text[pos] > 0xff ? 2 : 1);
|
||||
}
|
||||
+ else
|
||||
+ len ++;
|
||||
}
|
||||
- entry->pos = newpos;
|
||||
+ return pos;
|
||||
+}
|
||||
+
|
||||
+void gui_entry_set_linepos(GUI_ENTRY_REC *entry, int pos)
|
||||
+{
|
||||
+ g_return_if_fail(entry != NULL);
|
||||
+
|
||||
+ pos = gui_entry_linepos_to_pos(entry, pos);
|
||||
+ if (pos >= 0 && pos <= entry->text_len)
|
||||
+ entry->pos = pos;
|
||||
+
|
||||
+ gui_entry_fix_cursor(entry);
|
||||
+ gui_entry_draw(entry);
|
||||
+}
|
||||
+
|
||||
+void gui_entry_move_pos(GUI_ENTRY_REC *entry, int pos)
|
||||
+{
|
||||
+ g_return_if_fail(entry != NULL);
|
||||
+
|
||||
+ if (entry->pos+pos >= 0 && entry->pos+pos <= entry->text_len)
|
||||
+ entry->pos += pos;
|
||||
|
||||
gui_entry_fix_cursor(entry);
|
||||
gui_entry_draw(entry);
|
@ -1,18 +0,0 @@
|
||||
--- src/fe-text/gui-entry.h.orig Mon Oct 20 03:10:02 2003
|
||||
+++ src/fe-text/gui-entry.h Thu Apr 29 14:33:16 2004
|
||||
@@ -34,6 +34,7 @@
|
||||
|
||||
void gui_entry_set_text(GUI_ENTRY_REC *entry, const char *str);
|
||||
char *gui_entry_get_text(GUI_ENTRY_REC *entry);
|
||||
+char *gui_entry_get_text_and_pos(GUI_ENTRY_REC *entry, int *pos);
|
||||
|
||||
void gui_entry_insert_text(GUI_ENTRY_REC *entry, const char *str);
|
||||
void gui_entry_insert_char(GUI_ENTRY_REC *entry, unichar chr);
|
||||
@@ -48,6 +49,7 @@
|
||||
|
||||
int gui_entry_get_pos(GUI_ENTRY_REC *entry);
|
||||
void gui_entry_set_pos(GUI_ENTRY_REC *entry, int pos);
|
||||
+void gui_entry_set_linepos(GUI_ENTRY_REC *entry, int pos);
|
||||
void gui_entry_move_pos(GUI_ENTRY_REC *entry, int pos);
|
||||
void gui_entry_move_words(GUI_ENTRY_REC *entry, int count, int to_space);
|
||||
|
@ -1,11 +0,0 @@
|
||||
--- src/fe-text/gui-printtext.c.orig Mon Dec 30 00:10:02 2002
|
||||
+++ src/fe-text/gui-printtext.c Sun Dec 14 01:54:28 2003
|
||||
@@ -255,7 +255,7 @@
|
||||
if (flags & GUI_PRINT_FLAG_CLRTOEOL)
|
||||
term_clrtoeol(root_window);
|
||||
term_addstr(root_window, str);
|
||||
- next_xpos += strlen(str);
|
||||
+ next_xpos += strlen(str); // FIXME utf8 or big5
|
||||
return;
|
||||
}
|
||||
|
@ -1,52 +0,0 @@
|
||||
--- src/fe-text/gui-readline.c.orig Thu Nov 27 01:30:03 2003
|
||||
+++ src/fe-text/gui-readline.c Thu Apr 29 14:33:01 2004
|
||||
@@ -187,7 +187,12 @@
|
||||
out[utf16_char_to_utf8(arr[i], out)] = '\0';
|
||||
g_string_append(str, out);
|
||||
} else {
|
||||
- g_string_append_c(str, arr[i]);
|
||||
+ if(term_type==TERM_TYPE_BIG5) {
|
||||
+ if(arr[i]>0xff)
|
||||
+ g_string_append_c(str, arr[i]>>8&0xff);
|
||||
+ g_string_append_c(str, arr[i]&0xff);
|
||||
+ } else
|
||||
+ g_string_append_c(str, arr[i]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -620,15 +625,13 @@
|
||||
char *text, *line;
|
||||
int pos;
|
||||
|
||||
- pos = gui_entry_get_pos(active_entry);
|
||||
-
|
||||
- text = gui_entry_get_text(active_entry);
|
||||
+ text = gui_entry_get_text_and_pos(active_entry, &pos);
|
||||
line = word_complete(active_win, text, &pos, erase);
|
||||
g_free(text);
|
||||
|
||||
if (line != NULL) {
|
||||
gui_entry_set_text(active_entry, line);
|
||||
- gui_entry_set_pos(active_entry, pos);
|
||||
+ gui_entry_set_linepos(active_entry, pos);
|
||||
g_free(line);
|
||||
}
|
||||
}
|
||||
@@ -648,15 +651,13 @@
|
||||
char *text, *line;
|
||||
int pos;
|
||||
|
||||
- pos = gui_entry_get_pos(active_entry);
|
||||
-
|
||||
- text = gui_entry_get_text(active_entry);
|
||||
+ text = gui_entry_get_text_and_pos(active_entry, &pos);
|
||||
line = auto_word_complete(text, &pos);
|
||||
g_free(text);
|
||||
|
||||
if (line != NULL) {
|
||||
gui_entry_set_text(active_entry, line);
|
||||
- gui_entry_set_pos(active_entry, pos);
|
||||
+ gui_entry_set_linepos(active_entry, pos);
|
||||
g_free(line);
|
||||
}
|
||||
}
|
@ -1,44 +0,0 @@
|
||||
--- src/fe-text/term-terminfo.c.orig Mon Oct 20 03:10:02 2003
|
||||
+++ src/fe-text/term-terminfo.c Sun Apr 11 21:11:41 2004
|
||||
@@ -421,16 +421,21 @@
|
||||
if (vcy == term_height-1 && vcx == term_width-1)
|
||||
return; /* last char in screen */
|
||||
|
||||
- term_printed_text(1);
|
||||
switch (term_type) {
|
||||
case TERM_TYPE_UTF8:
|
||||
+ term_printed_text(utf8_width(chr));
|
||||
term_addch_utf8(window, chr);
|
||||
break;
|
||||
case TERM_TYPE_BIG5:
|
||||
- putc((chr >> 8) & 0xff, window->term->out);
|
||||
+ if(chr>0xff) {
|
||||
+ term_printed_text(2);
|
||||
+ putc((chr >> 8) & 0xff, window->term->out);
|
||||
+ } else
|
||||
+ term_printed_text(1);
|
||||
putc((chr & 0xff), window->term->out);
|
||||
break;
|
||||
default:
|
||||
+ term_printed_text(1);
|
||||
putc(chr, window->term->out);
|
||||
break;
|
||||
}
|
||||
@@ -443,7 +448,7 @@
|
||||
if (term_detached) return;
|
||||
|
||||
if (vcmove) term_move_real();
|
||||
- len = strlen(str);
|
||||
+ len = strlen(str); // FIXME utf8 or big5
|
||||
term_printed_text(len);
|
||||
|
||||
if (vcy != term_height || vcx != 0)
|
||||
@@ -640,7 +645,7 @@
|
||||
if (i >= term_inbuf_pos)
|
||||
term_inbuf_pos = 0;
|
||||
else if (i > 0) {
|
||||
- memmove(term_inbuf+i, term_inbuf, term_inbuf_pos-i);
|
||||
+ memmove(term_inbuf, term_inbuf+i, term_inbuf_pos-i);
|
||||
term_inbuf_pos -= i;
|
||||
}
|
||||
}
|
@ -1,18 +0,0 @@
|
||||
--- src/fe-text/textbuffer-view.c.orig Sun Oct 26 13:45:02 2003
|
||||
+++ src/fe-text/textbuffer-view.c Sun Dec 14 01:54:28 2003
|
||||
@@ -435,7 +435,14 @@
|
||||
unichar chr = get_utf8_char(&end, 6);
|
||||
char_width = utf8_width(chr);
|
||||
} else {
|
||||
- char_width = 1;
|
||||
+ if(term_type==TERM_TYPE_BIG5) {
|
||||
+ if(is_big5(end[0],end[1]))
|
||||
+ char_width=2;
|
||||
+ else
|
||||
+ char_width=1;
|
||||
+ } else
|
||||
+ char_width = 1;
|
||||
+ end+=char_width-1;
|
||||
}
|
||||
|
||||
xpos += char_width;
|
@ -1,27 +0,0 @@
|
||||
--- src/fe-text/utf8.c.orig Tue Oct 15 02:45:08 2002
|
||||
+++ src/fe-text/utf8.c Wed Apr 7 11:04:22 2004
|
||||
@@ -180,6 +180,24 @@
|
||||
*out = '\0';
|
||||
}
|
||||
|
||||
+void utf16_to_utf8_with_pos(const unichar *str, int spos, char *out, int *opos)
|
||||
+{
|
||||
+ int len;
|
||||
+ const unichar *sstart = str;
|
||||
+ char *ostart = out;
|
||||
+
|
||||
+ *opos = 0;
|
||||
+ while (*str != '\0') {
|
||||
+ len = utf16_char_to_utf8(*str, out);
|
||||
+ out += len;
|
||||
+
|
||||
+ str++;
|
||||
+ if(str - sstart == spos)
|
||||
+ *opos = out - ostart;
|
||||
+ }
|
||||
+ *out = '\0';
|
||||
+}
|
||||
+
|
||||
static const unichar wcc[] = {
|
||||
0x0, 0x300, 0x34F, 0x360, 0x363, 0x483, 0x487, 0x488, 0x48A, 0x591,
|
||||
0x5A2, 0x5A3, 0x5BA, 0x5BB, 0x5BE, 0x5BF, 0x5C0, 0x5C1, 0x5C3, 0x5C4,
|
@ -1,13 +0,0 @@
|
||||
--- src/fe-text/utf8.h.orig Mon Oct 20 03:10:02 2003
|
||||
+++ src/fe-text/utf8.h Wed Apr 7 11:06:22 2004
|
||||
@@ -18,6 +18,10 @@
|
||||
Make sure out is at least 6 x length of str. */
|
||||
void utf16_to_utf8(const unichar *str, char *out);
|
||||
|
||||
+/* unichar -> UTF-8 string with position transformed. The NUL is copied as well.
|
||||
+ Make sure out is at least 6 x length of str. */
|
||||
+void utf16_to_utf8_with_pos(const unichar *str, int spos, char *out, int *opos);
|
||||
+
|
||||
/* XXX I didn't check the encoding range of big5+. This is standard big5. */
|
||||
#define is_big5_los(lo) (0x40 <= (lo) && (lo) <= 0x7E) /* standard */
|
||||
#define is_big5_lox(lo) (0x80 <= (lo) && (lo) <= 0xFE) /* extended */
|
Loading…
Reference in New Issue
Block a user