// Copyright (c) 2012 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. #ifndef PPAPI_CPP_PRIVATE_FLASH_CLIPBOARD_H_ #define PPAPI_CPP_PRIVATE_FLASH_CLIPBOARD_H_ #include <string> #include <vector> #include "ppapi/c/private/ppb_flash_clipboard.h" #include "ppapi/cpp/var.h" namespace pp { class InstanceHandle; namespace flash { class Clipboard { public: // Returns true if the required interface is available. static bool IsAvailable(); // Returns a format ID on success or PP_FLASH_CLIPBOARD_FORMAT_INVALID on // failure. static uint32_t RegisterCustomFormat(const InstanceHandle& instance, const std::string& format_name); // Returns true if the given format is available from the given clipboard. static bool IsFormatAvailable(const InstanceHandle& instance, PP_Flash_Clipboard_Type clipboard_type, uint32_t format); // Returns true on success, in which case |out| will be filled with // data read from the given clipboard in the given format. static bool ReadData(const InstanceHandle& instance, PP_Flash_Clipboard_Type clipboard_type, uint32_t clipboard_format, Var* out); // Returns true on success in which case all of |data| will be written to // the clipboard. Otherwise nothing will be written. static bool WriteData(const InstanceHandle& instance, PP_Flash_Clipboard_Type clipboard_type, const std::vector<uint32_t>& formats, const std::vector<Var>& data_items); // Outputs a sequence number that uniquely identifies the clipboard state in // |sequence_number| and returns true if successful. static bool GetSequenceNumber(const InstanceHandle& instance, PP_Flash_Clipboard_Type clipboard_type, uint64_t* sequence_number); }; } // namespace flash } // namespace pp #endif // PPAPI_CPP_PRIVATE_FLASH_CLIPBOARD_H_