///////////////////////////////////////////////////////////////////////////////
-// Name: src/mac/carbon/dnd.cpp
+// Name: src/osx/carbon/dnd.cpp
// Purpose: wxDropTarget, wxDropSource implementations
// Author: Stefan Csomor
// Modified by:
#include "wx/gdicmn.h"
#endif // WX_PRECOMP
-#include "wx/mac/private.h"
+#include "wx/osx/private.h"
// ----------------------------------------------------------------------------
// globals
return CurrentDragHasSupportedFormat() ? def : wxDragNone;
}
+wxDataFormat wxDropTarget::GetMatchingPair()
+{
+ wxFAIL_MSG("wxDropTarget::GetMatchingPair() not implemented in src/osx/carbon/dnd.cpp");
+ return wxDF_INVALID;
+}
+
bool wxDropTarget::OnDrop( wxCoord WXUNUSED(x), wxCoord WXUNUSED(y) )
{
if (m_dataObject == NULL)
if ( !supported )
{
- PasteboardRef pasteboard;
-
- if ( GetDragPasteboard( (DragReference)m_currentDrag, &pasteboard ) == noErr )
- {
- supported = m_dataObject->HasDataInPasteboard( pasteboard );
- }
+ supported = m_dataObject->HasDataInPasteboard( m_currentDragPasteboard );
}
return supported;
if ( !transferred )
{
- PasteboardRef pasteboard;
-
- if ( GetDragPasteboard( (DragReference)m_currentDrag, &pasteboard ) == noErr )
- {
- transferred = m_dataObject->GetFromPasteboard( pasteboard );
- }
+ transferred = m_dataObject->GetFromPasteboard( m_currentDragPasteboard );
}
return transferred;
if ((m_data == NULL) || (m_data->GetFormatCount() == 0))
return (wxDragResult)wxDragNone;
+#if wxOSX_USE_CARBON
DragReference theDrag;
RgnHandle dragRegion;
OSStatus err = noErr;
DisposeDrag( theDrag );
CFRelease( pasteboard );
gTrackingGlobals.m_currentSource = NULL;
+#else
+ wxUnusedVar(flags);
+#endif
return gTrackingGlobals.m_result;
}
// passing the globals via refcon is not needed by the CFM and later architectures anymore
// but I'll leave it in there, just in case...
+#if wxOSX_USE_CARBON
pascal OSErr wxMacWindowDragTrackingHandler(
DragTrackingMessage theMessage, WindowPtr theWindow,
void *handlerRefCon, DragReference theDrag );
pascal OSErr wxMacWindowDragReceiveHandler(
WindowPtr theWindow, void *handlerRefCon,
DragReference theDrag );
+#endif
void wxMacEnsureTrackingHandlersInstalled()
{
+#if wxOSX_USE_CARBON
if ( !gTrackingGlobalsInstalled )
{
OSStatus err;
gTrackingGlobalsInstalled = true;
}
+#endif
}
+#if wxOSX_USE_CARBON
pascal OSErr wxMacWindowDragTrackingHandler(
DragTrackingMessage theMessage, WindowPtr theWindow,
void *handlerRefCon, DragReference theDrag )
DragAttributes attributes;
GetDragAttributes( theDrag, &attributes );
-
- wxNonOwnedWindow* toplevel = wxFindWinFromMacWindow( theWindow );
+ PasteboardRef pasteboard = 0;
+ GetDragPasteboard( theDrag, &pasteboard );
+ wxNonOwnedWindow* toplevel = wxNonOwnedWindow::GetFromWXWindow( (WXWindow) theWindow );
bool optionDown = GetCurrentKeyModifiers() & optionKey;
wxDragResult result = optionDown ? wxDragCopy : wxDragMove;
break;
GetDragMouse( theDrag, &mouse, 0L );
- localMouse = mouse;
- wxMacGlobalToLocal( theWindow, &localMouse );
+ int x = mouse.h ;
+ int y = mouse.v ;
+ toplevel->GetNonOwnedPeer()->ScreenToWindow( &x, &y );
+ localMouse.h = x;
+ localMouse.v = y;
{
wxWindow *win = NULL;
ControlPartCode controlPart;
ControlRef control = FindControlUnderMouse( localMouse, theWindow, &controlPart );
if ( control )
- win = wxFindControlFromMacControl( control );
+ win = wxFindWindowFromWXWidget( (WXWidget) control );
else
win = toplevel;
#ifndef __LP64__
HideDragHilite( theDrag );
#endif
- trackingGlobals->m_currentTarget->SetCurrentDrag( theDrag );
+ trackingGlobals->m_currentTarget->SetCurrentDragPasteboard( pasteboard );
trackingGlobals->m_currentTarget->OnLeave();
trackingGlobals->m_currentTarget = NULL;
trackingGlobals->m_currentTargetWindow = NULL;
{
if ( trackingGlobals->m_currentTarget )
{
- trackingGlobals->m_currentTarget->SetCurrentDrag( theDrag );
+ trackingGlobals->m_currentTarget->SetCurrentDragPasteboard( pasteboard );
result = trackingGlobals->m_currentTarget->OnEnter( localx, localy, result );
}
{
if ( trackingGlobals->m_currentTarget )
{
- trackingGlobals->m_currentTarget->SetCurrentDrag( theDrag );
+ trackingGlobals->m_currentTarget->SetCurrentDragPasteboard( pasteboard );
result = trackingGlobals->m_currentTarget->OnDragOver( localx, localy, result );
}
}
{
if ( !trackingGlobals->m_currentSource->MacInstallDefaultCursor( result ) )
{
- int cursorID = wxCURSOR_NONE;
+ wxStockCursor cursorID = wxCURSOR_NONE;
switch (result)
{
if (trackingGlobals->m_currentTarget)
{
- trackingGlobals->m_currentTarget->SetCurrentDrag( theDrag );
+ trackingGlobals->m_currentTarget->SetCurrentDragPasteboard( pasteboard );
trackingGlobals->m_currentTarget->OnLeave();
#ifndef __LP64__
HideDragHilite( theDrag );
Point mouse, localMouse;
int localx, localy;
- trackingGlobals->m_currentTarget->SetCurrentDrag( theDrag );
+ PasteboardRef pasteboard = 0;
+ GetDragPasteboard( theDrag, &pasteboard );
+ trackingGlobals->m_currentTarget->SetCurrentDragPasteboard( pasteboard );
GetDragMouse( theDrag, &mouse, 0L );
localMouse = mouse;
- wxMacGlobalToLocal( theWindow, &localMouse );
localx = localMouse.h;
localy = localMouse.v;
+ wxNonOwnedWindow* tlw = wxNonOwnedWindow::GetFromWXWindow((WXWindow) theWindow);
+ if ( tlw )
+ tlw->GetNonOwnedPeer()->ScreenToWindow( &localx, &localy );
// TODO : should we use client coordinates?
if ( trackingGlobals->m_currentTargetWindow )
return noErr;
}
+#endif
#endif // wxUSE_DRAG_AND_DROP