- From: <bugzilla@jessica.w3.org>
- Date: Fri, 15 Jun 2012 11:33:39 +0000
- To: public-webapps-bugzilla@w3.org
https://www.w3.org/Bugs/Public/show_bug.cgi?id=17090 --- Comment #8 from Hayato Ito <hayato@chromium.org> 2012-06-15 11:33:35 UTC --- I've updated the algorithm. Because we should treat the case for fallback elements in an insertion point, I've added a check logic which makes sure that LAST is actually distributed to a insertion point. 6.1. Event Retargeting Input NODE, a DOM node Output TARGETS, a list of tuples, each containing NODE's ancestor and its relative target 1. Let STACK be a stack of DOM nodes 2. Let ANCESTOR be NODE 3. Let LAST be undefined 4. Repeat while ANCESTOR exists: 1. If STACK is empty, push ANCESTOR into STACK 2. Otherwise, if ANCESTOR is an insertion point or a shadow insertion point: 1. If LAST is distributed or assigned into ANCESTOR: 1. Let TARGET be the DOM node at the top of STACK 2. push TARGET into STACK 3. Let TARGET be the DOM node at the top of STACK 4. Add (TARGET, ANCESTOR) tuple to TARGETS 5. If ANCESTOR is a shadow root, pop STACK 6. Let LAST be ANCESTOR 7. Set ANCESTOR to be the result of parent calculation algorithm, given ANCESTOR as input 6.2. Retargeting relatedTarget Input NODE, the DOM node on which event listeners would be invoked RELATED, the related target for the event Output ADJUSTED, the adjusted related target for NODE 1. Let TARGET be NODE 2. Let ADJUSTED be undefined 3. Repeat while TARGET exists 1. Let STACK be a stack of DOM nodes 2. Let ANCESTOR be RELATED 3. Let LAST be undefined 4. Repeat while ANCESTOR exists: 1. If STACK is empty, push ANCESTOR into STACK 2. Otherwise, if ANCESTOR is an insertion point or a shadow insertion point: 1. If LAST is distributed or assigned into ANCESTOR: 1. Let HEAD be the DOM node at the top of STACK 2. push HEAD into STACK 3. If a ANCESTOR and TARGET are in the same subtree: 1. let ADJUSTED be the DOM node at the top of STACK 2. stops 4. If ANCESTOR is a shadow root, pop STACK 5. Let LAST be ANCESTOR 6. Set ANCESTOR to be the result of parent calculation algorithm, given ANCESTOR as input 5. If TARGET is a shadow root, let TARGET be the shadow host of TARGET 6. Otherwise, let TARGET be TARGET's parent node -- Configure bugmail: https://www.w3.org/Bugs/Public/userprefs.cgi?tab=email ------- You are receiving this mail because: ------- You are the QA contact for the bug.
Received on Friday, 15 June 2012 11:34:04 UTC