Split up javascript engine makefiles

by splitting javascript engine specific makefiles and source up we
avoid having to consider old JSAPI or none code while working on
duktape.
This commit is contained in:
Vincent Sanders 2015-10-12 17:40:35 +01:00
parent 3877d4ad03
commit ce32141057
10 changed files with 134 additions and 104 deletions

View File

@ -1,103 +1,34 @@
# #
# NetSurf javascript source file inclusion # NetSurf javascript source file inclusion
# #
# Included by Makefile.sources # Included by Makefile
# #
# ---------------------------------------------------------------------------- # Check if jsapi is required
# JSAPI binding
# ----------------------------------------------------------------------------
S_JSAPI_BINDING:=
D_JSAPI_BINDING:=
JSAPI_BINDING_htmldocument := javascript/jsapi/htmldocument.bnd
JSAPI_BINDING_htmlelement := javascript/jsapi/htmlelement.bnd
JSAPI_BINDING_window := javascript/jsapi/window.bnd
JSAPI_BINDING_navigator := javascript/jsapi/navigator.bnd
JSAPI_BINDING_console := javascript/jsapi/console.bnd
JSAPI_BINDING_location := javascript/jsapi/location.bnd
JSAPI_BINDING_htmlcollection := javascript/jsapi/htmlcollection.bnd
JSAPI_BINDING_nodelist := javascript/jsapi/nodelist.bnd
JSAPI_BINDING_text := javascript/jsapi/text.bnd
JSAPI_BINDING_comment := javascript/jsapi/comment.bnd
JSAPI_BINDING_node := javascript/jsapi/node.bnd
JSAPI_BINDING_event := javascript/jsapi/event.bnd
# 1: input binding file
# 2: source output file
# 3: header output file
# 4: binding name
define convert_jsapi_binding
S_JSAPI_BINDING += $(2)
D_JSAPI_BINDING += $(patsubst %.c,%.d,$(2))
$(2): $(1) $(OBJROOT)/created
$$(VQ)echo " GENBIND: $(1)"
$(Q)nsgenbind -g -I javascript/WebIDL -d $(patsubst %.c,%.d,$(2)) -h $(3) -o $(2) $(1)
$(3): $(2)
endef
# Javascript sources
ifeq ($(NETSURF_USE_JS),YES) ifeq ($(NETSURF_USE_JS),YES)
WANT_JS_SOURCE := YES WANT_JS_SOURCE := YES
endif else
ifeq ($(NETSURF_USE_MOZJS),YES) ifeq ($(NETSURF_USE_MOZJS),YES)
WANT_JS_SOURCE := YES WANT_JS_SOURCE := YES
endif endif
endif
S_JAVASCRIPT_BINDING:=
ifeq ($(WANT_JS_SOURCE),YES) ifeq ($(WANT_JS_SOURCE),YES)
# JSAPI (spidemonkey)
S_JSAPI := include javascript/jsapi/Makefile
S_JAVASCRIPT += content.c jsapi.c fetcher.c $(addprefix jsapi/,$(S_JSAPI))
$(eval $(foreach V,$(filter JSAPI_BINDING_%,$(.VARIABLES)),$(call convert_jsapi_binding,$($(V)),$(OBJROOT)/$(patsubst JSAPI_BINDING_%,%,$(V)).c,$(OBJROOT)/$(patsubst JSAPI_BINDING_%,%,$(V)).h,$(patsubst JSAPI_BINDING_%,%,$(V))_jsapi)))
ifeq ($(filter $(MAKECMDGOALS),clean test coverage),)
-include $(D_JSAPI_BINDING)
endif
else else
ifeq ($(NETSURF_USE_DUKTAPE),YES) ifeq ($(NETSURF_USE_DUKTAPE),YES)
# Duktape
javascript/dukky.c: $(OBJROOT)/duktape/binding.h include javascript/duktape/Makefile
BINDINGS := $(wildcard javascript/duktape/*.bnd)
$(OBJROOT)/duktape/binding.h $(OBJROOT)/duktape/Makefile: javascript/duktape/netsurf.bnd $(BINDINGS)
$(Q)mkdir -p $(OBJROOT)/duktape
$(VQ)echo " GENBIND: $<"
$(Q)nsgenbind -D -I javascript/WebIDL $< $(OBJROOT)/duktape
# create unimplemented report for doxygen
Docs/UnimplementedJavascript.txt: javascript/duktape/netsurf.bnd $(BINDINGS)
$(Q)mkdir -p $(OBJROOT)/duktape
$(VQ)echo "/** \page unimplemented Unimplemented javascript bindings" > $@
$(VQ)echo "This is a list of all the binding methods, getters and setters without an implementation in a binding." >> $@
$(VQ)echo "" >> $@
$(VQ)echo " GENBIND: $<"
$(Q)nsgenbind -Wunimplemented -I javascript/WebIDL $< $(OBJROOT)/duktape 2>&1 >/dev/null | grep "Unimplemented" | cut -d' ' -f4- | sort -k 2 | awk '{print $$0"\\n" }' >> $@
$(VQ)echo "*/" >> $@
ifeq ($(filter $(MAKECMDGOALS),clean test coverage),)
-include $(OBJROOT)/duktape/Makefile
endif
S_JSAPI_BINDING:=$(addprefix $(OBJROOT)/duktape/,$(NSGENBIND_SOURCES))
$(S_JSAPI_BINDING): $(BINDINGS)
S_JAVASCRIPT += dukky.c content.c fetcher.c duktape/duktape.c
CFLAGS += -DDUK_OPT_HAVE_CUSTOM_H
else else
S_JAVASCRIPT += none.c fetcher.c # None
include javascript/none/Makefile
endif endif
endif endif
S_JAVASCRIPT := $(addprefix javascript/,$(S_JAVASCRIPT)) $(S_JSAPI_BINDING) # Fetcher for javascript scheme is always required
S_JAVASCRIPT += fetcher.c
S_JAVASCRIPT := $(addprefix javascript/,$(S_JAVASCRIPT)) $(S_JAVASCRIPT_BINDING)

View File

@ -0,0 +1,37 @@
#
# NetSurf javascript source file inclusion
#
# Included by javascript/Makefile
#
javascript/dukky.c: $(OBJROOT)/duktape/binding.h
BINDINGS := $(wildcard javascript/duktape/*.bnd)
$(OBJROOT)/duktape/binding.h $(OBJROOT)/duktape/Makefile: javascript/duktape/netsurf.bnd $(BINDINGS)
$(Q)mkdir -p $(OBJROOT)/duktape
$(VQ)echo " GENBIND: $<"
$(Q)nsgenbind -D -g -I javascript/WebIDL $< $(OBJROOT)/duktape
$(VQ)echo " GENBIND: completed"
# create unimplemented report for doxygen
Docs/UnimplementedJavascript.txt: javascript/duktape/netsurf.bnd $(BINDINGS)
$(Q)mkdir -p $(OBJROOT)/duktape
$(VQ)echo "/** \page unimplemented Unimplemented javascript bindings" > $@
$(VQ)echo "This is a list of all the binding methods, getters and setters without an implementation in a binding." >> $@
$(VQ)echo "" >> $@
$(VQ)echo " GENBIND: $<"
$(Q)nsgenbind -Wunimplemented -I javascript/WebIDL $< $(OBJROOT)/duktape 2>&1 >/dev/null | grep "Unimplemented" | cut -d' ' -f4- | sort -k 2 | awk '{print $$0"\\n" }' >> $@
$(VQ)echo "*/" >> $@
ifeq ($(filter $(MAKECMDGOALS),clean test coverage),)
-include $(OBJROOT)/duktape/Makefile
endif
S_JAVASCRIPT_BINDING:=$(addprefix $(OBJROOT)/duktape/,$(NSGENBIND_SOURCES))
$(S_JAVASCRIPT_BINDING): $(BINDINGS)
S_JAVASCRIPT += content.c duktape/dukky.c duktape/duktape.c
CFLAGS += -DDUK_OPT_HAVE_CUSTOM_H

View File

@ -32,7 +32,7 @@
#include "duktape/binding.h" #include "duktape/binding.h"
#include "duktape/duktape.h" #include "duktape.h"
#include "dukky.h" #include "dukky.h"
#include <dom/dom.h> #include <dom/dom.h>
@ -152,7 +152,7 @@ dukky_push_node_klass(duk_context *ctx, struct dom_node *node)
} }
switch(nodetype) { switch(nodetype) {
case DOM_ELEMENT_NODE: { case DOM_ELEMENT_NODE: {
dom_string *namespace, *tag; dom_string *namespace, *tag;
err = dom_node_get_namespace(node, &namespace); err = dom_node_get_namespace(node, &namespace);
if (err != DOM_NO_ERR) { if (err != DOM_NO_ERR) {
@ -190,23 +190,23 @@ dukky_push_node_klass(duk_context *ctx, struct dom_node *node)
break; break;
} }
case DOM_TEXT_NODE: case DOM_TEXT_NODE:
duk_push_string(ctx, PROTO_NAME(TEXT)); duk_push_string(ctx, PROTO_NAME(TEXT));
break; break;
case DOM_COMMENT_NODE: case DOM_COMMENT_NODE:
duk_push_string(ctx, PROTO_NAME(COMMENT)); duk_push_string(ctx, PROTO_NAME(COMMENT));
break; break;
case DOM_DOCUMENT_NODE: case DOM_DOCUMENT_NODE:
duk_push_string(ctx, PROTO_NAME(DOCUMENT)); duk_push_string(ctx, PROTO_NAME(DOCUMENT));
break; break;
case DOM_ATTRIBUTE_NODE: case DOM_ATTRIBUTE_NODE:
case DOM_PROCESSING_INSTRUCTION_NODE: case DOM_PROCESSING_INSTRUCTION_NODE:
case DOM_DOCUMENT_TYPE_NODE: case DOM_DOCUMENT_TYPE_NODE:
case DOM_DOCUMENT_FRAGMENT_NODE: case DOM_DOCUMENT_FRAGMENT_NODE:
case DOM_NOTATION_NODE: case DOM_NOTATION_NODE:
case DOM_ENTITY_REFERENCE_NODE: case DOM_ENTITY_REFERENCE_NODE:
case DOM_ENTITY_NODE: case DOM_ENTITY_NODE:
case DOM_CDATA_SECTION_NODE: case DOM_CDATA_SECTION_NODE:
default: default:
/* Oh bum, just node then */ /* Oh bum, just node then */
duk_push_string(ctx, PROTO_NAME(NODE)); duk_push_string(ctx, PROTO_NAME(NODE));

View File

@ -47,7 +47,7 @@ struct dom_html_br_element;
%}; %};
prologue %{ prologue %{
#include "javascript/dukky.h" #include "javascript/duktape/dukky.h"
%}; %};
}; };

