gecko/dom/workers/EventTarget.cpp
Boris Zbarsky 1833a29c14 Bug 749485. Switch new DOM bindings to using a struct for keeping track of failures for fallible methods. r=peterv,bent
ErrorResult is in a separate header file so it can be included from all over the
place without having to pull in mozilla/dom/Utils.h and all the xpconnect gunk
that needs.
2012-05-05 21:15:11 -04:00

101 lines
2.8 KiB
C++

/* -*- Mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; tab-width: 40 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "EventTarget.h"
USING_WORKERS_NAMESPACE
using mozilla::ErrorResult;
void
EventTarget::_Trace(JSTracer* aTrc)
{
mListenerManager._Trace(aTrc);
DOMBindingBase::_Trace(aTrc);
}
void
EventTarget::_Finalize(JSFreeOp* aFop)
{
mListenerManager._Finalize(aFop);
DOMBindingBase::_Finalize(aFop);
}
JSObject*
EventTarget::GetEventListener(const nsAString& aType, ErrorResult& aRv) const
{
JSContext* cx = GetJSContext();
JSString* type =
JS_NewUCStringCopyN(cx, aType.BeginReading(), aType.Length());
if (!type || !(type = JS_InternJSString(cx, type))) {
aRv.Throw(NS_ERROR_OUT_OF_MEMORY);
return NULL;
}
return mListenerManager.GetEventListener(INTERNED_STRING_TO_JSID(cx, type));
}
void
EventTarget::SetEventListener(const nsAString& aType, JSObject* aListener,
ErrorResult& aRv)
{
JSContext* cx = GetJSContext();
JSString* type =
JS_NewUCStringCopyN(cx, aType.BeginReading(), aType.Length());
if (!type || !(type = JS_InternJSString(cx, type))) {
aRv.Throw(NS_ERROR_OUT_OF_MEMORY);
return;
}
mListenerManager.SetEventListener(cx, INTERNED_STRING_TO_JSID(cx, type),
aListener, aRv);
}
void
EventTarget::AddEventListener(const nsAString& aType, JSObject* aListener,
bool aCapturing, Nullable<bool> aWantsUntrusted,
ErrorResult& aRv)
{
if (!aListener) {
return;
}
JSContext* cx = GetJSContext();
JSString* type =
JS_NewUCStringCopyN(cx, aType.BeginReading(), aType.Length());
if (!type || !(type = JS_InternJSString(cx, type))) {
aRv.Throw(NS_ERROR_OUT_OF_MEMORY);
return;
}
bool wantsUntrusted = !aWantsUntrusted.IsNull() && aWantsUntrusted.Value();
mListenerManager.AddEventListener(cx, INTERNED_STRING_TO_JSID(cx, type),
aListener, aCapturing, wantsUntrusted,
aRv);
}
void
EventTarget::RemoveEventListener(const nsAString& aType, JSObject* aListener,
bool aCapturing, ErrorResult& aRv)
{
if (!aListener) {
return;
}
JSContext* cx = GetJSContext();
JSString* type =
JS_NewUCStringCopyN(cx, aType.BeginReading(), aType.Length());
if (!type || !(type = JS_InternJSString(cx, type))) {
aRv.Throw(NS_ERROR_OUT_OF_MEMORY);
return;
}
mListenerManager.RemoveEventListener(cx, INTERNED_STRING_TO_JSID(cx, type),
aListener, aCapturing);
}