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

Side by Side Diff: third_party/WebKit/Source/core/xmlhttprequest/XMLHttpRequestProgressEventThrottle.cpp

Issue 2269513002: Use per-frame task runner in XHR (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: make XHRPT own a clone of WebTaskRunner Created 4 years, 3 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
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2010 Julien Chaffraix <jchaffraix@webkit.org> All right reserv ed. 2 * Copyright (C) 2010 Julien Chaffraix <jchaffraix@webkit.org> All right reserv ed.
3 * Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies) 3 * Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies)
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions 6 * modification, are permitted provided that the following conditions
7 * are met: 7 * are met:
8 * 1. Redistributions of source code must retain the above copyright 8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright 10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the 11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution. 12 * documentation and/or other materials provided with the distribution.
13 * 13 *
14 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 14 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
15 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 15 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
16 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 16 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
17 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 17 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
18 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 18 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
19 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 19 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
20 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 20 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 21 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 22 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 */ 25 */
26 26
27 #include "core/xmlhttprequest/XMLHttpRequestProgressEventThrottle.h" 27 #include "core/xmlhttprequest/XMLHttpRequestProgressEventThrottle.h"
28 28
29 #include "core/EventTypeNames.h" 29 #include "core/EventTypeNames.h"
30 #include "core/dom/TaskRunnerHelper.h"
30 #include "core/events/ProgressEvent.h" 31 #include "core/events/ProgressEvent.h"
31 #include "core/inspector/InspectorInstrumentation.h" 32 #include "core/inspector/InspectorInstrumentation.h"
32 #include "core/inspector/InspectorTraceEvents.h" 33 #include "core/inspector/InspectorTraceEvents.h"
33 #include "core/xmlhttprequest/XMLHttpRequest.h" 34 #include "core/xmlhttprequest/XMLHttpRequest.h"
34 #include "public/platform/Platform.h" 35 #include "public/platform/Platform.h"
35 #include "public/platform/WebScheduler.h" 36 #include "public/platform/WebScheduler.h"
36 #include "public/platform/WebThread.h" 37 #include "public/platform/WebThread.h"
37 #include "wtf/Assertions.h" 38 #include "wtf/Assertions.h"
38 #include "wtf/text/AtomicString.h" 39 #include "wtf/text/AtomicString.h"
39 40
40 namespace blink { 41 namespace blink {
41 42
42 static const double kMinimumProgressEventDispatchingIntervalInSeconds = .05; // 50 ms per specification. 43 static const double kMinimumProgressEventDispatchingIntervalInSeconds = .05; // 50 ms per specification.
43 44
45 // static
46 XMLHttpRequestProgressEventThrottle* XMLHttpRequestProgressEventThrottle::create (XMLHttpRequest* eventTarget)
47 {
48 return new XMLHttpRequestProgressEventThrottle(eventTarget, TaskRunnerHelper ::get(TaskType::Networking, eventTarget->getExecutionContext())->clone());
49 }
50
44 XMLHttpRequestProgressEventThrottle::DeferredEvent::DeferredEvent() 51 XMLHttpRequestProgressEventThrottle::DeferredEvent::DeferredEvent()
45 { 52 {
46 clear(); 53 clear();
47 } 54 }
48 55
49 void XMLHttpRequestProgressEventThrottle::DeferredEvent::set(bool lengthComputab le, unsigned long long loaded, unsigned long long total) 56 void XMLHttpRequestProgressEventThrottle::DeferredEvent::set(bool lengthComputab le, unsigned long long loaded, unsigned long long total)
50 { 57 {
51 m_isSet = true; 58 m_isSet = true;
52 59
53 m_lengthComputable = lengthComputable; 60 m_lengthComputable = lengthComputable;
(...skipping 12 matching lines...) Expand all
66 73
67 Event* XMLHttpRequestProgressEventThrottle::DeferredEvent::take() 74 Event* XMLHttpRequestProgressEventThrottle::DeferredEvent::take()
68 { 75 {
69 ASSERT(m_isSet); 76 ASSERT(m_isSet);
70 77
71 Event* event = ProgressEvent::create(EventTypeNames::progress, m_lengthCompu table, m_loaded, m_total); 78 Event* event = ProgressEvent::create(EventTypeNames::progress, m_lengthCompu table, m_loaded, m_total);
72 clear(); 79 clear();
73 return event; 80 return event;
74 } 81 }
75 82
76 XMLHttpRequestProgressEventThrottle::XMLHttpRequestProgressEventThrottle(XMLHttp Request* target) 83 XMLHttpRequestProgressEventThrottle::XMLHttpRequestProgressEventThrottle(XMLHttp Request* target, std::unique_ptr<WebTaskRunner> taskRunner)
77 : TimerBase(Platform::current()->currentThread()->scheduler()->timerTaskRunn er()) 84 : TimerBase(taskRunner.get())
85 , m_taskRunner(std::move(taskRunner))
dcheng 2016/08/24 23:30:34 I'm a bit confused why we need to clone() and keep
haraken 2016/08/24 23:51:58 It's normally a problem today. Currently we need t
78 , m_target(target) 86 , m_target(target)
79 , m_hasDispatchedProgressProgressEvent(false) 87 , m_hasDispatchedProgressProgressEvent(false)
80 { 88 {
81 ASSERT(target); 89 ASSERT(target);
82 } 90 }
83 91
84 XMLHttpRequestProgressEventThrottle::~XMLHttpRequestProgressEventThrottle() 92 XMLHttpRequestProgressEventThrottle::~XMLHttpRequestProgressEventThrottle()
85 { 93 {
86 } 94 }
87 95
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after
175 // event-handler could insert new active DOM objects to the list. 183 // event-handler could insert new active DOM objects to the list.
176 startOneShot(0, BLINK_FROM_HERE); 184 startOneShot(0, BLINK_FROM_HERE);
177 } 185 }
178 186
179 DEFINE_TRACE(XMLHttpRequestProgressEventThrottle) 187 DEFINE_TRACE(XMLHttpRequestProgressEventThrottle)
180 { 188 {
181 visitor->trace(m_target); 189 visitor->trace(m_target);
182 } 190 }
183 191
184 } // namespace blink 192 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698