JSMessageEventCustom.cpp [plain text]
#include "config.h"
#include "JSMessageEvent.h"
#include "JSBlob.h"
#include "JSDOMBinding.h"
#include "JSDOMConvert.h"
#include "JSDOMWindow.h"
#include "JSEventTarget.h"
#include "JSMessagePort.h"
#include "MessageEvent.h"
#include <runtime/JSArray.h>
#include <runtime/JSArrayBuffer.h>
using namespace JSC;
namespace WebCore {
JSValue JSMessageEvent::data(ExecState& state) const
{
if (JSValue cachedValue = m_data.get()) {
if (!cachedValue.isObject() || &worldForDOMObject(cachedValue.getObject()) == ¤tWorld(&state))
return cachedValue;
ASSERT_NOT_REACHED();
}
MessageEvent& event = wrapped();
JSValue result;
switch (event.dataType()) {
case MessageEvent::DataTypeScriptValue: {
JSValue dataValue = event.dataAsScriptValue();
if (!dataValue)
result = jsNull();
else {
if (dataValue.isObject() && &worldForDOMObject(dataValue.getObject()) != ¤tWorld(&state)) {
RefPtr<SerializedScriptValue> serializedValue = event.trySerializeData(&state);
if (serializedValue)
result = serializedValue->deserialize(state, globalObject());
else
result = jsNull();
} else
result = dataValue;
}
break;
}
case MessageEvent::DataTypeSerializedScriptValue:
if (RefPtr<SerializedScriptValue> serializedValue = event.dataAsSerializedScriptValue()) {
Vector<RefPtr<MessagePort>> ports = wrapped().ports();
result = serializedValue->deserialize(state, globalObject(), ports, SerializationErrorMode::NonThrowing);
} else
result = jsNull();
break;
case MessageEvent::DataTypeString:
result = jsStringWithCache(&state, event.dataAsString());
break;
case MessageEvent::DataTypeBlob:
result = toJS(&state, globalObject(), event.dataAsBlob());
break;
case MessageEvent::DataTypeArrayBuffer:
result = toJS(&state, globalObject(), event.dataAsArrayBuffer());
break;
}
m_data.set(state.vm(), this, result);
return result;
}
static JSC::JSValue handleInitMessageEvent(JSMessageEvent* jsEvent, JSC::ExecState& state)
{
VM& vm = state.vm();
auto scope = DECLARE_THROW_SCOPE(vm);
const String& typeArg = state.argument(0).toWTFString(&state);
RETURN_IF_EXCEPTION(scope, JSValue());
bool canBubbleArg = state.argument(1).toBoolean(&state);
RETURN_IF_EXCEPTION(scope, JSValue());
bool cancelableArg = state.argument(2).toBoolean(&state);
RETURN_IF_EXCEPTION(scope, JSValue());
JSValue dataArg = state.argument(3);
const String originArg = convert<IDLUSVString>(state, state.argument(4));
RETURN_IF_EXCEPTION(scope, JSValue());
const String lastEventIdArg = state.argument(5).toWTFString(&state);
RETURN_IF_EXCEPTION(scope, JSValue());
auto sourceArg = convert<IDLNullable<IDLUnion<IDLInterface<DOMWindow>, IDLInterface<MessagePort>>>>(state, state.argument(6));
RETURN_IF_EXCEPTION(scope, JSValue());
Vector<RefPtr<MessagePort>> messagePorts;
if (!state.argument(7).isUndefinedOrNull()) {
messagePorts = convert<IDLSequence<IDLInterface<MessagePort>>>(state, state.argument(7));
RETURN_IF_EXCEPTION(scope, JSValue());
}
MessageEvent& event = jsEvent->wrapped();
event.initMessageEvent(state, typeArg, canBubbleArg, cancelableArg, dataArg, originArg, lastEventIdArg, WTFMove(sourceArg), WTFMove(messagePorts));
jsEvent->m_data.set(vm, jsEvent, dataArg);
return jsUndefined();
}
JSC::JSValue JSMessageEvent::initMessageEvent(JSC::ExecState& state)
{
return handleInitMessageEvent(this, state);
}
JSC::JSValue JSMessageEvent::webkitInitMessageEvent(JSC::ExecState& state)
{
return handleInitMessageEvent(this, state);
}
}