Say hello to zh-tintin++.
Add the Chinese port of net/tintin++, it is a slave port with tintin++ v1.5pl9 too.
This commit is contained in:
parent
5c20a96770
commit
7ffd33cf11
Notes:
svn2git
2021-03-31 03:12:20 +00:00
svn path=/head/; revision=33136
2 changed files with 214 additions and 0 deletions
14
chinese/tintin++/Makefile
Normal file
14
chinese/tintin++/Makefile
Normal file
|
@ -0,0 +1,14 @@
|
|||
# New ports collection makefile for: tintin++ with Chinese(Big5) support.
|
||||
# Date created: Tue 26, 2000
|
||||
# Whom: Foxfair Hu <foxfair@FreeBSD.org>
|
||||
#
|
||||
# $FreeBSD$
|
||||
#
|
||||
|
||||
MASTERDIR= ${.CURDIR}/../../net/tintin++
|
||||
|
||||
MAINTAINER= foxfair@FreeBSD.org
|
||||
|
||||
EXTRA_PATCHES= ${.CURDIR}/patches/patch.1
|
||||
|
||||
.include "${MASTERDIR}/Makefile"
|
200
chinese/tintin++/files/extra-patch.1
Normal file
200
chinese/tintin++/files/extra-patch.1
Normal file
|
@ -0,0 +1,200 @@
|
|||
--- src/llist.c Sun Aug 28 22:12:04 1994
|
||||
+++ llist.c Thu Mar 19 15:32:01 1998
|
||||
@@ -48,6 +48,9 @@
|
||||
{
|
||||
struct listnode *nexttodel;
|
||||
|
||||
+ if(nptr==NULL);
|
||||
+ return;
|
||||
+
|
||||
nexttodel=nptr->next;
|
||||
free(nptr);
|
||||
|
||||
--- src/main.c Sun Aug 28 22:12:06 1994
|
||||
+++ main.c Thu Mar 19 15:32:08 1998
|
||||
@@ -306,6 +326,43 @@
|
||||
if (!*k_input)
|
||||
text_came=FALSE;
|
||||
while (*tptr) {
|
||||
+ /* «ö¦Ç¦â¤è¦VÁä ©M home ..µ¥Áä */
|
||||
+ if (*tptr==27 && *(tptr+1)=='[' &&
|
||||
+ ( (*(tptr+2)>='A' && *(tptr+2)<='D') ||
|
||||
+ ( *(tptr+2)>='1' && *(tptr+2)<='6' && *(tptr+3)=='~' )
|
||||
+ )
|
||||
+ ) {
|
||||
+ text_came=FALSE;
|
||||
+ input_row=split_line+1;
|
||||
+ input_col=1;
|
||||
+ if( *(tptr+2) == 'A' )
|
||||
+ sprintf(strng," north");
|
||||
+ else if( *(tptr+2) == 'B' )
|
||||
+ sprintf(strng," south");
|
||||
+ else if( *(tptr+2) == 'C' )
|
||||
+ sprintf(strng," east");
|
||||
+ else if( *(tptr+2) == 'D' )
|
||||
+ sprintf(strng," west");
|
||||
+ else if( *(tptr+2) == '1' && *(tptr+3)=='~' )
|
||||
+ sprintf(strng," up");
|
||||
+ else if( *(tptr+2) == '2' && *(tptr+3)=='~' )
|
||||
+ sprintf(strng," northwest");
|
||||
+ else if( *(tptr+2) == '3' && *(tptr+3)=='~' )
|
||||
+ sprintf(strng," southwest");
|
||||
+ else if( *(tptr+2) == '4' && *(tptr+3)=='~' )
|
||||
+ sprintf(strng," down");
|
||||
+ else if( *(tptr+2) == '5' && *(tptr+3)=='~' )
|
||||
+ sprintf(strng," northeast");
|
||||
+ else if( *(tptr+2) == '6' && *(tptr+3)=='~' )
|
||||
+ sprintf(strng," southeast");
|
||||
+
|
||||
+ sprintf(done_input,"%s %s\n\r",k_input,strng);
|
||||
+ write(1,strng,strlen(strng));
|
||||
+
|
||||
+ *strng='\0';
|
||||
+ *k_input='\0';
|
||||
+ return 1;
|
||||
+ }
|
||||
/* return was pressed, get ready to send line */
|
||||
if (*tptr=='\n' || *tptr=='\r') {
|
||||
text_came=FALSE;
|
||||
--- src/parse.c Sun Aug 28 22:12:10 1994
|
||||
+++ parse.c Thu Mar 19 15:32:24 1998
|
||||
@@ -57,6 +57,7 @@
|
||||
extern char *cryptkey;
|
||||
extern char *get_arg_all();
|
||||
extern void tstphandler();
|
||||
+int iscspace();
|
||||
|
||||
/**************************************************************************/
|
||||
/* parse input, check for TINTIN commands and aliases and send to session */
|
||||
@@ -472,14 +479,13 @@
|
||||
s=space_out(s);
|
||||
while(*s) {
|
||||
|
||||
- if(*s=='\\') {
|
||||
+ /* if(*s=='\\') {
|
||||
*arg++=*s++;
|
||||
if(*s)
|
||||
*arg++=*s++;
|
||||
- }
|
||||
-
|
||||
-
|
||||
- else if(*s==';' && nest<1) {
|
||||
+ }
|
||||
+ else */
|
||||
+ if(*s==';' && nest<1) {
|
||||
break;
|
||||
}
|
||||
|
||||
@@ -493,8 +499,11 @@
|
||||
*arg++=*s++;
|
||||
}
|
||||
|
||||
- else
|
||||
+ else {
|
||||
+ if(*s & 128)
|
||||
+ *arg++=*s++;
|
||||
*arg++=*s++;
|
||||
+ }
|
||||
}
|
||||
|
||||
*arg='\0';
|
||||
@@ -517,13 +526,12 @@
|
||||
s=space_out(s);
|
||||
while(*s) {
|
||||
|
||||
- if(*s=='\\') {
|
||||
+ /* if(*s=='\\') {
|
||||
if(*++s)
|
||||
*arg++=*s++;
|
||||
}
|
||||
-
|
||||
-
|
||||
- else if(*s==';' && nest==0) {
|
||||
+ else */
|
||||
+ if(*s==';' && nest==0) {
|
||||
break;
|
||||
}
|
||||
else if(*s==DEFAULT_OPEN) {
|
||||
@@ -533,9 +541,18 @@
|
||||
else if(*s==DEFAULT_CLOSE) {
|
||||
*arg++=*s++;
|
||||
nest--;
|
||||
- }
|
||||
- else
|
||||
+ } else
|
||||
+ if(*s == '`' && *(s+1) == '^' && *(s+2) == '[' )
|
||||
+ {
|
||||
+ s += 3;
|
||||
+ *arg++=27;
|
||||
+ *arg++='[';
|
||||
+ }
|
||||
+ else {
|
||||
+ if(*s & 128 )
|
||||
+ *arg++=*s++;
|
||||
*arg++=*s++;
|
||||
+ }
|
||||
}
|
||||
*arg='\0';
|
||||
return s;
|
||||
@@ -568,7 +585,10 @@
|
||||
else if(*s==DEFAULT_CLOSE) {
|
||||
nest--;
|
||||
}
|
||||
+ else if(*s & 128)
|
||||
+ *arg++=*s++;
|
||||
*arg++=*s++;
|
||||
+
|
||||
}
|
||||
if (!*s)
|
||||
tintin_puts2("#Unmatched braces error!", (struct session *)NULL);
|
||||
@@ -590,11 +610,12 @@
|
||||
s=space_out(s);
|
||||
|
||||
while(*s) {
|
||||
- if(*s=='\\') {
|
||||
+ /* if(*s=='\\') {
|
||||
if(*++s)
|
||||
*arg++=*s++;
|
||||
}
|
||||
- else if(*s=='"') {
|
||||
+ else */
|
||||
+ if(*s=='"') {
|
||||
s++;
|
||||
inside=!inside;
|
||||
}
|
||||
@@ -608,8 +629,11 @@
|
||||
|
||||
else if(!inside && *s==' ')
|
||||
break;
|
||||
- else
|
||||
+ else {
|
||||
+ if(*s & 128)
|
||||
+ *arg++=*s++;
|
||||
*arg++=*s++;
|
||||
+ }
|
||||
}
|
||||
|
||||
*arg='\0';
|
||||
@@ -623,7 +647,7 @@
|
||||
char *space_out(s)
|
||||
char *s;
|
||||
{
|
||||
- while(isspace(*s))
|
||||
+ while(iscspace(*s))
|
||||
s++;
|
||||
return s;
|
||||
}
|
||||
@@ -678,6 +702,10 @@
|
||||
}
|
||||
}
|
||||
|
||||
-
|
||||
-
|
||||
-
|
||||
+int iscspace(c)
|
||||
+ char c;
|
||||
+{
|
||||
+ if (c==' '||c==9||c==13||c==10)
|
||||
+ {return(1);}
|
||||
+ else {return(0);}
|
||||
+}
|
Loading…
Reference in a new issue