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

Unified Diff: third_party/WebKit/Source/core/workers/ThreadedMessagingProxyBase.h

Issue 2310673002: [worklets] Split up InProcessWorkerMessagingProxy into a base+worker class. (Closed)
Patch Set: cleanup. 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 side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/core/workers/ThreadedMessagingProxyBase.h
diff --git a/third_party/WebKit/Source/core/workers/InProcessWorkerMessagingProxy.h b/third_party/WebKit/Source/core/workers/ThreadedMessagingProxyBase.h
similarity index 33%
copy from third_party/WebKit/Source/core/workers/InProcessWorkerMessagingProxy.h
copy to third_party/WebKit/Source/core/workers/ThreadedMessagingProxyBase.h
index 65a768ec6f97d9505a6f661307028ffe5a849374..04400d87a950c5f8aee5766ef8c86f736160d181 100644
--- a/third_party/WebKit/Source/core/workers/InProcessWorkerMessagingProxy.h
+++ b/third_party/WebKit/Source/core/workers/ThreadedMessagingProxyBase.h
@@ -1,82 +1,37 @@
-/*
- * Copyright (C) 2008 Apple Inc. All Rights Reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
- * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
- * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- */
-
-#ifndef InProcessWorkerMessagingProxy_h
-#define InProcessWorkerMessagingProxy_h
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef ThreadedMessagingProxyBase_h
+#define ThreadedMessagingProxyBase_h
#include "core/CoreExport.h"
-#include "core/dom/ExecutionContext.h"
-#include "core/dom/MessagePort.h"
#include "core/inspector/ConsoleTypes.h"
#include "core/workers/WorkerLoaderProxy.h"
-#include "platform/heap/Handle.h"
#include "wtf/Forward.h"
-#include "wtf/Noncopyable.h"
-#include "wtf/PassRefPtr.h"
-#include "wtf/RefPtr.h"
-#include "wtf/Vector.h"
-#include <memory>
namespace blink {
class ExecutionContext;
-class InProcessWorkerBase;
-class InProcessWorkerObjectProxy;
class ParentFrameTaskRunners;
-class WorkerClients;
class WorkerInspectorProxy;
+class WorkerLoaderProxy;
class WorkerThread;
+class WorkerThreadStartupData;
-// TODO(nhiroki): "MessagingProxy" is not well-defined term among worker
-// components. Probably we should rename this to something more suitable.
-// (http://crbug.com/603785)
-class CORE_EXPORT InProcessWorkerMessagingProxy : private WorkerLoaderProxyProvider {
- WTF_MAKE_NONCOPYABLE(InProcessWorkerMessagingProxy);
+class CORE_EXPORT ThreadedMessagingProxyBase : private WorkerLoaderProxyProvider {
public:
- // These methods should only be used on the parent context thread.
- void startWorkerGlobalScope(const KURL& scriptURL, const String& userAgent, const String& sourceCode);
- void terminateWorkerGlobalScope();
- void postMessageToWorkerGlobalScope(PassRefPtr<SerializedScriptValue>, std::unique_ptr<MessagePortChannelArray>);
- bool hasPendingActivity() const;
- void workerObjectDestroyed();
-
- // These methods come from worker context thread via
- // InProcessWorkerObjectProxy and are called on the parent context thread.
- void postMessageToWorkerObject(PassRefPtr<SerializedScriptValue>, std::unique_ptr<MessagePortChannelArray>);
- void dispatchErrorEvent(const String& errorMessage, std::unique_ptr<SourceLocation>, int exceptionId);
+ void terminateGlobalScope();
+
+ virtual void workerThreadCreated();
+ virtual void parentObjectDestroyed();
yhirano 2016/09/07 04:46:37 Is "parent object" defined? Can you write some com
ikilpatrick 2016/09/07 17:53:57 Added comments in this file.
+
void reportConsoleMessage(MessageSource, MessageLevel, const String& message, std::unique_ptr<SourceLocation>);
void postMessageToPageInspector(const String&);
// 'virtual' for testing.
- virtual void confirmMessageFromWorkerObject();
- virtual void pendingActivityFinished();
virtual void workerThreadTerminated();
- void workerThreadCreated();
-
ExecutionContext* getExecutionContext() const { return m_executionContext.get(); }
ParentFrameTaskRunners* getParentFrameTaskRunners() { return m_parentFrameTaskRunners.get(); }
@@ -85,53 +40,43 @@ public:
static int proxyCount();
protected:
- InProcessWorkerMessagingProxy(InProcessWorkerBase*, WorkerClients*);
- ~InProcessWorkerMessagingProxy() override;
+ ThreadedMessagingProxyBase(ExecutionContext*);
+ ~ThreadedMessagingProxyBase() override;
+ void initializeWorkerThread(std::unique_ptr<WorkerThreadStartupData>);
virtual std::unique_ptr<WorkerThread> createWorkerThread(double originTime) = 0;
- PassRefPtr<WorkerLoaderProxy> loaderProxy() { return m_loaderProxy; }
- InProcessWorkerObjectProxy& workerObjectProxy() { return *m_workerObjectProxy.get(); }
+ WorkerThread* workerThread() const { return m_workerThread.get(); }
-private:
- friend class InProcessWorkerMessagingProxyForTest;
- InProcessWorkerMessagingProxy(ExecutionContext*, InProcessWorkerBase*, WorkerClients*);
+ bool askedToTerminate() const { return m_askedToTerminate; }
- void workerObjectDestroyedInternal();
+ PassRefPtr<WorkerLoaderProxy> loaderProxy() { return m_loaderProxy; }
+ WorkerInspectorProxy* workerInspectorProxy() { return m_workerInspectorProxy.get(); }
+
+ // Returns true if this is called on the parent context thread.
+ bool isParentContextThread() const;
// WorkerLoaderProxyProvider
// These methods are called on different threads to schedule loading
// requests and to send callbacks back to WorkerGlobalScope.
void postTaskToLoader(const WebTraceLocation&, std::unique_ptr<ExecutionContextTask>) override;
void postTaskToWorkerGlobalScope(const WebTraceLocation&, std::unique_ptr<ExecutionContextTask>) override;
-
- // Returns true if this is called on the parent context thread.
- bool isParentContextThread() const;
+private:
+ friend class InProcessWorkerMessagingProxyForTest;
+ void parentObjectDestroyedInternal();
Persistent<ExecutionContext> m_executionContext;
- std::unique_ptr<InProcessWorkerObjectProxy> m_workerObjectProxy;
- WeakPersistent<InProcessWorkerBase> m_workerObject;
- bool m_mayBeDestroyed;
- std::unique_ptr<WorkerThread> m_workerThread;
-
- // Unconfirmed messages from the parent context thread to the worker thread.
- unsigned m_unconfirmedMessageCount;
-
- bool m_workerGlobalScopeMayHavePendingActivity;
- bool m_askedToTerminate;
-
- // Tasks are queued here until there's a thread object created.
- Vector<std::unique_ptr<ExecutionContextTask>> m_queuedEarlyTasks;
-
Persistent<WorkerInspectorProxy> m_workerInspectorProxy;
-
- Persistent<WorkerClients> m_workerClients;
-
Persistent<ParentFrameTaskRunners> m_parentFrameTaskRunners;
+ std::unique_ptr<WorkerThread> m_workerThread;
+
RefPtr<WorkerLoaderProxy> m_loaderProxy;
+
+ bool m_mayBeDestroyed;
+ bool m_askedToTerminate;
};
} // namespace blink
-#endif // InProcessWorkerMessagingProxy_h
+#endif // ThreadedMessagingProxyBase_h

Powered by Google App Engine
This is Rietveld 408576698