Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(268)

Side by Side Diff: Source/core/events/MouseEvent.cpp

Issue 181153003: Make Event RefCountedGarbageCollected and implement trace() methods to the Event hierarcy (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2001 Peter Kelly (pmk@post.com) 2 * Copyright (C) 2001 Peter Kelly (pmk@post.com)
3 * Copyright (C) 2001 Tobias Anton (anton@stud.fbi.fh-darmstadt.de) 3 * Copyright (C) 2001 Tobias Anton (anton@stud.fbi.fh-darmstadt.de)
4 * Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) 4 * Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com)
5 * Copyright (C) 2003, 2005, 2006, 2008 Apple Inc. All rights reserved. 5 * Copyright (C) 2003, 2005, 2006, 2008 Apple Inc. All rights reserved.
6 * 6 *
7 * This library is free software; you can redistribute it and/or 7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Library General Public 8 * modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either 9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version. 10 * version 2 of the License, or (at your option) any later version.
(...skipping 172 matching lines...) Expand 10 before | Expand all | Expand 10 after
183 183
184 Node* MouseEvent::fromElement() const 184 Node* MouseEvent::fromElement() const
185 { 185 {
186 // MSIE extension - "object from which activation or the mouse pointer is ex iting during the event" (huh?) 186 // MSIE extension - "object from which activation or the mouse pointer is ex iting during the event" (huh?)
187 if (type() != EventTypeNames::mouseout && type() != EventTypeNames::mouselea ve) 187 if (type() != EventTypeNames::mouseout && type() != EventTypeNames::mouselea ve)
188 return relatedTarget() ? relatedTarget()->toNode() : 0; 188 return relatedTarget() ? relatedTarget()->toNode() : 0;
189 189
190 return target() ? target()->toNode() : 0; 190 return target() ? target()->toNode() : 0;
191 } 191 }
192 192
193 void MouseEvent::trace(Visitor* visitor)
Mads Ager (chromium) 2014/02/26 09:03:52 You need to trace m_clipBoard
194 {
195 MouseRelatedEvent::trace(visitor);
196 }
197
193 PassRefPtr<SimulatedMouseEvent> SimulatedMouseEvent::create(const AtomicString& eventType, PassRefPtr<AbstractView> view, PassRefPtr<Event> underlyingEvent) 198 PassRefPtr<SimulatedMouseEvent> SimulatedMouseEvent::create(const AtomicString& eventType, PassRefPtr<AbstractView> view, PassRefPtr<Event> underlyingEvent)
194 { 199 {
195 return adoptRef(new SimulatedMouseEvent(eventType, view, underlyingEvent)); 200 return adoptRef(new SimulatedMouseEvent(eventType, view, underlyingEvent));
196 } 201 }
197 202
198 SimulatedMouseEvent::~SimulatedMouseEvent() 203 SimulatedMouseEvent::~SimulatedMouseEvent()
199 { 204 {
200 } 205 }
201 206
202 SimulatedMouseEvent::SimulatedMouseEvent(const AtomicString& eventType, PassRefP tr<AbstractView> view, PassRefPtr<Event> underlyingEvent) 207 SimulatedMouseEvent::SimulatedMouseEvent(const AtomicString& eventType, PassRefP tr<AbstractView> view, PassRefPtr<Event> underlyingEvent)
203 : MouseEvent(eventType, true, true, view, 0, 0, 0, 0, 0, 208 : MouseEvent(eventType, true, true, view, 0, 0, 0, 0, 0,
204 0, 0, 209 0, 0,
205 false, false, false, false, 0, nullptr, nullptr, true) 210 false, false, false, false, 0, nullptr, nullptr, true)
206 { 211 {
207 if (UIEventWithKeyState* keyStateEvent = findEventWithKeyState(underlyingEve nt.get())) { 212 if (UIEventWithKeyState* keyStateEvent = findEventWithKeyState(underlyingEve nt.get())) {
208 m_ctrlKey = keyStateEvent->ctrlKey(); 213 m_ctrlKey = keyStateEvent->ctrlKey();
209 m_altKey = keyStateEvent->altKey(); 214 m_altKey = keyStateEvent->altKey();
210 m_shiftKey = keyStateEvent->shiftKey(); 215 m_shiftKey = keyStateEvent->shiftKey();
211 m_metaKey = keyStateEvent->metaKey(); 216 m_metaKey = keyStateEvent->metaKey();
212 } 217 }
213 setUnderlyingEvent(underlyingEvent); 218 setUnderlyingEvent(underlyingEvent);
214 219
215 if (this->underlyingEvent() && this->underlyingEvent()->isMouseEvent()) { 220 if (this->underlyingEvent() && this->underlyingEvent()->isMouseEvent()) {
216 MouseEvent* mouseEvent = toMouseEvent(this->underlyingEvent()); 221 MouseEvent* mouseEvent = toMouseEvent(this->underlyingEvent());
217 m_screenLocation = mouseEvent->screenLocation(); 222 m_screenLocation = mouseEvent->screenLocation();
218 initCoordinates(mouseEvent->clientLocation()); 223 initCoordinates(mouseEvent->clientLocation());
219 } 224 }
220 } 225 }
221 226
227 void SimulatedMouseEvent::trace(Visitor* visitor)
228 {
229 MouseEvent::trace(visitor);
230 }
231
222 PassRefPtr<MouseEventDispatchMediator> MouseEventDispatchMediator::create(PassRe fPtr<MouseEvent> mouseEvent, MouseEventType mouseEventType) 232 PassRefPtr<MouseEventDispatchMediator> MouseEventDispatchMediator::create(PassRe fPtr<MouseEvent> mouseEvent, MouseEventType mouseEventType)
223 { 233 {
224 return adoptRef(new MouseEventDispatchMediator(mouseEvent, mouseEventType)); 234 return adoptRef(new MouseEventDispatchMediator(mouseEvent, mouseEventType));
225 } 235 }
226 236
227 MouseEventDispatchMediator::MouseEventDispatchMediator(PassRefPtr<MouseEvent> mo useEvent, MouseEventType mouseEventType) 237 MouseEventDispatchMediator::MouseEventDispatchMediator(PassRefPtr<MouseEvent> mo useEvent, MouseEventType mouseEventType)
228 : EventDispatchMediator(mouseEvent), m_mouseEventType(mouseEventType) 238 : EventDispatchMediator(mouseEvent), m_mouseEventType(mouseEventType)
229 { 239 {
230 } 240 }
231 241
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
268 event()->button(), relatedTarget); 278 event()->button(), relatedTarget);
269 if (event()->defaultHandled()) 279 if (event()->defaultHandled())
270 doubleClickEvent->setDefaultHandled(); 280 doubleClickEvent->setDefaultHandled();
271 EventDispatcher::dispatchEvent(dispatcher->node(), MouseEventDispatchMediato r::create(doubleClickEvent)); 281 EventDispatcher::dispatchEvent(dispatcher->node(), MouseEventDispatchMediato r::create(doubleClickEvent));
272 if (doubleClickEvent->defaultHandled() || doubleClickEvent->defaultPrevented ()) 282 if (doubleClickEvent->defaultHandled() || doubleClickEvent->defaultPrevented ())
273 return false; 283 return false;
274 return !swallowEvent; 284 return !swallowEvent;
275 } 285 }
276 286
277 } // namespace WebCore 287 } // namespace WebCore
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698