-#ifdef Q_WS_WIN
-
-static FORMATETC cfFromMime(QString const & mimetype)
-{
- FORMATETC formatetc;
- if (mimetype == emf_mime_type) {
- formatetc.cfFormat = CF_ENHMETAFILE;
- formatetc.tymed = TYMED_ENHMF;
- } else if (mimetype == wmf_mime_type) {
- formatetc.cfFormat = CF_METAFILEPICT;
- formatetc.tymed = TYMED_MFPICT;
- }
- formatetc.ptd = 0;
- formatetc.dwAspect = DVASPECT_CONTENT;
- formatetc.lindex = -1;
- return formatetc;
-}
-
-
-class QWindowsMimeMetafile : public QWindowsMime {
-public:
- bool canConvertFromMime(FORMATETC const & formatetc, QMimeData const * mimedata) const;
- bool canConvertToMime(QString const & mimetype, IDataObject * pDataObj) const;
- bool convertFromMime(FORMATETC const & formatetc, const QMimeData * mimedata, STGMEDIUM * pmedium) const;
- QVariant convertToMime(QString const & mimetype, IDataObject * pDataObj, QVariant::Type preferredType) const;
- QVector<FORMATETC> formatsForMime(QString const & mimeType, QMimeData const * mimeData) const;
- QString mimeForFormat(FORMATETC const &) const;
-};
-
-
-QString QWindowsMimeMetafile::mimeForFormat(FORMATETC const & formatetc) const
-{
- QString f;
- if (formatetc.cfFormat == CF_ENHMETAFILE)
- f = emf_mime_type;
- else if (formatetc.cfFormat == CF_METAFILEPICT)
- f = wmf_mime_type;
- return f;
-}
-
-
-bool QWindowsMimeMetafile::canConvertFromMime(FORMATETC const & formatetc,
- QMimeData const * mimedata) const
-{
- return false;
-}
-
-
-bool QWindowsMimeMetafile::canConvertToMime(QString const & mimetype,
- IDataObject * pDataObj) const
-{
- if (mimetype != emf_mime_type && mimetype != wmf_mime_type)
- return false;
- FORMATETC formatetc = cfFromMime(mimetype);
- return pDataObj->QueryGetData(&formatetc) == S_OK;
-}
-
-
-bool QWindowsMimeMetafile::convertFromMime(FORMATETC const & formatetc,
- QMimeData const * mimedata, STGMEDIUM * pmedium) const
-{
- return false;
-}
-
-
-QVariant QWindowsMimeMetafile::convertToMime(QString const & mimetype,
- IDataObject * pDataObj, QVariant::Type preferredType) const
-{
- QByteArray data;
- if (!canConvertToMime(mimetype, pDataObj))
- return data;
-
- FORMATETC formatetc = cfFromMime(mimetype);
- STGMEDIUM s;
- if (pDataObj->GetData(&formatetc, &s) != S_OK)
- return data;
-
- int dataSize;
- if (s.tymed == TYMED_ENHMF) {
- dataSize = GetEnhMetaFileBits(s.hEnhMetaFile, 0, 0);
- data.resize(dataSize);
- dataSize = GetEnhMetaFileBits(s.hEnhMetaFile, dataSize, (LPBYTE)data.data());
- } else if (s.tymed == TYMED_MFPICT) {
- dataSize = GetMetaFileBitsEx((HMETAFILE)s.hMetaFilePict, 0, 0);
- data.resize(dataSize);
- dataSize = GetMetaFileBitsEx((HMETAFILE)s.hMetaFilePict, dataSize, (LPBYTE)data.data());
- }
- data.detach();
- ReleaseStgMedium(&s);
-
- return data;
-}
-
-
-QVector<FORMATETC> QWindowsMimeMetafile::formatsForMime(
- QString const & mimetype, QMimeData const * mimedata) const
-{
- QVector<FORMATETC> formats;
- formats += cfFromMime(mimetype);
- return formats;
-}
-
-static std::auto_ptr<QWindowsMimeMetafile> metafileWindowsMime;