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

Side by Side Diff: third_party/WebKit/Source/core/dom/ScriptedIdleTaskController.cpp

Issue 2514643002: DevTools: support all handlers that end up with function call in perfmonitor. (Closed)
Patch Set: review comments addressed. Created 4 years, 1 month 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
OLDNEW
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/dom/ScriptedIdleTaskController.h" 5 #include "core/dom/ScriptedIdleTaskController.h"
6 6
7 #include "core/dom/ExecutionContext.h" 7 #include "core/dom/ExecutionContext.h"
8 #include "core/dom/IdleRequestCallback.h" 8 #include "core/dom/IdleRequestCallback.h"
9 #include "core/dom/IdleRequestOptions.h" 9 #include "core/dom/IdleRequestOptions.h"
10 #include "core/frame/PerformanceMonitor.h"
10 #include "core/inspector/InspectorTraceEvents.h" 11 #include "core/inspector/InspectorTraceEvents.h"
11 #include "platform/Histogram.h" 12 #include "platform/Histogram.h"
12 #include "platform/tracing/TraceEvent.h" 13 #include "platform/tracing/TraceEvent.h"
13 #include "public/platform/Platform.h" 14 #include "public/platform/Platform.h"
14 #include "public/platform/WebScheduler.h" 15 #include "public/platform/WebScheduler.h"
15 #include "public/platform/WebTraceLocation.h" 16 #include "public/platform/WebTraceLocation.h"
16 #include "wtf/CurrentTime.h" 17 #include "wtf/CurrentTime.h"
17 #include "wtf/Functional.h" 18 #include "wtf/Functional.h"
18 #include "wtf/RefCounted.h" 19 #include "wtf/RefCounted.h"
19 20
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after
162 return; 163 return;
163 164
164 double allottedTimeMillis = 165 double allottedTimeMillis =
165 std::max((deadlineSeconds - monotonicallyIncreasingTime()) * 1000, 0.0); 166 std::max((deadlineSeconds - monotonicallyIncreasingTime()) * 1000, 0.0);
166 167
167 DEFINE_STATIC_LOCAL( 168 DEFINE_STATIC_LOCAL(
168 CustomCountHistogram, idleCallbackDeadlineHistogram, 169 CustomCountHistogram, idleCallbackDeadlineHistogram,
169 ("WebCore.ScriptedIdleTaskController.IdleCallbackDeadline", 0, 50, 50)); 170 ("WebCore.ScriptedIdleTaskController.IdleCallbackDeadline", 0, 50, 50));
170 idleCallbackDeadlineHistogram.count(allottedTimeMillis); 171 idleCallbackDeadlineHistogram.count(allottedTimeMillis);
171 172
173 PerformanceMonitor::HandlerCall handlerCall(getExecutionContext(),
174 "requestIdleCallback", true);
172 TRACE_EVENT1( 175 TRACE_EVENT1(
173 "devtools.timeline", "FireIdleCallback", "data", 176 "devtools.timeline", "FireIdleCallback", "data",
174 InspectorIdleCallbackFireEvent::data( 177 InspectorIdleCallbackFireEvent::data(
175 getExecutionContext(), id, allottedTimeMillis, 178 getExecutionContext(), id, allottedTimeMillis,
176 callbackType == IdleDeadline::CallbackType::CalledByTimeout)); 179 callbackType == IdleDeadline::CallbackType::CalledByTimeout));
177 callback->handleEvent(IdleDeadline::create(deadlineSeconds, callbackType)); 180 callback->handleEvent(IdleDeadline::create(deadlineSeconds, callbackType));
178 181
179 double overrunMillis = 182 double overrunMillis =
180 std::max((monotonicallyIncreasingTime() - deadlineSeconds) * 1000, 0.0); 183 std::max((monotonicallyIncreasingTime() - deadlineSeconds) * 1000, 0.0);
181 184
(...skipping 27 matching lines...) Expand all
209 RefPtr<internal::IdleRequestCallbackWrapper> callbackWrapper = 212 RefPtr<internal::IdleRequestCallbackWrapper> callbackWrapper =
210 internal::IdleRequestCallbackWrapper::create(callback.key, this); 213 internal::IdleRequestCallbackWrapper::create(callback.key, this);
211 m_scheduler->postIdleTask( 214 m_scheduler->postIdleTask(
212 BLINK_FROM_HERE, 215 BLINK_FROM_HERE,
213 WTF::bind(&internal::IdleRequestCallbackWrapper::idleTaskFired, 216 WTF::bind(&internal::IdleRequestCallbackWrapper::idleTaskFired,
214 callbackWrapper)); 217 callbackWrapper));
215 } 218 }
216 } 219 }
217 220
218 } // namespace blink 221 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698