1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

SMJS: Give user scripts access to the view_state

Introduce the view_state object to ECMAScript with properties .uri and
.plain and pass the current view_state to preformat hooks.
This commit is contained in:
Miciah Dashiel Butler Masters 2006-01-28 03:23:17 +00:00 committed by Jonas Fonseca
parent b69e0d4eb2
commit b9d5bcee1c
6 changed files with 137 additions and 9 deletions

View File

@ -1,7 +1,7 @@
/* Play videos at video.google.com with minimal niggling. Just follow the link /* Play videos at video.google.com with minimal niggling. Just follow the link
* from the front page or the search page, and the video will automatically * from the front page or the search page, and the video will automatically
* be loaded. */ * be loaded. */
function load_google_video(cached) { function load_google_video(cached, vs) {
if (!cached.uri.match(/^http:\/\/video.google.com\/videoplay/)) if (!cached.uri.match(/^http:\/\/video.google.com\/videoplay/))
return true; return true;

View File

@ -8,9 +8,9 @@ elinks.keymaps.main["@"] = function () {
}; };
elinks.preformat_html_hooks = new Array(); elinks.preformat_html_hooks = new Array();
elinks.preformat_html = function (cached) { elinks.preformat_html = function (cached, vs) {
for (var i in elinks.preformat_html_hooks) for (var i in elinks.preformat_html_hooks)
if (!elinks.preformat_html_hooks[i](cached)) if (!elinks.preformat_html_hooks[i](cached, vs))
return false; return false;
return true; return true;
@ -36,13 +36,13 @@ elinks.follow_url_hook = function (url) {
return url; return url;
}; };
function root_w00t(cached) { function root_w00t(cached, vs) {
cached.content = cached.content.replace(/root/g, "w00t"); cached.content = cached.content.replace(/root/g, "w00t");
return true; return true;
}; };
elinks.preformat_html_hooks.push(root_w00t); elinks.preformat_html_hooks.push(root_w00t);
function mangle_deb_bugnumbers(cached) { function mangle_deb_bugnumbers(cached, vs) {
if (!cached.uri.match(/^[a-z0-9]+:\/\/[a-z0-9A-Z.-]+debian\.org/) if (!cached.uri.match(/^[a-z0-9]+:\/\/[a-z0-9A-Z.-]+debian\.org/)
&& !cached.uri.match(/changelog\.Debian/)) && !cached.uri.match(/changelog\.Debian/))
return true; return true;

View File

@ -4,6 +4,6 @@ include $(top_builddir)/Makefile.config
INCLUDES += $(SPIDERMONKEY_CFLAGS) INCLUDES += $(SPIDERMONKEY_CFLAGS)
OBJS = smjs.o core.o global_object.o hooks.o elinks_object.o cache_object.o \ OBJS = smjs.o core.o global_object.o hooks.o elinks_object.o cache_object.o \
bookmarks.o keybinding.o view_state_object.o bookmarks.o keybinding.o
include $(top_srcdir)/Makefile.lib include $(top_srcdir)/Makefile.lib

View File

@ -12,10 +12,13 @@
#include "main/event.h" #include "main/event.h"
#include "main/module.h" #include "main/module.h"
#include "scripting/smjs/cache_object.h" #include "scripting/smjs/cache_object.h"
#include "scripting/smjs/view_state_object.h"
#include "scripting/smjs/core.h" #include "scripting/smjs/core.h"
#include "scripting/smjs/elinks_object.h" #include "scripting/smjs/elinks_object.h"
#include "scripting/smjs/hooks.h" #include "scripting/smjs/hooks.h"
#include "session/location.h"
#include "session/session.h" #include "session/session.h"
#include "viewer/text/vs.h"
static enum evhook_status static enum evhook_status
@ -88,8 +91,8 @@ script_hook_pre_format_html(va_list ap, void *data)
struct session *ses = va_arg(ap, struct session *); struct session *ses = va_arg(ap, struct session *);
struct cache_entry *cached = va_arg(ap, struct cache_entry *); struct cache_entry *cached = va_arg(ap, struct cache_entry *);
enum evhook_status ret = EVENT_HOOK_STATUS_NEXT; enum evhook_status ret = EVENT_HOOK_STATUS_NEXT;
JSObject *cache_entry_object; JSObject *cache_entry_object, *view_state_object = JSVAL_NULL;
jsval args[1], rval; jsval args[2], rval;
evhook_use_params(ses && cached); evhook_use_params(ses && cached);
@ -97,13 +100,20 @@ script_hook_pre_format_html(va_list ap, void *data)
smjs_ses = ses; smjs_ses = ses;
if (have_location(ses)) {
struct view_state *vs = &cur_loc(ses)->vs;
view_state_object = smjs_get_view_state_object(vs);
}
cache_entry_object = smjs_get_cache_entry_object(cached); cache_entry_object = smjs_get_cache_entry_object(cached);
if (!cache_entry_object) goto end; if (!cache_entry_object) goto end;
args[0] = OBJECT_TO_JSVAL(cache_entry_object); args[0] = OBJECT_TO_JSVAL(cache_entry_object);
args[1] = OBJECT_TO_JSVAL(view_state_object);
if (JS_TRUE == smjs_invoke_elinks_object_method("preformat_html", if (JS_TRUE == smjs_invoke_elinks_object_method("preformat_html",
args, 1, &rval)) args, 2, &rval))
if (JS_FALSE == JSVAL_TO_BOOLEAN(rval)) if (JS_FALSE == JSVAL_TO_BOOLEAN(rval))
ret = EVENT_HOOK_STATUS_LAST; ret = EVENT_HOOK_STATUS_LAST;

View File

@ -0,0 +1,109 @@
/* Exports struct view_state to the world of ECMAScript */
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <stdlib.h>
#include "elinks.h"
#include "ecmascript/spidermonkey/util.h"
#include "protocol/uri.h"
#include "scripting/smjs/view_state_object.h"
#include "scripting/smjs/core.h"
#include "util/error.h"
#include "util/memory.h"
#include "viewer/text/vs.h"
enum view_state_prop {
VIEW_STATE_PLAIN,
VIEW_STATE_URI,
};
static const JSPropertySpec view_state_props[] = {
{ "plain", VIEW_STATE_PLAIN, JSPROP_ENUMERATE },
{ "uri", VIEW_STATE_URI, JSPROP_ENUMERATE | JSPROP_READONLY },
{ NULL }
};
static JSBool
view_state_get_property(JSContext *ctx, JSObject *obj, jsval id, jsval *vp)
{
struct view_state *vs = JS_GetPrivate(ctx, obj);
undef_to_jsval(ctx, vp);
if (!JSVAL_IS_INT(id))
return JS_FALSE;
switch (JSVAL_TO_INT(id)) {
case VIEW_STATE_PLAIN:
*vp = INT_TO_JSVAL(vs->plain);
return JS_TRUE;
case VIEW_STATE_URI:
*vp = STRING_TO_JSVAL(JS_NewStringCopyZ(smjs_ctx,
struri(vs->uri)));
return JS_TRUE;
default:
INTERNAL("Invalid ID %d in view_state_get_property().",
JSVAL_TO_INT(id));
}
return JS_FALSE;
}
static JSBool
view_state_set_property(JSContext *ctx, JSObject *obj, jsval id, jsval *vp)
{
struct view_state *vs = JS_GetPrivate(ctx, obj);
if (!JSVAL_IS_INT(id))
return JS_FALSE;
switch (JSVAL_TO_INT(id)) {
case VIEW_STATE_PLAIN: {
vs->plain = atol(jsval_to_string(ctx, vp));
return JS_TRUE;
}
default:
INTERNAL("Invalid ID %d in view_state_set_property().",
JSVAL_TO_INT(id));
}
return JS_FALSE;
}
static const JSClass view_state_class = {
"view_state",
JSCLASS_HAS_PRIVATE,
JS_PropertyStub, JS_PropertyStub,
view_state_get_property, view_state_set_property,
JS_EnumerateStub, JS_ResolveStub, JS_ConvertStub, JS_FinalizeStub
};
JSObject *
smjs_get_view_state_object(struct view_state *vs)
{
JSObject *view_state_object;
assert(smjs_ctx);
view_state_object = JS_NewObject(smjs_ctx,
(JSClass *) &view_state_class,
NULL, NULL);
if (!view_state_object) return NULL;
if (JS_FALSE == JS_SetPrivate(smjs_ctx, view_state_object, vs))
return NULL;
if (JS_FALSE == JS_DefineProperties(smjs_ctx, view_state_object,
(JSPropertySpec *) view_state_props))
return NULL;
return view_state_object;
}

View File

@ -0,0 +1,9 @@
#ifndef EL__SCRIPTING_SMJS_VIEW_STATE_OBJECT_H
#define EL__SCRIPTING_SMJS_VIEW_STATE_OBJECT_H
struct view_state;
JSObject *smjs_get_view_state_object(struct view_state *vs);
#endif