1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00
This commit is contained in:
Kalle Olavi Niemitalo 2006-02-10 09:15:12 +02:00 committed by Kalle Olavi Niemitalo
commit 0066214b47
24 changed files with 358 additions and 327 deletions

View File

@ -7,10 +7,12 @@ AC_DEFUN([AM_ICONV],
dnl Some systems have iconv in libc, some have it in libiconv (OSF/1 and dnl Some systems have iconv in libc, some have it in libiconv (OSF/1 and
dnl those with the standalone portable GNU libiconv installed). dnl those with the standalone portable GNU libiconv installed).
EL_SAVE_FLAGS
AC_ARG_WITH([libiconv], AC_ARG_WITH([libiconv],
[ --with-libiconv=DIR search for libiconv in DIR/include and DIR/lib], [ [ --with-libiconv=DIR search for libiconv in DIR/include and DIR/lib], [
for dir in `echo "$withval" | tr : ' '`; do for dir in `echo "$withval" | tr : ' '`; do
if test -d $dir/include; then CPPFLAGS="$CPPFLAGS -I$dir/include"; fi if test -d $dir/include; then CFLAGS="$CFLAGS -I$dir/include"; fi
if test -d $dir/lib; then LDFLAGS="$LDFLAGS -L$dir/lib"; fi if test -d $dir/lib; then LDFLAGS="$LDFLAGS -L$dir/lib"; fi
done done
]) ])
@ -64,5 +66,7 @@ size_t iconv();
LIBICONV= LIBICONV=
if test "$am_cv_lib_iconv" = yes; then if test "$am_cv_lib_iconv" = yes; then
LIBICONV="-liconv" LIBICONV="-liconv"
else
EL_RESTORE_FLAGS
fi fi
]) ])

View File

@ -99,23 +99,9 @@ AC_SUBST(CONFIG_POD2HTML)
AC_SUBST(CONFIG_XMLTO) AC_SUBST(CONFIG_XMLTO)
AC_SUBST(CONFIG_JW) AC_SUBST(CONFIG_JW)
EL_CONFIG_DEPENDS(CONFIG_DOC, [CONFIG_ASCIIDOC CONFIG_XMLTO CONFIG_JW CONFIG_POD2HTML], [Documentation]) EL_CONFIG_DEPENDS(CONFIG_DOC, [CONFIG_ASCIIDOC CONFIG_XMLTO CONFIG_JW CONFIG_POD2HTML], [Documentation Tools])
EL_CONFIG_DEPENDS(CONFIG_MANUAL, [MANUAL_ASCIIDOC MANUAL_XMLTO MANUAL_JW], [Manual Formats])
if test "$CONFIG_ASCIIDOC" = yes && EL_CONFIG_DEPENDS(CONFIG_MANPAGE, [MAN_ASCIIDOC MAN_XMLTO], [Man Page Formats])
test "$CONFIG_XMLTO" = yes &&
test "$CONFIG_JW" = yes; then
EL_CONFIG_DEPENDS(CONFIG_MANUAL, [MANUAL_ASCIIDOC MANUAL_XMLTO MANUAL_JW], [Manual Formats])
fi
if test "$CONFIG_ASCIIDOC" = yes &&
test "$CONFIG_XMLTO" = yes; then
EL_CONFIG_DEPENDS(CONFIG_MANUAL, [MAN_ASCIIDOC MAN_XMLTO], [Man Page Formats])
fi
AC_SUBST(CONFIG_ASCIIDOC)
AC_SUBST(CONFIG_POD2HTML)
AC_SUBST(CONFIG_XMLTO)
AC_SUBST(CONFIG_JW)
dnl gcc specific options (to be continued at the bottom of configure) dnl gcc specific options (to be continued at the bottom of configure)
if test "x$ac_cv_prog_gcc" = "xyes"; then if test "x$ac_cv_prog_gcc" = "xyes"; then

View File

@ -36,6 +36,9 @@ def pre_format_html_hook(url, html):
if re.search("cygwin\.com", url): if re.search("cygwin\.com", url):
html2 = re.sub("<body bgcolor=\"#000000\" color=\"#000000\"", "<body bgcolor=\"#ffffff\" color=\"#000000\"", html) html2 = re.sub("<body bgcolor=\"#000000\" color=\"#000000\"", "<body bgcolor=\"#ffffff\" color=\"#000000\"", html)
return html2 return html2
if re.search("https://www.mbank.com.pl/ib_navibar_3.asp", url):
html2 = re.sub("<td valign=\"top\"><img", "<tr><td valign=\"top\"><img", html)
return html2
return None return None
def proxy_for_hook(url): def proxy_for_hook(url):

