2 * Ole 2 Create functions implementation
4 * Copyright (C) 1999-2000 Abey George
10 #include "debugtools.h"
15 DEFAULT_DEBUG_CHANNEL(ole)
17 #define MAX_CLIPFORMAT_NAME 80
19 /******************************************************************************
20 * Function : OleQueryCreateFromData [OLE32.117]
21 * Author : Abey George
22 * Checks whether an object can become an embedded object.
23 * the clipboard or OLE drag and drop.
24 * Returns : S_OK - Format that supports Embedded object creation are present.
25 * OLE_E_STATIC - Format that supports static object creation are present.
26 * S_FALSE - No acceptable format is available.
29 HRESULT WINAPI OleQueryCreateFromData(LPDATAOBJECT pSrcDataObject)
33 CHAR szFmtName[MAX_CLIPFORMAT_NAME];
34 BOOL bFoundStatic = FALSE;
36 HRESULT hr = IDataObject_EnumFormatEtc(pSrcDataObject, DATADIR_GET, &pfmt);
39 hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
43 GetClipboardFormatNameA(fmt.cfFormat, szFmtName, MAX_CLIPFORMAT_NAME-1);
45 /* first, Check for Embedded Object, Embed Source or Filename */
47 if (!strcmp(szFmtName, CF_EMBEDDEDOBJECT) || !strcmp(szFmtName, CF_EMBEDSOURCE) || !strcmp(szFmtName, CF_FILENAME))
50 /* Check for Metafile, Bitmap or DIB */
52 if (fmt.cfFormat == CF_METAFILEPICT || fmt.cfFormat == CF_BITMAP || fmt.cfFormat == CF_DIB)
55 hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
58 /* Found a static format, but no embed format */
66 /******************************************************************************
67 * Function : OleCreateFromData [OLE32.92]
68 * Author : Abey George
69 * Creates an embedded object from data transfer object retrieved from
70 * the clipboard or OLE drag and drop.
71 * Returns : S_OK - Embedded object was created successfully.
72 * OLE_E_STATIC - OLE can create only a static object
73 * DV_E_FORMATETC - No acceptable format is available (only error return code)
74 * TODO : CF_FILENAME, CF_EMBEDEDOBJECT formats. Parameter renderopt is currently ignored.
77 HRESULT WINAPI OleCreateFromData(LPDATAOBJECT pSrcDataObject, REFIID riid,
78 DWORD renderopt, LPFORMATETC pFormatEtc,
79 LPOLECLIENTSITE pClientSite, LPSTORAGE pStg,
84 CHAR szFmtName[MAX_CLIPFORMAT_NAME];
89 hr = IDataObject_EnumFormatEtc(pSrcDataObject, DATADIR_GET, &pfmt);
93 memset(&std, 0, sizeof(STGMEDIUM));
95 hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
98 GetClipboardFormatNameA(fmt.cfFormat, szFmtName, MAX_CLIPFORMAT_NAME-1);
100 /* first, Check for Embedded Object, Embed Source or Filename */
101 /* TODO: Currently checks only for Embed Source. */
103 if (!strcmp(szFmtName, CF_EMBEDSOURCE))
105 std.tymed = TYMED_HGLOBAL;
107 if ((hr1 = IDataObject_GetData(pSrcDataObject, &fmt, &std)) == S_OK)
109 ILockBytes *ptrILockBytes = 0;
110 IStorage *pStorage = 0;
111 IOleObject *pOleObject = 0;
112 IPersistStorage *pPersistStorage = 0;
115 /* Create ILock bytes */
117 hr1 = CreateILockBytesOnHGlobal(std.u.hGlobal, FALSE, &ptrILockBytes);
119 /* Open storage on the ILock bytes */
122 hr1 = StgOpenStorageOnILockBytes(ptrILockBytes, NULL, STGM_SHARE_EXCLUSIVE, NULL, 0, &pStorage);
124 /* Get Class ID from the opened storage */
127 hr1 = ReadClassStg(pStorage, &clsID);
129 /* Create default handler for Persist storage */
132 hr1 = OleCreateDefaultHandler(&clsID, NULL, &IID_IPersistStorage, (LPVOID*)&pPersistStorage);
134 /* Load the storage to Persist storage */
137 hr1 = IPersistStorage_Load(pPersistStorage, pStorage);
139 /* Query for IOleObject */
142 hr1 = IPersistStorage_QueryInterface(pPersistStorage, &IID_IOleObject, (LPVOID*)&pOleObject);
144 /* Set client site with the IOleObject */
147 hr1 = IOleObject_SetClientSite(pOleObject, pClientSite);
149 IPersistStorage_Release(pPersistStorage);
150 /* Query for the requested interface */
153 hr1 = IPersistStorage_QueryInterface(pPersistStorage, riid, ppvObj);
155 IPersistStorage_Release(pPersistStorage);
157 IStorage_Release(pStorage);
165 return DV_E_FORMATETC;
168 hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
172 return DV_E_FORMATETC;