aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--www/w3m/Makefile14
-rw-r--r--www/w3m/distinfo3
-rw-r--r--www/w3m/files/patch-av156
-rw-r--r--www/w3m/files/patch-aw160
-rw-r--r--www/w3m/files/patch-ax98
-rw-r--r--www/w3m/files/patch-ay12
-rw-r--r--www/w3m/pkg-plist.ja4
7 files changed, 440 insertions, 7 deletions
diff --git a/www/w3m/Makefile b/www/w3m/Makefile
index ba95e199bec8..3d0da595f505 100644
--- a/www/w3m/Makefile
+++ b/www/w3m/Makefile
@@ -17,15 +17,19 @@ MASTER_SITES= ftp://ei5nazha.yz.yamagata-u.ac.jp/w3m/dev/ \
DISTNAME= ${PORTNAME}-${W3M_VERSION}-pre
PATCH_SITES= http://www4.ocn.ne.jp/~okabek/
-PATCHFILES= ${PORTNAME}-${W3M_VERSION}-pre-kokb${W3M_PATCHLEVEL}.patch.gz
+PATCHFILES= ${PORTNAME}-${W3M_VERSION}-pre-kokb22.patch.gz \
+ ${PORTNAME}-${W3M_VERSION}-pre-kokb22_${W3M_PATCHLEVEL}test.patch
+
PATCH_DIST_STRIP= -p1
MAINTAINER= nobutaka@nobutaka.com
-BUILD_DEPENDS= ${LOCALBASE}/lib/libgc.a:${PORTSDIR}/devel/boehm-gc
+BUILD_DEPENDS= ${LOCALBASE}/lib/libgc.a:${PORTSDIR}/devel/boehm-gc \
+ ${LOCALBASE}/bin/patch:${PORTSDIR}/devel/patch
+PATCH= ${LOCALBASE}/bin/patch
W3M_VERSION= 0.1.11
-W3M_PATCHLEVEL= 17
+W3M_PATCHLEVEL= 23
MAN1= w3m.1
MANLANG= ""
@@ -47,8 +51,8 @@ SED_CMD+= -e "s,undef INET6,define INET6,g"
.if defined(JAPANESE)
SED_CMD+= -e "s,undef JAPANESE,define JAPANESE,g"
MANLANG+= ja
-DOCS_JP= ${DOCS} HISTORY.kokb README.keymap README.kokb \
- README.menu
+DOCS_JP= ${DOCS} HISTORY.kokb README.SSL README.cookie \
+ README.keymap README.mailcap README.menu
.endif
.if defined(USE_OPENSSL)
diff --git a/www/w3m/distinfo b/www/w3m/distinfo
index 69ffe308347e..1884b9b5ed3d 100644
--- a/www/w3m/distinfo
+++ b/www/w3m/distinfo
@@ -1,2 +1,3 @@
MD5 (w3m-0.1.11-pre.tar.gz) = d9fb24700ecde78624280467dda1aee5
-MD5 (w3m-0.1.11-pre-kokb17.patch.gz) = bc4f626a2b6882e0e8bfe1841d8a820d
+MD5 (w3m-0.1.11-pre-kokb22.patch.gz) = 1d107b4756767749d5d5b875e480e5fc
+MD5 (w3m-0.1.11-pre-kokb22_23test.patch) = 06df74db37985350ba2edd70db2a99f4
diff --git a/www/w3m/files/patch-av b/www/w3m/files/patch-av
new file mode 100644
index 000000000000..624e49717155
--- /dev/null
+++ b/www/w3m/files/patch-av
@@ -0,0 +1,156 @@
+diff -u file.c.orig file.c
+--- file.c.orig Thu Dec 7 22:41:39 2000
++++ file.c Thu Dec 7 23:04:23 2000
+@@ -71,6 +71,10 @@
+ #ifdef JP_CHARSET
+ static char content_charset = '\0';
+ static char guess_charset(char *p);
++#ifdef NEW_FORM
++static char check_charset(char *p);
++static char check_accept_charset(char *p);
++#endif
+ char DocumentCode = '\0';
+ #endif
+
+@@ -2545,61 +2549,68 @@
+ }
+
+ #ifdef NEW_FORM
+-char *
+-process_accept_charset(char *ac)
+-{
+- static Str temp = NULL;
+- char *s = ac, *e;
+ #ifdef JP_CHARSET
+- char res[2] = { '\0', '\0' };
+-#endif
+-
+- while (*s) {
+- while (*s && (IS_SPACE(*s) || *s == ',')) ++s;
+- if (!*s) break;
+- for (e = s ; *e && !(IS_SPACE(*e) || *e == ',') ; ++e);
+-
+- if (temp)
+- Strclear(temp);
+- else
+- temp = Strnew();
+-
+- Strcat_charp_n(temp, s, e - s);
++char
++check_charset(char *s)
++{
++ switch (*s) {
++ case CODE_EUC:
++ case CODE_SJIS:
++ case CODE_JIS_n:
++ case CODE_JIS_m:
++ case CODE_JIS_N:
++ case CODE_JIS_j:
++ case CODE_JIS_J:
++ case CODE_INNER_EUC:
++ return *s;
++ }
++ return 0;
++}
+
+-#ifdef JP_CHARSET
+- if ((res[0] = guess_charset(temp->ptr)))
+- return Strnew_charp(res)->ptr;
+-#else
+- if (strcasecmp(temp->ptr, "us-ascii") ||
+- strcasecmp(temp->ptr, "iso-8859-1"))
+-#endif
+- return Strnew_charp(temp->ptr)->ptr;
++char
++check_accept_charset(char *s)
++{
++ char *e;
++ char c;
+
++ while (*s) {
++ while (*s && (IS_SPACE(*s) || *s == ','))
++ s++;
++ if (!*s)
++ break;
++ e = s;
++ while (*e && !(IS_SPACE(*e) || *e == ','))
++ e++;
++ c = guess_charset(Strnew_charp_n(s, e - s)->ptr);
++ if (c)
++ return c;
+ s = e;
+ }
+-
+- return NULL;
++ return 0;
+ }
++#endif
+
+ Str
+ process_form(struct parsed_tag *tag)
+ {
+- char *p, *q, *r, *s, *acs, *tg;
++ char *p, *q, *r, *s, *tg;
++ char cs = 0;
+
+ p = "get";
+ parsedtag_get_value(tag, ATTR_METHOD, &p);
+ q = "!CURRENT_URL!";
+ parsedtag_get_value(tag, ATTR_ACTION, &q);
+ r = NULL;
+- parsedtag_get_value(tag, ATTR_CHARSET, &r);
+- acs = NULL;
+- if (parsedtag_get_value(tag, ATTR_ACCEPT_CHARSET, &acs))
+- acs = process_accept_charset(acs);
++#ifdef JP_CHARSET
++ if (parsedtag_get_value(tag, ATTR_ACCEPT_CHARSET, &r))
++ cs = check_accept_charset(r);
++ if (! cs && parsedtag_get_value(tag, ATTR_CHARSET, &r))
++ cs = check_charset(r);
++#endif
+ s = NULL;
+ parsedtag_get_value(tag, ATTR_ENCTYPE, &s);
+ tg = NULL;
+ parsedtag_get_value(tag, ATTR_TARGET, &tg);
+- if (!r) r = acs;
+ form_max++;
+ form_sp++;
+ if (forms_size == 0) {
+@@ -2611,7 +2622,7 @@
+ forms = New_Reuse(FormList *, forms, forms_size);
+ }
+ forms[form_max] =
+- newFormList(q, p, r, s, tg, (form_max > 0) ? forms[form_max - 1] : NULL);
++ newFormList(q, p, &cs, s, tg, (form_max > 0) ? forms[form_max - 1] : NULL);
+ form_stack[form_sp] = form_max;
+
+ return NULL;
+@@ -3515,6 +3526,7 @@
+ Anchor *a_href = NULL, *a_img = NULL, *a_form = NULL;
+ char outc[LINELEN];
+ char *p, *q, *r, *str;
++ char cs;
+ Lineprop outp[LINELEN], mode, effect;
+ int pos;
+ int nlines;
+@@ -3731,13 +3743,16 @@
+ case HTML_FORM_INT:
+ p = "get";
+ q = "/";
+- r = NULL;
+ s = NULL;
++ cs = 0;
+ parsedtag_get_value(tag, ATTR_METHOD, &p);
+ parsedtag_get_value(tag, ATTR_ACTION, &q);
+- parsedtag_get_value(tag, ATTR_CHARSET, &r);
++#ifdef JP_CHARSET
++ if (parsedtag_get_value(tag, ATTR_CHARSET, &r))
++ cs = check_charset(r);
++#endif
+ parsedtag_get_value(tag, ATTR_ENCTYPE, &s);
+- buf->formlist = newFormList(q, p, r, s, buf->formlist);
++ buf->formlist = newFormList(q, p, &cs, s, buf->formlist);
+ form_sp++;
+ form_stack[form_sp] = buf->formlist;
+ break;
+
diff --git a/www/w3m/files/patch-aw b/www/w3m/files/patch-aw
new file mode 100644
index 000000000000..848f9b68f5cc
--- /dev/null
+++ b/www/w3m/files/patch-aw
@@ -0,0 +1,160 @@
+diff -Nru --exclude config.h --exclude XXMakefile --exclude tagtable.c ../w3m-0.1.11-pre/etc.c ./etc.c
+--- ../w3m-0.1.11-pre/etc.c Fri Dec 8 01:14:57 2000
++++ ./etc.c Fri Dec 8 01:28:24 2000
+@@ -277,7 +277,7 @@
+ int do_copy = FALSE;
+ int size = (len < s->length) ? len : s->length;
+
+- if (ShowEffect && (bs = memchr(str, '\b', s->length)) ||
++ if ((ShowEffect && (bs = memchr(str, '\b', s->length))) ||
+ s->length > size) {
+ s = Strnew_size(size);
+ do_copy = TRUE;
+diff -Nru --exclude config.h --exclude XXMakefile --exclude tagtable.c ../w3m-0.1.11-pre/file.c ./file.c
+--- ../w3m-0.1.11-pre/file.c Fri Dec 8 01:15:31 2000
++++ ./file.c Fri Dec 8 01:27:33 2000
+@@ -230,8 +230,8 @@
+ static int
+ is_plain_text_type(char *type)
+ {
+- return (type && strcasecmp(type, "text/plain") == 0 ||
+- is_text_type(type) && !is_dump_text_type(type));
++ return (type && (strcasecmp(type, "text/plain") == 0 ||
++ (is_text_type(type) && !is_dump_text_type(type))));
+ }
+
+ static void
+@@ -326,7 +326,7 @@
+ uf->guess_type = "text/plain";
+ if (strcasecmp(uf->guess_type, "text/html") == 0)
+ return;
+- if (fp = lessopen_stream(path)) {
++ if ((fp = lessopen_stream(path)) != NULL) {
+ UFclose(uf);
+ uf->stream = newFileStream(fp, (void (*)()) pclose);
+ uf->guess_type = "text/plain";
+@@ -3479,6 +3479,7 @@
+ s = Sprintf("<A HREF=\"%s\">applet archive(%s)</A>", q, q);
+ HTMLlineproc1(s->ptr, h_env);
+ }
++ }
+ return 1;
+ #endif /* VIEW_UNSEENOBJECTS */
+ case HTML_BODY:
+@@ -4162,12 +4163,12 @@
+ return;
+ }
+ q = h_env->tagbuf->ptr;
+- if (tag = parse_tag(&q, internal))
++ if ((tag = parse_tag(&q, internal)) != NULL)
+ cmd = tag->tagid;
+ else
+ cmd = HTML_UNKNOWN;
+- if (obuf->flag & RB_XMPMODE && cmd != HTML_N_XMP ||
+- obuf->flag & RB_LSTMODE && cmd != HTML_N_LISTING) {
++ if (((obuf->flag & RB_XMPMODE) && cmd != HTML_N_XMP) ||
++ ((obuf->flag & RB_LSTMODE) && cmd != HTML_N_LISTING)) {
+ Str tmp = Strdup(h_env->tagbuf);
+ Strcat_charp(tmp, str);
+ str = tmp->ptr;
+diff -Nru --exclude config.h --exclude XXMakefile --exclude tagtable.c ../w3m-0.1.11-pre/istream.c ./istream.c
+--- ../w3m-0.1.11-pre/istream.c Fri Dec 8 01:14:47 2000
++++ ./istream.c Fri Dec 8 01:32:01 2000
+@@ -193,7 +193,7 @@
+ do_update(base);
+ }
+ else {
+- if (p = memchr(&sb->buf[sb->cur], '\n', sb->next - sb->cur)) {
++ if ((p = memchr(&sb->buf[sb->cur], '\n', sb->next - sb->cur)) != NULL) {
+ len = p - &sb->buf[sb->cur] + 1;
+ if (s == NULL)
+ s = Strnew_size(len);
+diff -Nru --exclude config.h --exclude XXMakefile --exclude tagtable.c ../w3m-0.1.11-pre/mailcap.c ./mailcap.c
+--- ../w3m-0.1.11-pre/mailcap.c Fri Dec 8 01:14:57 2000
++++ ./mailcap.c Fri Dec 8 01:30:13 2000
+@@ -242,7 +242,7 @@
+ goto no_user_mailcap;
+
+ for (i = 0; i < mailcap_list->nitem; i++) {
+- if (p = searchMailcap(UserMailcap[i], type))
++ if ((p = searchMailcap(UserMailcap[i], type)) != NULL)
+ return p;
+ }
+
+diff -Nru --exclude config.h --exclude XXMakefile --exclude tagtable.c ../w3m-0.1.11-pre/parsetagx.c ./parsetagx.c
+--- ../w3m-0.1.11-pre/parsetagx.c Fri Dec 8 01:14:57 2000
++++ ./parsetagx.c Fri Dec 8 01:31:27 2000
+@@ -118,8 +118,8 @@
+
+ tag_id = getHash_si(&tagtable, tagname, HTML_UNKNOWN);
+
+- if (tag_id == HTML_UNKNOWN ||
+- !internal && TagMAP[tag_id].flag & TFLG_INT)
++ if ((tag_id == HTML_UNKNOWN) ||
++ (!internal && (TagMAP[tag_id].flag & TFLG_INT)))
+ goto skip_parse_tagarg;
+
+ tag = New(struct parsed_tag);
+@@ -189,9 +189,9 @@
+ }
+ if (i != nattr) {
+ if (!internal &&
+- (AttrMAP[attr_id].flag & AFLG_INT ||
+- value && AttrMAP[attr_id].vtype == VTYPE_METHOD &&
+- !strcasecmp(value->ptr, "internal"))) {
++ ((AttrMAP[attr_id].flag & AFLG_INT) ||
++ (value && AttrMAP[attr_id].vtype == VTYPE_METHOD &&
++ !strcasecmp(value->ptr, "internal")))) {
+ tag->need_reconstruct = TRUE;
+ continue;
+ }
+diff -Nru --exclude config.h --exclude XXMakefile --exclude tagtable.c ../w3m-0.1.11-pre/table.c ./table.c
+--- ../w3m-0.1.11-pre/table.c Fri Dec 8 01:14:57 2000
++++ ./table.c Fri Dec 8 01:29:24 2000
+@@ -758,7 +758,7 @@
+ int id = -1;
+ char *p = l->ptr;
+ struct parsed_tag *tag;
+- if (tag = parse_tag(&p, TRUE))
++ if ((tag = parse_tag(&p, TRUE)) != NULL)
+ parsedtag_get_value(tag, ATTR_TID, &id);
+ if (id >= 0 && id < tbl->ntable) {
+ int alignment;
+@@ -1199,8 +1199,8 @@
+ if (dmax > 0. && dmin > dmax)
+ dmin = dmax;
+ span = ecol - bcol;
+- if (span == t->maxcol + 1 && dmin >= 0. ||
+- span != t->maxcol + 1 && dmin > rulewidth * 0.5) {
++ if ((span == t->maxcol + 1 && dmin >= 0.) ||
++ (span != t->maxcol + 1 && dmin > rulewidth * 0.5)) {
+ int nwidth = ceil_at_intervals(round(owidth - dmin), rulewidth);
+ correct_table_matrix(t, bcol, ecol - bcol, nwidth, 1.);
+ corr++;
+@@ -2425,11 +2425,11 @@
+
+ if (
+ #ifdef MENU_SELECT
+- mode->pre_mode & TBLM_INSELECT && cmd != HTML_N_SELECT ||
++ (mode->pre_mode & TBLM_INSELECT && cmd != HTML_N_SELECT) ||
+ #endif /* MENU_SELECT */
+- mode->pre_mode & TBLM_INTXTA && cmd != HTML_N_TEXTAREA ||
+- mode->pre_mode & TBLM_XMP && cmd != HTML_N_XMP ||
+- mode->pre_mode & TBLM_LST && cmd != HTML_N_LISTING)
++ (mode->pre_mode & TBLM_INTXTA && cmd != HTML_N_TEXTAREA) ||
++ (mode->pre_mode & TBLM_XMP && cmd != HTML_N_XMP) ||
++ (mode->pre_mode & TBLM_LST && cmd != HTML_N_LISTING))
+ return TAG_ACTION_FEED;
+
+ if (mode->pre_mode & TBLM_PRE) {
+diff -Nru --exclude config.h --exclude XXMakefile --exclude tagtable.c ../w3m-0.1.11-pre/url.c ./url.c
+--- ../w3m-0.1.11-pre/url.c Fri Dec 8 01:14:57 2000
++++ ./url.c Fri Dec 8 01:30:29 2000
+@@ -1502,7 +1502,7 @@
+ goto no_user_mimetypes;
+
+ for (i = 0; i < mimetypes_list->nitem; i++) {
+- if (ret = guessContentTypeFromTable(UserMimeTypes[i], filename))
++ if ((ret = guessContentTypeFromTable(UserMimeTypes[i], filename)) != NULL)
+ return ret;
+ }
diff --git a/www/w3m/files/patch-ax b/www/w3m/files/patch-ax
new file mode 100644
index 000000000000..d1d04cde968f
--- /dev/null
+++ b/www/w3m/files/patch-ax
@@ -0,0 +1,98 @@
+diff -u -r1.46 file.c
+--- file.c 2000/12/07 15:31:25 1.46
++++ file.c 2000/12/07 15:38:00
+@@ -3244,12 +3244,16 @@
+ y = 1;
+ z = 0;
+ width = 0;
+- if (parsedtag_get_value(tag, ATTR_BORDER, &w)) {
+- if (w > 2)
+- w = BORDER_THICK;
+- else if (w < 0) { /* weird */
+- w = BORDER_THIN;
++ if (parsedtag_exists(tag, ATTR_BORDER)) {
++ if (parsedtag_get_value(tag, ATTR_BORDER, &w)) {
++ if (w > 2)
++ w = BORDER_THICK;
++ else if (w < 0) { /* weird */
++ w = BORDER_THIN;
++ }
+ }
++ else
++ w = BORDER_THIN;
+ }
+ if (parsedtag_get_value(tag, ATTR_WIDTH, &i)) {
+ if (obuf->table_level == 0)
+Index: html.c
+===================================================================
+RCS file: /home/okabe/CVS_DB/w3m/html.c,v
+retrieving revision 1.5
+diff -u -r1.5 html.c
+--- html.c 2000/12/07 08:05:24 1.5
++++ html.c 2000/12/07 15:39:36
+@@ -276,7 +276,7 @@
+ {"fid" , VTYPE_NUMBER, AFLG_INT}, /* 54 ATTR_FID */
+ {"for_table" , VTYPE_NONE, AFLG_INT}, /* 55 ATTR_FOR_TABLE */
+ {"framename" , VTYPE_STR, AFLG_INT}, /* 56 ATTR_FRAMENAME */
+- {"hborder" , VTYPE_NONE, AFLG_INT}, /* 57 ATTR_HBORDER */
++ {"hborder" , VTYPE_NONE, 0}, /* 57 ATTR_HBORDER */
+ {"hseq" , VTYPE_NUMBER, AFLG_INT}, /* 58 ATTR_HSEQ */
+ {"no_effect" , VTYPE_NONE, AFLG_INT}, /* 59 ATTR_NO_EFFECT */
+ {"referer" , VTYPE_STR, AFLG_INT}, /* 60 ATTR_REFERER */
+Index: parsetagx.c
+===================================================================
+RCS file: /home/okabe/CVS_DB/w3m/parsetagx.c,v
+retrieving revision 1.1.2.3
+retrieving revision 1.6
+diff -u -r1.1.2.3 -r1.6
+--- parsetagx.c 2000/12/07 08:04:47 1.1.2.3
++++ parsetagx.c 2000/12/07 15:54:21 1.6
+@@ -195,13 +195,11 @@
+ tag->need_reconstruct = TRUE;
+ continue;
+ }
+- if (AttrMAP[attr_id].vtype == VTYPE_NONE || value) {
+- tag->attrid[i] = attr_id;
+- if (value)
+- tag->value[i] = cleanup_str(value->ptr);
+- else
+- tag->value[i] = NULL;
+- }
++ tag->attrid[i] = attr_id;
++ if (value)
++ tag->value[i] = cleanup_str(value->ptr);
++ else
++ tag->value[i] = NULL;
+ }
+ }
+
+@@ -224,14 +222,12 @@
+ return 0;
+
+ i = tag->map[id];
+- if (AttrMAP[id].vtype == VTYPE_NONE || value) {
+- tag->attrid[i] = id;
+- if (value)
+- tag->value[i] = allocStr(value, 0);
+- else
+- tag->value[i] = NULL;
+- return 1;
+- }
++ tag->attrid[i] = id;
++ if (value)
++ tag->value[i] = allocStr(value, 0);
++ else
++ tag->value[i] = NULL;
++ return 1;
+ return 0;
+ }
+
+@@ -255,7 +251,7 @@
+ Strcat_char(tagstr, '<');
+ Strcat_charp(tagstr, tag->tagname);
+ for (i = 0; i < nattr; i++) {
+- if (parsedtag_exists(tag, TagMAP[tag_id].accept_attribute[i])) {
++ if (tag->attrid[i] != ATTR_UNKNOWN) {
+ Strcat_char(tagstr, ' ');
+ Strcat_charp(tagstr, AttrMAP[tag->attrid[i]].name);
+ if (tag->value[i])
diff --git a/www/w3m/files/patch-ay b/www/w3m/files/patch-ay
new file mode 100644
index 000000000000..6591f60bccf5
--- /dev/null
+++ b/www/w3m/files/patch-ay
@@ -0,0 +1,12 @@
+--- frame.c.orig Fri Dec 8 22:21:42 2000
++++ frame.c Fri Dec 8 22:21:58 2000
+@@ -426,9 +426,7 @@
+ int r, c, status, t_stack;
+ InputStream f2;
+ Str tmp, tok;
+-#ifdef JP_CHARSET
+ char code, ic, charset[2];
+-#endif /* JP_CHARSET */
+ char *d_target, *p_target, *s_target, *t_target;
+ ParsedURL *currentURL, base;
+ MySignalHandler(*prevtrap) (SIGNAL_ARG) = NULL;
diff --git a/www/w3m/pkg-plist.ja b/www/w3m/pkg-plist.ja
index f68ea3513bcc..7f88ca42e9a1 100644
--- a/www/w3m/pkg-plist.ja
+++ b/www/w3m/pkg-plist.ja
@@ -7,10 +7,12 @@ share/doc/ja/w3m/HISTORY
share/doc/ja/w3m/HISTORY.kokb
share/doc/ja/w3m/MANUAL.html
share/doc/ja/w3m/README
+share/doc/ja/w3m/README.SSL
+share/doc/ja/w3m/README.cookie
share/doc/ja/w3m/README.dict
share/doc/ja/w3m/README.func
share/doc/ja/w3m/README.keymap
-share/doc/ja/w3m/README.kokb
+share/doc/ja/w3m/README.mailcap
share/doc/ja/w3m/README.menu
share/doc/ja/w3m/STORY.html
share/doc/ja/w3m/keymap.default