OLD | NEW |
| (Empty) |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef WEBKIT_GLUE_CLIPBOARD_CLIENT_H_ | |
6 #define WEBKIT_GLUE_CLIPBOARD_CLIENT_H_ | |
7 | |
8 #include "ui/base/clipboard/clipboard.h" | |
9 | |
10 class GURL; | |
11 | |
12 namespace webkit_glue { | |
13 | |
14 // Interface for the webkit glue embedder to implement to support clipboard. | |
15 class ClipboardClient { | |
16 public: | |
17 class WriteContext { | |
18 public: | |
19 virtual ~WriteContext() { } | |
20 | |
21 // Writes bitmap data into the context, updating the ObjectMap. | |
22 virtual void WriteBitmapFromPixels(ui::Clipboard::ObjectMap* objects, | |
23 const void* pixels, | |
24 const gfx::Size& size) = 0; | |
25 | |
26 // Flushes all gathered data. | |
27 virtual void Flush(const ui::Clipboard::ObjectMap& objects) = 0; | |
28 }; | |
29 | |
30 virtual ~ClipboardClient() { } | |
31 | |
32 // Get a clipboard that can be used to construct a ScopedClipboardWriterGlue. | |
33 virtual ui::Clipboard* GetClipboard() = 0; | |
34 | |
35 // Get a sequence number which uniquely identifies clipboard state. | |
36 virtual uint64 GetSequenceNumber(ui::Clipboard::Buffer buffer) = 0; | |
37 | |
38 // Tests whether the clipboard contains a certain format | |
39 virtual bool IsFormatAvailable(const ui::Clipboard::FormatType& format, | |
40 ui::Clipboard::Buffer buffer) = 0; | |
41 | |
42 // Clear the contents of the clipboard. | |
43 virtual void Clear(ui::Clipboard::Buffer buffer) = 0; | |
44 | |
45 // Reads the available types from the clipboard, if available. | |
46 virtual void ReadAvailableTypes(ui::Clipboard::Buffer buffer, | |
47 std::vector<base::string16>* types, | |
48 bool* contains_filenames) = 0; | |
49 | |
50 // Reads UNICODE text from the clipboard, if available. | |
51 virtual void ReadText(ui::Clipboard::Buffer buffer, | |
52 base::string16* result) = 0; | |
53 | |
54 // Reads ASCII text from the clipboard, if available. | |
55 virtual void ReadAsciiText(ui::Clipboard::Buffer buffer, | |
56 std::string* result) = 0; | |
57 | |
58 // Reads HTML from the clipboard, if available. | |
59 virtual void ReadHTML(ui::Clipboard::Buffer buffer, base::string16* markup, | |
60 GURL* url, uint32* fragment_start, | |
61 uint32* fragment_end) = 0; | |
62 | |
63 // Reads RTF from the clipboard, if available. | |
64 virtual void ReadRTF(ui::Clipboard::Buffer buffer, std::string* result) = 0; | |
65 | |
66 // Reads and image from the clipboard, if available. | |
67 virtual void ReadImage(ui::Clipboard::Buffer buffer, std::string* data) = 0; | |
68 | |
69 // Reads a custom data type from the clipboard, if available. | |
70 virtual void ReadCustomData(ui::Clipboard::Buffer buffer, | |
71 const base::string16& type, | |
72 base::string16* data) = 0; | |
73 | |
74 // Reads raw data from the clipboard for a given format. | |
75 virtual void ReadData(const ui::Clipboard::FormatType& format, | |
76 std::string* data) = 0; | |
77 | |
78 // Creates a context to write clipboard data. May return NULL. | |
79 virtual WriteContext* CreateWriteContext() = 0; | |
80 }; | |
81 | |
82 } // namespace webkit_glue | |
83 | |
84 #endif // WEBKIT_GLUE_CLIPBOARD_CLIENT_H_ | |
OLD | NEW |