Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "core/timing/PerformanceObserver.h" | 5 #include "core/timing/PerformanceObserver.h" |
| 6 | 6 |
| 7 #include "bindings/core/v8/ExceptionState.h" | 7 #include "bindings/core/v8/ExceptionState.h" |
| 8 #include "bindings/core/v8/PerformanceObserverCallback.h" | 8 #include "bindings/core/v8/PerformanceObserverCallback.h" |
| 9 #include "core/dom/ExecutionContext.h" | 9 #include "core/dom/ExecutionContext.h" |
| 10 #include "core/timing/PerformanceBase.h" | 10 #include "core/timing/PerformanceBase.h" |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 42 } | 42 } |
| 43 | 43 |
| 44 PerformanceEntryTypeMask entryTypes = PerformanceEntry::Invalid; | 44 PerformanceEntryTypeMask entryTypes = PerformanceEntry::Invalid; |
| 45 if (observerInit.hasEntryTypes() && observerInit.entryTypes().size()) { | 45 if (observerInit.hasEntryTypes() && observerInit.entryTypes().size()) { |
| 46 const Vector<String>& sequence = observerInit.entryTypes(); | 46 const Vector<String>& sequence = observerInit.entryTypes(); |
| 47 for (const auto& entryTypeString : sequence) | 47 for (const auto& entryTypeString : sequence) |
| 48 entryTypes |= PerformanceEntry::toEntryTypeEnum(entryTypeString); | 48 entryTypes |= PerformanceEntry::toEntryTypeEnum(entryTypeString); |
| 49 } | 49 } |
| 50 if (entryTypes == PerformanceEntry::Invalid) { | 50 if (entryTypes == PerformanceEntry::Invalid) { |
| 51 exceptionState.throwTypeError( | 51 exceptionState.throwTypeError( |
| 52 "A Performance Observer MUST have a non-empty entryTypes attribute."); | 52 "A Performance Observer MUST have a valid entryTypes attribute."); |
|
Yoav Weiss
2016/11/04 21:49:16
Just to clarify, if one of the entries is valid, t
sunjian
2016/11/09 23:27:58
Done.
| |
| 53 return; | 53 return; |
| 54 } | 54 } |
| 55 m_filterOptions = entryTypes; | 55 m_filterOptions = entryTypes; |
| 56 if (m_isRegistered) | 56 if (m_isRegistered) |
| 57 m_performance->updatePerformanceObserverFilterOptions(); | 57 m_performance->updatePerformanceObserverFilterOptions(); |
| 58 else | 58 else |
| 59 m_performance->registerPerformanceObserver(*this); | 59 m_performance->registerPerformanceObserver(*this); |
| 60 m_isRegistered = true; | 60 m_isRegistered = true; |
| 61 } | 61 } |
| 62 | 62 |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 97 visitor->trace(m_callback); | 97 visitor->trace(m_callback); |
| 98 visitor->trace(m_performance); | 98 visitor->trace(m_performance); |
| 99 visitor->trace(m_performanceEntries); | 99 visitor->trace(m_performanceEntries); |
| 100 } | 100 } |
| 101 | 101 |
| 102 DEFINE_TRACE_WRAPPERS(PerformanceObserver) { | 102 DEFINE_TRACE_WRAPPERS(PerformanceObserver) { |
| 103 visitor->traceWrappers(m_callback); | 103 visitor->traceWrappers(m_callback); |
| 104 } | 104 } |
| 105 | 105 |
| 106 } // namespace blink | 106 } // namespace blink |
| OLD | NEW |