| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2012 Victor Carbune (victor@rosedu.org) | 2 * Copyright (C) 2012 Victor Carbune (victor@rosedu.org) |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 49 } | 49 } |
| 50 | 50 |
| 51 bool GenericEventQueue::enqueueEvent(PassRefPtr<Event> event) | 51 bool GenericEventQueue::enqueueEvent(PassRefPtr<Event> event) |
| 52 { | 52 { |
| 53 if (m_isClosed) | 53 if (m_isClosed) |
| 54 return false; | 54 return false; |
| 55 | 55 |
| 56 if (event->target() == m_owner) | 56 if (event->target() == m_owner) |
| 57 event->setTarget(0); | 57 event->setTarget(0); |
| 58 | 58 |
| 59 TRACE_EVENT_ASYNC_BEGIN1("event", "GenericEventQueue:enqueueEvent", event.ge
t(), "type", event->type().string().ascii()); | 59 TRACE_EVENT_ASYNC_BEGIN1("event", "GenericEventQueue:enqueueEvent", event.ge
t(), "type", event->type().ascii()); |
| 60 m_pendingEvents.append(event); | 60 m_pendingEvents.append(event); |
| 61 | 61 |
| 62 if (!m_timer.isActive()) | 62 if (!m_timer.isActive()) |
| 63 m_timer.startOneShot(0); | 63 m_timer.startOneShot(0); |
| 64 | 64 |
| 65 return true; | 65 return true; |
| 66 } | 66 } |
| 67 | 67 |
| 68 bool GenericEventQueue::cancelEvent(Event* event) | 68 bool GenericEventQueue::cancelEvent(Event* event) |
| 69 { | 69 { |
| 70 bool found = m_pendingEvents.contains(event); | 70 bool found = m_pendingEvents.contains(event); |
| 71 | 71 |
| 72 if (found) { | 72 if (found) { |
| 73 m_pendingEvents.remove(m_pendingEvents.find(event)); | 73 m_pendingEvents.remove(m_pendingEvents.find(event)); |
| 74 TRACE_EVENT_ASYNC_END2("event", "GenericEventQueue:enqueueEvent", event,
"type", event->type().string().ascii(), "status", "cancelled"); | 74 TRACE_EVENT_ASYNC_END2("event", "GenericEventQueue:enqueueEvent", event,
"type", event->type().ascii(), "status", "cancelled"); |
| 75 } | 75 } |
| 76 | 76 |
| 77 if (m_pendingEvents.isEmpty()) | 77 if (m_pendingEvents.isEmpty()) |
| 78 m_timer.stop(); | 78 m_timer.stop(); |
| 79 | 79 |
| 80 return found; | 80 return found; |
| 81 } | 81 } |
| 82 | 82 |
| 83 void GenericEventQueue::timerFired(Timer<GenericEventQueue>*) | 83 void GenericEventQueue::timerFired(Timer<GenericEventQueue>*) |
| 84 { | 84 { |
| 85 ASSERT(!m_timer.isActive()); | 85 ASSERT(!m_timer.isActive()); |
| 86 ASSERT(!m_pendingEvents.isEmpty()); | 86 ASSERT(!m_pendingEvents.isEmpty()); |
| 87 | 87 |
| 88 Vector<RefPtr<Event> > pendingEvents; | 88 Vector<RefPtr<Event> > pendingEvents; |
| 89 m_pendingEvents.swap(pendingEvents); | 89 m_pendingEvents.swap(pendingEvents); |
| 90 | 90 |
| 91 RefPtr<EventTarget> protect(m_owner); | 91 RefPtr<EventTarget> protect(m_owner); |
| 92 for (size_t i = 0; i < pendingEvents.size(); ++i) { | 92 for (size_t i = 0; i < pendingEvents.size(); ++i) { |
| 93 Event* event = pendingEvents[i].get(); | 93 Event* event = pendingEvents[i].get(); |
| 94 EventTarget* target = event->target() ? event->target() : m_owner; | 94 EventTarget* target = event->target() ? event->target() : m_owner; |
| 95 CString type(event->type().string().ascii()); | 95 CString type(event->type().ascii()); |
| 96 TRACE_EVENT_ASYNC_STEP_INTO1("event", "GenericEventQueue:enqueueEvent",
event, "dispatch", "type", type); | 96 TRACE_EVENT_ASYNC_STEP_INTO1("event", "GenericEventQueue:enqueueEvent",
event, "dispatch", "type", type); |
| 97 target->dispatchEvent(pendingEvents[i].release()); | 97 target->dispatchEvent(pendingEvents[i].release()); |
| 98 TRACE_EVENT_ASYNC_END1("event", "GenericEventQueue:enqueueEvent", event,
"type", type); | 98 TRACE_EVENT_ASYNC_END1("event", "GenericEventQueue:enqueueEvent", event,
"type", type); |
| 99 } | 99 } |
| 100 } | 100 } |
| 101 | 101 |
| 102 void GenericEventQueue::close() | 102 void GenericEventQueue::close() |
| 103 { | 103 { |
| 104 m_isClosed = true; | 104 m_isClosed = true; |
| 105 cancelAllEvents(); | 105 cancelAllEvents(); |
| 106 } | 106 } |
| 107 | 107 |
| 108 void GenericEventQueue::cancelAllEvents() | 108 void GenericEventQueue::cancelAllEvents() |
| 109 { | 109 { |
| 110 m_timer.stop(); | 110 m_timer.stop(); |
| 111 | 111 |
| 112 for (size_t i = 0; i < m_pendingEvents.size(); ++i) { | 112 for (size_t i = 0; i < m_pendingEvents.size(); ++i) { |
| 113 Event* event = m_pendingEvents[i].get(); | 113 Event* event = m_pendingEvents[i].get(); |
| 114 TRACE_EVENT_ASYNC_END2("event", "GenericEventQueue:enqueueEvent", event,
"type", event->type().string().ascii(), "status", "cancelled"); | 114 TRACE_EVENT_ASYNC_END2("event", "GenericEventQueue:enqueueEvent", event,
"type", event->type().ascii(), "status", "cancelled"); |
| 115 } | 115 } |
| 116 m_pendingEvents.clear(); | 116 m_pendingEvents.clear(); |
| 117 } | 117 } |
| 118 | 118 |
| 119 bool GenericEventQueue::hasPendingEvents() const | 119 bool GenericEventQueue::hasPendingEvents() const |
| 120 { | 120 { |
| 121 return m_pendingEvents.size(); | 121 return m_pendingEvents.size(); |
| 122 } | 122 } |
| 123 | 123 |
| 124 } | 124 } |
| OLD | NEW |