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

Unified Diff: third_party/WebKit/Source/modules/time_zone_monitor/TimeZoneMonitorClient.cpp

Issue 2402983002: [TimeZoneMonitor] Decouple renderer side impl from content to blink. (Closed)
Patch Set: Fix blink_heap_unittests Created 4 years, 2 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/modules/time_zone_monitor/TimeZoneMonitorClient.cpp
diff --git a/third_party/WebKit/Source/modules/time_zone_monitor/TimeZoneMonitorClient.cpp b/third_party/WebKit/Source/modules/time_zone_monitor/TimeZoneMonitorClient.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..d5dbdb51d78a4a690f9e879cd3f1f4655a49edd8
--- /dev/null
+++ b/third_party/WebKit/Source/modules/time_zone_monitor/TimeZoneMonitorClient.cpp
@@ -0,0 +1,83 @@
+// 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.
+
+#include "modules/time_zone_monitor/TimeZoneMonitorClient.h"
+
+#include "bindings/core/v8/V8Binding.h"
+#include "bindings/core/v8/V8PerIsolateData.h"
+#include "core/dom/ExecutionContext.h"
+#include "core/dom/ExecutionContextTask.h"
+#include "core/workers/WorkerBackingThread.h"
+#include "core/workers/WorkerThread.h"
+#include "public/platform/InterfaceProvider.h"
+#include "public/platform/Platform.h"
+#include "third_party/icu/source/i18n/unicode/timezone.h"
+#include <v8.h>
+
+namespace blink {
+
+namespace {
+
+// Notify V8 that the date/time configuration of the system might have changed.
+void NotifyTimezoneChangeToV8(v8::Isolate* isolate) {
+ DCHECK(isolate);
+ v8::Date::DateTimeConfigurationChangeNotification(isolate);
+}
+
+void NotifyTimezoneChangeOnWorkerThread(ExecutionContext* context) {
+ NotifyTimezoneChangeToV8(toIsolate(context));
+}
+
+} // namespace
+
+// static
+void TimeZoneMonitorClient::Init() {
+ DEFINE_STATIC_LOCAL(TimeZoneMonitorClient, instance, ());
+ instance.Bind();
+}
+
+TimeZoneMonitorClient::TimeZoneMonitorClient() : m_binding(this) {
+ DCHECK(isMainThread());
+}
+
+TimeZoneMonitorClient::~TimeZoneMonitorClient() {}
+
+void TimeZoneMonitorClient::Bind() {
+ DCHECK(isMainThread());
+ if (m_binding.is_bound())
blundell 2016/10/27 15:31:19 Do you expect this method to be called more than o
leonhsl(Using Gerrit) 2016/10/28 05:59:06 This should happen only once, so I added the guard
blundell 2016/10/28 14:36:13 You could presumably just inline the code and use
leonhsl(Using Gerrit) 2016/10/30 13:24:18 Done.
+ return;
+
+ device::mojom::blink::TimeZoneMonitorPtr monitor;
+ Platform::current()->interfaceProvider()->getInterface(
+ mojo::GetProxy(&monitor));
+ monitor->AddClient(m_binding.CreateInterfacePtrAndBind());
+}
+
+void TimeZoneMonitorClient::OnTimeZoneChange(const WTF::String& timeZoneInfo) {
dcheng 2016/10/27 22:34:50 Nit: omit WTF::
leonhsl(Using Gerrit) 2016/10/28 05:59:06 Done.
+ DCHECK(isMainThread());
+
+ if (!timeZoneInfo.isEmpty()) {
+ icu::TimeZone* zone = icu::TimeZone::createTimeZone(
+ icu::UnicodeString::fromUTF8(timeZoneInfo.utf8().data()));
+ icu::TimeZone::adoptDefault(zone);
+ VLOG(1) << "ICU default timezone is set to " << timeZoneInfo;
+ }
+
+ NotifyTimezoneChangeToV8(V8PerIsolateData::mainThreadIsolate());
+
+ HashSet<WorkerThread*>& threads = WorkerThread::workerThreads();
+ HashSet<WorkerBackingThread*> posted;
+ for (WorkerThread* thread : threads) {
+ // Ensure every WorkerBackingThread(holding one platform thread) only get
+ // the task posted once, because one WorkerBackingThread could be shared
+ // among multiple WorkerThreads.
+ if (posted.contains(&thread->workerBackingThread()))
+ continue;
+ thread->postTask(BLINK_FROM_HERE, createCrossThreadTask(
+ &NotifyTimezoneChangeOnWorkerThread));
+ posted.add(&thread->workerBackingThread());
+ }
+}
+
+} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698