JSTestCallback.cpp [plain text]
#include "config.h"
#if ENABLE(SQL_DATABASE)
#include "JSTestCallback.h"
#include "JSClass1.h"
#include "JSClass2.h"
#include "JSClass8.h"
#include "JSDOMStringList.h"
#include "JSThisClass.h"
#include "ScriptExecutionContext.h"
#include <runtime/JSLock.h>
using namespace JSC;
namespace WebCore {
JSTestCallback::JSTestCallback(JSObject* callback, JSDOMGlobalObject* globalObject)
: ActiveDOMCallback(globalObject->scriptExecutionContext())
, m_data(new JSCallbackData(callback, globalObject))
{
}
JSTestCallback::~JSTestCallback()
{
ScriptExecutionContext* context = scriptExecutionContext();
if (!context || context->isContextThread())
delete m_data;
else
context->postTask(DeleteCallbackDataTask::create(m_data));
#ifndef NDEBUG
m_data = 0;
#endif
}
bool JSTestCallback::callbackWithNoParam()
{
if (!canInvokeCallback())
return true;
RefPtr<JSTestCallback> protect(this);
JSLockHolder lock(m_data->globalObject()->globalData());
ExecState* exec = m_data->globalObject()->globalExec();
MarkedArgumentBuffer args;
bool raisedException = false;
m_data->invokeCallback(args, &raisedException);
return !raisedException;
}
bool JSTestCallback::callbackWithClass1Param(Class1* class1Param)
{
if (!canInvokeCallback())
return true;
RefPtr<JSTestCallback> protect(this);
JSLockHolder lock(m_data->globalObject()->globalData());
ExecState* exec = m_data->globalObject()->globalExec();
MarkedArgumentBuffer args;
args.append(toJS(exec, m_data->globalObject(), class1Param));
bool raisedException = false;
m_data->invokeCallback(args, &raisedException);
return !raisedException;
}
bool JSTestCallback::callbackWithClass2Param(Class2* class2Param, const String& strArg)
{
if (!canInvokeCallback())
return true;
RefPtr<JSTestCallback> protect(this);
JSLockHolder lock(m_data->globalObject()->globalData());
ExecState* exec = m_data->globalObject()->globalExec();
MarkedArgumentBuffer args;
args.append(toJS(exec, m_data->globalObject(), class2Param));
args.append(jsString(exec, strArg));
bool raisedException = false;
m_data->invokeCallback(args, &raisedException);
return !raisedException;
}
bool JSTestCallback::callbackWithStringList(DOMStringList* listParam)
{
if (!canInvokeCallback())
return true;
RefPtr<JSTestCallback> protect(this);
JSLockHolder lock(m_data->globalObject()->globalData());
ExecState* exec = m_data->globalObject()->globalExec();
MarkedArgumentBuffer args;
args.append(toJS(exec, m_data->globalObject(), listParam));
bool raisedException = false;
m_data->invokeCallback(args, &raisedException);
return !raisedException;
}
bool JSTestCallback::callbackWithBoolean(bool boolParam)
{
if (!canInvokeCallback())
return true;
RefPtr<JSTestCallback> protect(this);
JSLockHolder lock(m_data->globalObject()->globalData());
ExecState* exec = m_data->globalObject()->globalExec();
MarkedArgumentBuffer args;
args.append(jsBoolean(boolParam));
bool raisedException = false;
m_data->invokeCallback(args, &raisedException);
return !raisedException;
}
bool JSTestCallback::callbackRequiresThisToPass(Class8* class8Param, ThisClass* thisClassParam)
{
ASSERT(thisClassParam);
if (!canInvokeCallback())
return true;
RefPtr<JSTestCallback> protect(this);
JSLockHolder lock(m_data->globalObject()->globalData());
ExecState* exec = m_data->globalObject()->globalExec();
MarkedArgumentBuffer args;
args.append(toJS(exec, m_data->globalObject(), class8Param));
args.append(toJS(exec, m_data->globalObject(), thisClassParam));
bool raisedException = false;
JSValue jsthisClassParam = toJS(exec, m_data->globalObject(), thisClassParam);
m_data->invokeCallback(jsthisClassParam, args, &raisedException);
return !raisedException;
}
}
#endif // ENABLE(SQL_DATABASE)