53
javascript/jsapi/Makefile Normal file
View File

@ -0,0 +1,53 @@
#
# NetSurf javascript source file inclusion
#
# Included by javascript/Makefile
#
# ----------------------------------------------------------------------------
# JSAPI binding
# ----------------------------------------------------------------------------
D_JSAPI_BINDING:=
JSAPI_BINDING_htmldocument := javascript/jsapi/htmldocument.bnd
JSAPI_BINDING_htmlelement := javascript/jsapi/htmlelement.bnd
JSAPI_BINDING_window := javascript/jsapi/window.bnd
JSAPI_BINDING_navigator := javascript/jsapi/navigator.bnd
JSAPI_BINDING_console := javascript/jsapi/console.bnd
JSAPI_BINDING_location := javascript/jsapi/location.bnd
JSAPI_BINDING_htmlcollection := javascript/jsapi/htmlcollection.bnd
JSAPI_BINDING_nodelist := javascript/jsapi/nodelist.bnd
JSAPI_BINDING_text := javascript/jsapi/text.bnd
JSAPI_BINDING_comment := javascript/jsapi/comment.bnd
JSAPI_BINDING_node := javascript/jsapi/node.bnd
JSAPI_BINDING_event := javascript/jsapi/event.bnd
# 1: input binding file
# 2: source output file
# 3: header output file
# 4: binding name
define convert_jsapi_binding
S_JAVASCRIPT_BINDING += $(2)
D_JSAPI_BINDING += $(patsubst %.c,%.d,$(2))
$(2): $(1) $(OBJROOT)/created
$$(VQ)echo " GENBIND: $(1)"
$(Q)nsgenbind -g -I javascript/WebIDL -d $(patsubst %.c,%.d,$(2)) -h $(3) -o $(2) $(1)
$(3): $(2)
endef
S_JSAPI :=
S_JAVASCRIPT += content.c jsapi/jsapi.c $(addprefix jsapi/,$(S_JSAPI))
$(eval $(foreach V,$(filter JSAPI_BINDING_%,$(.VARIABLES)),$(call convert_jsapi_binding,$($(V)),$(OBJROOT)/$(patsubst JSAPI_BINDING_%,%,$(V)).c,$(OBJROOT)/$(patsubst JSAPI_BINDING_%,%,$(V)).h,$(patsubst JSAPI_BINDING_%,%,$(V))_jsapi)))
ifeq ($(filter $(MAKECMDGOALS),clean test coverage),)
-include $(D_JSAPI_BINDING)
endif

9
javascript/none/Makefile Normal file
View File

@ -0,0 +1,9 @@
#
# NetSurf javascript source file inclusion
#
# Included by javascript/Makefile
#
# no javascript interpreter
S_JAVASCRIPT += none/none.c