VirtualBox

source: vbox/trunk/src/VBox/Additions/WINNT/VBoxTray/VBoxDnDEnumFormat.cpp@ 53517

Last change on this file since 53517 was 51469, checked in by vboxsync, 11 years ago

VBoxTray: Logging; ripped out all custom logging.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.6 KB
Line 
1/* $Id: VBoxDnDEnumFormat.cpp 51469 2014-05-30 11:49:42Z vboxsync $ */
2/** @file
3 * VBoxDnDEnumFormat.cpp - IEnumFORMATETC ("Format et cetera") implementation.
4 */
5
6/*
7 * Copyright (C) 2013 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17#include <windows.h>
18#include <new> /* For bad_alloc. */
19
20#include "VBoxTray.h"
21#include "VBoxHelpers.h"
22#include "VBoxDnD.h"
23
24#ifdef DEBUG
25# define LOG_ENABLED
26# define LOG_GROUP LOG_GROUP_DEFAULT
27#endif
28#include <VBox/log.h>
29
30
31
32VBoxDnDEnumFormatEtc::VBoxDnDEnumFormatEtc(FORMATETC *pFormatEtc, ULONG cFormats)
33 : m_lRefCount(1),
34 m_nIndex(0)
35{
36 HRESULT hr;
37
38 try
39 {
40 LogFlowFunc(("pFormatEtc=%p, cFormats=%RU32\n", pFormatEtc, cFormats));
41 m_pFormatEtc = new FORMATETC[cFormats];
42
43 for (ULONG i = 0; i < cFormats; i++)
44 {
45 LogFlowFunc(("Format %RU32: cfFormat=%RI16, sFormat=%s, tyMed=%RU32, dwAspect=%RU32\n",
46 i, pFormatEtc[i].cfFormat, VBoxDnDDataObject::ClipboardFormatToString(pFormatEtc[i].cfFormat),
47 pFormatEtc[i].tymed, pFormatEtc[i].dwAspect));
48 VBoxDnDEnumFormatEtc::CopyFormat(&m_pFormatEtc[i], &pFormatEtc[i]);
49 }
50
51 m_nNumFormats = cFormats;
52 hr = S_OK;
53 }
54 catch (std::bad_alloc &)
55 {
56 hr = E_OUTOFMEMORY;
57 }
58
59 LogFlowFunc(("hr=%Rhrc\n", hr));
60}
61
62VBoxDnDEnumFormatEtc::~VBoxDnDEnumFormatEtc(void)
63{
64 if (m_pFormatEtc)
65 {
66 for (ULONG i = 0; i < m_nNumFormats; i++)
67 {
68 if(m_pFormatEtc[i].ptd)
69 CoTaskMemFree(m_pFormatEtc[i].ptd);
70 }
71
72 delete[] m_pFormatEtc;
73 m_pFormatEtc = NULL;
74 }
75
76 LogFlowFunc(("m_lRefCount=%RI32\n", m_lRefCount));
77}
78
79/*
80 * IUnknown methods.
81 */
82
83STDMETHODIMP_(ULONG) VBoxDnDEnumFormatEtc::AddRef(void)
84{
85 return InterlockedIncrement(&m_lRefCount);
86}
87
88STDMETHODIMP_(ULONG) VBoxDnDEnumFormatEtc::Release(void)
89{
90 LONG lCount = InterlockedDecrement(&m_lRefCount);
91 if (lCount == 0)
92 {
93 delete this;
94 return 0;
95 }
96
97 return lCount;
98}
99
100STDMETHODIMP VBoxDnDEnumFormatEtc::QueryInterface(REFIID iid, void **ppvObject)
101{
102 if ( iid == IID_IEnumFORMATETC
103 || iid == IID_IUnknown)
104 {
105 AddRef();
106 *ppvObject = this;
107 return S_OK;
108 }
109
110 *ppvObject = 0;
111 return E_NOINTERFACE;
112}
113
114STDMETHODIMP VBoxDnDEnumFormatEtc::Next(ULONG cFormats, FORMATETC *pFormatEtc, ULONG *pcFetched)
115{
116 ULONG ulCopied = 0;
117
118 if(cFormats == 0 || pFormatEtc == 0)
119 return E_INVALIDARG;
120
121 while ( m_nIndex < m_nNumFormats
122 && ulCopied < cFormats)
123 {
124 VBoxDnDEnumFormatEtc::CopyFormat(&pFormatEtc[ulCopied],
125 &m_pFormatEtc[m_nIndex]);
126 ulCopied++;
127 m_nIndex++;
128 }
129
130 if (pcFetched)
131 *pcFetched = ulCopied;
132
133 return (ulCopied == cFormats) ? S_OK : S_FALSE;
134}
135
136STDMETHODIMP VBoxDnDEnumFormatEtc::Skip(ULONG cFormats)
137{
138 m_nIndex += cFormats;
139 return (m_nIndex <= m_nNumFormats) ? S_OK : S_FALSE;
140}
141
142STDMETHODIMP VBoxDnDEnumFormatEtc::Reset(void)
143{
144 m_nIndex = 0;
145 return S_OK;
146}
147
148STDMETHODIMP VBoxDnDEnumFormatEtc::Clone(IEnumFORMATETC **ppEnumFormatEtc)
149{
150 HRESULT hResult =
151 CreateEnumFormatEtc(m_nNumFormats, m_pFormatEtc, ppEnumFormatEtc);
152
153 if (hResult == S_OK)
154 ((VBoxDnDEnumFormatEtc *) *ppEnumFormatEtc)->m_nIndex = m_nIndex;
155
156 return hResult;
157}
158
159/* static */
160void VBoxDnDEnumFormatEtc::CopyFormat(FORMATETC *pDest, FORMATETC *pSource)
161{
162 AssertPtrReturnVoid(pDest);
163 AssertPtrReturnVoid(pSource);
164
165 *pDest = *pSource;
166
167 if (pSource->ptd)
168 {
169 pDest->ptd = (DVTARGETDEVICE*)CoTaskMemAlloc(sizeof(DVTARGETDEVICE));
170 *(pDest->ptd) = *(pSource->ptd);
171 }
172}
173
174/* static */
175HRESULT VBoxDnDEnumFormatEtc::CreateEnumFormatEtc(UINT nNumFormats, FORMATETC *pFormatEtc, IEnumFORMATETC **ppEnumFormatEtc)
176{
177 AssertReturn(nNumFormats, E_INVALIDARG);
178 AssertPtrReturn(pFormatEtc, E_INVALIDARG);
179 AssertPtrReturn(ppEnumFormatEtc, E_INVALIDARG);
180
181 HRESULT hr;
182 try
183 {
184 *ppEnumFormatEtc = new VBoxDnDEnumFormatEtc(pFormatEtc, nNumFormats);
185 hr = S_OK;
186 }
187 catch(std::bad_alloc &)
188 {
189 hr = E_OUTOFMEMORY;
190 }
191
192 return hr;
193}
194
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette