netsurf/javascript/jsapi/window.bnd

306 lines
6.5 KiB
Plaintext
Raw Normal View History

2012-11-26 02:04:01 +04:00
/* Binding to generate window interface
*
* Copyright 2012 Vincent Sanders <vince@netsurf-browser.org>
*
* This file is part of NetSurf, http://www.netsurf-browser.org/
*
* Released under the terms of the MIT License,
* http://www.opensource.org/licenses/mit-license
*/
2012-10-30 00:09:29 +04:00
webidlfile "html.idl";
webidlfile "dom.idl";
2012-10-30 00:09:29 +04:00
2012-11-26 02:04:01 +04:00
hdrcomment "Copyright 2012 Vincent Sanders <vince@netsurf-browser.org>";
hdrcomment "This file is part of NetSurf, http://www.netsurf-browser.org/";
hdrcomment "Released under the terms of the MIT License,";
hdrcomment " http://www.opensource.org/licenses/mit-license";
2012-10-30 00:09:29 +04:00
preamble %{
#include <dom/dom.h>
2012-10-30 00:09:29 +04:00
#include "utils/config.h"
#include "utils/log.h"
2012-11-28 22:07:36 +04:00
#include "utils/corestrings.h"
#include "render/html_internal.h"
2012-10-30 00:09:29 +04:00
#include "javascript/jsapi.h"
#include "console.h"
#include "navigator.h"
#include "event.h"
#include "node.h"
#include "htmlcollection.h"
#include "nodelist.h"
#include "htmldocument.h"
#include "text.h"
#include "comment.h"
#include "htmlelement.h"
#include "window.h"
#include "location.h"
2012-11-28 22:53:11 +04:00
struct browser_window *jsapi_get_browser_window(JSContext *cx);
%}
prologue %{
struct browser_window *jsapi_get_browser_window(JSContext *cx)
{
struct jsclass_private *private;
private = JS_GetInstancePrivate(cx,
JS_GetGlobalObject(cx),
&JSClass_Window,
NULL);
if (private != NULL) {
return private->bw;
}
return NULL;
}
2012-10-30 00:09:29 +04:00
%}
2012-11-02 03:30:28 +04:00
binding window {
type js_libdom; /* the binding type */
interface Window; /* Web IDL interface to generate */
private "struct browser_window *" bw;
private "struct html_content *" htmlc;
2012-11-19 21:23:24 +04:00
2012-11-02 03:30:28 +04:00
internal "JSObject *" document;
internal "JSObject *" navigator;
internal "JSObject *" console;
property unshared type EventHandler;
2012-11-02 03:30:28 +04:00
}
api mark %{
if (private != NULL) {
if (private->document != NULL) {
JSAPI_GCMARK(private->document);
}
if (private->navigator != NULL) {
JSAPI_GCMARK(private->navigator);
}
if (private->console != NULL) {
JSAPI_GCMARK(private->console);
}
}
%}
2012-11-03 17:52:13 +04:00
api global %{
%}
2012-10-30 00:09:29 +04:00
api init %{
JSObject *user_proto;
prototype = JS_NewCompartmentAndGlobalObject(cx, &JSClass_Window, NULL);
if (prototype == NULL) {
return NULL;
}
/** @todo reconsider global object handling. future
* editions of spidermonkey appear to be removing the
* idea of a global so we probably need to handle
* global object references internally
*/
/* set the contexts global */
JS_SetGlobalObject(cx, prototype);
/* Populate the global object with the standard globals, like
* Object and Array.
*/
if (!JS_InitStandardClasses(cx, prototype)) {
return NULL;
}
/* add functions to prototype */
if (!JS_DefineFunctions(cx, prototype, jsclass_functions)) {
return NULL;
}
/* add properties to prototype */
if (!JS_DefineProperties(cx, prototype, jsclass_properties))
return NULL;
/* Initialises all the user javascript classes to make their
* prototypes available.
2012-10-30 00:09:29 +04:00
*/
/** @todo should we be managing these prototype objects ourselves */
user_proto = jsapi_InitClass_Document(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
2012-10-31 05:22:35 +04:00
user_proto = jsapi_InitClass_Navigator(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
2012-10-31 18:31:18 +04:00
2012-11-02 03:30:28 +04:00
user_proto = jsapi_InitClass_Location(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
2012-10-31 18:31:18 +04:00
user_proto = jsapi_InitClass_Console(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
2012-11-02 01:13:14 +04:00
user_proto = jsapi_InitClass_HTMLElement(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
user_proto = jsapi_InitClass_HTMLCollection(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
user_proto = jsapi_InitClass_NodeList(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
2012-11-07 22:52:30 +04:00
user_proto = jsapi_InitClass_Text(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
user_proto = jsapi_InitClass_Comment(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
user_proto = jsapi_InitClass_Node(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
2012-11-28 22:07:36 +04:00
user_proto = jsapi_InitClass_Event(cx, prototype);
if (user_proto == NULL) {
return NULL;
}
2012-10-30 00:09:29 +04:00
%}
api new %{
/* @todo sort out windows that are not globals */
assert(parent == NULL);
/* the window object is the global so its prototype *is* the instance */
newobject = prototype;
2012-10-30 00:09:29 +04:00
/* instantiate the subclasses off the window global */
private->document = jsapi_new_Document(cx,
NULL,
newobject,
(dom_document *)dom_node_ref(htmlc->document),
htmlc);
if (private->document == NULL) {
2012-10-30 00:09:29 +04:00
free(private);
return NULL;
}
2012-10-31 05:22:35 +04:00
private->navigator = jsapi_new_Navigator(cx, NULL, newobject);
if (private->navigator == NULL) {
2012-10-30 00:09:29 +04:00
free(private);
return NULL;
}
2012-10-31 05:22:35 +04:00
2012-10-31 18:31:18 +04:00
private->console = jsapi_new_Console(cx, NULL, newobject);
2012-10-30 00:09:29 +04:00
if (private->console == NULL) {
free(private);
return NULL;
}
2012-11-02 03:30:28 +04:00
/** @todo forms, history */
2012-10-30 00:09:29 +04:00
LOG(("Created new window object %p", newobject));
%}
2012-11-02 03:30:28 +04:00
operation confirm %{
warn_user(message, NULL);
%}
2012-10-30 00:09:29 +04:00
2012-11-02 03:30:28 +04:00
operation alert %{
warn_user(message, NULL);
%}
2012-10-30 00:09:29 +04:00
2012-11-02 03:30:28 +04:00
operation prompt %{
warn_user(message, NULL);
%}
2012-11-28 22:07:36 +04:00
/* boolean dispatchEvent(Event event); */
operation dispatchEvent %{
/* this implementation is unique to the window object as it is
* not a "real" dom node.
2012-11-28 22:07:36 +04:00
*/
/* caution, this must match the struct generated from event.bnd */
2012-11-29 02:08:11 +04:00
struct {
dom_event *event;
} *event_private;
dom_string *type_dom = NULL;
dom_exception exc;
jsval eventval = JSVAL_VOID;
jsval event_argv[1];
jsval event_rval;
event_private = JS_GetInstancePrivate(cx, event, &JSClass_Event, NULL);
if (event_private->event == NULL) {
/** @todo type error? */
2012-11-28 22:07:36 +04:00
jsret = JS_FALSE;
} else {
2012-11-29 02:08:11 +04:00
exc = dom_event_get_type(event_private->event, &type_dom);
if (exc == DOM_NO_ERR) {
if (dom_string_isequal(type_dom, corestring_dom_load)) {
JS_GetProperty(cx, JSAPI_THIS_OBJECT(cx, vp), "onload", &eventval);
}
2012-11-29 02:35:40 +04:00
if (!JSVAL_IS_VOID(eventval)) {
2012-11-29 02:08:11 +04:00
event_argv[0] = eventval;
jsret = JS_CallFunctionValue(cx, NULL, eventval, 1, event_argv, &event_rval);
2012-11-28 22:07:36 +04:00
}
}
}
2012-11-28 22:07:36 +04:00
%}
2012-12-07 16:08:56 +04:00
getter location %{
jsval loc;
JS_GetProperty(cx, private->document, "location", &loc);
jsret = JSVAL_TO_OBJECT(loc);
%}
getter window %{
jsret = obj;
%}
getter self %{
jsret = obj;
%}
getter EventHandler %{
2012-11-28 22:07:36 +04:00
/* this implementation is unique to the window object as it is
* not a dom node.
2012-11-28 22:07:36 +04:00
*/
JSLOG("propname[%d]=\"%s\"",
tinyid,
jsclass_properties[tinyid].name);
%}
setter EventHandler %{
2012-11-28 22:07:36 +04:00
/* this implementation is unique to the window object as it is
* not a dom node.
2012-11-28 22:07:36 +04:00
*/
JSLOG("propname[%d]=\"%s\"",
tinyid,
jsclass_properties[tinyid].name);
%}