Index: components/arc/clipboard/arc_clipboard_bridge.cc |
diff --git a/components/arc/clipboard/arc_clipboard_bridge.cc b/components/arc/clipboard/arc_clipboard_bridge.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ea586752a4ec36cf3b7b8d35c833fadeae520399 |
--- /dev/null |
+++ b/components/arc/clipboard/arc_clipboard_bridge.cc |
@@ -0,0 +1,78 @@ |
+// Copyright 2015 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 "components/arc/clipboard/arc_clipboard_bridge.h" |
+ |
+#include "base/logging.h" |
+#include "base/strings/utf_string_conversions.h" |
+#include "base/threading/thread_checker.h" |
+#include "ui/base/clipboard/clipboard.h" |
+#include "ui/base/clipboard/clipboard_types.h" |
+#include "ui/base/clipboard/scoped_clipboard_writer.h" |
+ |
+namespace mojo { |
+ |
+template <> |
+struct TypeConverter<base::string16, String> { |
+ static base::string16 Convert(const String& input) { |
+ return base::UTF8ToUTF16(input.get()); |
+ } |
+}; |
+ |
+template <> |
+struct TypeConverter<String, base::string16> { |
+ static String Convert(const base::string16& input) { |
+ return String(base::UTF16ToUTF8(input)); |
+ } |
+}; |
+ |
+} // namespace mojo |
+ |
+namespace arc { |
+ |
+ArcClipboardBridge::ArcClipboardBridge(ArcBridgeService* bridge_service) |
+ : bridge_service_(bridge_service), binding_(this) { |
+ bridge_service_->AddObserver(this); |
+} |
+ |
+ArcClipboardBridge::~ArcClipboardBridge() { |
+ DCHECK(CalledOnValidThread()); |
+ bridge_service_->RemoveObserver(this); |
+} |
+ |
+void ArcClipboardBridge::OnClipboardInstanceReady() { |
+ ClipboardInstance* clipboard_instance = bridge_service_->clipboard_instance(); |
+ if (!clipboard_instance) { |
+ LOG(ERROR) << "OnClipboardInstanceReady called, " |
+ << "but no clipboard instance found"; |
+ return; |
+ } |
+ |
+ ClipboardHostPtr host; |
+ binding_.Bind(mojo::GetProxy(&host)); |
+ clipboard_instance->Init(std::move(host)); |
dcheng
2015/12/30 19:51:52
#include <utility>
|
+} |
+ |
+void ArcClipboardBridge::SetTextContent(const mojo::String& text) { |
+ DCHECK(CalledOnValidThread()); |
dcheng
2015/12/30 19:51:52
Just to double-check... is this the UI thread?
|
+ ui::ScopedClipboardWriter writer(ui::CLIPBOARD_TYPE_COPY_PASTE); |
+ writer.WriteText(text.To<base::string16>()); |
+} |
+ |
+void ArcClipboardBridge::GetTextContent() { |
+ DCHECK(CalledOnValidThread()); |
+ |
+ base::string16 text; |
+ ui::Clipboard* clipboard = ui::Clipboard::GetForCurrentThread(); |
+ clipboard->ReadText(ui::CLIPBOARD_TYPE_COPY_PASTE, &text); |
+ |
+ ClipboardInstance* clipboard_instance = bridge_service_->clipboard_instance(); |
+ clipboard_instance->OnGetTextContent(mojo::String::From(text)); |
+} |
+ |
+bool ArcClipboardBridge::CalledOnValidThread() { |
+ return thread_checker_.CalledOnValidThread(); |
+} |
+ |
+} // namespace arc |