X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/51d4293d689966f36adcb7649973c6e84a986d46..6d7b547184bfdcdf67790755deb0122050b1d728:/src/mac/carbon/dnd.cpp diff --git a/src/mac/carbon/dnd.cpp b/src/mac/carbon/dnd.cpp index 808dc49fa4..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,7 +192,7 @@ bool wxDropTarget::GetData() FlavorType theType; FlavorFlags theFlags; UInt16 flavors; - bool firstFileAdded = false; + wxString filenamesPassed; CountDragItems( (DragReference)m_currentDrag, &items ); for (UInt16 index = 1; index <= items; ++index) @@ -199,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 ); @@ -224,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 @@ -243,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: @@ -260,28 +264,16 @@ bool wxDropTarget::GetData() #endif case kDragFlavorTypeHFS: + if (theData != NULL) { - wxFileDataObject *fdo = dynamic_cast(m_dataObject); - wxASSERT( fdo != NULL ); - - if ((theData != NULL) && (fdo != NULL)) - { - HFSFlavor* theFile = (HFSFlavor*) theData; - wxString name = wxMacFSSpec2MacFilename( &theFile->fileSpec ); - - if ( !firstFileAdded ) - { - // reset file list - fdo->SetData( 0, "" ); - firstFileAdded = true; - } - - if (!name.IsEmpty()) - fdo->AddFile( name ); - } + 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; @@ -293,6 +285,12 @@ bool wxDropTarget::GetData() } } } + + if (filenamesPassed.length() > 0) + { + wxCharBuffer buf = filenamesPassed.fn_str(); + m_dataObject->SetData( wxDataFormat(wxDF_FILENAME), strlen( buf ), (const char*)buf ); + } } return true; @@ -337,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 @@ -428,11 +425,9 @@ wxDragResult wxDropSource::DoDragDrop(int flags) #if !TARGET_CARBON // TODO ev = (EventRecord*) wxTheApp->MacGetCurrentEvent(); #else - { - EventRecord rec; - ev = &rec; - wxMacConvertEventToRecord( (EventRef) wxTheApp->MacGetCurrentEvent(), &rec ); - } + EventRecord rec; + ev = &rec; + wxMacConvertEventToRecord( (EventRef) wxTheApp->MacGetCurrentEvent(), &rec ); #endif const short dragRegionOuterBoundary = 10; @@ -624,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: @@ -654,6 +642,12 @@ pascal OSErr wxMacWindowDragTrackingHandler( // put these here to make gcc happy ; } + + if (cursorID != wxCURSOR_NONE) + { + wxCursor cursor( cursorID ); + cursor.MacInstall(); + } } } }