blob: 6bc42857c34900438e68833abb0dfaee6a18cbb6 [file] [log] [blame]
/*
* Copyright (C) 2003 Apple Computer, Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "config.h"
#include "runtime.h"
#include "JSLock.h"
#include "NP_jsobject.h"
#include "c_instance.h"
#include "jni_instance.h"
#include "objc_instance.h"
#include "runtime_object.h"
namespace KJS { namespace Bindings {
void deleteMethodList(CFAllocatorRef, const void* value)
{
const MethodList* methodList = static_cast<const MethodList*>(value);
int end = methodList->length();
for (int i = 0; i < end; i++) {
delete methodList->methodAt(i);
}
delete methodList;
}
void deleteMethod(CFAllocatorRef, const void* value)
{
delete static_cast<const Method*>(value);
}
void deleteField(CFAllocatorRef, const void* value)
{
delete static_cast<const Field*>(value);
}
void MethodList::addMethod(Method *aMethod)
{
Method **_newMethods = new Method *[_length + 1];
if (_length > 0) {
memcpy(_newMethods, _methods, sizeof(Method *) * _length);
delete [] _methods;
}
_methods = _newMethods;
_methods[_length++] = aMethod;
}
unsigned int MethodList::length() const
{
return _length;
}
Method *MethodList::methodAt(unsigned int index) const
{
assert(index < _length);
return _methods[index];
}
MethodList::~MethodList()
{
delete [] _methods;
}
MethodList::MethodList(const MethodList &other)
{
_length = other._length;
_methods = new Method *[_length];
if (_length > 0)
memcpy (_methods, other._methods, sizeof(Method *) * _length);
}
MethodList &MethodList::operator=(const MethodList &other)
{
if (this == &other)
return *this;
delete [] _methods;
_length = other._length;
_methods = new Method *[_length];
if (_length > 0)
memcpy(_methods, other._methods, sizeof(Method *) * _length);
return *this;
}
Instance::Instance()
: _executionContext(0)
, _refCount(0)
{
}
static KJSDidExecuteFunctionPtr _DidExecuteFunction;
void Instance::setDidExecuteFunction(KJSDidExecuteFunctionPtr func) { _DidExecuteFunction = func; }
KJSDidExecuteFunctionPtr Instance::didExecuteFunction() { return _DidExecuteFunction; }
JSValue *Instance::getValueOfField(ExecState *exec, const Field *aField) const
{
return aField->valueFromInstance(exec, this);
}
void Instance::setValueOfField(ExecState *exec, const Field *aField, JSValue *aValue) const
{
aField->setValueToInstance(exec, this, aValue);
}
Instance *Instance::createBindingForLanguageInstance(BindingLanguage language, void *nativeInstance, const RootObject *executionContext)
{
Instance *newInstance = 0;
switch (language) {
case Instance::JavaLanguage: {
newInstance = new Bindings::JavaInstance((jobject)nativeInstance, executionContext);
break;
}
case Instance::ObjectiveCLanguage: {
newInstance = new Bindings::ObjcInstance((ObjectStructPtr)nativeInstance);
break;
}
case Instance::CLanguage: {
newInstance = new Bindings::CInstance((NPObject *)nativeInstance);
break;
}
default:
break;
}
if (newInstance)
newInstance->setExecutionContext(executionContext);
return newInstance;
}
JSObject *Instance::createRuntimeObject(BindingLanguage language, void *nativeInstance, const RootObject *executionContext)
{
Instance *interfaceObject = Instance::createBindingForLanguageInstance(language, nativeInstance, executionContext);
JSLock lock;
return new RuntimeObjectImp(interfaceObject);
}
void *Instance::createLanguageInstanceForValue(ExecState *exec, BindingLanguage language, JSObject *value, const RootObject *origin, const RootObject *current)
{
void *result = 0;
if (!value->isObject())
return 0;
JSObject *imp = static_cast<JSObject*>(value);
switch (language) {
case Instance::ObjectiveCLanguage: {
result = createObjcInstanceForValue(value, origin, current);
break;
}
case Instance::CLanguage: {
result = _NPN_CreateScriptObject(0, imp, origin, current);
break;
}
case Instance::JavaLanguage: {
// FIXME: factor creation of jni_jsobjects, also remove unnecessary thread
// invocation code.
break;
}
default:
break;
}
return result;
}
} } // namespace KJS::Bindings