454
po/fr.po

File diff suppressed because it is too large Load Diff

View File

@ -724,7 +724,16 @@ static struct option_info config_options_info[] = {
INIT_OPT_TREE("document", N_("URI passing"), INIT_OPT_TREE("document", N_("URI passing"),
"uri_passing", OPT_SORT | OPT_AUTOCREATE, "uri_passing", OPT_SORT | OPT_AUTOCREATE,
N_("Rules for passing URIs to external commands.")), N_("Rules for passing URIs to external commands. When one rule\n"
"is defined the link and tab menu will have a menu item that\n"
"makes it possible to pass the the link, frame or tab URI to\n"
"an external command. If several rules are defined the link and\n"
"tab menu will have a submenu of items for each rule. Note, this\n"
"is mostly useful for launching graphical viewers, since there\n"
"is not support for releasing the terminal while the command runs.\n"
"The action and submenus are also available by binding keys to\n"
"the frame-external-command, the link-external-command, and\n"
"the tab-external-command actions.")),
INIT_OPT_STRING("document.uri_passing", NULL, INIT_OPT_STRING("document.uri_passing", NULL,
"_template_", 0, "", "_template_", 0, "",

View File

@ -859,7 +859,17 @@ form_put(struct SEE_interpreter *interp, struct SEE_object *o,
return; return;
if (p == s_action) { if (p == s_action) {
mem_free_set(&form->action, string); if (form->action) {
struct uri *uri = get_uri(form->action, URI_HTTP_REFERRER_HOST);
if (uri) {
mem_free_set(&form->action, join_urls(uri, string));
mem_free(string);
done_uri(uri);
}
} else {
mem_free_set(&form->action, string);
}
} else if (p == s_encoding) { } else if (p == s_encoding) {
if (!strcasecmp(string, "application/x-www-form-urlencoded")) { if (!strcasecmp(string, "application/x-www-form-urlencoded")) {
form->method = form->method == FORM_METHOD_GET ? FORM_METHOD_GET form->method = form->method == FORM_METHOD_GET ? FORM_METHOD_GET

View File

@ -735,6 +735,15 @@ form_set_property(JSContext *ctx, JSObject *obj, jsval id, jsval *vp)
switch (JSVAL_TO_INT(id)) { switch (JSVAL_TO_INT(id)) {
case JSP_FORM_ACTION: case JSP_FORM_ACTION:
if (form->action) {
struct uri *uri = get_uri(form->action, URI_HTTP_REFERRER_HOST);
if (uri) {
mem_free_set(&form->action, join_urls(uri, jsval_to_string(ctx, vp)));
done_uri(uri);
break;
}
}
mem_free_set(&form->action, stracpy(jsval_to_string(ctx, vp))); mem_free_set(&form->action, stracpy(jsval_to_string(ctx, vp)));
break; break;

View File

@ -724,6 +724,9 @@ abort_connection(struct connection *conn, enum connection_state state)
assertm(is_in_result_state(state), assertm(is_in_result_state(state),
"connection didn't end in result state (%d)", state); "connection didn't end in result state (%d)", state);
if (state == S_OK && conn->cached)
normalize_cache_entry(conn->cached, conn->from);
set_connection_state(conn, state); set_connection_state(conn, state);
if (conn->running) interrupt_connection(conn); if (conn->running) interrupt_connection(conn);
@ -1021,7 +1024,7 @@ void
move_download(struct download *old, struct download *new, move_download(struct download *old, struct download *new,
enum connection_priority newpri) enum connection_priority newpri)
{ {
struct connection *conn = old->conn; struct connection *conn;
assert(old); assert(old);
@ -1029,7 +1032,9 @@ move_download(struct download *old, struct download *new,
* example the file protocol loads it's object immediately. This is * example the file protocol loads it's object immediately. This is
* catched by the result state check below. */ * catched by the result state check below. */
new->conn = old->conn; conn = old->conn;
new->conn = conn;
new->cached = old->cached; new->cached = old->cached;
new->prev_error = old->prev_error; new->prev_error = old->prev_error;
new->progress = old->progress; new->progress = old->progress;
@ -1037,8 +1042,13 @@ move_download(struct download *old, struct download *new,
new->pri = newpri; new->pri = newpri;
if (is_in_result_state(old->state)) { if (is_in_result_state(old->state)) {
if (new->callback) /* Ensure that new->conn is always "valid", that is NULL if the
* connection has been detached and non-NULL otherwise. */
if (new->callback) {
new->conn = NULL;
new->progress = NULL;
new->callback(new, new->data); new->callback(new, new->data);
}
return; return;
} }

View File

@ -114,8 +114,6 @@ about_protocol_handler(struct connection *conn)
} }
#endif #endif
normalize_cache_entry(cached, len);
/* Set content to known type */ /* Set content to known type */
mem_free_set(&cached->content_type, stracpy("text/html")); mem_free_set(&cached->content_type, stracpy("text/html"));
} }

View File

@ -157,7 +157,6 @@ data_protocol_handler(struct connection *conn)
int datalen = strlen(data); int datalen = strlen(data);
add_fragment(cached, conn->from, data, datalen); add_fragment(cached, conn->from, data, datalen);
normalize_cache_entry(cached, datalen);
} }
mem_free(data); mem_free(data);

View File

@ -279,6 +279,7 @@ file_protocol_handler(struct connection *connection)
} else { } else {
add_fragment(cached, 0, page.source, page.length); add_fragment(cached, 0, page.source, page.length);
connection->from += page.length;
if (!cached->content_type) { if (!cached->content_type) {
unsigned char *ctype = null_or_stracpy(type); unsigned char *ctype = null_or_stracpy(type);
@ -287,15 +288,10 @@ file_protocol_handler(struct connection *connection)
* allocation. */ * allocation. */
if (type && !ctype) if (type && !ctype)
state = S_OUT_OF_MEM; state = S_OUT_OF_MEM;
else
normalize_cache_entry(cached, page.length);
/* Setup file read or directory listing for /* Setup file read or directory listing for
* viewing. */ * viewing. */
mem_free_set(&cached->content_type, ctype); mem_free_set(&cached->content_type, ctype);
} else {
normalize_cache_entry(cached, page.length);
} }
done_string(&page); done_string(&page);

View File

@ -27,15 +27,6 @@ struct module finger_protocol_module = struct_module(
/* done: */ NULL /* done: */ NULL
); );
static void
finger_end_request(struct connection *conn, enum connection_state state)
{
if (state == S_OK && conn->cached)
normalize_cache_entry(conn->cached, conn->from);
abort_connection(conn, state);
}
static void static void
finger_get_response(struct socket *socket, struct read_buffer *rb) finger_get_response(struct socket *socket, struct read_buffer *rb)
{ {
@ -50,7 +41,7 @@ finger_get_response(struct socket *socket, struct read_buffer *rb)
conn->cached = cached; conn->cached = cached;
if (socket->state == SOCKET_CLOSED) { if (socket->state == SOCKET_CLOSED) {
finger_end_request(conn, S_OK); abort_connection(conn, S_OK);
return; return;
} }

View File

@ -232,8 +232,6 @@ fsp_got_data(struct socket *socket, struct read_buffer *rb)
} }
if (!len) { if (!len) {
if (conn->from)
normalize_cache_entry(conn->cached, conn->from);
abort_connection(conn, S_OK); abort_connection(conn, S_OK);
return; return;
} }

View File

@ -1347,11 +1347,10 @@ out_of_mem:
static void static void
ftp_end_request(struct connection *conn, enum connection_state state) ftp_end_request(struct connection *conn, enum connection_state state)
{ {
set_connection_state(conn, state); if (state == S_OK && conn->cached) {
if (conn->state == S_OK && conn->cached) {
normalize_cache_entry(conn->cached, conn->from); normalize_cache_entry(conn->cached, conn->from);
} }
set_connection_state(conn, state);
add_keepalive_connection(conn, FTP_KEEPALIVE_TIMEOUT, NULL); add_keepalive_connection(conn, FTP_KEEPALIVE_TIMEOUT, NULL);
} }

View File

@ -329,30 +329,6 @@ init_gopher_connection_info(struct connection *conn)
} }
static void
end_gopher_connection(struct connection *conn, enum connection_state state)
{
if (state == S_OK && conn->cached) {
#if 0
/* Seeing dots at all files .. trying to remove the end-marker
* ".\r\n" */
struct gopher_connection_info *gopher = conn->info;
if (gopher
&& gopher->entity
&& gopher->entity->type != GOPHER_DIRECTORY
&& gopher->entity->type != GOPHER_INDEX
&& gopher->entity->type != GOPHER_CSO) {
conn->from -= 3;
}
#endif
normalize_cache_entry(conn->cached, conn->from);
}
abort_connection(conn, state);
}
/* Add a link. The title of the destination is set, as there is no way of /* Add a link. The title of the destination is set, as there is no way of
* knowing what the title is when we arrive. * knowing what the title is when we arrive.
* *
@ -713,7 +689,7 @@ read_gopher_response_data(struct socket *socket, struct read_buffer *rb)
assert(gopher && gopher->entity); assert(gopher && gopher->entity);
if (!conn->cached && !init_gopher_cache_entry(conn)) { if (!conn->cached && !init_gopher_cache_entry(conn)) {
end_gopher_connection(conn, S_OUT_OF_MEM); abort_connection(conn, S_OUT_OF_MEM);
return; return;
} }
@ -763,7 +739,7 @@ read_gopher_response_data(struct socket *socket, struct read_buffer *rb)
} }
if (state != S_TRANS) { if (state != S_TRANS) {
end_gopher_connection(conn, state); abort_connection(conn, state);
return; return;
} }
@ -797,7 +773,7 @@ gopher_protocol_handler(struct connection *conn)
* - FM */ * - FM */
if (uri->datalen == 1 && *uri->data == GOPHER_CSO) { if (uri->datalen == 1 && *uri->data == GOPHER_CSO) {
/* FIXME: redirect_cache() */ /* FIXME: redirect_cache() */
end_gopher_connection(conn, S_GOPHER_CSO_ERROR); abort_connection(conn, S_GOPHER_CSO_ERROR);
} }
break; break;
@ -810,7 +786,7 @@ gopher_protocol_handler(struct connection *conn)
* - FM */ * - FM */
if (uri->datalen >= 1 && *uri->data == GOPHER_FILE) { if (uri->datalen >= 1 && *uri->data == GOPHER_FILE) {
/* FIXME: redirect_cache() */ /* FIXME: redirect_cache() */
end_gopher_connection(conn, S_OK); abort_connection(conn, S_OK);
} }
#endif #endif
break; break;
@ -819,7 +795,7 @@ gopher_protocol_handler(struct connection *conn)
state = init_gopher_connection_info(conn); state = init_gopher_connection_info(conn);
if (state != S_CONN) { if (state != S_CONN) {
/* FIXME: Handle bad selector ... */ /* FIXME: Handle bad selector ... */
end_gopher_connection(conn, state); abort_connection(conn, state);
return; return;
} }

View File

@ -470,14 +470,12 @@ http_end_request(struct connection *conn, enum connection_state state,
{ {
shutdown_connection_stream(conn); shutdown_connection_stream(conn);
if (state == S_OK && conn->cached) {
normalize_cache_entry(conn->cached, !notrunc ? conn->from : -1);
}
if (conn->info && !((struct http_connection_info *) conn->info)->close if (conn->info && !((struct http_connection_info *) conn->info)->close
&& (!conn->socket->ssl) /* We won't keep alive ssl connections */ && (!conn->socket->ssl) /* We won't keep alive ssl connections */
&& (!get_opt_bool("protocol.http.bugs.post_no_keepalive") && (!get_opt_bool("protocol.http.bugs.post_no_keepalive")
|| !conn->uri->post)) { || !conn->uri->post)) {
if (state == S_OK && conn->cached)
normalize_cache_entry(conn->cached, !notrunc ? conn->from : -1);
set_connection_state(conn, state); set_connection_state(conn, state);
add_keepalive_connection(conn, HTTP_KEEPALIVE_TIMEOUT, NULL); add_keepalive_connection(conn, HTTP_KEEPALIVE_TIMEOUT, NULL);
} else { } else {

View File

@ -217,17 +217,16 @@ nntp_end_request(struct connection *conn, enum connection_state state)
return; return;
} }
set_connection_state(conn, state); if (state == S_OK) {
if (conn->state == S_OK) {
if (conn->cached) { if (conn->cached) {
normalize_cache_entry(conn->cached, conn->from); normalize_cache_entry(conn->cached, conn->from);
} }
} else if (conn->state == S_OUT_OF_MEM) { } else if (state == S_OUT_OF_MEM) {
/* FIXME: Clear the socket buffers before ending so the one /* FIXME: Clear the socket buffers before ending so the one
* grabing the keepalive connection will be able to go on. */ * grabing the keepalive connection will be able to go on. */
} }
set_connection_state(conn, state);
add_keepalive_connection(conn, NNTP_KEEPALIVE_TIMEOUT, nntp_quit); add_keepalive_connection(conn, NNTP_KEEPALIVE_TIMEOUT, nntp_quit);
} }

View File

@ -475,10 +475,8 @@ end_smb_connection(struct connection *conn)
if (smb_get_cache(conn)) return; if (smb_get_cache(conn)) return;
if (conn->from) { if (conn->from)
normalize_cache_entry(conn->cached, conn->from);
goto bye; goto bye;
}
/* Ensure termination by LF + NUL chars, memory for this /* Ensure termination by LF + NUL chars, memory for this
* was reserved by smb_read_text(). */ * was reserved by smb_read_text(). */
@ -507,7 +505,6 @@ end_smb_connection(struct connection *conn)
add_fragment(conn->cached, 0, page.source, page.length); add_fragment(conn->cached, 0, page.source, page.length);
conn->from += page.length; conn->from += page.length;
normalize_cache_entry(conn->cached, page.length);
done_string(&page); done_string(&page);
mem_free_set(&conn->cached->content_type, stracpy("text/html")); mem_free_set(&conn->cached->content_type, stracpy("text/html"));

View File

@ -460,6 +460,8 @@ struct string *
add_uri_to_string(struct string *string, struct uri *uri, add_uri_to_string(struct string *string, struct uri *uri,
enum uri_component components) enum uri_component components)
{ {
int add_host = 0;
/* Custom or unknown keep the URI untouched. */ /* Custom or unknown keep the URI untouched. */
if (uri->protocol == PROTOCOL_UNKNOWN) if (uri->protocol == PROTOCOL_UNKNOWN)
return add_to_string(string, struri(uri)); return add_to_string(string, struri(uri));
@ -486,7 +488,7 @@ add_uri_to_string(struct string *string, struct uri *uri,
} }
if (wants(URI_HOST) && uri->hostlen) { if (wants(URI_HOST) && uri->hostlen) {
int add_host = 1; add_host = 1;
#ifdef CONFIG_IPV6 #ifdef CONFIG_IPV6
/* Rationale for wants(URI_PORT): The [notation] was invented /* Rationale for wants(URI_PORT): The [notation] was invented
@ -550,7 +552,7 @@ add_uri_to_string(struct string *string, struct uri *uri,
} }
/* Only add slash if we need to separate */ /* Only add slash if we need to separate */
if ((wants(URI_DATA) || wants(URI_POST)) if ((wants(URI_DATA) || wants(URI_POST) || add_host)
&& wants(~(URI_DATA | URI_PORT)) && wants(~(URI_DATA | URI_PORT))
&& get_protocol_need_slash_after_host(uri->protocol)) && get_protocol_need_slash_after_host(uri->protocol))
add_char_to_string(string, '/'); add_char_to_string(string, '/');

View File

@ -968,10 +968,7 @@ tp_display(struct type_query *type_query)
new->callback = (download_callback_T *) doc_loading_callback; new->callback = (download_callback_T *) doc_loading_callback;
new->data = ses; new->data = ses;
if (is_in_progress_state(old->state)) move_download(old, new, PRI_MAIN);
move_download(old, new, PRI_MAIN);
else
new->state = old->state;
} }
display_timer(ses); display_timer(ses);

View File

@ -604,11 +604,19 @@ doc_loading_callback(struct download *download, struct session *ses)
print_screen_status(ses); print_screen_status(ses);
#ifdef CONFIG_GLOBHIST #ifdef CONFIG_GLOBHIST
if (download->conn && download->pri != PRI_CSS) { if (download->pri != PRI_CSS) {
unsigned char *title = ses->doc_view->document->title; unsigned char *title = ses->doc_view->document->title;
struct uri *uri = download->conn->proxied_uri; struct uri *uri;
add_global_history_item(struri(uri), title, time(NULL)); if (download->conn)
uri = download->conn->proxied_uri;
else if (download->cached)
uri = download->cached->uri;
else
uri = NULL;
if (uri)
add_global_history_item(struri(uri), title, time(NULL));
} }
#endif #endif

View File

@ -373,5 +373,4 @@ refresh_view(struct session *ses, struct document_view *doc_view, int frames)
draw_doc(ses, doc_view, 1); draw_doc(ses, doc_view, 1);
if (frames) draw_frames(ses); if (frames) draw_frames(ses);
print_screen_status(ses); print_screen_status(ses);
redraw_from_window(ses->tab);
} }

View File

@ -982,8 +982,6 @@ get_form_uri(struct session *ses, struct document_view *doc_view,
if (fc->type == FC_RESET) { if (fc->type == FC_RESET) {
do_reset_form(doc_view, form); do_reset_form(doc_view, form);
return NULL; return NULL;
} else if (fc->type == FC_BUTTON) {
return NULL;
} }
if (!form->action if (!form->action

View File

@ -860,18 +860,28 @@ get_link_uri(struct session *ses, struct document_view *doc_view,
} }
} }
static void static int
try_submit_given_form(struct session *ses, struct document_view *doc_view, call_onsubmit_and_submit(struct session *ses, struct document_view *doc_view,
struct form *form, int do_reload) struct form_control *fc, int do_reload)
{ {
struct uri *uri = NULL;
enum cache_mode mode = do_reload ? CACHE_MODE_FORCE_RELOAD : CACHE_MODE_NORMAL;
assert(fc->form); /* regardless of whether there is a FORM element */
if_assert_failed return 0;
#ifdef CONFIG_ECMASCRIPT #ifdef CONFIG_ECMASCRIPT
if (form->onsubmit) { /* If the form has multiple submit buttons, this does not
* explicitly tell the ECMAScript code which of them was
* pressed. W3C DOM Level 3 doesn't seem to include such a
* feature. */
if (fc->form->onsubmit) {
struct string code; struct string code;
if (init_string(&code)) { if (init_string(&code)) {
struct view_state *vs = doc_view->vs; struct view_state *vs = doc_view->vs;
struct ecmascript_interpreter *interpreter; struct ecmascript_interpreter *interpreter;
unsigned char *ret = form->onsubmit; unsigned char *ret = fc->form->onsubmit;
int res; int res;
if (vs->ecmascript_fragile) if (vs->ecmascript_fragile)
@ -883,14 +893,24 @@ try_submit_given_form(struct session *ses, struct document_view *doc_view,
while ((ret = strstr(ret, "return "))) while ((ret = strstr(ret, "return ")))
while (*ret != ' ') *ret++ = ' '; while (*ret != ' ') *ret++ = ' ';
add_to_string(&code, form->onsubmit); add_to_string(&code, fc->form->onsubmit);
res = ecmascript_eval_boolback(interpreter, &code); res = ecmascript_eval_boolback(interpreter, &code);
done_string(&code); done_string(&code);
if (!res) return; /* If the user presses Enter in a text field,
* and document.browse.forms.auto_submit is
* true, and the form has an onsubmit script
* that returns false, then insert mode should
* end, so return 1 here rather than 0. */
if (!res) return 1;
} }
} }
#endif #endif /* CONFIG_ECMASCRIPT */
submit_given_form(ses, doc_view, form, do_reload);
uri = get_form_uri(ses, doc_view, fc);
if (!uri) return 0;
goto_uri_frame(ses, uri, fc->form->target, mode);
done_uri(uri);
return 1;
} }
struct link * struct link *
@ -907,10 +927,11 @@ goto_current_link(struct session *ses, struct document_view *doc_view, int do_re
if (link_is_form(link)) { if (link_is_form(link)) {
struct form_control *fc = link->data.form_control; struct form_control *fc = link->data.form_control;
struct form *form = fc->form;
try_submit_given_form(ses, doc_view, form, do_reload); if (!call_onsubmit_and_submit(ses, doc_view, fc, do_reload))
return link; return NULL;
else
return link;
} else } else
uri = get_link_uri(ses, doc_view, link); uri = get_link_uri(ses, doc_view, link);