1 // Copyright 2014 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.
14 // Mime type constants
15 const string MIME_TYPE_TEXT = "text/plain";
16 const string MIME_TYPE_HTML = "text/html";
17 const string MIME_TYPE_URL = "text/url";
19 // Returns a sequence number which uniquely identifies clipboard state.
20 // Clients are able to assume that the clipboard contents are unchanged as
21 // long as this number has not changed. This number is monotonically
22 // increasing, is increased when the clipboard state changes, and is
23 // provided by Windows, Linux, and Mac.
24 GetSequenceNumber(Type clipboard_type) => (uint64 sequence);
26 // Returns the available mime types. (Note: the chrome interface has a
27 // |contains_filenames| parameter here, but it appears to always be set
29 GetAvailableMimeTypes(Type clipboard_types) => (array<string> types);
31 // Returns the data associated with a Mime type, returning NULL if that data
32 // doesn't exist. Note: because of the inherit raciness of clipboard access,
33 // this may return NULL even if you just verified that it exists with
34 // GetAvailableFormatMimeTypes(). We don't want to provide one API to return
35 // the entire clipboard state because the combined size of the clipboard can
36 // be megabytes, especially when image data is involved.
37 ReadMimeType(Type clipboard_type, string mime_type) => (array<uint8>? data);
39 // Writes a set of mime types to the clipboard. This will increment the
40 // sequence number. In the case of an empty or null map, this will just
41 // clear the clipboard.
42 WriteClipboardData(Type clipboard_type, map<string, array<uint8>>? data);