#include "wx/intl.h"
#include "wx/log.h"
-#include "wx/mac/private.h"
#ifndef __DARWIN__
#include <Scrap.h>
#endif
+#include "wx/mac/uma.h"
#define wxUSE_DATAOBJ 1
case wxDF_TEXT:
break;
+ case wxDF_BITMAP :
+ case wxDF_METAFILE :
+ break ;
default:
{
wxLogError(_("Unsupported clipboard format."));
{
mac = textDataObject->GetText() ;
}
- #if !TARGET_CARBON
- err = PutScrap( mac.Length() , 'TEXT' , mac.c_str() ) ;
- #else
- ScrapRef scrap;
- err = GetCurrentScrap (&scrap);
- if ( !err )
- {
- err = PutScrapFlavor (scrap, 'TEXT', 0, mac.Length(), mac.c_str());
- }
- #endif
+ err = UMAPutScrap( mac.Length() , 'TEXT' , (void*) mac.c_str() ) ;
}
break ;
#if wxUSE_DRAG_AND_DROP
case wxDF_METAFILE:
{
- wxMetafileDataObject* metaFileDataObject =
+ wxMetafileDataObject* metaFileDataObject =
(wxMetafileDataObject*) data;
- wxMetafile metaFile = metaFileDataObject->GetMetafile();
- PicHandle pict = (PicHandle) metaFile.GetHMETAFILE() ;
- HLock( (Handle) pict ) ;
- #if !TARGET_CARBON
- err = PutScrap( GetHandleSize( (Handle) pict ) , 'PICT' , *pict ) ;
- #else
- ScrapRef scrap;
- err = GetCurrentScrap (&scrap);
- if ( !err )
- {
- err = PutScrapFlavor (scrap, 'PICT', 0, GetHandleSize((Handle) pict), *pict);
- }
- #endif
- HUnlock( (Handle) pict ) ;
+ wxMetafile metaFile = metaFileDataObject->GetMetafile();
+ PicHandle pict = (PicHandle) metaFile.GetHMETAFILE() ;
+ HLock( (Handle) pict ) ;
+ err = UMAPutScrap( GetHandleSize( (Handle) pict ) , 'PICT' , *pict ) ;
+ HUnlock( (Handle) pict ) ;
}
break ;
#endif
case wxDF_BITMAP:
case wxDF_DIB:
+ {
+ bool created = false ;
+ PicHandle pict = NULL ;
+
+ wxBitmapDataObject* bitmapDataObject = (wxBitmapDataObject*) data ;
+ pict = (PicHandle) bitmapDataObject->GetBitmap().GetPict( &created ) ;
+
+ HLock( (Handle) pict ) ;
+ err = UMAPutScrap( GetHandleSize( (Handle) pict ) , 'PICT' , *pict ) ;
+ HUnlock( (Handle) pict ) ;
+ if ( created )
+ KillPicture( pict ) ;
+ }
default:
break ;
}
switch ( format.GetType() )
{
- case wxDF_TEXT:
- case wxDF_OEMTEXT:
+ case wxDF_TEXT :
+ case wxDF_OEMTEXT :
+ case wxDF_BITMAP :
+ case wxDF_METAFILE :
{
long len ;
char* s = (char*)wxGetClipboardData(format, &len );
#include "wx/defs.h"
#include "wx/dc.h"
-#include "wx/mac/uma.h"
#include <MacTextEditor.h>
#ifndef __DARWIN__
# endif
#endif
+#ifndef __DARWIN__
+#include <Scrap.h>
+#endif
+#include "wx/mac/uma.h"
+
// since we have decided that we only support 8.6 upwards we are
// checking for these minimum requirements in the startup code of
// the application so all wxWindows code can safely assume that appearance 1.1
}
}
+OSStatus UMAPutScrap( Size size , OSType type , void *data )
+{
+ OSStatus err = noErr ;
+#if !TARGET_CARBON
+ err = PutScrap( size , type , data ) ;
+#else
+ ScrapRef scrap;
+ err = GetCurrentScrap (&scrap);
+ if ( !err )
+ {
+ err = PutScrapFlavor (scrap, type , 0, size, data);
+ }
+#endif
+ return err ;
+}
+
#include "wx/intl.h"
#include "wx/log.h"
-#include "wx/mac/private.h"
#ifndef __DARWIN__
#include <Scrap.h>
#endif
+#include "wx/mac/uma.h"
#define wxUSE_DATAOBJ 1
case wxDF_TEXT:
break;
+ case wxDF_BITMAP :
+ case wxDF_METAFILE :
+ break ;
default:
{
wxLogError(_("Unsupported clipboard format."));
{
mac = textDataObject->GetText() ;
}
- #if !TARGET_CARBON
- err = PutScrap( mac.Length() , 'TEXT' , mac.c_str() ) ;
- #else
- ScrapRef scrap;
- err = GetCurrentScrap (&scrap);
- if ( !err )
- {
- err = PutScrapFlavor (scrap, 'TEXT', 0, mac.Length(), mac.c_str());
- }
- #endif
+ err = UMAPutScrap( mac.Length() , 'TEXT' , (void*) mac.c_str() ) ;
}
break ;
#if wxUSE_DRAG_AND_DROP
case wxDF_METAFILE:
{
- wxMetafileDataObject* metaFileDataObject =
+ wxMetafileDataObject* metaFileDataObject =
(wxMetafileDataObject*) data;
- wxMetafile metaFile = metaFileDataObject->GetMetafile();
- PicHandle pict = (PicHandle) metaFile.GetHMETAFILE() ;
- HLock( (Handle) pict ) ;
- #if !TARGET_CARBON
- err = PutScrap( GetHandleSize( (Handle) pict ) , 'PICT' , *pict ) ;
- #else
- ScrapRef scrap;
- err = GetCurrentScrap (&scrap);
- if ( !err )
- {
- err = PutScrapFlavor (scrap, 'PICT', 0, GetHandleSize((Handle) pict), *pict);
- }
- #endif
- HUnlock( (Handle) pict ) ;
+ wxMetafile metaFile = metaFileDataObject->GetMetafile();
+ PicHandle pict = (PicHandle) metaFile.GetHMETAFILE() ;
+ HLock( (Handle) pict ) ;
+ err = UMAPutScrap( GetHandleSize( (Handle) pict ) , 'PICT' , *pict ) ;
+ HUnlock( (Handle) pict ) ;
}
break ;
#endif
case wxDF_BITMAP:
case wxDF_DIB:
+ {
+ bool created = false ;
+ PicHandle pict = NULL ;
+
+ wxBitmapDataObject* bitmapDataObject = (wxBitmapDataObject*) data ;
+ pict = (PicHandle) bitmapDataObject->GetBitmap().GetPict( &created ) ;
+
+ HLock( (Handle) pict ) ;
+ err = UMAPutScrap( GetHandleSize( (Handle) pict ) , 'PICT' , *pict ) ;
+ HUnlock( (Handle) pict ) ;
+ if ( created )
+ KillPicture( pict ) ;
+ }
default:
break ;
}
switch ( format.GetType() )
{
- case wxDF_TEXT:
- case wxDF_OEMTEXT:
+ case wxDF_TEXT :
+ case wxDF_OEMTEXT :
+ case wxDF_BITMAP :
+ case wxDF_METAFILE :
{
long len ;
char* s = (char*)wxGetClipboardData(format, &len );
#include "wx/defs.h"
#include "wx/dc.h"
-#include "wx/mac/uma.h"
#include <MacTextEditor.h>
#ifndef __DARWIN__
# endif
#endif
+#ifndef __DARWIN__
+#include <Scrap.h>
+#endif
+#include "wx/mac/uma.h"
+
// since we have decided that we only support 8.6 upwards we are
// checking for these minimum requirements in the startup code of
// the application so all wxWindows code can safely assume that appearance 1.1
}
}
+OSStatus UMAPutScrap( Size size , OSType type , void *data )
+{
+ OSStatus err = noErr ;
+#if !TARGET_CARBON
+ err = PutScrap( size , type , data ) ;
+#else
+ ScrapRef scrap;
+ err = GetCurrentScrap (&scrap);
+ if ( !err )
+ {
+ err = PutScrapFlavor (scrap, type , 0, size, data);
+ }
+#endif
+ return err ;
+}
+