cleanup - added some error checking, reformatting
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@38184 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -144,7 +144,7 @@ void * wxGetClipboardData( wxDataFormat dataFormat, long *len )
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( dataFormat.GetType() == wxDF_TEXT )
|
if (dataFormat.GetType() == wxDF_TEXT)
|
||||||
wxMacConvertNewlines10To13( (char*)data );
|
wxMacConvertNewlines10To13( (char*)data );
|
||||||
|
|
||||||
return data;
|
return data;
|
||||||
@@ -160,19 +160,19 @@ wxClipboard::wxClipboard()
|
|||||||
|
|
||||||
wxClipboard::~wxClipboard()
|
wxClipboard::~wxClipboard()
|
||||||
{
|
{
|
||||||
if (m_data)
|
if (m_data != NULL)
|
||||||
{
|
{
|
||||||
delete m_data;
|
delete m_data;
|
||||||
m_data = (wxDataObject*)NULL;
|
m_data = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxClipboard::Clear()
|
void wxClipboard::Clear()
|
||||||
{
|
{
|
||||||
if (m_data)
|
if (m_data != NULL)
|
||||||
{
|
{
|
||||||
delete m_data;
|
delete m_data;
|
||||||
m_data = (wxDataObject*)NULL;
|
m_data = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
@@ -242,11 +242,11 @@ bool wxClipboard::AddData( wxDataObject *data )
|
|||||||
|
|
||||||
size_t sz = data->GetDataSize( array[ i ] );
|
size_t sz = data->GetDataSize( array[ i ] );
|
||||||
void* buf = malloc( sz + 1 );
|
void* buf = malloc( sz + 1 );
|
||||||
if ( buf )
|
if ( buf != NULL )
|
||||||
{
|
{
|
||||||
// empty the buffer because in some case GetDataHere does not fill buf
|
// empty the buffer because in some case GetDataHere does not fill buf
|
||||||
memset(buf, 0, sz + 1);
|
memset( buf, 0, sz + 1 );
|
||||||
data->GetDataHere( array[ i ] , buf );
|
data->GetDataHere( array[ i ], buf );
|
||||||
OSType mactype = 0;
|
OSType mactype = 0;
|
||||||
switch ( array[i].GetType() )
|
switch ( array[i].GetType() )
|
||||||
{
|
{
|
||||||
@@ -275,7 +275,7 @@ bool wxClipboard::AddData( wxDataObject *data )
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
mactype = (OSType)(array[i].GetFormatId());
|
mactype = (OSType)(array[ i ].GetFormatId());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -310,6 +310,8 @@ bool wxClipboard::IsSupported( const wxDataFormat &dataFormat )
|
|||||||
if ( m_data )
|
if ( m_data )
|
||||||
return m_data->IsSupported( dataFormat );
|
return m_data->IsSupported( dataFormat );
|
||||||
|
|
||||||
|
bool hasData = false;
|
||||||
|
|
||||||
#if TARGET_CARBON
|
#if TARGET_CARBON
|
||||||
OSStatus err = noErr;
|
OSStatus err = noErr;
|
||||||
ScrapRef scrapRef;
|
ScrapRef scrapRef;
|
||||||
@@ -325,23 +327,22 @@ bool wxClipboard::IsSupported( const wxDataFormat &dataFormat )
|
|||||||
{
|
{
|
||||||
err = GetScrapFlavorSize( scrapRef, dataFormat.GetFormatId(), &byteCount );
|
err = GetScrapFlavorSize( scrapRef, dataFormat.GetFormatId(), &byteCount );
|
||||||
if (err == noErr)
|
if (err == noErr)
|
||||||
return true;
|
hasData = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
long offset;
|
|
||||||
|
long offset = 0;
|
||||||
Handle datahandle = NewHandle( 0 );
|
Handle datahandle = NewHandle( 0 );
|
||||||
HLock( datahandle );
|
HLock( datahandle );
|
||||||
GetScrap( datahandle, dataFormat.GetFormatId(), &offset );
|
GetScrap( datahandle, dataFormat.GetFormatId(), &offset );
|
||||||
HUnlock( datahandle );
|
HUnlock( datahandle );
|
||||||
bool hasData = GetHandleSize( datahandle ) > 0;
|
hasData = GetHandleSize( datahandle ) > 0;
|
||||||
DisposeHandle( datahandle );
|
DisposeHandle( datahandle );
|
||||||
|
#endif
|
||||||
|
|
||||||
return hasData;
|
return hasData;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxClipboard::GetData( wxDataObject& data )
|
bool wxClipboard::GetData( wxDataObject& data )
|
||||||
@@ -372,7 +373,7 @@ bool wxClipboard::GetData( wxDataObject& data )
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
char *d = new char[ dataSize ];
|
char *d = new char[ dataSize ];
|
||||||
m_data->GetDataHere( format, (void*) d );
|
m_data->GetDataHere( format, (void*)d );
|
||||||
data.SetData( format, dataSize, d );
|
data.SetData( format, dataSize, d );
|
||||||
delete [] d;
|
delete [] d;
|
||||||
}
|
}
|
||||||
@@ -413,6 +414,7 @@ bool wxClipboard::GetData( wxDataObject& data )
|
|||||||
}
|
}
|
||||||
|
|
||||||
delete [] array;
|
delete [] array;
|
||||||
|
|
||||||
return transferred;
|
return transferred;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -96,7 +96,7 @@ void wxDataFormat::SetType( wxDataFormatId dataType )
|
|||||||
|
|
||||||
wxString wxDataFormat::GetId() const
|
wxString wxDataFormat::GetId() const
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( !IsStandard(), wxEmptyString ,
|
wxCHECK_MSG( !IsStandard(), wxEmptyString,
|
||||||
wxT("name of predefined format cannot be retrieved") );
|
wxT("name of predefined format cannot be retrieved") );
|
||||||
|
|
||||||
return m_id;
|
return m_id;
|
||||||
@@ -342,8 +342,8 @@ bool wxBitmapDataObject::SetData( size_t nSize, const void *pBuf )
|
|||||||
|
|
||||||
// ownership is transferred to the bitmap
|
// ownership is transferred to the bitmap
|
||||||
m_pictCreated = false;
|
m_pictCreated = false;
|
||||||
Rect frame ;
|
Rect frame;
|
||||||
wxMacGetPictureBounds( picHandle , &frame ) ;
|
wxMacGetPictureBounds( picHandle, &frame );
|
||||||
|
|
||||||
wxMetafile mf;
|
wxMetafile mf;
|
||||||
mf.SetHMETAFILE( (WXHMETAFILE)m_pictHandle );
|
mf.SetHMETAFILE( (WXHMETAFILE)m_pictHandle );
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
// Name: metafile.cpp
|
// Name: src/mac/carbon/metafile.cpp
|
||||||
// Purpose: wxMetaFile, wxMetaFileDC etc. These classes are optional.
|
// Purpose: wxMetaFile, wxMetaFileDC etc. These classes are optional.
|
||||||
// Author: Stefan Csomor
|
// Author: Stefan Csomor
|
||||||
// Modified by:
|
// Modified by:
|
||||||
@@ -8,13 +8,13 @@
|
|||||||
// Copyright: (c) Stefan Csomor
|
// Copyright: (c) Stefan Csomor
|
||||||
// Licence: wxWindows licence
|
// Licence: wxWindows licence
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Currently, the only purpose for making a metafile
|
||||||
|
// is to put it on the clipboard.
|
||||||
|
|
||||||
|
|
||||||
#include "wx/wxprec.h"
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
#ifdef __BORLANDC__
|
|
||||||
#pragma hdrstop
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if wxUSE_METAFILE
|
#if wxUSE_METAFILE
|
||||||
|
|
||||||
#ifndef WX_PRECOMP
|
#ifndef WX_PRECOMP
|
||||||
@@ -48,16 +48,13 @@ private:
|
|||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
extern bool wxClipboardIsOpen;
|
extern bool wxClipboardIsOpen;
|
||||||
|
|
||||||
|
|
||||||
// Metafiles:
|
|
||||||
// Currently, the only purpose for making a metafile
|
|
||||||
// is to put it on the clipboard.
|
|
||||||
|
|
||||||
wxMetafileRefData::wxMetafileRefData()
|
wxMetafileRefData::wxMetafileRefData()
|
||||||
{
|
{
|
||||||
m_metafile = 0;
|
m_metafile = NULL;
|
||||||
|
|
||||||
#if wxMAC_USE_CORE_GRAPHICS
|
#if wxMAC_USE_CORE_GRAPHICS
|
||||||
m_qdPictRef = NULL;
|
m_qdPictRef = NULL;
|
||||||
@@ -82,8 +79,8 @@ wxMetaFile::wxMetaFile(const wxString& file)
|
|||||||
{
|
{
|
||||||
m_refData = new wxMetafileRefData;
|
m_refData = new wxMetafileRefData;
|
||||||
|
|
||||||
M_METAFILEDATA->m_metafile = 0;
|
M_METAFILEDATA->m_metafile = NULL;
|
||||||
wxASSERT_MSG( file.empty(), wxT("no file based metafile support yet") );
|
wxASSERT_MSG( file.empty(), wxT("no file-based metafile support yet") );
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if (!file.IsNull() && (file.Cmp("") == 0))
|
if (!file.IsNull() && (file.Cmp("") == 0))
|
||||||
@@ -97,7 +94,7 @@ wxMetaFile::~wxMetaFile()
|
|||||||
|
|
||||||
bool wxMetaFile::Ok() const
|
bool wxMetaFile::Ok() const
|
||||||
{
|
{
|
||||||
return (M_METAFILEDATA && (M_METAFILEDATA->m_metafile != 0));
|
return (M_METAFILEDATA && (M_METAFILEDATA->m_metafile != NULL));
|
||||||
}
|
}
|
||||||
|
|
||||||
WXHMETAFILE wxMetaFile::GetHMETAFILE() const
|
WXHMETAFILE wxMetaFile::GetHMETAFILE() const
|
||||||
@@ -110,8 +107,8 @@ bool wxMetaFile::SetClipboard(int width, int height)
|
|||||||
bool success = true;
|
bool success = true;
|
||||||
|
|
||||||
#if wxUSE_DRAG_AND_DROP
|
#if wxUSE_DRAG_AND_DROP
|
||||||
// TODO: to finish this port, we need the data obj first
|
// TODO: to finish this port, we need the data object first
|
||||||
if (!m_refData)
|
if (m_refData == NULL)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
bool alreadyOpen = wxTheClipboard->IsOpened();
|
bool alreadyOpen = wxTheClipboard->IsOpened();
|
||||||
@@ -136,19 +133,20 @@ void wxMetafile::SetHMETAFILE(WXHMETAFILE mf)
|
|||||||
|
|
||||||
m_refData = new wxMetafileRefData;
|
m_refData = new wxMetafileRefData;
|
||||||
|
|
||||||
M_METAFILEDATA->m_metafile = (PicHandle) mf;
|
M_METAFILEDATA->m_metafile = (PicHandle)mf;
|
||||||
|
|
||||||
#if wxMAC_USE_CORE_GRAPHICS
|
#if wxMAC_USE_CORE_GRAPHICS
|
||||||
size_t sz = GetHandleSize( (Handle) M_METAFILEDATA->m_metafile );
|
size_t sz = GetHandleSize( (Handle) M_METAFILEDATA->m_metafile );
|
||||||
wxMemoryBuffer* membuf = new wxMemoryBuffer( sz );
|
wxMemoryBuffer* membuf = new wxMemoryBuffer( sz );
|
||||||
void *data = membuf->GetWriteBuf( sz );
|
void *data = membuf->GetWriteBuf( sz );
|
||||||
|
|
||||||
memcpy( data, *M_METAFILEDATA->m_metafile, sz );
|
memcpy( data, *M_METAFILEDATA->m_metafile, sz );
|
||||||
membuf->UngetWriteBuf( sz );
|
membuf->UngetWriteBuf( sz );
|
||||||
CGDataProviderRef provider = CGDataProviderCreateWithData(
|
CGDataProviderRef provider = CGDataProviderCreateWithData(
|
||||||
membuf, data, sz, wxMacMemoryBufferReleaseProc );
|
membuf, data, sz, wxMacMemoryBufferReleaseProc );
|
||||||
M_METAFILEDATA->m_qdPictRef = NULL;
|
M_METAFILEDATA->m_qdPictRef = NULL;
|
||||||
|
|
||||||
if ( provider != NULL )
|
if (provider != NULL)
|
||||||
{
|
{
|
||||||
M_METAFILEDATA->m_qdPictRef = QDPictCreateWithProvider( provider );
|
M_METAFILEDATA->m_qdPictRef = QDPictCreateWithProvider( provider );
|
||||||
CGDataProviderRelease( provider );
|
CGDataProviderRelease( provider );
|
||||||
@@ -161,7 +159,7 @@ bool wxMetaFile::Play(wxDC *dc)
|
|||||||
if (!m_refData)
|
if (!m_refData)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!dc->Ok() )
|
if (!dc->Ok())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -171,15 +169,15 @@ bool wxMetaFile::Play(wxDC *dc)
|
|||||||
CGRect bounds = QDPictGetBounds( cgPictRef );
|
CGRect bounds = QDPictGetBounds( cgPictRef );
|
||||||
|
|
||||||
CGContextSaveGState( cg );
|
CGContextSaveGState( cg );
|
||||||
CGContextTranslateCTM( cg, 0 , bounds.size.width );
|
CGContextTranslateCTM( cg, 0, bounds.size.width );
|
||||||
CGContextScaleCTM( cg, 1, -1 );
|
CGContextScaleCTM( cg, 1, -1 );
|
||||||
QDPictDrawToCGContext( cg , bounds, cgPictRef );
|
QDPictDrawToCGContext( cg, bounds, cgPictRef );
|
||||||
CGContextRestoreGState( cg );
|
CGContextRestoreGState( cg );
|
||||||
#else
|
#else
|
||||||
PicHandle pict = (PicHandle) GetHMETAFILE();
|
PicHandle pict = (PicHandle)GetHMETAFILE();
|
||||||
wxMacPortSetter helper( dc );
|
wxMacPortSetter helper( dc );
|
||||||
Rect picFrame ;
|
Rect picFrame;
|
||||||
DrawPicture( pict , wxMacGetPictureBounds( pict , &picFrame ) );
|
DrawPicture( pict, wxMacGetPictureBounds( pict, &picFrame ) );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -188,18 +186,18 @@ bool wxMetaFile::Play(wxDC *dc)
|
|||||||
|
|
||||||
wxSize wxMetaFile::GetSize() const
|
wxSize wxMetaFile::GetSize() const
|
||||||
{
|
{
|
||||||
wxSize size = wxDefaultSize ;
|
wxSize dataSize = wxDefaultSize;
|
||||||
|
|
||||||
if ( Ok() )
|
if (Ok())
|
||||||
{
|
{
|
||||||
PicHandle pict = (PicHandle) GetHMETAFILE() ;
|
PicHandle pict = (PicHandle)GetHMETAFILE();
|
||||||
Rect r ;
|
Rect r;
|
||||||
wxMacGetPictureBounds( pict , &r ) ;
|
wxMacGetPictureBounds( pict, &r );
|
||||||
size.x = r.right - r.left ;
|
dataSize.x = r.right - r.left;
|
||||||
size.y = r.bottom - r.top ;
|
dataSize.y = r.bottom - r.top;
|
||||||
}
|
}
|
||||||
|
|
||||||
return size;
|
return dataSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Metafile device context
|
// Metafile device context
|
||||||
@@ -207,12 +205,13 @@ wxSize wxMetaFile::GetSize() const
|
|||||||
// New constructor that takes origin and extent. If you use this, don't
|
// New constructor that takes origin and extent. If you use this, don't
|
||||||
// give origin/extent arguments to wxMakeMetaFilePlaceable.
|
// give origin/extent arguments to wxMakeMetaFilePlaceable.
|
||||||
|
|
||||||
wxMetaFileDC::wxMetaFileDC(const wxString& filename ,
|
wxMetaFileDC::wxMetaFileDC(
|
||||||
int width , int height ,
|
const wxString& filename,
|
||||||
const wxString& WXUNUSED(description) )
|
int width, int height,
|
||||||
|
const wxString& WXUNUSED(description) )
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( width == 0 || height == 0 , wxT("no arbitration of metafilesize supported") );
|
wxASSERT_MSG( width <= 0 || height <= 0, wxT("no arbitration of metafile size supported") );
|
||||||
wxASSERT_MSG( filename.empty() , wxT("no file based metafile support yet"));
|
wxASSERT_MSG( filename.empty(), wxT("no file based metafile support yet"));
|
||||||
|
|
||||||
m_metaFile = new wxMetaFile( filename );
|
m_metaFile = new wxMetaFile( filename );
|
||||||
|
|
||||||
@@ -220,13 +219,13 @@ wxMetaFileDC::wxMetaFileDC(const wxString& filename ,
|
|||||||
#else
|
#else
|
||||||
Rect r = { 0, 0, height, width };
|
Rect r = { 0, 0, height, width };
|
||||||
|
|
||||||
RectRgn( (RgnHandle) m_macBoundaryClipRgn , &r );
|
RectRgn( (RgnHandle)m_macBoundaryClipRgn, &r );
|
||||||
CopyRgn( (RgnHandle) m_macBoundaryClipRgn , (RgnHandle) m_macCurrentClipRgn );
|
CopyRgn( (RgnHandle)m_macBoundaryClipRgn, (RgnHandle)m_macCurrentClipRgn );
|
||||||
|
|
||||||
m_metaFile->SetHMETAFILE( (WXHMETAFILE) OpenPicture( &r ) );
|
m_metaFile->SetHMETAFILE( (WXHMETAFILE)OpenPicture( &r ) );
|
||||||
::GetPort( (GrafPtr*) &m_macPort );
|
::GetPort( (GrafPtr*)&m_macPort );
|
||||||
|
|
||||||
m_ok = true ;
|
m_ok = true;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
SetMapMode( wxMM_TEXT );
|
SetMapMode( wxMM_TEXT );
|
||||||
@@ -238,9 +237,9 @@ wxMetaFileDC::~wxMetaFileDC()
|
|||||||
|
|
||||||
void wxMetaFileDC::DoGetSize(int *width, int *height) const
|
void wxMetaFileDC::DoGetSize(int *width, int *height) const
|
||||||
{
|
{
|
||||||
wxCHECK_RET( m_metaFile , wxT("GetSize() doesn't work without a metafile") );
|
wxCHECK_RET( m_metaFile, wxT("GetSize() doesn't work without a metafile") );
|
||||||
|
|
||||||
wxSize sz = m_metaFile->GetSize() ;
|
wxSize sz = m_metaFile->GetSize();
|
||||||
if (width)
|
if (width)
|
||||||
(*width) = sz.x;
|
(*width) = sz.x;
|
||||||
if (height)
|
if (height)
|
||||||
@@ -249,7 +248,7 @@ void wxMetaFileDC::DoGetSize(int *width, int *height) const
|
|||||||
|
|
||||||
wxMetaFile *wxMetaFileDC::Close()
|
wxMetaFile *wxMetaFileDC::Close()
|
||||||
{
|
{
|
||||||
ClosePicture() ;
|
ClosePicture();
|
||||||
|
|
||||||
return m_metaFile;
|
return m_metaFile;
|
||||||
}
|
}
|
||||||
@@ -262,10 +261,13 @@ size_t wxMetafileDataObject::GetDataSize() const
|
|||||||
|
|
||||||
bool wxMetafileDataObject::GetDataHere(void *buf) const
|
bool wxMetafileDataObject::GetDataHere(void *buf) const
|
||||||
{
|
{
|
||||||
memcpy( buf , (*(PicHandle)(*((wxMetafile*)&m_metafile)).GetHMETAFILE()) ,
|
Handle pictH = (Handle)(*((wxMetafile*)&m_metafile)).GetHMETAFILE();
|
||||||
GetHandleSize( (Handle) (*((wxMetafile*)&m_metafile)).GetHMETAFILE() ) );
|
bool result = (pictH != NULL);
|
||||||
|
|
||||||
return true;
|
if (result)
|
||||||
|
memcpy( buf, *pictH, GetHandleSize( pictH ) );
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxMetafileDataObject::SetData(size_t len, const void *buf)
|
bool wxMetafileDataObject::SetData(size_t len, const void *buf)
|
||||||
@@ -275,7 +277,7 @@ bool wxMetafileDataObject::SetData(size_t len, const void *buf)
|
|||||||
memcpy( *handle, buf, len );
|
memcpy( *handle, buf, len );
|
||||||
m_metafile.SetHMETAFILE( (WXHMETAFILE) handle );
|
m_metafile.SetHMETAFILE( (WXHMETAFILE) handle );
|
||||||
|
|
||||||
return true ;
|
return true;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user