| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2008 Apple Inc. All rights reserved. | 2 * Copyright (C) 2008 Apple Inc. All rights reserved. |
| 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 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 137 : m_type(type), | 137 : m_type(type), |
| 138 m_beginOrEnd(beginOrEnd), | 138 m_beginOrEnd(beginOrEnd), |
| 139 m_baseID(baseID), | 139 m_baseID(baseID), |
| 140 m_name(name), | 140 m_name(name), |
| 141 m_offset(offset), | 141 m_offset(offset), |
| 142 m_repeat(repeat) {} | 142 m_repeat(repeat) {} |
| 143 | 143 |
| 144 SVGSMILElement::Condition::~Condition() = default; | 144 SVGSMILElement::Condition::~Condition() = default; |
| 145 | 145 |
| 146 DEFINE_TRACE(SVGSMILElement::Condition) { | 146 DEFINE_TRACE(SVGSMILElement::Condition) { |
| 147 visitor->trace(m_syncBase); | 147 visitor->trace(m_baseElement); |
| 148 visitor->trace(m_eventListener); | 148 visitor->trace(m_eventListener); |
| 149 } | 149 } |
| 150 | 150 |
| 151 void SVGSMILElement::Condition::connectSyncBase(SVGSMILElement& timedElement) { | 151 void SVGSMILElement::Condition::connectSyncBase(SVGSMILElement& timedElement) { |
| 152 DCHECK(!m_baseID.isEmpty()); | 152 DCHECK(!m_baseID.isEmpty()); |
| 153 DCHECK_EQ(m_type, Syncbase); |
| 153 Element* element = timedElement.treeScope().getElementById(m_baseID); | 154 Element* element = timedElement.treeScope().getElementById(m_baseID); |
| 154 if (!element || !isSVGSMILElement(*element)) { | 155 if (!element || !isSVGSMILElement(*element)) { |
| 155 m_syncBase = nullptr; | 156 m_baseElement = nullptr; |
| 156 return; | 157 return; |
| 157 } | 158 } |
| 158 m_syncBase = toSVGSMILElement(element); | 159 m_baseElement = toSVGSMILElement(element); |
| 159 m_syncBase->addSyncBaseDependent(timedElement); | 160 toSVGSMILElement(*element).addSyncBaseDependent(timedElement); |
| 160 } | 161 } |
| 161 | 162 |
| 162 void SVGSMILElement::Condition::disconnectSyncBase( | 163 void SVGSMILElement::Condition::disconnectSyncBase( |
| 163 SVGSMILElement& timedElement) { | 164 SVGSMILElement& timedElement) { |
| 164 if (!m_syncBase) | 165 DCHECK_EQ(m_type, Syncbase); |
| 166 if (!m_baseElement) |
| 165 return; | 167 return; |
| 166 m_syncBase->removeSyncBaseDependent(timedElement); | 168 toSVGSMILElement(*m_baseElement).removeSyncBaseDependent(timedElement); |
| 167 m_syncBase = nullptr; | 169 m_baseElement = nullptr; |
| 168 } | 170 } |
| 169 | 171 |
| 170 SVGElement* SVGSMILElement::Condition::lookupEventBase( | 172 SVGElement* SVGSMILElement::Condition::lookupEventBase( |
| 171 SVGSMILElement& timedElement) const { | 173 SVGSMILElement& timedElement) const { |
| 172 Element* eventBase = m_baseID.isEmpty() | 174 Element* eventBase = m_baseID.isEmpty() |
| 173 ? timedElement.targetElement() | 175 ? timedElement.targetElement() |
| 174 : timedElement.treeScope().getElementById(m_baseID); | 176 : timedElement.treeScope().getElementById(m_baseID); |
| 175 if (!eventBase || !eventBase->isSVGElement()) | 177 if (!eventBase || !eventBase->isSVGElement()) |
| 176 return nullptr; | 178 return nullptr; |
| 177 return toSVGElement(eventBase); | 179 return toSVGElement(eventBase); |
| 178 } | 180 } |
| 179 | 181 |
| 180 void SVGSMILElement::Condition::connectEventBase(SVGSMILElement& timedElement) { | 182 void SVGSMILElement::Condition::connectEventBase(SVGSMILElement& timedElement) { |
| 181 DCHECK(!m_syncBase); | 183 DCHECK_EQ(m_type, EventBase); |
| 184 DCHECK(!m_baseElement); |
| 182 SVGElement* eventBase = lookupEventBase(timedElement); | 185 SVGElement* eventBase = lookupEventBase(timedElement); |
| 183 if (!eventBase) { | 186 if (!eventBase) { |
| 184 if (m_baseID.isEmpty()) | 187 if (m_baseID.isEmpty()) |
| 185 return; | 188 return; |
| 186 SVGTreeScopeResources& treeScopeResources = | 189 SVGTreeScopeResources& treeScopeResources = |
| 187 timedElement.treeScope().ensureSVGTreeScopedResources(); | 190 timedElement.treeScope().ensureSVGTreeScopedResources(); |
| 188 if (!treeScopeResources.isElementPendingResource(timedElement, m_baseID)) | 191 if (!treeScopeResources.isElementPendingResource(timedElement, m_baseID)) |
| 189 treeScopeResources.addPendingResource(m_baseID, timedElement); | 192 treeScopeResources.addPendingResource(m_baseID, timedElement); |
| 190 return; | 193 return; |
| 191 } | 194 } |
| 192 DCHECK(!m_eventListener); | 195 DCHECK(!m_eventListener); |
| 193 m_eventListener = ConditionEventListener::create(&timedElement, this); | 196 m_eventListener = ConditionEventListener::create(&timedElement, this); |
| 194 eventBase->addEventListener(m_name, m_eventListener, false); | 197 m_baseElement = eventBase; |
| 195 timedElement.addReferenceTo(eventBase); | 198 m_baseElement->addEventListener(m_name, m_eventListener, false); |
| 199 timedElement.addReferenceTo(m_baseElement); |
| 196 } | 200 } |
| 197 | 201 |
| 198 void SVGSMILElement::Condition::disconnectEventBase( | 202 void SVGSMILElement::Condition::disconnectEventBase( |
| 199 SVGSMILElement& timedElement) { | 203 SVGSMILElement& timedElement) { |
| 200 DCHECK(!m_syncBase); | 204 DCHECK_EQ(m_type, EventBase); |
| 201 if (!m_eventListener) | 205 if (!m_eventListener) |
| 202 return; | 206 return; |
| 203 // Note: It's a memory optimization to try to remove our condition event | 207 m_baseElement->removeEventListener(m_name, m_eventListener, false); |
| 204 // listener, but it's not guaranteed to work, since we have no guarantee that | 208 m_baseElement = nullptr; |
| 205 // we will be able to find our condition's original eventBase. So, we also | |
| 206 // have to disconnect ourselves from our condition event listener, in case it | |
| 207 // later fires. | |
| 208 if (SVGElement* eventBase = lookupEventBase(timedElement)) | |
| 209 eventBase->removeEventListener(m_name, m_eventListener, false); | |
| 210 m_eventListener->disconnectAnimation(); | 209 m_eventListener->disconnectAnimation(); |
| 211 m_eventListener = nullptr; | 210 m_eventListener = nullptr; |
| 212 } | 211 } |
| 213 | 212 |
| 214 SVGSMILElement::SVGSMILElement(const QualifiedName& tagName, Document& doc) | 213 SVGSMILElement::SVGSMILElement(const QualifiedName& tagName, Document& doc) |
| 215 : SVGElement(tagName, doc), | 214 : SVGElement(tagName, doc), |
| 216 SVGTests(this), | 215 SVGTests(this), |
| 217 m_attributeName(anyQName()), | 216 m_attributeName(anyQName()), |
| 218 m_targetElement(nullptr), | 217 m_targetElement(nullptr), |
| 219 m_syncBaseConditionsConnected(false), | 218 m_syncBaseConditionsConnected(false), |
| (...skipping 1071 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1291 DEFINE_TRACE(SVGSMILElement) { | 1290 DEFINE_TRACE(SVGSMILElement) { |
| 1292 visitor->trace(m_targetElement); | 1291 visitor->trace(m_targetElement); |
| 1293 visitor->trace(m_timeContainer); | 1292 visitor->trace(m_timeContainer); |
| 1294 visitor->trace(m_conditions); | 1293 visitor->trace(m_conditions); |
| 1295 visitor->trace(m_syncBaseDependents); | 1294 visitor->trace(m_syncBaseDependents); |
| 1296 SVGElement::trace(visitor); | 1295 SVGElement::trace(visitor); |
| 1297 SVGTests::trace(visitor); | 1296 SVGTests::trace(visitor); |
| 1298 } | 1297 } |
| 1299 | 1298 |
| 1300 } // namespace blink | 1299 } // namespace blink |
| OLD | NEW |