Merge branch 'devel' of https://github.com/Neha03/gsoc2012-javascript into devel
Conflicts: .project COPYRIGHT Doc/Manual/style.css Examples/Makefile.in Examples/test-suite/common.mk Lib/typemaps/strings.swg Makefile.in Source/DOH/fio.c Source/Makefile.am Source/Modules/emit.cxx Source/Modules/javascript.cxx configure.in git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/branches/oliverb-javascript-v8@13764 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
360ef44e09
commit
050219d998
136 changed files with 7987 additions and 141 deletions
292
Lib/javascript/jsc/javascriptcode.swg
Normal file
292
Lib/javascript/jsc/javascriptcode.swg
Normal file
|
|
@ -0,0 +1,292 @@
|
|||
/*********************************************************************
|
||||
*getproperty: This template gives name to generated wrapper for the getproperty
|
||||
*{LOCALS}: declarations for input arguments
|
||||
*{CODE}: contains input marshalling, and the action
|
||||
*********************************************************************/
|
||||
|
||||
%fragment ("JS_getproperty", "templates")
|
||||
%{
|
||||
JSValueRef ${getname}(JSContextRef context, JSObjectRef thisObject, JSStringRef propertyName, JSValueRef* exception)
|
||||
{
|
||||
${LOCALS}
|
||||
${CODE}
|
||||
return jsresult;
|
||||
|
||||
goto fail;
|
||||
fail:
|
||||
return NULL;
|
||||
}
|
||||
%}
|
||||
|
||||
/**********************************************************************
|
||||
*setproperty: This template gives name to generated wrapper for the setproperty
|
||||
*{LOCALS}: declarations for input arguments
|
||||
*{CODE}: contains input marshalling, and the action
|
||||
**********************************************************************/
|
||||
|
||||
%fragment ("JS_setproperty", "templates")
|
||||
%{
|
||||
bool ${setname}(JSContextRef context, JSObjectRef thisObject, JSStringRef propertyName, JSValueRef value, JSValueRef* exception)
|
||||
{
|
||||
${LOCALS}
|
||||
${CODE}
|
||||
|
||||
return true;
|
||||
|
||||
goto fail;
|
||||
fail:
|
||||
return false;
|
||||
}
|
||||
%}
|
||||
|
||||
/************************************************************************************
|
||||
*functionwrapper: This template gives name to generated wrapper for the function
|
||||
*{LOCALS}: declarations for input arguments
|
||||
*{CODE} contains input marshalling, and the action
|
||||
************************************************************************************/
|
||||
%fragment ("JS_functionwrapper", "templates")
|
||||
%{
|
||||
JSValueRef ${functionname}(JSContextRef context, JSObjectRef function, JSObjectRef thisObject, size_t argc, const JSValueRef argv[], JSValueRef* exception)
|
||||
{
|
||||
${LOCALS}
|
||||
${CODE}
|
||||
return jsresult;
|
||||
|
||||
goto fail;
|
||||
fail:
|
||||
return NULL;
|
||||
}
|
||||
%}
|
||||
|
||||
/**************************************************************************************
|
||||
function_dispatch_case: This template is used for the function which is overloaded
|
||||
***************************************************************************************/
|
||||
|
||||
%fragment ("JS_function_dispatch_case", "templates")
|
||||
%{if(argc == ${argcount}) {
|
||||
jsresult = ${functionwrapper}(context, function, thisObject, argc, argv, exception);
|
||||
} else %}
|
||||
|
||||
%fragment ("JS_function_dispatch_case_default", "templates")
|
||||
%{
|
||||
{
|
||||
// TODO: throw JS exception
|
||||
throw "Invalid function arguments.";
|
||||
}
|
||||
%}
|
||||
|
||||
/* Added template for function declaration */
|
||||
|
||||
%fragment ("JS_variabledecl", "templates")
|
||||
%{{"${propertyname}",${getname}, ${setname},kJSPropertyAttributeNone},%}
|
||||
|
||||
|
||||
/* Added template for function declaration */
|
||||
|
||||
%fragment ("JS_functiondecl", "templates")
|
||||
%{{"${functionname}",${functionwrapper}, kJSPropertyAttributeNone},%}
|
||||
|
||||
%fragment ("JS_globaldefn", "templates")
|
||||
%{
|
||||
JSStaticValue ${namespace}_values[] = {
|
||||
${jsglobalvariables}
|
||||
{ 0, 0, 0, 0 }
|
||||
};
|
||||
|
||||
JSStaticFunction ${namespace}_functions[] = {
|
||||
${jsglobalfunctions}
|
||||
{ 0, 0, 0 }
|
||||
};
|
||||
|
||||
JSClassDefinition ${namespace}_classDefinition;
|
||||
%}
|
||||
|
||||
/******************************************************************************************
|
||||
* class_definition:
|
||||
* This code template is used for wrapper of classes definition.
|
||||
* ${classname_mangled}:the mangled name of the qualified class name, e.g., foo::A -> foo_A
|
||||
*****************************************************************************************/
|
||||
|
||||
%fragment ("JS_class_definition", "templates")
|
||||
%{
|
||||
JSClassDefinition ${classname_mangled}_classDefinition;
|
||||
|
||||
JSClassDefinition ${classname_mangled}_objectDefinition;
|
||||
|
||||
JSClassRef ${classname_mangled}_classRef;
|
||||
%}
|
||||
|
||||
/*********************************************************************
|
||||
* class_table:
|
||||
* This code template is used to add the wrapper for class declaration
|
||||
* ${classname_mangled}: The mangled name of the qualified class name, e.g., foo::A -> foo_A
|
||||
***********************************************************************/
|
||||
|
||||
%fragment ("JS_class_tables", "templates")
|
||||
%{
|
||||
JSStaticValue ${classname_mangled}_staticValues[] = {
|
||||
${jsstaticclassvariables}
|
||||
{ 0, 0, 0, 0 }
|
||||
};
|
||||
|
||||
JSStaticFunction ${classname_mangled}_staticFunctions[] = {
|
||||
${jsstaticclassfunctions}
|
||||
{ 0, 0, 0 }
|
||||
};
|
||||
|
||||
JSStaticValue ${classname_mangled}_values[] = {
|
||||
${jsclassvariables}
|
||||
{ 0, 0, 0, 0 }
|
||||
};
|
||||
|
||||
JSStaticFunction ${classname_mangled}_functions[] = {
|
||||
${jsclassfunctions}
|
||||
{ 0, 0, 0 }
|
||||
};
|
||||
%}
|
||||
|
||||
/*********************************************************************
|
||||
* destructordefn:
|
||||
* This code template is used to adds the destructor wrapper function
|
||||
* ${classname_mangled}: The mangled name of the qualified class name, e.g., foo::A -> foo_A
|
||||
***********************************************************************/
|
||||
|
||||
%fragment ("JS_destructordefn", "templates")
|
||||
%{
|
||||
void _wrap_${classname_mangled}_finalize(JSObjectRef thisObject)
|
||||
{
|
||||
SWIG_PRV_DATA* t = (SWIG_PRV_DATA*)JSObjectGetPrivate(thisObject);
|
||||
if(t && t->swigCMemOwn) free ((${type}*)t->swigCObject);
|
||||
if(t) free(t);
|
||||
}
|
||||
%}
|
||||
|
||||
/*********************************************************************
|
||||
* constructor_definition:
|
||||
* This code template is used to adds the main constructor wrapper function
|
||||
* ${classname_mangled}: The mangled name of the qualified class name, e.g., foo::A -> foo_A
|
||||
***********************************************************************/
|
||||
|
||||
|
||||
%fragment ("JS_mainctordefn", "templates")
|
||||
%{
|
||||
JSObjectRef _wrap_create_${classname_mangled}(JSContextRef context, JSObjectRef ctorObject,
|
||||
size_t argc, const JSValueRef argv[], JSValueRef* exception)
|
||||
{
|
||||
JSObjectRef thisObject;
|
||||
|
||||
${DISPATCH_CASES}
|
||||
{
|
||||
// TODO: handle illegal arguments
|
||||
SWIG_exception_fail(SWIG_ERROR, "Illegal arguments for contruction of ${classname_mangled}");
|
||||
}
|
||||
|
||||
return thisObject;
|
||||
|
||||
fail:
|
||||
return NULL;
|
||||
}
|
||||
%}
|
||||
|
||||
/**************************************************************************************
|
||||
ctor_dispatch_case: This template is used for the constructor which is overloaded
|
||||
***************************************************************************************/
|
||||
|
||||
%fragment ("JS_ctor_dispatch_case", "templates")
|
||||
%{if(argc == ${argcount}) {
|
||||
thisObject = _wrap_create_${classname_mangled}${overloadext}(context, NULL, argc, argv, exception);
|
||||
} else %}
|
||||
|
||||
|
||||
%fragment ("JS_ctordefn", "templates")
|
||||
%{
|
||||
JSObjectRef _wrap_create_${classname_mangled}${overloadext}(JSContextRef context, JSObjectRef thisObject, size_t argc, const JSValueRef argv[], JSValueRef* exception)
|
||||
{
|
||||
${LOCALS}
|
||||
${CODE}
|
||||
|
||||
return SWIG_JSC_NewPointerObj(context, result, SWIGTYPE_${type_mangled}, SWIG_POINTER_OWN);
|
||||
|
||||
goto fail;
|
||||
fail:
|
||||
return NULL;
|
||||
}
|
||||
%}
|
||||
/**********************************************************************
|
||||
initializer:This template is dynamic growing and aggregates everything
|
||||
**********************************************************************/
|
||||
|
||||
%fragment ("JS_initializer", "templates") %{
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
bool ${modulename}_initialize(JSGlobalContextRef context) {
|
||||
SWIG_InitializeModule(0);
|
||||
|
||||
JSObjectRef global_object = JSContextGetGlobalObject(context);
|
||||
|
||||
/* Initialize the base swig type object */
|
||||
_SwigObject_objectDefinition.staticFunctions = _SwigObject_functions;
|
||||
_SwigObject_objectDefinition.staticValues = _SwigObject_values;
|
||||
_SwigObject_classRef = JSClassCreate(&_SwigObject_objectDefinition);
|
||||
|
||||
/* Create objects for namespaces */
|
||||
${create_namespaces}
|
||||
|
||||
/* Create classes */
|
||||
${initializercode}
|
||||
|
||||
/* Register namespaces */
|
||||
${register_namespaces}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
%}
|
||||
|
||||
/*****************************************************************************************
|
||||
*create_class_template:
|
||||
*This template is used to add a Static references to class templates.
|
||||
*${classname_mangled}: The mangled name of the qualified class name, e.g., foo::A -> foo_A
|
||||
*****************************************************************************************/
|
||||
|
||||
%fragment ("JS_create_class_template", "templates")
|
||||
%{ ${classname_mangled}_classDefinition.staticFunctions = ${classname_mangled}_staticFunctions;
|
||||
${classname_mangled}_classDefinition.staticValues = ${classname_mangled}_staticValues;
|
||||
${classname_mangled}_classDefinition.callAsConstructor = _wrap_create_${classname_mangled};
|
||||
${classname_mangled}_objectDefinition.staticValues = ${classname_mangled}_values;
|
||||
${classname_mangled}_objectDefinition.staticFunctions = ${classname_mangled}_functions;
|
||||
${classname_mangled}_objectDefinition.parentClass = ${base_classname}_classRef;
|
||||
JSClassRef ${classname_mangled}_classRef = JSClassCreate(&${classname_mangled}_objectDefinition);
|
||||
SWIGTYPE_${classtype_mangled}->clientdata = ${classname_mangled}_classRef;%}
|
||||
|
||||
/*****************************************************************************************
|
||||
*register_class:
|
||||
*This template is used to adds a class registration statement to initializer function
|
||||
*${classname_mangled}: The mangled name of the qualified class name, e.g., foo::A -> foo_A
|
||||
*****************************************************************************************/
|
||||
|
||||
%fragment ("JS_register_class", "templates")
|
||||
%{JS_registerClass(context, ${namespace_mangled}_object, "${classname}", &${classname_mangled}_classDefinition);%}
|
||||
|
||||
/* register global function */
|
||||
%fragment ("JS_register_global_function", "templates")
|
||||
%{JS_registerFunction(${context}, ${context_object}, "${functionname}", ${functionwrapper});%}
|
||||
|
||||
|
||||
/* create and register namespaces */
|
||||
|
||||
%fragment ("JS_create_namespace", "templates")
|
||||
%{ ${namespace}_classDefinition.staticFunctions = ${namespace}_functions;
|
||||
${namespace}_classDefinition.staticValues = ${namespace}_values;
|
||||
JSObjectRef ${namespace}_object = JSObjectMake(context, JSClassCreate(&${namespace}_classDefinition), NULL);
|
||||
%}
|
||||
|
||||
%fragment ("JS_register_namespace", "templates")
|
||||
%{
|
||||
JS_registerNamespace(context, ${namespace_mangled}_object, ${parent_namespace}_object, "${namespace}"); %}
|
||||
Loading…
Add table
Add a link
Reference in a new issue