WX_DEFINE_LIST(wxSimpleDataObjectList);
+// ----------------------------------------------------------------------------
+// globals
+// ----------------------------------------------------------------------------
+
+static wxDataFormat dataFormatInvalid;
+const wxDataFormat& wxFormatInvalid = dataFormatInvalid;
+
// ============================================================================
// implementation
// ============================================================================
{
wxSimpleDataObjectList::Node *node = m_dataObjects.Item( m_preferred );
- wxCHECK_MSG( node, wxDF_INVALID, wxT("no preferred format") );
+ wxCHECK_MSG( node, wxFormatInvalid, wxT("no preferred format") );
wxDataObjectSimple* dataObj = node->GetData();
// wxFileDataObjectBase
// ----------------------------------------------------------------------------
+// VZ: I don't need this in MSW finally, so if it is needed in wxGTK, it should
+// be moved to gtk/dataobj.cpp
+#if 0
+
wxString wxFileDataObjectBase::GetFilenames() const
{
wxString str;
}
}
+#endif // 0
+
// ----------------------------------------------------------------------------
// wxCustomDataObject
// ----------------------------------------------------------------------------
+wxCustomDataObject::wxCustomDataObject(const wxDataFormat& format)
+ : wxDataObjectSimple(format)
+{
+}
+
+
wxCustomDataObject::~wxCustomDataObject()
{
Free();
return TRUE;
}
-bool wxCustomDataObject::SetData(size_t len, const void *buf)
+bool wxCustomDataObject::SetData(size_t size, const void *buf)
{
Free();
if ( !m_data )
return FALSE;
- memcpy(m_data, buf, m_size = len);
+ memcpy(m_data, buf, m_size = size);
return TRUE;
}
+// ============================================================================
+// some common dnd related code
+// ============================================================================
+
+#if wxUSE_DRAG_AND_DROP
+
+#include "wx/dnd.h"
+
+// ----------------------------------------------------------------------------
+// wxTextDropTarget
+// ----------------------------------------------------------------------------
+
+wxTextDropTarget::wxTextDropTarget()
+ : wxDropTarget(new wxTextDataObject)
+{
+}
+
+wxDragResult wxTextDropTarget::OnData(wxCoord x, wxCoord y, wxDragResult def)
+{
+ if ( !GetData() )
+ return wxDragNone;
+
+ wxTextDataObject *dobj = (wxTextDataObject *)m_dataObject;
+ return OnDropText(x, y, dobj->GetText()) ? def : wxDragNone;
+}
+
+// ----------------------------------------------------------------------------
+// wxFileDropTarget
+// ----------------------------------------------------------------------------
+
+wxFileDropTarget::wxFileDropTarget()
+ : wxDropTarget(new wxFileDataObject)
+{
+}
+
+wxDragResult wxFileDropTarget::OnData(wxCoord x, wxCoord y, wxDragResult def)
+{
+ if ( !GetData() )
+ return wxDragNone;
+
+ wxFileDataObject *dobj = (wxFileDataObject *)m_dataObject;
+ return OnDropFiles(x, y, dobj->GetFilenames()) ? def : wxDragNone;
+}
+
+#endif
+