// Copyright 2019 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef THIRD_PARTY_BLINK_RENDERER_MODULES_CLIPBOARD_CLIPBOARD_READER_H_ #define THIRD_PARTY_BLINK_RENDERER_MODULES_CLIPBOARD_CLIPBOARD_READER_H_ #include "base/sequence_checker.h" #include "base/task/single_thread_task_runner.h" #include "third_party/blink/renderer/core/fileapi/blob.h" #include "third_party/blink/renderer/platform/heap/garbage_collected.h" namespace blink { class SystemClipboard; class ClipboardPromise; // Interface for reading an individual Clipboard API format from the sanitized // System Clipboard as a Blob. // // Reading a type from the system clipboard to a Blob is accomplished by: // (1) Reading - the format from the system clipboard. // (2) Encoding - the system clipboard's contents for a format. Encoding may be // time-consuming, so it is done on a background thread whenever possible. // An example where encoding is done on the main thread is HTML, where // Blink's HTML encoder can only be used on the main thread. // (3) Writing - the encoded contents to a Blob. // // ClipboardReader takes as input a ClipboardPromise, from which it expects // a clipboard format, and to which it provides a Blob containing an encoded // SystemClipboard-originated clipboard payload. All System Clipboard // operations should be called from the main thread. // // Subclasses of ClipboardReader should be implemented for each supported // format. Subclasses should: // (1) Begin execution by implementing ClipboardReader::Read(). // (2) Encode the payload on a background thread (if possible) by implementing // a static EncodeOnBackgroundThread() function. This function is called by // Read() via worker_pool::PostTask(). // (3) Create a Blob and send it to the ClipboardPromise by implementing // ClipboardReader::NextRead(). class ClipboardReader : public GarbageCollected<ClipboardReader> { … }; } // namespace blink #endif // THIRD_PARTY_BLINK_RENDERER_MODULES_CLIPBOARD_CLIPBOARD_READER_H_