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();
// wxCustomDataObject
// ----------------------------------------------------------------------------
+wxCustomDataObject::wxCustomDataObject(const wxDataFormat& format)
+ : wxDataObjectSimple(format)
+{
+ m_data = (void *)NULL;
+}
+
wxCustomDataObject::~wxCustomDataObject()
{
Free();
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
+