Merge branch 'feature/siteconf'

This commit is contained in:
Tatsuya Kinoshita
2013-04-08 21:56:59 +09:00
21 changed files with 782 additions and 265 deletions
+15 -22
View File
@@ -200,10 +200,11 @@ _put_anchor_news(Buffer *buf, char *p1, char *p2, int line, int pos)
if (*(p2 - 1) == '>') if (*(p2 - 1) == '>')
p2--; p2--;
} }
tmp = wc_Str_conv_strict(Strnew_charp_n(p1, p2 - p1), InnerCharset, tmp = Strnew_charp("news:");
buf->document_charset); Strcat_charp_n(tmp, p1, p2 - p1);
tmp = Sprintf("news:%s", file_quote(tmp->ptr)); return registerHref(buf, url_encode(tmp->ptr, baseURL(buf),
return registerHref(buf, tmp->ptr, NULL, NO_REFERER, NULL, '\0', line, buf->document_charset),
NULL, NO_REFERER, NULL, '\0', line,
pos); pos);
} }
#endif /* USE_NNTP */ #endif /* USE_NNTP */
@@ -213,9 +214,10 @@ _put_anchor_all(Buffer *buf, char *p1, char *p2, int line, int pos)
{ {
Str tmp; Str tmp;
tmp = wc_Str_conv_strict(Strnew_charp_n(p1, p2 - p1), InnerCharset, tmp = Strnew_charp_n(p1, p2 - p1);
buf->document_charset); return registerHref(buf, url_encode(tmp->ptr, baseURL(buf),
return registerHref(buf, url_quote(tmp->ptr), NULL, NO_REFERER, NULL, buf->document_charset),
NULL, NO_REFERER, NULL,
'\0', line, pos); '\0', line, pos);
} }
@@ -756,7 +758,7 @@ link_list_panel(Buffer *buf)
p = parsedURL2Str(&pu)->ptr; p = parsedURL2Str(&pu)->ptr;
u = html_quote(p); u = html_quote(p);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(p, buf->document_charset)); p = html_quote(url_decode2(p, buf));
else else
p = u; p = u;
} }
@@ -787,7 +789,7 @@ link_list_panel(Buffer *buf)
p = parsedURL2Str(&pu)->ptr; p = parsedURL2Str(&pu)->ptr;
u = html_quote(p); u = html_quote(p);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(p, buf->document_charset)); p = html_quote(url_decode2(p, buf));
else else
p = u; p = u;
t = getAnchorText(buf, al, a); t = getAnchorText(buf, al, a);
@@ -809,16 +811,13 @@ link_list_panel(Buffer *buf)
p = parsedURL2Str(&pu)->ptr; p = parsedURL2Str(&pu)->ptr;
u = html_quote(p); u = html_quote(p);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(p, buf->document_charset)); p = html_quote(url_decode2(p, buf));
else else
p = u; p = u;
if (a->title && *a->title) if (a->title && *a->title)
t = html_quote(a->title); t = html_quote(a->title);
else if (DecodeURL)
t = html_quote(url_unquote_conv
(a->url, buf->document_charset));
else else
t = html_quote(a->url); t = html_quote(url_decode2(a->url, buf));
Strcat_m_charp(tmp, "<li><a href=\"", u, "\">", t, "</a><br>", p, Strcat_m_charp(tmp, "<li><a href=\"", u, "\">", t, "</a><br>", p,
"\n", NULL); "\n", NULL);
a = retrieveAnchor(buf->formitem, a->start.line, a->start.pos); a = retrieveAnchor(buf->formitem, a->start.line, a->start.pos);
@@ -842,19 +841,13 @@ link_list_panel(Buffer *buf)
p = parsedURL2Str(&pu)->ptr; p = parsedURL2Str(&pu)->ptr;
u = html_quote(p); u = html_quote(p);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(p, p = html_quote(url_decode2(p, buf));
buf->
document_charset));
else else
p = u; p = u;
if (m->alt && *m->alt) if (m->alt && *m->alt)
t = html_quote(m->alt); t = html_quote(m->alt);
else if (DecodeURL)
t = html_quote(url_unquote_conv(m->url,
buf->
document_charset));
else else
t = html_quote(m->url); t = html_quote(url_decode2(m->url, buf));
Strcat_m_charp(tmp, "<li><a href=\"", u, "\">", t, Strcat_m_charp(tmp, "<li><a href=\"", u, "\">", t,
"</a><br>", p, "\n", NULL); "</a><br>", p, "\n", NULL);
} }
+1
View File
@@ -25,6 +25,7 @@
#define PASSWD_FILE RC_DIR "/passwd" #define PASSWD_FILE RC_DIR "/passwd"
#define PRE_FORM_FILE RC_DIR "/pre_form" #define PRE_FORM_FILE RC_DIR "/pre_form"
#define SITECONF_FILE RC_DIR "/siteconf"
#define USER_MAILCAP RC_DIR "/mailcap" #define USER_MAILCAP RC_DIR "/mailcap"
#define SYS_MAILCAP CONF_DIR "/mailcap" #define SYS_MAILCAP CONF_DIR "/mailcap"
#define USER_MIMETYPES "~/.mime.types" #define USER_MIMETYPES "~/.mime.types"
+1 -1
View File
@@ -257,7 +257,7 @@ make_lastline_link(Buffer *buf, char *title, char *url)
parseURL2(url, &pu, baseURL(buf)); parseURL2(url, &pu, baseURL(buf));
u = parsedURL2Str(&pu); u = parsedURL2Str(&pu);
if (DecodeURL) if (DecodeURL)
u = Strnew_charp(url_unquote_conv(u->ptr, buf->document_charset)); u = Strnew_charp(url_decode2(u->ptr, buf));
#ifdef USE_M17N #ifdef USE_M17N
u = checkType(u, &pr, NULL); u = checkType(u, &pr, NULL);
#endif #endif
+60
View File
@@ -0,0 +1,60 @@
siteconf: サイト別カスタマイズ
siteconf は、 URL のパターンと、それに紐付けられた設定から成ります。
siteconf を使うと、サイト毎に文字コードを指定して "decode_url"
の出力を改善したり、 Google のリダイレクタを迂回して性能や
プライバシーを向上させたりすることができます。
デフォルトでは siteconf は ~/.w3m/siteconf から読み込まれます。
===== 構文 =====
url <url>|/<re-url>/|m@<re-url>@i [exact]
substitute_url "<destination-url>"
url_charset <charset>
no_referer_from on|off
no_referer_to on|off
後ろの方に書かれたものが優先されます。
===== 例 =====
url "http://twitter.com/#!/"
substitute_url "http://mobile.twitter.com/"
twitter.com をモバイルサイトに転送します。
url "http://your.bookmark.net/"
no_referer_from on
your.bookmark.net から張ったリンクを辿る際に、 HTTP referer を
送らないようにします。
url "http://www.google.com/url?" exact
substitute_url "file:///cgi-bin/your-redirector.cgi?"
Google のリダイレクタを local CGI に転送します。
url /^http:\/\/[a-z]*\.wikipedia\.org\//
url_charset utf-8
同時に "decode_url" オプションをオンにすると、 Wikipedia への
リンクを UTF-8 としてデコードして表示します。
===== 正規表現について =====
次の正規表現はいずれも同じ意味を表します。
/http:\/\/www\.example\.com\//
m/http:\/\/www\.example\.com\//
m@http://www\.example\.com/@
m!http://www\.example\.com/!
最後に 'i' 修飾子を付けると、大文字小文字を区別せずに照合を行います。
例えば、 m@^http://www\.example\.com/abc/@i は以下のいずれとも一致します。
http://www.example.com/abc/
http://www.example.com/Abc/
http://www.example.com/ABC/
ただし、ホスト名の部分は常に小文字に変換してから比較します。
+60
View File
@@ -0,0 +1,60 @@
The siteconf: Site-specific preferences
The siteconf consists of URL patterns and preferences associated to them.
You can improve "decode_url" feature by giving charsets of URLs site by site,
or bypass Google's redirector for performance and your privacy.
The siteconf is read from ~/.w3m/siteconf by default.
===== The syntax =====
url <url>|/<re-url>/|m@<re-url>@i [exact]
substitute_url "<destination-url>"
url_charset <charset>
no_referer_from on|off
no_referer_to on|off
The last match wins.
===== Examples =====
url "http://twitter.com/#!/"
substitute_url "http://mobile.twitter.com/"
This forwards the twitter.com to its mobile site.
url "http://your.bookmark.net/"
no_referer_from on
This prevents HTTP referers from being sent when you follow links
at the your.bookmark.net.
url "http://www.google.com/url?" exact
substitute_url "file:///cgi-bin/your-redirector.cgi?"
This forwards the Google's redirector to your local CGI.
url /^http:\/\/[a-z]*\.wikipedia\.org\//
url_charset utf-8
When combinated with "decode_url" option turned on, links to
Wikipedia will be human-readable.
===== Regular expressions notes =====
Following expressions are all equivalent:
/http:\/\/www\.example\.com\//
m/http:\/\/www\.example\.com\//
m@http://www\.example\.com/@
m!http://www\.example\.com/!
With a trailing 'i' modifier, you can specify a case-insensitive match.
For example, m@^http://www\.example\.com/abc/@i matches to:
http://www.example.com/abc/
http://www.example.com/Abc/
http://www.example.com/ABC/
Hostnames, however, are always converted to lowercases before compared.
+111 -120
View File
@@ -47,11 +47,11 @@ static JMP_BUF AbortLoading;
static struct table *tables[MAX_TABLE]; static struct table *tables[MAX_TABLE];
static struct table_mode table_mode[MAX_TABLE]; static struct table_mode table_mode[MAX_TABLE];
#ifdef USE_IMAGE #if defined(USE_M17N) || defined(USE_IMAGE)
static ParsedURL *cur_baseURL = NULL; static ParsedURL *cur_baseURL = NULL;
#ifdef USE_M17N
static char cur_document_charset;
#endif #endif
#ifdef USE_M17N
static wc_ces cur_document_charset = 0;
#endif #endif
static Str cur_title; static Str cur_title;
@@ -215,7 +215,6 @@ currentLn(Buffer *buf)
static Buffer * static Buffer *
loadSomething(URLFile *f, loadSomething(URLFile *f,
char *path,
Buffer *(*loadproc) (URLFile *, Buffer *), Buffer *defaultbuf) Buffer *(*loadproc) (URLFile *, Buffer *), Buffer *defaultbuf)
{ {
Buffer *buf; Buffer *buf;
@@ -223,17 +222,23 @@ loadSomething(URLFile *f,
if ((buf = loadproc(f, defaultbuf)) == NULL) if ((buf = loadproc(f, defaultbuf)) == NULL)
return NULL; return NULL;
buf->filename = path;
if (buf->buffername == NULL || buf->buffername[0] == '\0') { if (buf->buffername == NULL || buf->buffername[0] == '\0') {
buf->buffername = checkHeader(buf, "Subject:"); buf->buffername = checkHeader(buf, "Subject:");
if (buf->buffername == NULL) if (buf->buffername == NULL && buf->filename != NULL)
buf->buffername = conv_from_system(lastFileName(path)); buf->buffername = conv_from_system(lastFileName(buf->filename));
} }
if (buf->currentURL.scheme == SCM_UNKNOWN) if (buf->currentURL.scheme == SCM_UNKNOWN)
buf->currentURL.scheme = f->scheme; buf->currentURL.scheme = f->scheme;
buf->real_scheme = f->scheme;
if (f->scheme == SCM_LOCAL && buf->sourcefile == NULL) if (f->scheme == SCM_LOCAL && buf->sourcefile == NULL)
buf->sourcefile = path; buf->sourcefile = buf->filename;
if (loadproc == loadHTMLBuffer
#ifdef USE_IMAGE
|| loadproc == loadImageBuffer
#endif
)
buf->type = "text/html";
else
buf->type = "text/plain";
return buf; return buf;
} }
@@ -484,28 +489,6 @@ convertLine0(URLFile *uf, Str line, int mode)
return line; return line;
} }
/*
* loadFile: load file to buffer
*/
Buffer *
loadFile(char *path)
{
Buffer *buf;
URLFile uf;
init_stream(&uf, SCM_LOCAL, NULL);
examineFile(path, &uf);
if (uf.stream == NULL)
return NULL;
buf = newBuffer(INIT_BUFFER_WIDTH);
current_content_length = 0;
#ifdef USE_M17N
content_charset = 0;
#endif
buf = loadSomething(&uf, path, loadBuffer, buf);
UFclose(&uf);
return buf;
}
int int
matchattr(char *p, char *attr, int len, Str *value) matchattr(char *p, char *attr, int len, Str *value)
{ {
@@ -1697,13 +1680,15 @@ getLinkNumberStr(int correction)
/* /*
* loadGeneralFile: load file to buffer * loadGeneralFile: load file to buffer
*/ */
#define DO_EXTERNAL ((Buffer *(*)(URLFile *, Buffer *))doExternal)
Buffer * Buffer *
loadGeneralFile(char *path, ParsedURL *volatile current, char *referer, loadGeneralFile(char *path, ParsedURL *volatile current, char *referer,
int flag, FormList *volatile request) int flag, FormList *volatile request)
{ {
URLFile f, *volatile of = NULL; URLFile f, *volatile of = NULL;
ParsedURL pu; ParsedURL pu;
Buffer *b = NULL, *(*volatile proc)() = loadBuffer; Buffer *b = NULL;
Buffer *(*volatile proc)(URLFile *, Buffer *) = loadBuffer;
char *volatile tpath; char *volatile tpath;
char *volatile t = "text/plain", *p, *volatile real_type = NULL; char *volatile t = "text/plain", *p, *volatile real_type = NULL;
Buffer *volatile t_buf = NULL; Buffer *volatile t_buf = NULL;
@@ -1730,7 +1715,22 @@ loadGeneralFile(char *path, ParsedURL *volatile current, char *referer,
add_auth_cookie_flag = 0; add_auth_cookie_flag = 0;
checkRedirection(NULL); checkRedirection(NULL);
load_doc: load_doc:
{
const char *sc_redirect;
parseURL2(tpath, &pu, current);
sc_redirect = query_SCONF_SUBSTITUTE_URL(&pu);
if (sc_redirect && *sc_redirect && checkRedirection(&pu)) {
tpath = (char *)sc_redirect;
request = NULL;
add_auth_cookie_flag = 0;
current = New(ParsedURL);
*current = pu;
status = HTST_NORMAL;
goto load_doc;
}
}
TRAP_OFF; TRAP_OFF;
url_option.referer = referer; url_option.referer = referer;
url_option.flag = flag; url_option.flag = flag;
@@ -1863,7 +1863,7 @@ loadGeneralFile(char *path, ParsedURL *volatile current, char *referer,
/* 302: Found */ /* 302: Found */
/* 303: See Other */ /* 303: See Other */
/* 307: Temporary Redirect (HTTP/1.1) */ /* 307: Temporary Redirect (HTTP/1.1) */
tpath = url_quote_conv(p, DocumentCharset); tpath = url_encode(p, NULL, 0);
request = NULL; request = NULL;
UFclose(&f); UFclose(&f);
current = New(ParsedURL); current = New(ParsedURL);
@@ -2022,7 +2022,7 @@ loadGeneralFile(char *path, ParsedURL *volatile current, char *referer,
if (f.is_cgi && (p = checkHeader(t_buf, "Location:")) != NULL && if (f.is_cgi && (p = checkHeader(t_buf, "Location:")) != NULL &&
checkRedirection(&pu)) { checkRedirection(&pu)) {
/* document moved */ /* document moved */
tpath = url_quote_conv(remove_space(p), DocumentCharset); tpath = url_encode(remove_space(p), NULL, 0);
request = NULL; request = NULL;
UFclose(&f); UFclose(&f);
add_auth_cookie_flag = 0; add_auth_cookie_flag = 0;
@@ -2123,10 +2123,6 @@ loadGeneralFile(char *path, ParsedURL *volatile current, char *referer,
if (real_type == NULL) if (real_type == NULL)
real_type = t; real_type = t;
proc = loadBuffer; proc = loadBuffer;
#ifdef USE_IMAGE
cur_baseURL = New(ParsedURL);
copyParsedURL(cur_baseURL, &pu);
#endif
current_content_length = 0; current_content_length = 0;
if ((p = checkHeader(t_buf, "Content-Length:")) != NULL) if ((p = checkHeader(t_buf, "Content-Length:")) != NULL)
@@ -2197,18 +2193,8 @@ loadGeneralFile(char *path, ParsedURL *volatile current, char *referer,
#endif #endif
else if (w3m_backend) ; else if (w3m_backend) ;
else if (!(w3m_dump & ~DUMP_FRAME) || is_dump_text_type(t)) { else if (!(w3m_dump & ~DUMP_FRAME) || is_dump_text_type(t)) {
if (!do_download && doExternal(f, if (!do_download && searchExtViewer(t) != NULL) {
pu.real_file ? pu.real_file : pu.file, proc = DO_EXTERNAL;
t, &b, t_buf)) {
if (b && b != NO_BUFFER) {
b->real_scheme = f.scheme;
b->real_type = real_type;
if (b->currentURL.host == NULL && b->currentURL.file == NULL)
copyParsedURL(&b->currentURL, &pu);
}
UFclose(&f);
TRAP_OFF;
return b;
} }
else { else {
TRAP_OFF; TRAP_OFF;
@@ -2232,36 +2218,30 @@ loadGeneralFile(char *path, ParsedURL *volatile current, char *referer,
else if (w3m_dump & DUMP_FRAME) else if (w3m_dump & DUMP_FRAME)
return NULL; return NULL;
if (t_buf == NULL)
t_buf = newBuffer(INIT_BUFFER_WIDTH);
copyParsedURL(&t_buf->currentURL, &pu);
t_buf->filename = pu.real_file ? pu.real_file :
pu.file ? conv_to_system(pu.file) : NULL;
if (flag & RG_FRAME) { if (flag & RG_FRAME) {
if (t_buf == NULL)
t_buf = newBuffer(INIT_BUFFER_WIDTH);
t_buf->bufferprop |= BP_FRAME; t_buf->bufferprop |= BP_FRAME;
} }
#ifdef USE_SSL #ifdef USE_SSL
if (t_buf) t_buf->ssl_certificate = f.ssl_certificate;
t_buf->ssl_certificate = f.ssl_certificate;
#endif #endif
frame_source = flag & RG_FRAME_SRC; frame_source = flag & RG_FRAME_SRC;
b = loadSomething(&f, pu.real_file ? pu.real_file : pu.file, proc, t_buf); if (proc == DO_EXTERNAL) {
b = doExternal(f, t, t_buf);
} else {
b = loadSomething(&f, proc, t_buf);
}
UFclose(&f); UFclose(&f);
frame_source = 0; frame_source = 0;
if (b) { if (b && b != NO_BUFFER) {
b->real_scheme = f.scheme; b->real_scheme = f.scheme;
b->real_type = real_type; b->real_type = real_type;
if (b->currentURL.host == NULL && b->currentURL.file == NULL) if (w3m_backend)
copyParsedURL(&b->currentURL, &pu); b->type = allocStr(t, -1);
if (is_html_type(t))
b->type = "text/html";
else if (w3m_backend) {
Str s = Strnew_charp(t);
b->type = s->ptr;
}
#ifdef USE_IMAGE
else if (proc == loadImageBuffer)
b->type = "text/html";
#endif
else
b->type = "text/plain";
if (pu.label) { if (pu.label) {
if (proc == loadHTMLBuffer) { if (proc == loadHTMLBuffer) {
Anchor *a; Anchor *a;
@@ -3250,7 +3230,7 @@ process_img(struct parsed_tag *tag, int width)
if (!parsedtag_get_value(tag, ATTR_SRC, &p)) if (!parsedtag_get_value(tag, ATTR_SRC, &p))
return tmp; return tmp;
p = remove_space(p); p = url_encode(remove_space(p), cur_baseURL, cur_document_charset);
q = NULL; q = NULL;
parsedtag_get_value(tag, ATTR_ALT, &q); parsedtag_get_value(tag, ATTR_ALT, &q);
if (!pseudoInlines && (q == NULL || (*q == '\0' && ignore_null_img_alt))) if (!pseudoInlines && (q == NULL || (*q == '\0' && ignore_null_img_alt)))
@@ -3344,12 +3324,7 @@ process_img(struct parsed_tag *tag, int width)
Image image; Image image;
ParsedURL u; ParsedURL u;
#ifdef USE_M17N
parseURL2(wc_conv(p, InnerCharset, cur_document_charset)->ptr, &u,
cur_baseURL);
#else
parseURL2(p, &u, cur_baseURL); parseURL2(p, &u, cur_baseURL);
#endif
image.url = parsedURL2Str(&u)->ptr; image.url = parsedURL2Str(&u)->ptr;
if (!uncompressed_file_type(u.file, &image.ext)) if (!uncompressed_file_type(u.file, &image.ext))
image.ext = filename_extension(u.file, TRUE); image.ext = filename_extension(u.file, TRUE);
@@ -4163,6 +4138,7 @@ process_form_int(struct parsed_tag *tag, int fid)
parsedtag_get_value(tag, ATTR_METHOD, &p); parsedtag_get_value(tag, ATTR_METHOD, &p);
q = "!CURRENT_URL!"; q = "!CURRENT_URL!";
parsedtag_get_value(tag, ATTR_ACTION, &q); parsedtag_get_value(tag, ATTR_ACTION, &q);
q = url_encode(remove_space(q), cur_baseURL, cur_document_charset);
r = NULL; r = NULL;
#ifdef USE_M17N #ifdef USE_M17N
if (parsedtag_get_value(tag, ATTR_ACCEPT_CHARSET, &r)) if (parsedtag_get_value(tag, ATTR_ACCEPT_CHARSET, &r))
@@ -5184,11 +5160,10 @@ HTMLtagproc1(struct parsed_tag *tag, struct html_feed_environ *h_env)
} }
return 1; return 1;
case HTML_BASE: case HTML_BASE:
#ifdef USE_IMAGE #if defined(USE_M17N) || defined(USE_IMAGE)
p = NULL; p = NULL;
if (parsedtag_get_value(tag, ATTR_HREF, &p)) { if (parsedtag_get_value(tag, ATTR_HREF, &p)) {
if (!cur_baseURL) cur_baseURL = New(ParsedURL);
cur_baseURL = New(ParsedURL);
parseURL(p, cur_baseURL, NULL); parseURL(p, cur_baseURL, NULL);
} }
#endif #endif
@@ -5446,6 +5421,13 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
#ifdef MENU_SELECT #ifdef MENU_SELECT
Anchor **a_select = NULL; Anchor **a_select = NULL;
#endif #endif
#if defined(USE_M17N) || defined(USE_IMAGE)
ParsedURL *base = baseURL(buf);
#endif
#ifdef USE_M17N
wc_ces name_charset = url_to_charset(NULL, &buf->currentURL,
buf->document_charset);
#endif
if (out_size == 0) { if (out_size == 0) {
out_size = LINELEN; out_size = LINELEN;
@@ -5640,16 +5622,17 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
hseq = 0; hseq = 0;
id = NULL; id = NULL;
if (parsedtag_get_value(tag, ATTR_NAME, &id)) { if (parsedtag_get_value(tag, ATTR_NAME, &id)) {
id = url_quote_conv(id, buf->document_charset); id = url_quote_conv(id, name_charset);
registerName(buf, id, currentLn(buf), pos); registerName(buf, id, currentLn(buf), pos);
} }
if (parsedtag_get_value(tag, ATTR_HREF, &p)) if (parsedtag_get_value(tag, ATTR_HREF, &p))
p = url_quote_conv(remove_space(p), p = url_encode(remove_space(p), base,
buf->document_charset); buf->document_charset);
if (parsedtag_get_value(tag, ATTR_TARGET, &q)) if (parsedtag_get_value(tag, ATTR_TARGET, &q))
q = url_quote_conv(q, buf->document_charset); q = url_quote_conv(q, buf->document_charset);
if (parsedtag_get_value(tag, ATTR_REFERER, &r)) if (parsedtag_get_value(tag, ATTR_REFERER, &r))
r = url_quote_conv(r, buf->document_charset); r = url_encode(r, base,
buf->document_charset);
parsedtag_get_value(tag, ATTR_TITLE, &s); parsedtag_get_value(tag, ATTR_TITLE, &s);
parsedtag_get_value(tag, ATTR_ACCESSKEY, &t); parsedtag_get_value(tag, ATTR_ACCESSKEY, &t);
parsedtag_get_value(tag, ATTR_HSEQ, &hseq); parsedtag_get_value(tag, ATTR_HSEQ, &hseq);
@@ -5735,7 +5718,7 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
ParsedURL u; ParsedURL u;
Image *image; Image *image;
parseURL2(a_img->url, &u, cur_baseURL); parseURL2(a_img->url, &u, base);
a_img->image = image = New(Image); a_img->image = image = New(Image);
image->url = parsedURL2Str(&u)->ptr; image->url = parsedURL2Str(&u)->ptr;
if (!uncompressed_file_type(u.file, &image->ext)) if (!uncompressed_file_type(u.file, &image->ext))
@@ -5756,7 +5739,7 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
image->map = q; image->map = q;
image->ismap = ismap; image->ismap = ismap;
image->touch = 0; image->touch = 0;
image->cache = getImage(image, cur_baseURL, image->cache = getImage(image, base,
IMG_FLAG_SKIP); IMG_FLAG_SKIP);
} }
else if (iseq < 0) { else if (iseq < 0) {
@@ -5893,8 +5876,8 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
break; break;
if (parsedtag_get_value(tag, ATTR_HREF, &p)) { if (parsedtag_get_value(tag, ATTR_HREF, &p)) {
MapArea *a; MapArea *a;
p = url_quote_conv(remove_space(p), p = url_encode(remove_space(p), base,
buf->document_charset); buf->document_charset);
t = NULL; t = NULL;
parsedtag_get_value(tag, ATTR_TARGET, &t); parsedtag_get_value(tag, ATTR_TARGET, &t);
q = ""; q = "";
@@ -5943,11 +5926,14 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
break; break;
case HTML_BASE: case HTML_BASE:
if (parsedtag_get_value(tag, ATTR_HREF, &p)) { if (parsedtag_get_value(tag, ATTR_HREF, &p)) {
p = url_quote_conv(remove_space(p), p = url_encode(remove_space(p), NULL,
buf->document_charset); buf->document_charset);
if (!buf->baseURL) if (!buf->baseURL)
buf->baseURL = New(ParsedURL); buf->baseURL = New(ParsedURL);
parseURL(p, buf->baseURL, NULL); parseURL(p, buf->baseURL, NULL);
#if defined(USE_M17N) || defined(USE_IMAGE)
base = buf->baseURL;
#endif
} }
if (parsedtag_get_value(tag, ATTR_TARGET, &p)) if (parsedtag_get_value(tag, ATTR_TARGET, &p))
buf->baseTarget = buf->baseTarget =
@@ -5962,8 +5948,8 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
int refresh_interval = getMetaRefreshParam(q, &tmp); int refresh_interval = getMetaRefreshParam(q, &tmp);
#ifdef USE_ALARM #ifdef USE_ALARM
if (tmp) { if (tmp) {
p = url_quote_conv(remove_space(tmp->ptr), p = url_encode(remove_space(tmp->ptr), base,
buf->document_charset); buf->document_charset);
buf->event = setAlarmEvent(buf->event, buf->event = setAlarmEvent(buf->event,
refresh_interval, refresh_interval,
AL_IMPLICIT_ONCE, AL_IMPLICIT_ONCE,
@@ -5976,8 +5962,8 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
FUNCNAME_reload, NULL); FUNCNAME_reload, NULL);
#else #else
if (tmp && refresh_interval == 0) { if (tmp && refresh_interval == 0) {
p = url_quote_conv(remove_space(tmp->ptr), p = url_encode(remove_space(tmp->ptr), base,
buf->document_charset); buf->document_charset);
pushEvent(FUNCNAME_gorURL, p); pushEvent(FUNCNAME_gorURL, p);
} }
#endif #endif
@@ -6061,7 +6047,7 @@ HTMLlineproc2body(Buffer *buf, Str (*feed) (), int llimit)
#ifdef ID_EXT #ifdef ID_EXT
id = NULL; id = NULL;
if (parsedtag_get_value(tag, ATTR_ID, &id)) { if (parsedtag_get_value(tag, ATTR_ID, &id)) {
id = url_quote_conv(id, buf->document_charset); id = url_quote_conv(id, name_charset);
registerName(buf, id, currentLn(buf), pos); registerName(buf, id, currentLn(buf), pos);
} }
if (renderFrameSet && if (renderFrameSet &&
@@ -6114,7 +6100,8 @@ addLink(Buffer *buf, struct parsed_tag *tag)
parsedtag_get_value(tag, ATTR_HREF, &href); parsedtag_get_value(tag, ATTR_HREF, &href);
if (href) if (href)
href = url_quote_conv(remove_space(href), buf->document_charset); href = url_encode(remove_space(href), baseURL(buf),
buf->document_charset);
parsedtag_get_value(tag, ATTR_TITLE, &title); parsedtag_get_value(tag, ATTR_TITLE, &title);
parsedtag_get_value(tag, ATTR_TYPE, &ctype); parsedtag_get_value(tag, ATTR_TYPE, &ctype);
parsedtag_get_value(tag, ATTR_REL, &rel); parsedtag_get_value(tag, ATTR_REL, &rel);
@@ -7110,8 +7097,6 @@ loadHTMLstream(URLFile *f, Buffer *newBuf, FILE * src, int internal)
image_flag = IMG_FLAG_AUTO; image_flag = IMG_FLAG_AUTO;
else else
image_flag = IMG_FLAG_SKIP; image_flag = IMG_FLAG_SKIP;
if (newBuf->currentURL.file)
cur_baseURL = baseURL(newBuf);
#endif #endif
if (w3m_halfload) { if (w3m_halfload) {
@@ -7134,6 +7119,9 @@ loadHTMLstream(URLFile *f, Buffer *newBuf, FILE * src, int internal)
htmlenv1.f = stdout; htmlenv1.f = stdout;
else else
htmlenv1.buf = newTextLineList(); htmlenv1.buf = newTextLineList();
#if defined(USE_M17N) || defined(USE_IMAGE)
cur_baseURL = baseURL(newBuf);
#endif
if (SETJMP(AbortLoading) != 0) { if (SETJMP(AbortLoading) != 0) {
HTMLlineproc1("<br>Transfer Interrupted!<br>", &htmlenv1); HTMLlineproc1("<br>Transfer Interrupted!<br>", &htmlenv1);
@@ -7195,7 +7183,7 @@ loadHTMLstream(URLFile *f, Buffer *newBuf, FILE * src, int internal)
} }
#endif #endif
lineBuf2 = convertLine(f, lineBuf2, HTML_MODE, &charset, doc_charset); lineBuf2 = convertLine(f, lineBuf2, HTML_MODE, &charset, doc_charset);
#if defined(USE_M17N) && defined(USE_IMAGE) #ifdef USE_M17N
cur_document_charset = charset; cur_document_charset = charset;
#endif #endif
HTMLlineproc0(lineBuf2->ptr, &htmlenv1, internal); HTMLlineproc0(lineBuf2->ptr, &htmlenv1, internal);
@@ -7207,6 +7195,12 @@ loadHTMLstream(URLFile *f, Buffer *newBuf, FILE * src, int internal)
obuf.status = R_ST_NORMAL; obuf.status = R_ST_NORMAL;
completeHTMLstream(&htmlenv1, &obuf); completeHTMLstream(&htmlenv1, &obuf);
flushline(&htmlenv1, &obuf, 0, 2, htmlenv1.limit); flushline(&htmlenv1, &obuf, 0, 2, htmlenv1.limit);
#if defined(USE_M17N) || defined(USE_IMAGE)
cur_baseURL = NULL;
#endif
#ifdef USE_M17N
cur_document_charset = 0;
#endif
if (htmlenv1.title) if (htmlenv1.title)
newBuf->buffername = htmlenv1.title; newBuf->buffername = htmlenv1.title;
if (w3m_halfdump) { if (w3m_halfdump) {
@@ -7354,7 +7348,7 @@ loadGopherDir(URLFile *uf, ParsedURL *pu, wc_ces * charset)
q = Strnew_m_charp("gopher://", host->ptr, ":", port->ptr, q = Strnew_m_charp("gopher://", host->ptr, ":", port->ptr,
"/", file->ptr, NULL)->ptr; "/", file->ptr, NULL)->ptr;
Strcat_m_charp(tmp, "<a href=\"", Strcat_m_charp(tmp, "<a href=\"",
html_quote(url_quote_conv(q, *charset)), html_quote(url_encode(q, NULL, *charset)),
"\">", p, html_quote(name->ptr + 1), "</a>\n", NULL); "\">", p, html_quote(name->ptr + 1), "</a>\n", NULL);
} }
@@ -7478,6 +7472,7 @@ loadImageBuffer(URLFile *uf, Buffer *newBuf)
URLFile f; URLFile f;
MySignalHandler(*volatile prevtrap) (SIGNAL_ARG) = NULL; MySignalHandler(*volatile prevtrap) (SIGNAL_ARG) = NULL;
struct stat st; struct stat st;
const ParsedURL *pu = newBuf ? &newBuf->currentURL : NULL;
loadImage(newBuf, IMG_FLAG_STOP); loadImage(newBuf, IMG_FLAG_STOP);
image.url = uf->url; image.url = uf->url;
@@ -7485,8 +7480,8 @@ loadImageBuffer(URLFile *uf, Buffer *newBuf)
image.width = -1; image.width = -1;
image.height = -1; image.height = -1;
image.cache = NULL; image.cache = NULL;
cache = getImage(&image, cur_baseURL, IMG_FLAG_AUTO); cache = getImage(&image, (ParsedURL *)pu, IMG_FLAG_AUTO);
if (!cur_baseURL->is_nocache && cache->loaded & IMG_FLAG_LOADED && if (!(pu && pu->is_nocache) && cache->loaded & IMG_FLAG_LOADED &&
!stat(cache->file, &st)) !stat(cache->file, &st))
goto image_buffer; goto image_buffer;
@@ -7727,8 +7722,11 @@ openGeneralPagerBuffer(InputStream stream)
#ifdef USE_M17N #ifdef USE_M17N
content_charset = 0; content_charset = 0;
#endif #endif
t_buf = newBuffer(INIT_BUFFER_WIDTH);
copyParsedURL(&t_buf->currentURL, NULL);
t_buf->currentURL.scheme = SCM_LOCAL;
t_buf->currentURL.file = "-";
if (SearchHeader) { if (SearchHeader) {
t_buf = newBuffer(INIT_BUFFER_WIDTH);
readHeader(&uf, t_buf, TRUE, NULL); readHeader(&uf, t_buf, TRUE, NULL);
t = checkContentType(t_buf); t = checkContentType(t_buf);
if (t == NULL) if (t == NULL)
@@ -7756,14 +7754,13 @@ openGeneralPagerBuffer(InputStream stream)
#ifdef USE_IMAGE #ifdef USE_IMAGE
else if (activeImage && displayImage && !useExtImageViewer && else if (activeImage && displayImage && !useExtImageViewer &&
!(w3m_dump & ~DUMP_FRAME) && !strncasecmp(t, "image/", 6)) { !(w3m_dump & ~DUMP_FRAME) && !strncasecmp(t, "image/", 6)) {
cur_baseURL = New(ParsedURL);
parseURL("-", cur_baseURL, NULL);
buf = loadImageBuffer(&uf, t_buf); buf = loadImageBuffer(&uf, t_buf);
buf->type = "text/html"; buf->type = "text/html";
} }
#endif #endif
else { else {
if (doExternal(uf, "-", t, &buf, t_buf)) { if (searchExtViewer(t)) {
buf = doExternal(uf, t, t_buf);
UFclose(&uf); UFclose(&uf);
if (buf == NULL || buf == NO_BUFFER) if (buf == NULL || buf == NO_BUFFER)
return buf; return buf;
@@ -7776,8 +7773,6 @@ openGeneralPagerBuffer(InputStream stream)
} }
} }
buf->real_type = t; buf->real_type = t;
buf->currentURL.scheme = SCM_LOCAL;
buf->currentURL.file = "-";
return buf; return buf;
} }
@@ -7970,9 +7965,8 @@ save2tmp(URLFile uf, char *tmpf)
return 0; return 0;
} }
int Buffer *
doExternal(URLFile uf, char *path, char *type, Buffer **bufp, doExternal(URLFile uf, char *type, Buffer *defaultbuf)
Buffer *defaultbuf)
{ {
Str tmpf, command; Str tmpf, command;
struct mailcap *mcap; struct mailcap *mcap;
@@ -7981,7 +7975,7 @@ doExternal(URLFile uf, char *path, char *type, Buffer **bufp,
char *header, *src = NULL, *ext = uf.ext; char *header, *src = NULL, *ext = uf.ext;
if (!(mcap = searchExtViewer(type))) if (!(mcap = searchExtViewer(type)))
return 0; return NULL;
if (mcap->nametemplate) { if (mcap->nametemplate) {
tmpf = unquote_mailcap(mcap->nametemplate, NULL, "", NULL, NULL); tmpf = unquote_mailcap(mcap->nametemplate, NULL, "", NULL, NULL);
@@ -8014,15 +8008,13 @@ doExternal(URLFile uf, char *path, char *type, Buffer **bufp,
UFclose(&uf); UFclose(&uf);
myExec(command->ptr); myExec(command->ptr);
} }
*bufp = NO_BUFFER; return NO_BUFFER;
return 1;
} }
else else
#endif #endif
{ {
if (save2tmp(uf, tmpf->ptr) < 0) { if (save2tmp(uf, tmpf->ptr) < 0) {
*bufp = NULL; return NULL;
return 1;
} }
} }
if (mcap->flags & (MAILCAP_HTMLOUTPUT | MAILCAP_COPIOUSOUTPUT)) { if (mcap->flags & (MAILCAP_HTMLOUTPUT | MAILCAP_COPIOUSOUTPUT)) {
@@ -8065,14 +8057,13 @@ doExternal(URLFile uf, char *path, char *type, Buffer **bufp,
buf = NO_BUFFER; buf = NO_BUFFER;
} }
if (buf && buf != NO_BUFFER) { if (buf && buf != NO_BUFFER) {
buf->filename = path; if ((buf->buffername == NULL || buf->buffername[0] == '\0') &&
if (buf->buffername == NULL || buf->buffername[0] == '\0') buf->filename)
buf->buffername = conv_from_system(lastFileName(path)); buf->buffername = conv_from_system(lastFileName(buf->filename));
buf->edit = mcap->edit; buf->edit = mcap->edit;
buf->mailcap = mcap; buf->mailcap = mcap;
} }
*bufp = buf; return buf;
return 1;
} }
static int static int
+13
View File
@@ -264,6 +264,18 @@ extern int REV_LB[];
#define IMG_FLAG_ERROR 2 #define IMG_FLAG_ERROR 2
#define IMG_FLAG_DONT_REMOVE 4 #define IMG_FLAG_DONT_REMOVE 4
#define IS_EMPTY_PARSED_URL(pu) ((pu)->scheme == SCM_UNKNOWN && !(pu)->file)
#define SCONF_RESERVED 0
#define SCONF_SUBSTITUTE_URL 1
#define SCONF_URL_CHARSET 2
#define SCONF_NO_REFERER_FROM 3
#define SCONF_NO_REFERER_TO 4
#define SCONF_N_FIELD 5
#define query_SCONF_SUBSTITUTE_URL(pu) ((const char *)querySiteconf(pu, SCONF_SUBSTITUTE_URL))
#define query_SCONF_URL_CHARSET(pu) ((const wc_ces *)querySiteconf(pu, SCONF_URL_CHARSET))
#define query_SCONF_NO_REFERER_FROM(pu) ((const int *)querySiteconf(pu, SCONF_NO_REFERER_FROM))
#define query_SCONF_NO_REFERER_TO(pu) ((const int *)querySiteconf(pu, SCONF_NO_REFERER_TO))
/* /*
* Macros. * Macros.
*/ */
@@ -981,6 +993,7 @@ global int BackgroundExtViewer init(TRUE);
global int disable_secret_security_check init(FALSE); global int disable_secret_security_check init(FALSE);
global char *passwd_file init(PASSWD_FILE); global char *passwd_file init(PASSWD_FILE);
global char *pre_form_file init(PRE_FORM_FILE); global char *pre_form_file init(PRE_FORM_FILE);
global char *siteconf_file init(SITECONF_FILE);
global char *ftppasswd init(NULL); global char *ftppasswd init(NULL);
global int ftppass_hostnamegen init(TRUE); global int ftppass_hostnamegen init(TRUE);
global int do_download init(FALSE); global int do_download init(FALSE);
+12 -17
View File
@@ -787,7 +787,7 @@ struct pre_form {
static struct pre_form *PreForm = NULL; static struct pre_form *PreForm = NULL;
static struct pre_form * static struct pre_form *
add_pre_form(struct pre_form *prev, char *url, char *name, char *action) add_pre_form(struct pre_form *prev, char *url, Regex *re_url, char *name, char *action)
{ {
ParsedURL pu; ParsedURL pu;
struct pre_form *new; struct pre_form *new;
@@ -796,21 +796,13 @@ add_pre_form(struct pre_form *prev, char *url, char *name, char *action)
new = prev->next = New(struct pre_form); new = prev->next = New(struct pre_form);
else else
new = PreForm = New(struct pre_form); new = PreForm = New(struct pre_form);
if (url && *url == '/') { if (url && !re_url) {
int l = strlen(url);
if (l > 1 && url[l - 1] == '/')
new->url = allocStr(url + 1, l - 2);
else
new->url = url + 1;
new->re_url = newRegex(new->url, FALSE, NULL, NULL);
if (!new->re_url)
new->url = NULL;
}
else if (url) {
parseURL2(url, &pu, NULL); parseURL2(url, &pu, NULL);
new->url = parsedURL2Str(&pu)->ptr; new->url = parsedURL2Str(&pu)->ptr;
new->re_url = NULL;
} }
else
new->url = url;
new->re_url = re_url;
new->name = (name && *name) ? name : NULL; new->name = (name && *name) ? name : NULL;
new->action = (action && *action) ? action : NULL; new->action = (action && *action) ? action : NULL;
new->item = NULL; new->item = NULL;
@@ -834,7 +826,7 @@ add_pre_form_item(struct pre_form *pf, struct pre_form_item *prev, int type,
new->name = name; new->name = name;
new->value = value; new->value = value;
if (checked && *checked && (!strcmp(checked, "0") || if (checked && *checked && (!strcmp(checked, "0") ||
strcasecmp(checked, "off") !strcasecmp(checked, "off")
|| !strcasecmp(checked, "no"))) || !strcasecmp(checked, "no")))
new->checked = 0; new->checked = 0;
else else
@@ -875,6 +867,7 @@ loadPreForm(void)
return; return;
while (1) { while (1) {
char *p, *s, *arg; char *p, *s, *arg;
Regex *re_arg;
line = Strfgets(fp); line = Strfgets(fp);
if (line->length == 0) if (line->length == 0)
@@ -890,18 +883,20 @@ loadPreForm(void)
if (*p == '#' || *p == '\0') if (*p == '#' || *p == '\0')
continue; /* comment or empty line */ continue; /* comment or empty line */
s = getWord(&p); s = getWord(&p);
arg = getWord(&p);
if (!strcmp(s, "url")) { if (!strcmp(s, "url")) {
arg = getRegexWord((const char **)&p, &re_arg);
if (!arg || !*arg) if (!arg || !*arg)
continue; continue;
p = getQWord(&p); p = getQWord(&p);
pf = add_pre_form(pf, arg, NULL, p); pf = add_pre_form(pf, arg, re_arg, NULL, p);
pi = pf->item; pi = pf->item;
continue; continue;
} }
if (!pf) if (!pf)
continue; continue;
arg = getWord(&p);
if (!strcmp(s, "form")) { if (!strcmp(s, "form")) {
if (!arg || !*arg) if (!arg || !*arg)
continue; continue;
@@ -913,7 +908,7 @@ loadPreForm(void)
} }
if (pf->item) { if (pf->item) {
struct pre_form *prev = pf; struct pre_form *prev = pf;
pf = add_pre_form(prev, "", s, p); pf = add_pre_form(prev, "", NULL, s, p);
/* copy previous URL */ /* copy previous URL */
pf->url = prev->url; pf->url = prev->url;
pf->re_url = prev->re_url; pf->re_url = prev->re_url;
+5 -4
View File
@@ -91,7 +91,8 @@ newFrame(struct parsed_tag *tag, Buffer *buf)
body->baseURL = baseURL(buf); body->baseURL = baseURL(buf);
if (tag) { if (tag) {
if (parsedtag_get_value(tag, ATTR_SRC, &p)) if (parsedtag_get_value(tag, ATTR_SRC, &p))
body->url = url_quote_conv(remove_space(p), buf->document_charset); body->url = url_encode(remove_space(p), body->baseURL,
buf->document_charset);
if (parsedtag_get_value(tag, ATTR_NAME, &p) && *p != '_') if (parsedtag_get_value(tag, ATTR_NAME, &p) && *p != '_')
body->name = url_quote_conv(p, buf->document_charset); body->name = url_quote_conv(p, buf->document_charset);
} }
@@ -639,7 +640,7 @@ createFrameFile(struct frameset *f, FILE * f1, Buffer *current, int level,
case HTML_BASE: case HTML_BASE:
/* "BASE" is prohibit tag */ /* "BASE" is prohibit tag */
if (parsedtag_get_value(tag, ATTR_HREF, &q)) { if (parsedtag_get_value(tag, ATTR_HREF, &q)) {
q = url_quote_conv(remove_space(q), charset); q = url_encode(remove_space(q), NULL, charset);
parseURL(q, &base, NULL); parseURL(q, &base, NULL);
} }
if (parsedtag_get_value(tag, ATTR_TARGET, &q)) { if (parsedtag_get_value(tag, ATTR_TARGET, &q)) {
@@ -768,8 +769,8 @@ createFrameFile(struct frameset *f, FILE * f1, Buffer *current, int level,
if (!tag->value[j]) if (!tag->value[j])
break; break;
tag->value[j] = tag->value[j] =
url_quote_conv(remove_space(tag->value[j]), url_encode(remove_space(tag->value[j]),
charset); &base, charset);
tag->need_reconstruct = TRUE; tag->need_reconstruct = TRUE;
parseURL2(tag->value[j], &url, &base); parseURL2(tag->value[j], &url, &base);
if (url.scheme == SCM_UNKNOWN || if (url.scheme == SCM_UNKNOWN ||
+88
View File
@@ -8,6 +8,7 @@
#include "fm.h" #include "fm.h"
#include "func.h" #include "func.h"
#include "myctype.h" #include "myctype.h"
#include "regex.h"
#include "funcname.c" #include "funcname.c"
#include "functable.c" #include "functable.c"
@@ -434,6 +435,93 @@ getQWord(char **str)
return tmp->ptr; return tmp->ptr;
} }
/* This extracts /regex/i or m@regex@i from the given string.
* Then advances *str to the end of regex.
* If the input does not seems to be a regex, this falls back to getQWord().
*
* Returns a word (no matter whether regex or not) in the give string.
* If regex_ret is non-NULL, compiles the regex and stores there.
*
* XXX: Actually this is unrelated to func.c.
*/
char *
getRegexWord(const char **str, Regex **regex_ret)
{
char *word = NULL;
const char *p, *headp, *bodyp, *tailp;
char delimiter;
int esc;
int igncase = 0;
p = *str;
SKIP_BLANKS(p);
headp = p;
/* Get the opening delimiter */
if (p[0] == 'm' && IS_PRINT(p[1]) && !IS_ALNUM(p[1]) && p[1] != '\\') {
delimiter = p[1];
p += 2;
}
else if (p[0] == '/') {
delimiter = '/';
p += 1;
}
else {
goto not_regex;
}
bodyp = p;
/* Scan the end of the expression */
for (esc = 0; *p; ++p) {
if (esc) {
esc = 0;
} else {
if (*p == delimiter)
break;
else if (*p == '\\')
esc = 1;
}
}
if (!*p && *headp == '/')
goto not_regex;
tailp = p;
/* Check the modifiers */
if (*p == delimiter) {
while (*++p && !IS_SPACE(*p)) {
switch (*p) {
case 'i':
igncase = 1;
break;
}
/* ignore unknown modifiers */
}
}
/* Save the expression */
word = allocStr(headp, p - headp);
/* Compile */
if (regex_ret) {
if (*tailp == delimiter)
word[tailp - headp] = 0;
*regex_ret = newRegex(word + (bodyp - headp), igncase, NULL, NULL);
if (*tailp == delimiter)
word[tailp - headp] = delimiter;
}
goto last;
not_regex:
p = headp;
word = getQWord((char **)&p);
if (regex_ret)
*regex_ret = NULL;
last:
*str = p;
return word;
}
#ifdef USE_MOUSE #ifdef USE_MOUSE
static MouseAction default_mouse_action = { static MouseAction default_mouse_action = {
NULL, NULL,
+1 -1
View File
@@ -17,7 +17,7 @@ historyBuffer(Hist *hist)
for (item = hist->list->last; item; item = item->prev) { for (item = hist->list->last; item; item = item->prev) {
q = html_quote((char *)item->ptr); q = html_quote((char *)item->ptr);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv((char *)item->ptr, 0)); p = html_quote(url_decode2((char *)item->ptr, NULL));
else else
p = q; p = q;
Strcat_charp(src, "<li><a href=\""); Strcat_charp(src, "<li><a href=\"");
+14
View File
@@ -357,6 +357,20 @@ strcasemstr(char *str, char *srch[], char **ret_ptr)
return -1; return -1;
} }
int
strmatchlen(const char *s1, const char *s2, int maxlen)
{
int i;
/* To allow the maxlen to be negatie (infinity),
* compare by "!=" instead of "<=". */
for (i = 0; i != maxlen; ++i) {
if (!s1[i] || !s2[i] || s1[i] != s2[i])
break;
}
return i;
}
char * char *
remove_space(char *str) remove_space(char *str)
{ {
+1
View File
@@ -52,6 +52,7 @@ extern int strncasecmp(const char *s1, const char *s2, size_t n);
extern char *strcasestr(const char *s1, const char *s2); extern char *strcasestr(const char *s1, const char *s2);
#endif #endif
extern int strcasemstr(char *str, char *srch[], char **ret_ptr); extern int strcasemstr(char *str, char *srch[], char **ret_ptr);
int strmatchlen(const char *s1, const char *s2, int maxlen);
extern char *remove_space(char *str); extern char *remove_space(char *str);
extern int non_null(char *s); extern int non_null(char *s);
extern void cleanup_line(Str s, int mode); extern void cleanup_line(Str s, int mode);
+2 -2
View File
@@ -1026,7 +1026,7 @@ _prev(void)
strCurrentBuf = strBuf; strCurrentBuf = strBuf;
} }
if (DecodeURL && (cm_mode & CPL_URL) ) if (DecodeURL && (cm_mode & CPL_URL) )
p = url_unquote_conv(p, 0); p = url_decode2(p, NULL);
strBuf = Strnew_charp(p); strBuf = Strnew_charp(p);
CLen = CPos = setStrType(strBuf, strProp); CLen = CPos = setStrType(strBuf, strProp);
offset = 0; offset = 0;
@@ -1045,7 +1045,7 @@ _next(void)
p = nextHist(hist); p = nextHist(hist);
if (p) { if (p) {
if (DecodeURL && (cm_mode & CPL_URL) ) if (DecodeURL && (cm_mode & CPL_URL) )
p = url_unquote_conv(p, 0); p = url_decode2(p, NULL);
strBuf = Strnew_charp(p); strBuf = Strnew_charp(p);
} }
else { else {
+39 -43
View File
@@ -914,12 +914,17 @@ main(int argc, char **argv, char **envp)
if (i >= 0) { if (i >= 0) {
SearchHeader = search_header; SearchHeader = search_header;
DefaultType = default_type; DefaultType = default_type;
char *url;
url = load_argv[i];
if (getURLScheme(&url) == SCM_MISSING && !ArgvIsURL)
url = file_to_url(load_argv[i]);
else
url = url_encode(conv_from_system(load_argv[i]), NULL, 0);
if (w3m_dump == DUMP_HEAD) { if (w3m_dump == DUMP_HEAD) {
request = New(FormList); request = New(FormList);
request->method = FORM_METHOD_HEAD; request->method = FORM_METHOD_HEAD;
newbuf = newbuf = loadGeneralFile(url, NULL, NO_REFERER, 0, request);
loadGeneralFile(load_argv[i], NULL, NO_REFERER, 0,
request);
} }
else { else {
if (post_file && i == 0) { if (post_file && i == 0) {
@@ -948,9 +953,7 @@ main(int argc, char **argv, char **envp)
else { else {
request = NULL; request = NULL;
} }
newbuf = newbuf = loadGeneralFile(url, NULL, NO_REFERER, 0, request);
loadGeneralFile(load_argv[i], NULL, NO_REFERER, 0,
request);
} }
if (newbuf == NULL) { if (newbuf == NULL) {
/* FIXME: gettextize? */ /* FIXME: gettextize? */
@@ -965,7 +968,7 @@ main(int argc, char **argv, char **envp)
break; break;
case SCM_LOCAL: case SCM_LOCAL:
case SCM_LOCAL_CGI: case SCM_LOCAL_CGI:
unshiftHist(LoadHist, conv_from_system(load_argv[i])); unshiftHist(LoadHist, url);
default: default:
pushHashHist(URLHist, parsedURL2Str(&newbuf->currentURL)->ptr); pushHashHist(URLHist, parsedURL2Str(&newbuf->currentURL)->ptr);
break; break;
@@ -1289,15 +1292,12 @@ do_dump(Buffer *buf)
printf("\nReferences:\n\n"); printf("\nReferences:\n\n");
for (i = 0; i < buf->href->nanchor; i++) { for (i = 0; i < buf->href->nanchor; i++) {
ParsedURL pu; ParsedURL pu;
static Str s = NULL; char *url;
if (buf->href->anchors[i].slave) if (buf->href->anchors[i].slave)
continue; continue;
parseURL2(buf->href->anchors[i].url, &pu, baseURL(buf)); parseURL2(buf->href->anchors[i].url, &pu, baseURL(buf));
s = parsedURL2Str(&pu); url = url_decode2(parsedURL2Str(&pu)->ptr, Currentbuf);
if (DecodeURL) printf("[%d] %s\n", buf->href->anchors[i].hseq + 1, url);
s = Strnew_charp(url_unquote_conv
(s->ptr, Currentbuf->document_charset));
printf("[%d] %s\n", buf->href->anchors[i].hseq + 1, s->ptr);
} }
} }
} }
@@ -2281,7 +2281,7 @@ DEFUN(movR1, MOVE_RIGHT1,
static wc_uint32 static wc_uint32
getChar(char *p) getChar(char *p)
{ {
return wc_any_to_ucs(wtf_parse1(&p)); return wc_any_to_ucs(wtf_parse1((wc_uchar **)&p));
} }
static int static int
@@ -2824,12 +2824,15 @@ loadLink(char *url, char *target, char *referer, FormList *request)
union frameset_element *f_element = NULL; union frameset_element *f_element = NULL;
int flag = 0; int flag = 0;
ParsedURL *base, pu; ParsedURL *base, pu;
const int *no_referer_ptr;
message(Sprintf("loading %s", url)->ptr, 0, 0); message(Sprintf("loading %s", url)->ptr, 0, 0);
refresh(); refresh();
no_referer_ptr = query_SCONF_NO_REFERER_FROM(&Currentbuf->currentURL);
base = baseURL(Currentbuf); base = baseURL(Currentbuf);
if (base == NULL || if ((no_referer_ptr && *no_referer_ptr) ||
base == NULL ||
base->scheme == SCM_LOCAL || base->scheme == SCM_LOCAL_CGI) base->scheme == SCM_LOCAL || base->scheme == SCM_LOCAL_CGI)
referer = NO_REFERER; referer = NO_REFERER;
if (referer == NULL) if (referer == NULL)
@@ -4075,6 +4078,7 @@ goURL0(char *prompt, int relative)
char *url, *referer; char *url, *referer;
ParsedURL p_url, *current; ParsedURL p_url, *current;
Buffer *cur_buf = Currentbuf; Buffer *cur_buf = Currentbuf;
const int *no_referer_ptr;
url = searchKeyData(); url = searchKeyData();
if (url == NULL) { if (url == NULL) {
@@ -4084,11 +4088,8 @@ goURL0(char *prompt, int relative)
current = baseURL(Currentbuf); current = baseURL(Currentbuf);
if (current) { if (current) {
char *c_url = parsedURL2Str(current)->ptr; char *c_url = parsedURL2Str(current)->ptr;
if (DefaultURLString == DEFAULT_URL_CURRENT) { if (DefaultURLString == DEFAULT_URL_CURRENT)
url = c_url; url = url_decode2(c_url, NULL);
if (DecodeURL)
url = url_unquote_conv(url, 0);
}
else else
pushHist(hist, c_url); pushHist(hist, c_url);
} }
@@ -4097,11 +4098,8 @@ goURL0(char *prompt, int relative)
char *a_url; char *a_url;
parseURL2(a->url, &p_url, current); parseURL2(a->url, &p_url, current);
a_url = parsedURL2Str(&p_url)->ptr; a_url = parsedURL2Str(&p_url)->ptr;
if (DefaultURLString == DEFAULT_URL_LINK) { if (DefaultURLString == DEFAULT_URL_LINK)
url = a_url; url = url_decode2(a_url, Currentbuf);
if (DecodeURL)
url = url_unquote_conv(url, Currentbuf->document_charset);
}
else else
pushHist(hist, a_url); pushHist(hist, a_url);
} }
@@ -4109,15 +4107,22 @@ goURL0(char *prompt, int relative)
if (url != NULL) if (url != NULL)
SKIP_BLANKS(url); SKIP_BLANKS(url);
} }
#ifdef USE_M17N if (relative) {
if (url != NULL) { no_referer_ptr = query_SCONF_NO_REFERER_FROM(&Currentbuf->currentURL);
if ((relative || *url == '#') && Currentbuf->document_charset) current = baseURL(Currentbuf);
url = wc_conv_strict(url, InnerCharset, if ((no_referer_ptr && *no_referer_ptr) ||
Currentbuf->document_charset)->ptr; current == NULL ||
current->scheme == SCM_LOCAL || current->scheme == SCM_LOCAL_CGI)
referer = NO_REFERER;
else else
url = conv_to_system(url); referer = parsedURL2Str(&Currentbuf->currentURL)->ptr;
url = url_encode(url, current, Currentbuf->document_charset);
}
else {
current = NULL;
referer = NULL;
url = url_encode(url, NULL, 0);
} }
#endif
if (url == NULL || *url == '\0') { if (url == NULL || *url == '\0') {
displayBuffer(Currentbuf, B_FORCE_REDRAW); displayBuffer(Currentbuf, B_FORCE_REDRAW);
return; return;
@@ -4126,14 +4131,6 @@ goURL0(char *prompt, int relative)
gotoLabel(url + 1); gotoLabel(url + 1);
return; return;
} }
if (relative) {
current = baseURL(Currentbuf);
referer = parsedURL2Str(&Currentbuf->currentURL)->ptr;
}
else {
current = NULL;
referer = NULL;
}
parseURL2(url, &p_url, current); parseURL2(url, &p_url, current);
pushHashHist(URLHist, parsedURL2Str(&p_url)->ptr); pushHashHist(URLHist, parsedURL2Str(&p_url)->ptr);
cmd_loadURL(url, current, referer, NULL); cmd_loadURL(url, current, referer, NULL);
@@ -4530,8 +4527,7 @@ _peekURL(int only_img)
s = parsedURL2Str(&pu); s = parsedURL2Str(&pu);
} }
if (DecodeURL) if (DecodeURL)
s = Strnew_charp(url_unquote_conv s = Strnew_charp(url_decode2(s->ptr, Currentbuf));
(s->ptr, Currentbuf->document_charset));
#ifdef USE_M17N #ifdef USE_M17N
s = checkType(s, &pp, NULL); s = checkType(s, &pp, NULL);
p = NewAtom_N(Lineprop, s->length); p = NewAtom_N(Lineprop, s->length);
@@ -4590,7 +4586,7 @@ DEFUN(curURL, PEEK, "Peek current URL")
offset = 0; offset = 0;
s = currentURL(); s = currentURL();
if (DecodeURL) if (DecodeURL)
s = Strnew_charp(url_unquote_conv(s->ptr, 0)); s = Strnew_charp(url_decode2(s->ptr, NULL));
#ifdef USE_M17N #ifdef USE_M17N
s = checkType(s, &pp, NULL); s = checkType(s, &pp, NULL);
p = NewAtom_N(Lineprop, s->length); p = NewAtom_N(Lineprop, s->length);
+8 -19
View File
@@ -279,7 +279,7 @@ follow_map_panel(Buffer *buf, char *name)
p = parsedURL2Str(&pu)->ptr; p = parsedURL2Str(&pu)->ptr;
q = html_quote(p); q = html_quote(p);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(p, buf->document_charset)); p = html_quote(url_decode2(p, buf));
else else
p = q; p = q;
Strcat_m_charp(mappage, "<tr valign=top><td><a href=\"", q, "\">", Strcat_m_charp(mappage, "<tr valign=top><td><a href=\"", q, "\">",
@@ -417,10 +417,7 @@ append_map_info(Buffer *buf, Str tmp, FormItemList *fi)
continue; continue;
parseURL2(a->url, &pu, baseURL(buf)); parseURL2(a->url, &pu, baseURL(buf));
q = html_quote(parsedURL2Str(&pu)->ptr); q = html_quote(parsedURL2Str(&pu)->ptr);
if (DecodeURL) p = html_quote(url_decode2(a->url, buf));
p = html_quote(url_unquote_conv(a->url, buf->document_charset));
else
p = html_quote(a->url);
Strcat_m_charp(tmp, "<tr valign=top><td>&nbsp;&nbsp;<td><a href=\"", Strcat_m_charp(tmp, "<tr valign=top><td>&nbsp;&nbsp;<td><a href=\"",
q, "\">", q, "\">",
html_quote(*a->alt ? a->alt : mybasename(a->url)), html_quote(*a->alt ? a->alt : mybasename(a->url)),
@@ -457,10 +454,8 @@ append_link_info(Buffer *buf, Str html, LinkList * link)
Strcat_charp(html, "[Rev]"); Strcat_charp(html, "[Rev]");
if (!l->url) if (!l->url)
url = "(empty)"; url = "(empty)";
else if (DecodeURL)
url = html_quote(url_unquote_conv(l->url, buf->document_charset));
else else
url = html_quote(l->url); url = html_quote(url_decode2(l->url, buf));
Strcat_m_charp(html, "<td>", url, NULL); Strcat_m_charp(html, "<td>", url, NULL);
if (l->ctype) if (l->ctype)
Strcat_m_charp(html, " (", html_quote(l->ctype), ")", NULL); Strcat_m_charp(html, " (", html_quote(l->ctype), ")", NULL);
@@ -498,8 +493,7 @@ append_frame_info(Buffer *buf, Str html, struct frameset *set, int level)
Strcat_charp(html, p); Strcat_charp(html, p);
} }
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(frame.body->url, p = html_quote(url_decode2(frame.body->url, buf));
buf->document_charset));
else else
p = q; p = q;
Strcat_m_charp(html, " ", p, "</a></pre_int><br>\n", NULL); Strcat_m_charp(html, " ", p, "</a></pre_int><br>\n", NULL);
@@ -550,9 +544,7 @@ page_info_panel(Buffer *buf)
#ifdef USE_M17N #ifdef USE_M17N
Strcat_charp(tmp, "<form method=internal action=charset>"); Strcat_charp(tmp, "<form method=internal action=charset>");
#endif #endif
p = parsedURL2Str(&buf->currentURL)->ptr; p = url_decode2(parsedURL2Str(&buf->currentURL)->ptr, NULL);
if (DecodeURL)
p = url_unquote_conv(p, 0);
Strcat_m_charp(tmp, "<table cellpadding=0>", Strcat_m_charp(tmp, "<table cellpadding=0>",
"<tr valign=top><td nowrap>Title<td>", "<tr valign=top><td nowrap>Title<td>",
html_quote(buf->buffername), html_quote(buf->buffername),
@@ -589,7 +581,7 @@ page_info_panel(Buffer *buf)
p = parsedURL2Str(&pu)->ptr; p = parsedURL2Str(&pu)->ptr;
q = html_quote(p); q = html_quote(p);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(p, buf->document_charset)); p = html_quote(url_decode2(p, buf));
else else
p = q; p = q;
Strcat_m_charp(tmp, Strcat_m_charp(tmp,
@@ -602,7 +594,7 @@ page_info_panel(Buffer *buf)
p = parsedURL2Str(&pu)->ptr; p = parsedURL2Str(&pu)->ptr;
q = html_quote(p); q = html_quote(p);
if (DecodeURL) if (DecodeURL)
p = html_quote(url_unquote_conv(p, buf->document_charset)); p = html_quote(url_decode2(p, buf));
else else
p = q; p = q;
Strcat_m_charp(tmp, Strcat_m_charp(tmp,
@@ -613,10 +605,7 @@ page_info_panel(Buffer *buf)
if (a != NULL) { if (a != NULL) {
FormItemList *fi = (FormItemList *)a->url; FormItemList *fi = (FormItemList *)a->url;
p = form2str(fi); p = form2str(fi);
if (DecodeURL) p = html_quote(url_decode2(p, buf));
p = html_quote(url_unquote_conv(p, buf->document_charset));
else
p = html_quote(p);
Strcat_m_charp(tmp, Strcat_m_charp(tmp,
"<tr valign=top><td nowrap>Method/type of current form&nbsp;<td>", "<tr valign=top><td nowrap>Method/type of current form&nbsp;<td>",
p, NULL); p, NULL);
+3 -9
View File
@@ -1365,9 +1365,7 @@ initSelectMenu(void)
break; break;
default: default:
Strcat_char(str, ' '); Strcat_char(str, ' ');
p = parsedURL2Str(&buf->currentURL)->ptr; p = url_decode2(parsedURL2Str(&buf->currentURL)->ptr, NULL);
if (DecodeURL)
p = url_unquote_conv(p, 0);
Strcat_charp(str, p); Strcat_charp(str, p);
break; break;
} }
@@ -1513,9 +1511,7 @@ initSelTabMenu(void)
case SCM_MISSING: case SCM_MISSING:
break; break;
default: default:
p = parsedURL2Str(&buf->currentURL)->ptr; p = url_decode2(parsedURL2Str(&buf->currentURL)->ptr, NULL);
if (DecodeURL)
p = url_unquote_conv(p, 0);
Strcat_charp(str, p); Strcat_charp(str, p);
break; break;
} }
@@ -1845,10 +1841,8 @@ link_menu(Buffer *buf)
Strcat_charp(str, " "); Strcat_charp(str, " ");
if (!l->url) if (!l->url)
p = ""; p = "";
else if (DecodeURL)
p = url_unquote_conv(l->url, buf->document_charset);
else else
p = l->url; p = url_decode2(l->url, buf);
Strcat_charp(str, p); Strcat_charp(str, p);
label[i] = str->ptr; label[i] = str->ptr;
if (len < str->length) if (len < str->length)
+4
View File
@@ -406,6 +406,10 @@ msgstr "パスワードファイル"
msgid "File for setting form on loading" msgid "File for setting form on loading"
msgstr "文書読込時のフォーム設定用ファイル" msgstr "文書読込時のフォーム設定用ファイル"
#: rc.c:149
msgid "File for preferences for each site"
msgstr "サイト別設定のファイル"
#: rc.c:149 #: rc.c:149
msgid "Password for anonymous FTP (your mail address)" msgid "Password for anonymous FTP (your mail address)"
msgstr "FTPのパスワード(普通は自分のmail addressを使う)" msgstr "FTPのパスワード(普通は自分のmail addressを使う)"
+23 -4
View File
@@ -162,6 +162,24 @@ extern Str searchURIMethods(ParsedURL *pu);
extern void chkExternalURIBuffer(Buffer *buf); extern void chkExternalURIBuffer(Buffer *buf);
#endif #endif
extern ParsedURL *schemeToProxy(int scheme); extern ParsedURL *schemeToProxy(int scheme);
#ifdef USE_M17N
extern wc_ces url_to_charset(const char *url, const ParsedURL *base,
wc_ces doc_charset);
extern char *url_encode(const char *url, const ParsedURL *base,
wc_ces doc_charset);
#if 0
extern char *url_decode(const char *url, const ParsedURL *base,
wc_ces doc_charset);
#endif
extern char *url_decode2(const char *url, const Buffer *buf);
#else /* !defined(USE_M17N) */
#define url_encode(url, base, cs) url_quote(url)
extern char *url_decode0(const char *url);
#if 0
#define url_decode(url, base, cs) url_decode0(url)
#endif
#define url_decode2(url, buf) url_decode0(url)
#endif /* !defined(USE_M17N) */
extern void examineFile(char *path, URLFile *uf); extern void examineFile(char *path, URLFile *uf);
extern char *acceptableEncoding(); extern char *acceptableEncoding();
extern int dir_exist(char *path); extern int dir_exist(char *path);
@@ -180,7 +198,6 @@ extern void push_symbol(Str str, char symbol, int width, int n);
#ifdef USE_UNICODE #ifdef USE_UNICODE
extern void update_utf8_symbol(void); extern void update_utf8_symbol(void);
#endif #endif
extern Buffer *loadFile(char *path);
extern Buffer *loadGeneralFile(char *path, ParsedURL *current, char *referer, extern Buffer *loadGeneralFile(char *path, ParsedURL *current, char *referer,
int flag, FormList *request); int flag, FormList *request);
extern int is_boundary(unsigned char *, unsigned char *); extern int is_boundary(unsigned char *, unsigned char *);
@@ -251,8 +268,7 @@ extern Buffer *openPagerBuffer(InputStream stream, Buffer *buf);
extern Buffer *openGeneralPagerBuffer(InputStream stream); extern Buffer *openGeneralPagerBuffer(InputStream stream);
extern Line *getNextPage(Buffer *buf, int plen); extern Line *getNextPage(Buffer *buf, int plen);
extern int save2tmp(URLFile uf, char *tmpf); extern int save2tmp(URLFile uf, char *tmpf);
extern int doExternal(URLFile uf, char *path, char *type, Buffer **bufp, extern Buffer *doExternal(URLFile uf, char *type, Buffer *defaultbuf);
Buffer *defaultbuf);
extern int _doFileCopy(char *tmpf, char *defstr, int download); extern int _doFileCopy(char *tmpf, char *defstr, int download);
#define doFileCopy(tmpf, defstr) _doFileCopy(tmpf, defstr, FALSE); #define doFileCopy(tmpf, defstr) _doFileCopy(tmpf, defstr, FALSE);
extern int doFileMove(char *tmpf, char *defstr); extern int doFileMove(char *tmpf, char *defstr);
@@ -509,7 +525,7 @@ extern ParsedURL *baseURL(Buffer *buf);
extern int openSocket(char *hostname, char *remoteport_name, extern int openSocket(char *hostname, char *remoteport_name,
unsigned short remoteport_num); unsigned short remoteport_num);
extern void parseURL(char *url, ParsedURL *p_url, ParsedURL *current); extern void parseURL(char *url, ParsedURL *p_url, ParsedURL *current);
extern void copyParsedURL(ParsedURL *p, ParsedURL *q); extern void copyParsedURL(ParsedURL *p, const ParsedURL *q);
extern void parseURL2(char *url, ParsedURL *pu, ParsedURL *current); extern void parseURL2(char *url, ParsedURL *pu, ParsedURL *current);
extern Str parsedURL2Str(ParsedURL *pu); extern Str parsedURL2Str(ParsedURL *pu);
extern int getURLScheme(char **url); extern int getURLScheme(char **url);
@@ -613,6 +629,7 @@ extern char *confFile(char *base);
extern char *auxbinFile(char *base); extern char *auxbinFile(char *base);
extern char *libFile(char *base); extern char *libFile(char *base);
extern char *helpFile(char *base); extern char *helpFile(char *base);
extern const void *querySiteconf(const ParsedURL *query_pu, int field);
extern Str localCookie(void); extern Str localCookie(void);
extern Str loadLocalDir(char *dirname); extern Str loadLocalDir(char *dirname);
extern void set_environ(char *var, char *value); extern void set_environ(char *var, char *value);
@@ -726,6 +743,8 @@ extern int getKey(char *s);
extern char *getKeyData(int key); extern char *getKeyData(int key);
extern char *getWord(char **str); extern char *getWord(char **str);
extern char *getQWord(char **str); extern char *getQWord(char **str);
struct regex;
extern char *getRegexWord(const char **str, struct regex **regex_ret);
#ifdef USE_MOUSE #ifdef USE_MOUSE
extern void initMouseAction(void); extern void initMouseAction(void);
#endif #endif
+222
View File
@@ -9,7 +9,9 @@
#include <errno.h> #include <errno.h>
#include "parsetag.h" #include "parsetag.h"
#include "local.h" #include "local.h"
#include "regex.h"
#include <stdlib.h> #include <stdlib.h>
#include <stddef.h>
struct param_ptr { struct param_ptr {
char *name; char *name;
@@ -146,6 +148,7 @@ static int OptionEncode = FALSE;
#define CMT_DISABLE_SECRET_SECURITY_CHECK N_("Disable secret file security check") #define CMT_DISABLE_SECRET_SECURITY_CHECK N_("Disable secret file security check")
#define CMT_PASSWDFILE N_("Password file") #define CMT_PASSWDFILE N_("Password file")
#define CMT_PRE_FORM_FILE N_("File for setting form on loading") #define CMT_PRE_FORM_FILE N_("File for setting form on loading")
#define CMT_SITECONF_FILE N_("File for preferences for each site")
#define CMT_FTPPASS N_("Password for anonymous FTP (your mail address)") #define CMT_FTPPASS N_("Password for anonymous FTP (your mail address)")
#define CMT_FTPPASS_HOSTNAMEGEN N_("Generate domain part of password for FTP") #define CMT_FTPPASS_HOSTNAMEGEN N_("Generate domain part of password for FTP")
#define CMT_USERAGENT N_("User-Agent identification string") #define CMT_USERAGENT N_("User-Agent identification string")
@@ -619,6 +622,8 @@ struct param_ptr params9[] = {
CMT_FTPPASS_HOSTNAMEGEN, NULL}, CMT_FTPPASS_HOSTNAMEGEN, NULL},
{"pre_form_file", P_STRING, PI_TEXT, (void *)&pre_form_file, {"pre_form_file", P_STRING, PI_TEXT, (void *)&pre_form_file,
CMT_PRE_FORM_FILE, NULL}, CMT_PRE_FORM_FILE, NULL},
{"siteconf_file", P_STRING, PI_TEXT, (void *)&siteconf_file,
CMT_SITECONF_FILE, NULL},
{"user_agent", P_STRING, PI_TEXT, (void *)&UserAgent, CMT_USERAGENT, NULL}, {"user_agent", P_STRING, PI_TEXT, (void *)&UserAgent, CMT_USERAGENT, NULL},
{"no_referer", P_INT, PI_ONOFF, (void *)&NoSendReferer, CMT_NOSENDREFERER, {"no_referer", P_INT, PI_ONOFF, (void *)&NoSendReferer, CMT_NOSENDREFERER,
NULL}, NULL},
@@ -1173,6 +1178,8 @@ do_mkdir(const char *dir, long mode)
#endif /* not __MINW32_VERSION */ #endif /* not __MINW32_VERSION */
#endif /* not __EMX__ */ #endif /* not __EMX__ */
static void loadSiteconf(void);
void void
sync_with_option(void) sync_with_option(void)
{ {
@@ -1199,6 +1206,7 @@ sync_with_option(void)
#endif #endif
loadPasswd(); loadPasswd();
loadPreForm(); loadPreForm();
loadSiteconf();
if (AcceptLang == NULL || *AcceptLang == '\0') { if (AcceptLang == NULL || *AcceptLang == '\0') {
/* TRANSLATORS: /* TRANSLATORS:
@@ -1556,3 +1564,217 @@ helpFile(char *base)
return expandPath(Strnew_m_charp(w3m_help_dir(), "/", base, NULL)->ptr); return expandPath(Strnew_m_charp(w3m_help_dir(), "/", base, NULL)->ptr);
} }
#endif #endif
/* siteconf */
/*
* url "<url>"|/<re-url>/|m@<re-url>@i [exact]
* substitute_url "<destination-url>"
* url_charset <charset>
* no_referer_from on|off
* no_referer_to on|off
*
* The last match wins.
*/
struct siteconf_rec {
struct siteconf_rec *next;
char *url;
Regex *re_url;
int url_exact;
unsigned char mask[(SCONF_N_FIELD + 7) >> 3];
char *substitute_url;
#ifdef USE_M17N
wc_ces url_charset;
#endif
int no_referer_from;
int no_referer_to;
};
#define SCONF_TEST(ent, f) ((ent)->mask[(f)>>3] & (1U<<((f)&7)))
#define SCONF_SET(ent, f) ((ent)->mask[(f)>>3] |= (1U<<((f)&7)))
#define SCONF_CLEAR(ent, f) ((ent)->mask[(f)>>3] &= ~(1U<<((f)&7)))
static struct siteconf_rec *siteconf_head = NULL;
static struct siteconf_rec *newSiteconfRec(void);
static struct siteconf_rec *
newSiteconfRec(void)
{
struct siteconf_rec *ent;
ent = New(struct siteconf_rec);
ent->next = NULL;
ent->url = NULL;
ent->re_url = NULL;
ent->url_exact = FALSE;
memset(ent->mask, 0, sizeof(ent->mask));
ent->substitute_url = NULL;
#ifdef USE_M17N
ent->url_charset = 0;
#endif
return ent;
}
static void
loadSiteconf(void)
{
char *efname;
FILE *fp;
Str line;
struct siteconf_rec *ent = NULL;
siteconf_head = NULL;
if (!siteconf_file)
return;
if ((efname = expandPath(siteconf_file)) == NULL)
return;
fp = fopen(efname, "r");
if (fp == NULL)
return;
while (line = Strfgets(fp), line->length > 0) {
char *p, *s;
Strchop(line);
p = line->ptr;
SKIP_BLANKS(p);
if (*p == '#' || *p == '\0')
continue;
s = getWord(&p);
/* The "url" begins a new record. */
if (strcmp(s, "url") == 0) {
char *url, *opt;
struct siteconf_rec *newent;
/* First, register the current record. */
if (ent) {
ent->next = siteconf_head;
siteconf_head = ent;
ent = NULL;
}
/* Second, create a new record. */
newent = newSiteconfRec();
url = getRegexWord((const char **)&p, &newent->re_url);
opt = getWord(&p);
SKIP_BLANKS(p);
if (!newent->re_url) {
ParsedURL pu;
if (!url || !*url)
continue;
parseURL2(url, &pu, NULL);
newent->url = parsedURL2Str(&pu)->ptr;
}
/* If we have an extra or unknown option, ignore this record
* for future extensions. */
if (strcmp(opt, "exact") == 0) {
newent->url_exact = TRUE;
}
else if (*opt != 0)
continue;
if (*p)
continue;
ent = newent;
continue;
}
/* If the current record is broken, skip to the next "url". */
if (!ent)
continue;
/* Fill the new record. */
if (strcmp(s, "substitute_url") == 0) {
ent->substitute_url = getQWord(&p);
SCONF_SET(ent, SCONF_SUBSTITUTE_URL);
}
#ifdef USE_M17N
else if (strcmp(s, "url_charset") == 0) {
char *charset = getWord(&p);
ent->url_charset = (charset && *charset) ?
wc_charset_to_ces(charset) : 0;
SCONF_SET(ent, SCONF_URL_CHARSET);
}
#endif /* USE_M17N */
else if (strcmp(s, "no_referer_from") == 0) {
ent->no_referer_from = str_to_bool(getWord(&p), 0);
SCONF_SET(ent, SCONF_NO_REFERER_FROM);
}
else if (strcmp(s, "no_referer_to") == 0) {
ent->no_referer_to = str_to_bool(getWord(&p), 0);
SCONF_SET(ent, SCONF_NO_REFERER_TO);
}
}
if (ent) {
ent->next = siteconf_head;
siteconf_head = ent;
ent = NULL;
}
fclose(fp);
}
const void *
querySiteconf(const ParsedURL *query_pu, int field)
{
const struct siteconf_rec *ent;
Str u;
char *firstp, *lastp;
if (field < 0 || field >= SCONF_N_FIELD)
return NULL;
if (!query_pu || IS_EMPTY_PARSED_URL(query_pu))
return NULL;
u = parsedURL2Str((ParsedURL *)query_pu);
if (u->length == 0)
return NULL;
for (ent = siteconf_head; ent; ent = ent->next) {
if (!SCONF_TEST(ent, field))
continue;
if (ent->re_url) {
if (RegexMatch(ent->re_url, u->ptr, u->length, 1)) {
MatchedPosition(ent->re_url, &firstp, &lastp);
if (!ent->url_exact)
goto url_found;
if (firstp != u->ptr || lastp == firstp)
continue;
if (*lastp == 0 || *lastp == '?' || *(lastp - 1) == '?' ||
*lastp == '#' || *(lastp - 1) == '#')
goto url_found;
}
} else {
int matchlen = strmatchlen(ent->url, u->ptr, u->length);
if (matchlen == 0 || ent->url[matchlen] != 0)
continue;
firstp = u->ptr;
lastp = u->ptr + matchlen;
if (*lastp == 0 || *lastp == '?' || *(lastp - 1) == '?' ||
*lastp == '#' || *(lastp - 1) == '#')
goto url_found;
if (!ent->url_exact && (*lastp == '/' || *(lastp - 1) == '/'))
goto url_found;
}
}
return NULL;
url_found:
switch (field) {
case SCONF_SUBSTITUTE_URL:
if (ent->substitute_url && *ent->substitute_url) {
Str tmp = Strnew_charp_n(u->ptr, firstp - u->ptr);
Strcat_charp(tmp, ent->substitute_url);
Strcat_charp(tmp, lastp);
return tmp->ptr;
}
return NULL;
#ifdef USE_M17N
case SCONF_URL_CHARSET:
return &ent->url_charset;
#endif
case SCONF_NO_REFERER_FROM:
return &ent->no_referer_from;
case SCONF_NO_REFERER_TO:
return &ent->no_referer_to;
}
return NULL;
}
+99 -23
View File
@@ -444,6 +444,8 @@ baseURL(Buffer *buf)
/* <BASE> tag is defined in the document */ /* <BASE> tag is defined in the document */
return buf->baseURL; return buf->baseURL;
} }
else if (IS_EMPTY_PARSED_URL(&buf->currentURL))
return NULL;
else else
return &buf->currentURL; return &buf->currentURL;
} }
@@ -638,16 +640,21 @@ openSocket(char *const hostname,
#define COPYPATH_SPC_ALLOW 0 #define COPYPATH_SPC_ALLOW 0
#define COPYPATH_SPC_IGNORE 1 #define COPYPATH_SPC_IGNORE 1
#define COPYPATH_SPC_REPLACE 2 #define COPYPATH_SPC_REPLACE 2
#define COPYPATH_SPC_MASK 3
#define COPYPATH_LOWERCASE 4
static char * static char *
copyPath(char *orgpath, int length, int option) copyPath(char *orgpath, int length, int option)
{ {
Str tmp = Strnew(); Str tmp = Strnew();
while (*orgpath && length != 0) { char ch;
if (IS_SPACE(*orgpath)) { while ((ch = *orgpath) != 0 && length != 0) {
switch (option) { if (option & COPYPATH_LOWERCASE)
ch = TOLOWER(ch);
if (IS_SPACE(ch)) {
switch (option & COPYPATH_SPC_MASK) {
case COPYPATH_SPC_ALLOW: case COPYPATH_SPC_ALLOW:
Strcat_char(tmp, *orgpath); Strcat_char(tmp, ch);
break; break;
case COPYPATH_SPC_IGNORE: case COPYPATH_SPC_IGNORE:
/* do nothing */ /* do nothing */
@@ -658,7 +665,7 @@ copyPath(char *orgpath, int length, int option)
} }
} }
else else
Strcat_char(tmp, *orgpath); Strcat_char(tmp, ch);
orgpath++; orgpath++;
length--; length--;
} }
@@ -668,22 +675,14 @@ copyPath(char *orgpath, int length, int option)
void void
parseURL(char *url, ParsedURL *p_url, ParsedURL *current) parseURL(char *url, ParsedURL *p_url, ParsedURL *current)
{ {
char *p, *q; char *p, *q, *qq;
Str tmp; Str tmp;
url = url_quote(url); /* quote 0x01-0x20, 0x7F-0xFF */ url = url_quote(url); /* quote 0x01-0x20, 0x7F-0xFF */
p = url; p = url;
copyParsedURL(p_url, NULL);
p_url->scheme = SCM_MISSING; p_url->scheme = SCM_MISSING;
p_url->port = 0;
p_url->user = NULL;
p_url->pass = NULL;
p_url->host = NULL;
p_url->is_nocache = 0;
p_url->file = NULL;
p_url->real_file = NULL;
p_url->query = NULL;
p_url->label = NULL;
/* RFC1808: Relative Uniform Resource Locators /* RFC1808: Relative Uniform Resource Locators
* 4. Resolving Relative URLs * 4. Resolving Relative URLs
@@ -694,7 +693,7 @@ parseURL(char *url, ParsedURL *p_url, ParsedURL *current)
goto do_label; goto do_label;
} }
#if defined( __EMX__ ) || defined( __CYGWIN__ ) #if defined( __EMX__ ) || defined( __CYGWIN__ )
if (!strncmp(url, "file://localhost/", 17)) { if (!strncasecmp(url, "file://localhost/", 17)) {
p_url->scheme = SCM_LOCAL; p_url->scheme = SCM_LOCAL;
p += 17 - 1; p += 17 - 1;
url += 17 - 1; url += 17 - 1;
@@ -802,19 +801,20 @@ parseURL(char *url, ParsedURL *p_url, ParsedURL *current)
/* scheme://user:pass@host or /* scheme://user:pass@host or
* scheme://host:port * scheme://host:port
*/ */
p_url->host = copyPath(q, p - q, COPYPATH_SPC_IGNORE); qq = q;
q = ++p; q = ++p;
while (*p && strchr("@/?#", *p) == NULL) while (*p && strchr("@/?#", *p) == NULL)
p++; p++;
if (*p == '@') { if (*p == '@') {
/* scheme://user:pass@... */ /* scheme://user:pass@... */
p_url->user = copyPath(qq, q - 1 - qq, COPYPATH_SPC_IGNORE);
p_url->pass = copyPath(q, p - q, COPYPATH_SPC_ALLOW); p_url->pass = copyPath(q, p - q, COPYPATH_SPC_ALLOW);
q = ++p; q = ++p;
p_url->user = p_url->host;
p_url->host = NULL;
goto analyze_url; goto analyze_url;
} }
/* scheme://host:port/ */ /* scheme://host:port/ */
p_url->host = copyPath(qq, q - 1 - qq,
COPYPATH_SPC_IGNORE | COPYPATH_LOWERCASE);
tmp = Strnew_charp_n(q, p - q); tmp = Strnew_charp_n(q, p - q);
p_url->port = atoi(tmp->ptr); p_url->port = atoi(tmp->ptr);
/* *p is one of ['\0', '/', '?', '#'] */ /* *p is one of ['\0', '/', '?', '#'] */
@@ -829,7 +829,8 @@ parseURL(char *url, ParsedURL *p_url, ParsedURL *current)
case '/': case '/':
case '?': case '?':
case '#': case '#':
p_url->host = copyPath(q, p - q, COPYPATH_SPC_IGNORE); p_url->host = copyPath(q, p - q,
COPYPATH_SPC_IGNORE | COPYPATH_LOWERCASE);
p_url->port = DefaultPort[p_url->scheme]; p_url->port = DefaultPort[p_url->scheme];
break; break;
} }
@@ -956,12 +957,16 @@ parseURL(char *url, ParsedURL *p_url, ParsedURL *current)
p_url->label = NULL; p_url->label = NULL;
} }
#define initParsedURL(p) bzero(p,sizeof(ParsedURL))
#define ALLOC_STR(s) ((s)==NULL?NULL:allocStr(s,-1)) #define ALLOC_STR(s) ((s)==NULL?NULL:allocStr(s,-1))
void void
copyParsedURL(ParsedURL *p, ParsedURL *q) copyParsedURL(ParsedURL *p, const ParsedURL *q)
{ {
if (q == NULL) {
memset(p, 0, sizeof(ParsedURL));
p->scheme = SCM_UNKNOWN;
return;
}
p->scheme = q->scheme; p->scheme = q->scheme;
p->port = q->port; p->port = q->port;
p->is_nocache = q->is_nocache; p->is_nocache = q->is_nocache;
@@ -1283,6 +1288,8 @@ static char *
otherinfo(ParsedURL *target, ParsedURL *current, char *referer) otherinfo(ParsedURL *target, ParsedURL *current, char *referer)
{ {
Str s = Strnew(); Str s = Strnew();
const int *no_referer_ptr;
int no_referer;
Strcat_charp(s, "User-Agent: "); Strcat_charp(s, "User-Agent: ");
if (UserAgent == NULL || *UserAgent == '\0') if (UserAgent == NULL || *UserAgent == '\0')
@@ -1306,7 +1313,12 @@ otherinfo(ParsedURL *target, ParsedURL *current, char *referer)
Strcat_charp(s, "Pragma: no-cache\r\n"); Strcat_charp(s, "Pragma: no-cache\r\n");
Strcat_charp(s, "Cache-control: no-cache\r\n"); Strcat_charp(s, "Cache-control: no-cache\r\n");
} }
if (!NoSendReferer) { no_referer = NoSendReferer;
no_referer_ptr = query_SCONF_NO_REFERER_FROM(current);
no_referer = NoSendReferer || (no_referer_ptr && *no_referer_ptr);
no_referer_ptr = query_SCONF_NO_REFERER_TO(target);
no_referer = no_referer || (no_referer_ptr && *no_referer_ptr);
if (!no_referer) {
#ifdef USE_SSL #ifdef USE_SSL
if (current && current->scheme == SCM_HTTPS && target->scheme != SCM_HTTPS) { if (current && current->scheme == SCM_HTTPS && target->scheme != SCM_HTTPS) {
/* Don't send Referer: if https:// -> http:// */ /* Don't send Referer: if https:// -> http:// */
@@ -1314,6 +1326,7 @@ otherinfo(ParsedURL *target, ParsedURL *current, char *referer)
else else
#endif #endif
if (referer == NULL && current && current->scheme != SCM_LOCAL && if (referer == NULL && current && current->scheme != SCM_LOCAL &&
current->scheme != SCM_LOCAL_CGI &&
(current->scheme != SCM_FTP || (current->scheme != SCM_FTP ||
(current->user == NULL && current->pass == NULL))) { (current->user == NULL && current->pass == NULL))) {
char *p = current->label; char *p = current->label;
@@ -2234,3 +2247,66 @@ schemeToProxy(int scheme)
} }
return pu; return pu;
} }
#ifdef USE_M17N
wc_ces
url_to_charset(const char *url, const ParsedURL *base, wc_ces doc_charset)
{
const ParsedURL *pu;
ParsedURL pu_buf;
const wc_ces *csptr;
if (url && *url && *url != '#') {
parseURL2((char *)url, &pu_buf, (ParsedURL *)base);
pu = &pu_buf;
} else {
pu = base;
}
if (pu && (pu->scheme == SCM_LOCAL || pu->scheme == SCM_LOCAL_CGI))
return SystemCharset;
csptr = query_SCONF_URL_CHARSET(pu);
return (csptr && *csptr) ? *csptr :
doc_charset ? doc_charset : DocumentCharset;
}
char *
url_encode(const char *url, const ParsedURL *base, wc_ces doc_charset)
{
return url_quote_conv((char *)url,
url_to_charset(url, base, doc_charset));
}
#if 0 /* unused */
char *
url_decode(const char *url, const ParsedURL *base, wc_ces doc_charset)
{
if (!DecodeURL)
return (char *)url;
return url_unquote_conv((char *)url,
url_to_charset(url, base, doc_charset));
}
#endif
char *
url_decode2(const char *url, const Buffer *buf)
{
wc_ces url_charset;
if (!DecodeURL)
return (char *)url;
url_charset = buf ?
url_to_charset(url, baseURL((Buffer *)buf), buf->document_charset) :
url_to_charset(url, NULL, 0);
return url_unquote_conv((char *)url, url_charset);
}
#else /* !defined(USE_M17N) */
char *
url_decode0(const char *url)
{
if (!DecodeURL)
return (char *)url;
return url_unquote_conv((char *)url, 0);
}
#endif /* !defined(USE_M17N) */