2000-03-08 19:49:36 +01:00
|
|
|
/*
|
|
|
|
* Ole 2 Create functions implementation
|
|
|
|
*
|
|
|
|
* Copyright (C) 1999-2000 Abey George
|
|
|
|
*/
|
|
|
|
|
2000-09-26 02:00:55 +02:00
|
|
|
#include "winbase.h"
|
2000-03-08 19:49:36 +01:00
|
|
|
#include "wingdi.h"
|
|
|
|
#include "winuser.h"
|
|
|
|
#include "debugtools.h"
|
2000-09-26 02:00:55 +02:00
|
|
|
#include "ole2.h"
|
2000-03-08 19:49:36 +01:00
|
|
|
#include "olestd.h"
|
|
|
|
#include "winreg.h"
|
|
|
|
|
2000-11-28 00:54:25 +01:00
|
|
|
DEFAULT_DEBUG_CHANNEL(ole);
|
2000-03-08 19:49:36 +01:00
|
|
|
|
|
|
|
#define MAX_CLIPFORMAT_NAME 80
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
|
|
* Function : OleQueryCreateFromData [OLE32.117]
|
|
|
|
* Author : Abey George
|
|
|
|
* Checks whether an object can become an embedded object.
|
|
|
|
* the clipboard or OLE drag and drop.
|
|
|
|
* Returns : S_OK - Format that supports Embedded object creation are present.
|
|
|
|
* OLE_E_STATIC - Format that supports static object creation are present.
|
|
|
|
* S_FALSE - No acceptable format is available.
|
|
|
|
*/
|
|
|
|
|
|
|
|
HRESULT WINAPI OleQueryCreateFromData(LPDATAOBJECT pSrcDataObject)
|
|
|
|
{
|
|
|
|
IEnumFORMATETC *pfmt;
|
|
|
|
FORMATETC fmt;
|
|
|
|
CHAR szFmtName[MAX_CLIPFORMAT_NAME];
|
|
|
|
BOOL bFoundStatic = FALSE;
|
|
|
|
|
|
|
|
HRESULT hr = IDataObject_EnumFormatEtc(pSrcDataObject, DATADIR_GET, &pfmt);
|
|
|
|
|
|
|
|
if (hr == S_OK)
|
|
|
|
hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
|
|
|
|
|
|
|
|
while (hr == S_OK)
|
|
|
|
{
|
|
|
|
GetClipboardFormatNameA(fmt.cfFormat, szFmtName, MAX_CLIPFORMAT_NAME-1);
|
|
|
|
|
|
|
|
/* first, Check for Embedded Object, Embed Source or Filename */
|
|
|
|
|
|
|
|
if (!strcmp(szFmtName, CF_EMBEDDEDOBJECT) || !strcmp(szFmtName, CF_EMBEDSOURCE) || !strcmp(szFmtName, CF_FILENAME))
|
|
|
|
return S_OK;
|
|
|
|
|
|
|
|
/* Check for Metafile, Bitmap or DIB */
|
|
|
|
|
|
|
|
if (fmt.cfFormat == CF_METAFILEPICT || fmt.cfFormat == CF_BITMAP || fmt.cfFormat == CF_DIB)
|
|
|
|
bFoundStatic = TRUE;
|
|
|
|
|
|
|
|
hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Found a static format, but no embed format */
|
|
|
|
|
|
|
|
if (bFoundStatic)
|
|
|
|
return OLE_S_STATIC;
|
|
|
|
|
|
|
|
return S_FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
|
|
* Function : OleCreateFromData [OLE32.92]
|
|
|
|
* Author : Abey George
|
|
|
|
* Creates an embedded object from data transfer object retrieved from
|
|
|
|
* the clipboard or OLE drag and drop.
|
|
|
|
* Returns : S_OK - Embedded object was created successfully.
|
|
|
|
* OLE_E_STATIC - OLE can create only a static object
|
|
|
|
* DV_E_FORMATETC - No acceptable format is available (only error return code)
|
|
|
|
* TODO : CF_FILENAME, CF_EMBEDEDOBJECT formats. Parameter renderopt is currently ignored.
|
|
|
|
*/
|
|
|
|
|
|
|
|
HRESULT WINAPI OleCreateFromData(LPDATAOBJECT pSrcDataObject, REFIID riid,
|
|
|
|
DWORD renderopt, LPFORMATETC pFormatEtc,
|
|
|
|
LPOLECLIENTSITE pClientSite, LPSTORAGE pStg,
|
|
|
|
LPVOID* ppvObj)
|
|
|
|
{
|
|
|
|
IEnumFORMATETC *pfmt;
|
|
|
|
FORMATETC fmt;
|
|
|
|
CHAR szFmtName[MAX_CLIPFORMAT_NAME];
|
|
|
|
STGMEDIUM std;
|
|
|
|
HRESULT hr;
|
|
|
|
HRESULT hr1;
|
|
|
|
|
|
|
|
hr = IDataObject_EnumFormatEtc(pSrcDataObject, DATADIR_GET, &pfmt);
|
|
|
|
|
|
|
|
if (hr == S_OK)
|
|
|
|
{
|
|
|
|
memset(&std, 0, sizeof(STGMEDIUM));
|
|
|
|
|
|
|
|
hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
|
|
|
|
while (hr == S_OK)
|
|
|
|
{
|
|
|
|
GetClipboardFormatNameA(fmt.cfFormat, szFmtName, MAX_CLIPFORMAT_NAME-1);
|
|
|
|
|
|
|
|
/* first, Check for Embedded Object, Embed Source or Filename */
|
|
|
|
/* TODO: Currently checks only for Embed Source. */
|
|
|
|
|
|
|
|
if (!strcmp(szFmtName, CF_EMBEDSOURCE))
|
|
|
|
{
|
|
|
|
std.tymed = TYMED_HGLOBAL;
|
|
|
|
|
|
|
|
if ((hr1 = IDataObject_GetData(pSrcDataObject, &fmt, &std)) == S_OK)
|
|
|
|
{
|
|
|
|
ILockBytes *ptrILockBytes = 0;
|
|
|
|
IStorage *pStorage = 0;
|
|
|
|
IOleObject *pOleObject = 0;
|
|
|
|
IPersistStorage *pPersistStorage = 0;
|
|
|
|
CLSID clsID;
|
|
|
|
|
|
|
|
/* Create ILock bytes */
|
|
|
|
|
|
|
|
hr1 = CreateILockBytesOnHGlobal(std.u.hGlobal, FALSE, &ptrILockBytes);
|
|
|
|
|
|
|
|
/* Open storage on the ILock bytes */
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
hr1 = StgOpenStorageOnILockBytes(ptrILockBytes, NULL, STGM_SHARE_EXCLUSIVE, NULL, 0, &pStorage);
|
|
|
|
|
|
|
|
/* Get Class ID from the opened storage */
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
hr1 = ReadClassStg(pStorage, &clsID);
|
|
|
|
|
|
|
|
/* Create default handler for Persist storage */
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
hr1 = OleCreateDefaultHandler(&clsID, NULL, &IID_IPersistStorage, (LPVOID*)&pPersistStorage);
|
|
|
|
|
|
|
|
/* Load the storage to Persist storage */
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
hr1 = IPersistStorage_Load(pPersistStorage, pStorage);
|
|
|
|
|
|
|
|
/* Query for IOleObject */
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
hr1 = IPersistStorage_QueryInterface(pPersistStorage, &IID_IOleObject, (LPVOID*)&pOleObject);
|
|
|
|
|
|
|
|
/* Set client site with the IOleObject */
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
hr1 = IOleObject_SetClientSite(pOleObject, pClientSite);
|
|
|
|
|
|
|
|
IPersistStorage_Release(pPersistStorage);
|
|
|
|
/* Query for the requested interface */
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
hr1 = IPersistStorage_QueryInterface(pPersistStorage, riid, ppvObj);
|
|
|
|
|
|
|
|
IPersistStorage_Release(pPersistStorage);
|
|
|
|
|
|
|
|
IStorage_Release(pStorage);
|
|
|
|
|
|
|
|
if (hr1 == S_OK)
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Return error */
|
|
|
|
|
|
|
|
return DV_E_FORMATETC;
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = IEnumFORMATETC_Next(pfmt, 1, &fmt, NULL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return DV_E_FORMATETC;
|
|
|
|
}
|
|
|
|
|