X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/55f5548f782e57d1067cf0ab10c51d7ec5af61ac..ab346e1c7e75d76f3aeef1b21a02a0620f7e3452:/src/mac/carbon/dnd.cpp diff --git a/src/mac/carbon/dnd.cpp b/src/mac/carbon/dnd.cpp index 3de09fe3e8..834533d04a 100644 --- a/src/mac/carbon/dnd.cpp +++ b/src/mac/carbon/dnd.cpp @@ -1,5 +1,5 @@ /////////////////////////////////////////////////////////////////////////////// -// Name: dnd.cpp +// Name: src/mac/carbon/dnd.cpp // Purpose: wxDropTarget, wxDropSource implementations // Author: Stefan Csomor // Modified by: @@ -14,10 +14,14 @@ #if wxUSE_DRAG_AND_DROP #include "wx/dnd.h" -#include "wx/window.h" -#include "wx/toplevel.h" -#include "wx/app.h" -#include "wx/gdicmn.h" + +#ifndef WX_PRECOMP + #include "wx/app.h" + #include "wx/window.h" + #include "wx/toplevel.h" + #include "wx/gdicmn.h" +#endif // WX_PRECOMP + #include "wx/mac/private.h" #ifndef __DARWIN__ @@ -188,9 +192,7 @@ bool wxDropTarget::GetData() FlavorType theType; FlavorFlags theFlags; UInt16 flavors; - bool firstFileAdded = false; - - wxString filenamesPassed ; + wxString filenamesPassed; CountDragItems( (DragReference)m_currentDrag, &items ); for (UInt16 index = 1; index <= items; ++index) @@ -201,22 +203,22 @@ bool wxDropTarget::GetData() wxDataFormat preferredFormat = m_dataObject->GetPreferredFormat( wxDataObject::Set ); bool hasPreferredFormat = false; - for ( UInt16 flavor = 1; flavor <= flavors; ++flavor ) + for (UInt16 flavor = 1; flavor <= flavors; ++flavor) { result = GetFlavorType( (DragReference)m_currentDrag, theItem, flavor, &theType ); wxDataFormat format( theType ); - if ( preferredFormat == format ) + if (preferredFormat == format) { hasPreferredFormat = true; break; } } - for ( UInt16 flavor = 1; flavor <= flavors; ++flavor ) + for (UInt16 flavor = 1; flavor <= flavors; ++flavor) { result = GetFlavorType( (DragReference)m_currentDrag, theItem, flavor, &theType ); wxDataFormat format( theType ); - if ( (hasPreferredFormat && format == preferredFormat) + if ((hasPreferredFormat && format == preferredFormat) || (!hasPreferredFormat && m_dataObject->IsSupportedFormat( format ))) { result = GetFlavorFlags( (DragReference)m_currentDrag, theItem, theType, &theFlags ); @@ -226,13 +228,13 @@ bool wxDropTarget::GetData() Ptr theData; GetFlavorDataSize( (DragReference)m_currentDrag, theItem, theType, &dataSize ); - if ( theType == kScrapFlavorTypeText ) + if (theType == kScrapFlavorTypeText) { // this increment is only valid for allocating: // on the next GetFlavorData call it is reset again to the original value dataSize++; } - else if ( theType == kScrapFlavorTypeUnicode ) + else if (theType == kScrapFlavorTypeUnicode) { // this increment is only valid for allocating: // on the next GetFlavorData call it is reset again to the original value @@ -245,7 +247,7 @@ bool wxDropTarget::GetData() else theData = NULL; - GetFlavorData( (DragReference)m_currentDrag, theItem, theType, (void*) theData, &dataSize, 0L ); + GetFlavorData( (DragReference)m_currentDrag, theItem, theType, (void*)theData, &dataSize, 0L ); switch (theType) { case kScrapFlavorTypeText: @@ -262,18 +264,16 @@ bool wxDropTarget::GetData() #endif case kDragFlavorTypeHFS: + if (theData != NULL) { - if (theData != NULL) - { - HFSFlavor* theFile = (HFSFlavor*) theData; - wxString name = wxMacFSSpec2MacFilename( &theFile->fileSpec ); - - if (!name.IsEmpty()) - filenamesPassed += name + wxT("\n"); - } + HFSFlavor* theFile = (HFSFlavor*)theData; + wxString name = wxMacFSSpec2MacFilename( &theFile->fileSpec ); + + if (!name.empty()) + filenamesPassed += name + wxT("\n"); } break; - + default: m_dataObject->SetData( format, dataSize, theData ); break; @@ -285,10 +285,11 @@ bool wxDropTarget::GetData() } } } - if ( filenamesPassed.Len() > 0 ) + + if (filenamesPassed.length() > 0) { wxCharBuffer buf = filenamesPassed.fn_str(); - m_dataObject->SetData( wxDataFormat( wxDF_FILENAME ) , strlen( buf ) , (const char*) buf ); + m_dataObject->SetData( wxDataFormat(wxDF_FILENAME), strlen( buf ), (const char*)buf ); } } @@ -334,15 +335,14 @@ wxDragResult wxDropSource::DoDragDrop(int flags) { wxASSERT_MSG( m_data, wxT("Drop source: no data") ); - if (!m_data) - return (wxDragResult) wxDragNone; - if (m_data->GetFormatCount() == 0) - return (wxDragResult) wxDragNone; + if ((m_data == NULL) || (m_data->GetFormatCount() == 0)) + return (wxDragResult)wxDragNone; OSStatus result; DragReference theDrag; RgnHandle dragRegion; - if ((result = NewDrag(&theDrag)) != noErr) + + if ((result = NewDrag( &theDrag )) != noErr) return wxDragNone; // add data to drag @@ -619,27 +619,20 @@ pascal OSErr wxMacWindowDragTrackingHandler( { if ( !trackingGlobals->m_currentSource->MacInstallDefaultCursor( result ) ) { - switch ( result ) + int cursorID = wxCURSOR_NONE; + + switch (result) { case wxDragCopy: - { - wxCursor cursor(wxCURSOR_COPY_ARROW); - cursor.MacInstall(); - } + cursorID = wxCURSOR_COPY_ARROW; break; case wxDragMove: - { - wxCursor cursor(wxCURSOR_ARROW); - cursor.MacInstall(); - } + cursorID = wxCURSOR_ARROW; break; case wxDragNone: - { - wxCursor cursor(wxCURSOR_NO_ENTRY); - cursor.MacInstall(); - } + cursorID = wxCURSOR_NO_ENTRY; break; case wxDragError: @@ -649,6 +642,12 @@ pascal OSErr wxMacWindowDragTrackingHandler( // put these here to make gcc happy ; } + + if (cursorID != wxCURSOR_NONE) + { + wxCursor cursor( cursorID ); + cursor.MacInstall(); + } } } }