mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
Merge with git+ssh://pasky.or.cz/srv/git/elinks.git
This commit is contained in:
commit
c87186e156
@ -74,7 +74,7 @@ function block_pr0n(uri) {
|
|||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return uri;
|
||||||
}
|
}
|
||||||
elinks.follow_url_hooks.push(block_pr0n);
|
elinks.follow_url_hooks.push(block_pr0n);
|
||||||
|
|
||||||
|
30
contrib/smjs/pornotube.js
Normal file
30
contrib/smjs/pornotube.js
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
/* Play videos at pornotube.com with minimal niggling. Just follow the link
|
||||||
|
* from the front page or the search page, and the video will automatically
|
||||||
|
* be loaded. */
|
||||||
|
|
||||||
|
function pornotube_callback(cached) {
|
||||||
|
var user_re = /\<user_id\>(\d+)\<\/user_id\>/;
|
||||||
|
var media_re = /\<media_id\>(\d+)\<\/media_id\>/;
|
||||||
|
|
||||||
|
var user = cached.content.match(user_re)[1];
|
||||||
|
var media = cached.content.match(media_re)[1];
|
||||||
|
|
||||||
|
var uri = "http://video.pornotube.com/" + user + "/" + media + ".flv";
|
||||||
|
|
||||||
|
elinks.location = uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
function load_pornotube(cached, vs) {
|
||||||
|
if (!cached.uri.match(/^http:\/\/(?:www\.)?pornotube\.com\/media\.php/))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
var re = /SWFObject\("player\/v\.swf\?v=(.*?)"/;
|
||||||
|
var hash = cached.content.match(re)[1];
|
||||||
|
|
||||||
|
var uri = "http://www.pornotube.com/player/player.php?" + hash;
|
||||||
|
|
||||||
|
elinks.load_uri(uri, pornotube_callback);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
elinks.preformat_html_hooks.push(load_pornotube);
|
27
contrib/smjs/youtube.js
Normal file
27
contrib/smjs/youtube.js
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
/* Play videos at YouTube with minimal niggling. Just load the page for a video,
|
||||||
|
* and the video will automatically be loaded. */
|
||||||
|
function load_youtube(cached, vs) {
|
||||||
|
if (!cached.uri.match(/http:\/\/(?:www\.)?youtube\.com\/(?:watch(?:\.php)?)?\?v=(?:[^&]+).*/))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
var params_match = cached.content.match(/player2\.swf\?([^"]+)"/);
|
||||||
|
if (!params_match) return true;
|
||||||
|
|
||||||
|
var url = 'http://www.youtube.com/get_video?' + params_match[1];
|
||||||
|
var meta = '<meta http-equiv="refresh" content="1; url=' + url + '" />';
|
||||||
|
|
||||||
|
cached.content = cached.content.replace(/<head>/, "<head>" + meta);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
elinks.preformat_html_hooks.push(load_youtube);
|
||||||
|
|
||||||
|
/* When one tries to follow a link to <http://www.youtube.com/v/foo>,
|
||||||
|
* redirect to <http://www.youtube.com/watch?v=foo>, which has the information
|
||||||
|
* that is necessary to get the actual video file. */
|
||||||
|
function redirect_embedded_youtube(uri) {
|
||||||
|
var uri_match = uri.match(/http:\/\/(?:www\.)?youtube\.com\/v\/([^&]+).*/);
|
||||||
|
if (!uri_match) return true;
|
||||||
|
return 'http://www.youtube.com/watch?v=' + uri_match[1];
|
||||||
|
}
|
||||||
|
elinks.follow_url_hooks.push(redirect_embedded_youtube);
|
@ -474,7 +474,8 @@ check_dialog(struct dialog_data *dlg_data)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (widget_data->widget->handler &&
|
if (widget_data->widget->handler &&
|
||||||
widget_data->widget->handler(dlg_data, widget_data)) {
|
widget_data->widget->handler(dlg_data, widget_data)
|
||||||
|
== EVENT_NOT_PROCESSED) {
|
||||||
select_widget(dlg_data, widget_data);
|
select_widget(dlg_data, widget_data);
|
||||||
redraw_dialog(dlg_data, 0);
|
redraw_dialog(dlg_data, 0);
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -383,6 +383,7 @@ tree_dup(struct option *opt, struct option *template)
|
|||||||
struct option *new_opt = copy_option(option);
|
struct option *new_opt = copy_option(option);
|
||||||
|
|
||||||
if (!new_opt) continue;
|
if (!new_opt) continue;
|
||||||
|
object_nolock(new_opt, "option");
|
||||||
add_to_list_end(*new, new_opt);
|
add_to_list_end(*new, new_opt);
|
||||||
new_opt->root = opt;
|
new_opt->root = opt;
|
||||||
|
|
||||||
|
@ -285,7 +285,7 @@ shrink_format_cache(int whole)
|
|||||||
assertm(format_cache_entries >= 0, "format_cache_entries underflow on entry");
|
assertm(format_cache_entries >= 0, "format_cache_entries underflow on entry");
|
||||||
if_assert_failed format_cache_entries = 0;
|
if_assert_failed format_cache_entries = 0;
|
||||||
|
|
||||||
foreachback (document, format_cache) {
|
foreachbacksafe (document, next, format_cache) {
|
||||||
if (is_object_used(document)) continue;
|
if (is_object_used(document)) continue;
|
||||||
|
|
||||||
/* If we are not purging the whole format cache, stop
|
/* If we are not purging the whole format cache, stop
|
||||||
@ -293,10 +293,7 @@ shrink_format_cache(int whole)
|
|||||||
if (!whole && format_cache_entries <= format_cache_size)
|
if (!whole && format_cache_entries <= format_cache_size)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* Jump back to already processed entry (or list head), and let
|
done_document(document);
|
||||||
* the foreachback move it to the next entry to go. */
|
|
||||||
document = document->next;
|
|
||||||
done_document(document->prev);
|
|
||||||
format_cache_entries--;
|
format_cache_entries--;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -159,7 +159,7 @@ do_real_lookup(unsigned char *name, struct sockaddr_storage **addrs, int *addrno
|
|||||||
memset(&hint, 0, sizeof(hint));
|
memset(&hint, 0, sizeof(hint));
|
||||||
hint.ai_family = AF_UNSPEC;
|
hint.ai_family = AF_UNSPEC;
|
||||||
hint.ai_socktype = SOCK_STREAM;
|
hint.ai_socktype = SOCK_STREAM;
|
||||||
if (getaddrinfo(name, NULL, &hint, &ai) != 0) return -1;
|
if (getaddrinfo(name, NULL, &hint, &ai) != 0) return DNS_ERROR;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* Seems there are problems on Mac, so we first need to try
|
/* Seems there are problems on Mac, so we first need to try
|
||||||
@ -386,7 +386,7 @@ do_queued_lookup(struct dnsquery *query)
|
|||||||
assertm(!dns_queue->next_in_queue, "DNS queue corrupted");
|
assertm(!dns_queue->next_in_queue, "DNS queue corrupted");
|
||||||
dns_queue->next_in_queue = query;
|
dns_queue->next_in_queue = query;
|
||||||
dns_queue = query;
|
dns_queue = query;
|
||||||
return -1;
|
return DNS_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
dns_queue = query;
|
dns_queue = query;
|
||||||
@ -512,7 +512,7 @@ kill_dns_request(void **queryref)
|
|||||||
assert(query);
|
assert(query);
|
||||||
|
|
||||||
query->done = NULL;
|
query->done = NULL;
|
||||||
done_dns_lookup(query, -1);
|
done_dns_lookup(query, DNS_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -360,14 +360,16 @@ handle_interlink_event(struct terminal *term, struct interlink_event *ilev)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key < 0x80 || key > 0xFF || !utf8_io) {
|
/* Note: We know that key <= 0xFF. */
|
||||||
|
|
||||||
|
if (key < 0x80 || !utf8_io) {
|
||||||
/* This byte is not part of a multibyte character
|
/* This byte is not part of a multibyte character
|
||||||
* encoding: either it is outside of the ranges for
|
* encoding: either it is outside of the ranges for
|
||||||
* UTF-8 start and continuation bytes or UTF-8 I/O mode
|
* UTF-8 start and continuation bytes or UTF-8 I/O mode
|
||||||
* is disabled. */
|
* is disabled. */
|
||||||
|
|
||||||
#ifdef CONFIG_UTF8
|
#ifdef CONFIG_UTF8
|
||||||
if (key >= 0 && key <= 0xFF && !utf8_io) {
|
if (key >= 0 && !utf8_io) {
|
||||||
/* Not special and UTF-8 mode is disabled:
|
/* Not special and UTF-8 mode is disabled:
|
||||||
* recode from the terminal charset to UCS-4. */
|
* recode from the terminal charset to UCS-4. */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user