summaryrefslogtreecommitdiffstats
path: root/widget/nsIClipboardHelper.idl
blob: ed4af112f1672bca523293048868d9d6c54358c4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsISupports.idl"
#include "nsIClipboard.idl"

%{ C++
#include "nsString.h" // needed for AString -> nsAString, unfortunately
%}

/**
 * helper service for common uses of nsIClipboard.
 */

[scriptable, uuid(438307fd-0c68-4d79-922a-f6cc9550cd02)]
interface nsIClipboardHelper : nsISupports
{
  cenum SensitiveData : 8 {
    NotSensitive = 0,
    Sensitive = 1,
  };

  /**
   * copy string to given clipboard
   *
   * @param aString, the string to copy to the clipboard
   * @param aClipboardID, the ID of the clipboard to copy to
   *        (eg. kSelectionClipboard -- see nsIClipboard.idl)
   * @param aSensitive, optional flag to indicate that data is sensitive, like a password.
   *        That will exclude data from Cloud Clipboard/Clipboard History on Windows.
   */
  void copyStringToClipboard(in AString aString, in long aClipboardID,
                             [optional, default(NotSensitive)] in nsIClipboardHelper_SensitiveData aSensitive);

  /**
   * copy string to (default) clipboard
   *
   * @param aString, the string to copy to the clipboard
   */
  void copyString(in AString aString,
                  [optional, default(NotSensitive)] in nsIClipboardHelper_SensitiveData aSensitive);
};