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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
/* -*- Mode: C++; 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/. */
#ifndef nsClipboard_h__
#define nsClipboard_h__
#include "nsBaseClipboard.h"
#include "nsIObserver.h"
#include "nsIURI.h"
#include <ole2.h>
#include <windows.h>
class nsITransferable;
class nsIWidget;
class nsIFile;
struct IDataObject;
/**
* Native Win32 Clipboard wrapper
*/
class nsClipboard : public nsBaseClipboard, public nsIObserver {
virtual ~nsClipboard();
public:
nsClipboard();
NS_DECL_ISUPPORTS_INHERITED
// nsIObserver
NS_DECL_NSIOBSERVER
// nsIClipboard
NS_IMETHOD HasDataMatchingFlavors(const nsTArray<nsCString>& aFlavorList,
int32_t aWhichClipboard,
bool* _retval) override;
NS_IMETHOD EmptyClipboard(int32_t aWhichClipboard) override;
// Internal Native Routines
enum class MightNeedToFlush : bool { No, Yes };
static nsresult CreateNativeDataObject(nsITransferable* aTransferable,
IDataObject** aDataObj, nsIURI* aUri,
MightNeedToFlush* = nullptr);
static nsresult SetupNativeDataObject(nsITransferable* aTransferable,
IDataObject* aDataObj,
MightNeedToFlush* = nullptr);
static nsresult GetDataFromDataObject(IDataObject* aDataObject, UINT anIndex,
nsIWidget* aWindow,
nsITransferable* aTransferable);
static nsresult GetNativeDataOffClipboard(nsIWidget* aWindow, UINT aIndex,
UINT aFormat, void** aData,
uint32_t* aLen);
static nsresult GetNativeDataOffClipboard(IDataObject* aDataObject,
UINT aIndex, UINT aFormat,
const char* aMIMEImageFormat,
void** aData, uint32_t* aLen);
static nsresult GetGlobalData(HGLOBAL aHGBL, void** aData, uint32_t* aLen);
// This function returns the internal Windows clipboard format identifier
// for a given Mime string. The default is to map kHTMLMime ("text/html")
// to the clipboard format CF_HTML ("HTLM Format"), but it can also be
// registered as clipboard format "text/html" to support previous versions
// of Gecko.
static UINT GetFormat(const char* aMimeStr, bool aMapHTMLMime = true);
static UINT GetHtmlClipboardFormat();
static UINT GetCustomClipboardFormat();
protected:
// @param aDataObject must be non-nullptr.
static HRESULT FillSTGMedium(IDataObject* aDataObject, UINT aFormat,
LPFORMATETC pFE, LPSTGMEDIUM pSTM, DWORD aTymed);
NS_IMETHOD SetNativeClipboardData(int32_t aWhichClipboard) override;
NS_IMETHOD GetNativeClipboardData(nsITransferable* aTransferable,
int32_t aWhichClipboard) override;
static bool IsInternetShortcut(const nsAString& inFileName);
static bool FindURLFromLocalFile(IDataObject* inDataObject, UINT inIndex,
void** outData, uint32_t* outDataLen);
static bool FindURLFromNativeURL(IDataObject* inDataObject, UINT inIndex,
void** outData, uint32_t* outDataLen);
static bool FindUnicodeFromPlainText(IDataObject* inDataObject, UINT inIndex,
void** outData, uint32_t* outDataLen);
static bool FindPlatformHTML(IDataObject* inDataObject, UINT inIndex,
void** outData, uint32_t* outStartOfData,
uint32_t* outDataLen);
static void ResolveShortcut(nsIFile* inFileName, nsACString& outURL);
nsIWidget* mWindow;
};
#define SET_FORMATETC(fe, cf, td, asp, li, med) \
{ \
(fe).cfFormat = cf; \
(fe).ptd = td; \
(fe).dwAspect = asp; \
(fe).lindex = li; \
(fe).tymed = med; \
}
#endif // nsClipboard_h__
|