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

Unified Diff: third_party/WebKit/Source/platform/exported/Platform.cpp

Issue 1660383002: Refactoring: Move some classes from content/child to platform (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: kinuko's review Created 4 years, 10 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/platform/exported/Platform.cpp
diff --git a/third_party/WebKit/Source/platform/exported/Platform.cpp b/third_party/WebKit/Source/platform/exported/Platform.cpp
index 11e174491a19f7d277edc1076d4f1c2dada86205..5bbd9e3a44c45457db97dd123796877a325fe0b0 100644
--- a/third_party/WebKit/Source/platform/exported/Platform.cpp
+++ b/third_party/WebKit/Source/platform/exported/Platform.cpp
@@ -28,12 +28,28 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
+#include "base/thread_task_runner_handle.h"
+#include "base/trace_event/memory_dump_manager.h"
#include "platform/PartitionAllocMemoryDumpProvider.h"
+#include "platform/WebMemoryDumpProviderAdapter.h"
#include "public/platform/Platform.h"
+#include "wtf/HashMap.h"
+#include "wtf/OwnPtr.h"
namespace blink {
static Platform* s_platform = 0;
+using ProviderToAdapterMap = HashMap<WebMemoryDumpProvider*, OwnPtr<WebMemoryDumpProviderAdapter>>;
+
+namespace {
+
+ProviderToAdapterMap& memoryDumpProviders()
+{
+ DEFINE_STATIC_LOCAL(ProviderToAdapterMap, providerToAdapterMap, ());
+ return providerToAdapterMap;
+}
+
+} // namespace
Platform::Platform()
: m_mainThread(0)
@@ -71,4 +87,25 @@ WebThread* Platform::mainThread() const
return m_mainThread;
}
+void Platform::registerMemoryDumpProviderImpl(WebMemoryDumpProvider* wmdp, const char* name)
+{
+ WebMemoryDumpProviderAdapter* adapter = new WebMemoryDumpProviderAdapter(wmdp);
+ ProviderToAdapterMap::AddResult result = memoryDumpProviders().add(wmdp, adoptPtr(adapter));
+ if (!result.isNewEntry)
+ return;
+ adapter->set_is_registered(true);
+ base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider(adapter, name, base::ThreadTaskRunnerHandle::Get());
+}
+
+void Platform::unregisterMemoryDumpProviderImpl(WebMemoryDumpProvider* wmdp)
+{
+ ProviderToAdapterMap::iterator it = memoryDumpProviders().find(wmdp);
+ if (it == memoryDumpProviders().end())
+ return;
+ WebMemoryDumpProviderAdapter* adapter = it->value.get();
+ base::trace_event::MemoryDumpManager::GetInstance()->UnregisterDumpProvider(adapter);
+ adapter->set_is_registered(false);
+ memoryDumpProviders().remove(it);
+}
+
} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698