void ScintillaWX::StartDrag() {
wxDropSource source(wMain.GetID());
- wxTextDataObject data(dragChars);
+ wxTextDataObject data(wxString(drag.s, drag.len));
wxDragResult result;
+ dropWentOutside = true;
source.SetData(data);
result = source.DoDragDrop(TRUE);
if (result == wxDragMove && dropWentOutside)
void ScintillaWX::Copy() {
if (currentPos != anchor) {
- char* text = CopySelectionRange();
+ SelectionText st;
+ CopySelectionRange(&st);
wxTheClipboard->Open();
- wxTheClipboard->SetData(new wxTextDataObject(text));
+ wxTheClipboard->SetData(new wxTextDataObject(wxString(st.s, st.len)));
wxTheClipboard->Close();
}
}
void ScintillaWX::DoAddChar(char ch) {
- //bool acActiveBeforeCharAdded = ac.Active();
AddChar(ch);
- //if (acActiveBeforeCharAdded)
- // AutoCompleteChanged(ch);
}
int ScintillaWX::DoKeyDown(int key, bool shift, bool ctrl, bool alt, bool* consumed) {
int rv = KeyDown(key, shift, ctrl, alt, consumed);
-// printf("key: %d shift: %d ctrl: %d alt: %d rv: %d consumed: %d\n",
-// key, shift, ctrl, alt, rv, *consumed);
-
if (key)
return rv;
else
wxDragResult ScintillaWX::DoDragEnter(wxCoord x, wxCoord y, wxDragResult def) {
- return def;
+ dragResult = def;
+ return dragResult;
}
wxDragResult ScintillaWX::DoDragOver(wxCoord x, wxCoord y, wxDragResult def) {
SetDragPosition(PositionFromLocation(Point(x, y)));
dragResult = def;
- return def;
+ return dragResult;
}