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

Unified Diff: components/mus/clipboard/clipboard_impl.cc

Issue 1978763003: Readd the clipboard service and get it compiling again. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Sequence numbers in state. Created 4 years, 7 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
« no previous file with comments | « components/mus/clipboard/clipboard_impl.h ('k') | components/mus/clipboard/clipboard_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/mus/clipboard/clipboard_impl.cc
diff --git a/components/mus/clipboard/clipboard_impl.cc b/components/mus/clipboard/clipboard_impl.cc
new file mode 100644
index 0000000000000000000000000000000000000000..0a66431592ab5d8810c2b39ad69e918e0b899c61
--- /dev/null
+++ b/components/mus/clipboard/clipboard_impl.cc
@@ -0,0 +1,113 @@
+// 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 "components/mus/clipboard/clipboard_impl.h"
+
+#include <string.h>
+#include <utility>
+
+#include "base/macros.h"
+#include "mojo/public/cpp/bindings/array.h"
+#include "mojo/public/cpp/bindings/callback.h"
+#include "mojo/public/cpp/bindings/string.h"
+
+using mojo::Array;
+using mojo::Map;
+using mojo::String;
+
+namespace mus {
+namespace clipboard {
+
+// ClipboardData contains data copied to the Clipboard for a variety of formats.
+// It mostly just provides APIs to cleanly access and manipulate this data.
+class ClipboardImpl::ClipboardData {
+ public:
+ ClipboardData() : sequence_number_(0) {}
+ ~ClipboardData() {}
+
+ uint64_t sequence_number() const {
+ return sequence_number_;
+ }
+
+ Array<String> GetMimeTypes() const {
+ Array<String> types(data_types_.size());
+ int i = 0;
+ for (auto it = data_types_.begin(); it != data_types_.end(); ++it, ++i)
+ types[i] = it->first;
+
+ return types;
+ }
+
+ void SetData(Map<String, Array<uint8_t>> data) {
+ sequence_number_++;
+ data_types_ = std::move(data);
+ }
+
+ void GetData(const String& mime_type, Array<uint8_t>* data) const {
+ auto it = data_types_.find(mime_type);
+ if (it != data_types_.end())
+ *data = it->second.Clone();
+ }
+
+ private:
+ uint64_t sequence_number_;
+ Map<String, Array<uint8_t>> data_types_;
+
+ DISALLOW_COPY_AND_ASSIGN(ClipboardData);
+};
+
+ClipboardImpl::ClipboardImpl() {
+ for (int i = 0; i < kNumClipboards; ++i)
+ clipboard_state_[i].reset(new ClipboardData);
+}
+
+ClipboardImpl::~ClipboardImpl() {
+}
+
+void ClipboardImpl::AddBinding(mojom::ClipboardRequest request) {
+ bindings_.AddBinding(this, std::move(request));
+}
+
+void ClipboardImpl::GetSequenceNumber(
+ Clipboard::Type clipboard_type,
+ const GetSequenceNumberCallback& callback) {
+ callback.Run(
+ clipboard_state_[static_cast<int>(clipboard_type)]->sequence_number());
+}
+
+void ClipboardImpl::GetAvailableMimeTypes(
+ Clipboard::Type clipboard_type,
+ const GetAvailableMimeTypesCallback& callback) {
+ int clipboard_num = static_cast<int>(clipboard_type);
+ callback.Run(clipboard_state_[clipboard_num]->sequence_number(),
+ clipboard_state_[clipboard_num]->GetMimeTypes());
+}
+
+void ClipboardImpl::ReadMimeType(
+ uint64_t sequence,
+ Clipboard::Type clipboard_type,
+ const String& mime_type,
+ const ReadMimeTypeCallback& callback) {
+ int clipboard_num = static_cast<int>(clipboard_type);
+ Array<uint8_t> mime_data(nullptr);
+ bool valid_sequence_number =
+ clipboard_state_[clipboard_num]->sequence_number() == sequence;
+
+ if (valid_sequence_number)
+ clipboard_state_[clipboard_num]->GetData(mime_type, &mime_data);
+
+ callback.Run(valid_sequence_number, std::move(mime_data));
+}
+
+void ClipboardImpl::WriteClipboardData(
+ Clipboard::Type clipboard_type,
+ Map<String, Array<uint8_t>> data,
+ const WriteClipboardDataCallback& callback) {
+ int clipboard_num = static_cast<int>(clipboard_type);
+ clipboard_state_[clipboard_num]->SetData(std::move(data));
+ callback.Run(clipboard_state_[clipboard_num]->sequence_number());
+}
+
+} // namespace clipboard
+} // namespace mus
« no previous file with comments | « components/mus/clipboard/clipboard_impl.h ('k') | components/mus/clipboard/clipboard_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698