mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-13 07:24:47 +00:00
Bug 906684, make sure to access the right EventTargetChainItem when forwarding events to chrome, r=jst
--HG-- extra : rebase_source : afb2b457c422585e85d7abccfd76f0b6f85315a4
This commit is contained in:
parent
240cf1fc53
commit
4e91e28a62
@ -461,6 +461,7 @@ nsEventDispatcher::Dispatch(nsISupports* aTarget,
|
||||
// Create the event target chain item for the event target.
|
||||
nsEventTargetChainItem* targetEtci =
|
||||
nsEventTargetChainItem::Create(chain, target->GetTargetForEventTargetChain());
|
||||
MOZ_ASSERT(&chain[0] == targetEtci);
|
||||
if (!targetEtci->IsValid()) {
|
||||
nsEventTargetChainItem::DestroyLast(chain, targetEtci);
|
||||
return NS_ERROR_FAILURE;
|
||||
@ -508,6 +509,7 @@ nsEventDispatcher::Dispatch(nsISupports* aTarget,
|
||||
nsEventTargetChainItem::DestroyLast(chain, targetEtci);
|
||||
targetEtci = EventTargetChainItemForChromeTarget(chain, content);
|
||||
NS_ENSURE_STATE(targetEtci);
|
||||
MOZ_ASSERT(&chain[0] == targetEtci);
|
||||
targetEtci->PreHandleEvent(preVisitor);
|
||||
}
|
||||
if (preVisitor.mCanHandle) {
|
||||
@ -516,6 +518,7 @@ nsEventDispatcher::Dispatch(nsISupports* aTarget,
|
||||
nsCOMPtr<EventTarget> t = do_QueryInterface(aEvent->target);
|
||||
targetEtci->SetNewTarget(t);
|
||||
nsEventTargetChainItem* topEtci = targetEtci;
|
||||
targetEtci = nullptr;
|
||||
while (preVisitor.mParentTarget) {
|
||||
EventTarget* parentTarget = preVisitor.mParentTarget;
|
||||
nsEventTargetChainItem* parentEtci =
|
||||
@ -551,7 +554,7 @@ nsEventDispatcher::Dispatch(nsISupports* aTarget,
|
||||
if (parentEtci) {
|
||||
parentEtci->PreHandleEvent(preVisitor);
|
||||
if (preVisitor.mCanHandle) {
|
||||
targetEtci->SetNewTarget(parentTarget);
|
||||
chain[0].SetNewTarget(parentTarget);
|
||||
topEtci = parentEtci;
|
||||
continue;
|
||||
}
|
||||
@ -591,8 +594,6 @@ nsEventDispatcher::Dispatch(nsISupports* aTarget,
|
||||
// Note, nsEventTargetChainItem objects are deleted when the chain goes out of
|
||||
// the scope.
|
||||
|
||||
targetEtci = nullptr;
|
||||
|
||||
aEvent->mFlags.mIsBeingDispatched = false;
|
||||
aEvent->mFlags.mDispatchedAtLeastOnce = true;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user