static const int X_SCROLL_PAGE = 10;
static const int Y_SCROLL_PAGE = 20;
+
+
+#define wxUSE_PRIVATE_CLIPBOARD_FORMAT 0
+
// ----------------------------------------------------------------------------
// event tables
// ----------------------------------------------------------------------------
case WXLOWIN_MENU_LUP:
if ( m_Selecting )
{
- m_llist->EndSelection();
+ // end selection at the cursor position corresponding to the
+ // current mouse position, but donĀ“t move cursor there.
+ m_llist->EndSelection(cursorPos,m_ClickPosition);
m_Selecting = false;
RequestUpdate(); // TODO: we don't have to redraw everything!
if(keyCode == WXK_F1)
{
m_llist->Debug();
- event.skip();
return;
}
#endif
if ( IsDirectionKey(keyCode) )
{
// just continue the old selection
- if ( m_Selecting )
+ if ( m_Selecting && event.ShiftDown() )
+ m_llist->ContinueSelection();
+ else
{
+ m_llist->DiscardSelection();
+ m_Selecting = false;
if( event.ShiftDown() )
- m_llist->ContinueSelection();
- else
{
- m_llist->DiscardSelection();
- m_Selecting = false;
+ m_Selecting = true;
+ m_llist->StartSelection();
}
}
- else if( event.ShiftDown() )
- {
- m_Selecting = true;
- m_llist->StartSelection();
- }
}
// If needed, make cursor visible:
FindAgain();
break;
default:
+ // we don't handle it, maybe an accelerator?
+ event.Skip();
;
}
else if( IsEditable() )
m_llist->DeleteToEndOfLine();
SetDirty();
break;
+ case 'c':
+ Copy();
+ break;
case 'v':
- Paste();
+ // if SHIFT is down, use primary selection
+ Paste( event.ShiftDown() );
break;
case 'x':
Cut();
break;
#endif
default:
- ;
+ // we don't handle it, maybe an accelerator?
+ event.Skip();
}
}
// ALT only:
SetDirty();
break;
default:
- ;
+ // we don't handle it, maybe an accelerator?
+ event.Skip();
}
}
// no control keys:
default:
if((!(event.ControlDown() || event.AltDown()
-//#if 0
- ///FIXME: wxGTK reports MetaDown always
- || event.MetaDown()
-//#endif
))
&& (keyCode < 256 && keyCode >= 32)
)
m_llist->Insert((char)keyCode);
SetDirty();
}
+ else
+ // we don't handle it, maybe an accelerator?
+ event.Skip();
break;
}
}
}// if(IsEditable())
+ else
+ // we don't handle it, maybe an accelerator?
+ event.Skip();
}// first switch()
if ( m_Selecting )
ScrollToCursor();
// refresh the screen
RequestUpdate(m_llist->GetUpdateRect());
- event.Skip();
}
void
updateRect->x+updateRect->width,
updateRect->y+updateRect->height));
}
- if(IsDirty())
- {
- WXLO_DEBUG(("InternalPaint, isdirty, list size: %ld,%ld",
- (unsigned long) m_llist->GetSize().x,
- (unsigned long) m_llist->GetSize().y));
-// m_llist->ForceTotalLayout();
- m_llist->Layout(dc);
- WXLO_DEBUG(("InternalPaint, isdirty, list size after layout: %ld,%ld",
- (unsigned long) m_llist->GetSize().x,
- (unsigned long) m_llist->GetSize().y));
- ResizeScrollbars();
- ResetDirty();
- }
+
+ ResizeScrollbars();
+
/* Check whether the window has grown, if so, we need to reallocate
the bitmap to be larger. */
event.Skip();
}
-// change the range and position of scrollbars
+/*
+Change the range and position of scrollbars. Has evolved into a
+generic Update function which will at some time later cause a repaint
+as needed.
+*/
+
void
wxLayoutWindow::ResizeScrollbars(bool exact)
{
- if(IsDirty())
- {
- wxClientDC dc( this );
- PrepareDC( dc );
+ if(! IsDirty())
+ return;
+
+ wxClientDC dc( this );
+ PrepareDC( dc );
// m_llist->ForceTotalLayout();
- m_llist->Layout(dc);
- ResetDirty();
- RequestUpdate();
- }
+ m_llist->Layout(dc);
+ ResetDirty();
wxPoint max = m_llist->GetSize();
wxSize size = GetClientSize();
// check if the text hasn't become too big
// TODO why do we set both at once? they're independent...
- if( max.x > m_maxx - WXLO_ROFFSET || max.y > m_maxy - WXLO_BOFFSET || exact )
+ if( max.x > m_maxx - WXLO_ROFFSET
+ || max.y > m_maxy - WXLO_BOFFSET
+ || max.x < m_maxx - X_SCROLL_PAGE
+ || max.y < m_maxy - Y_SCROLL_PAGE
+ || exact )
{
// text became too large
if ( !exact )
max.y += WXLO_BOFFSET;
}
- ViewStart(&m_ViewStartX, &m_ViewStartY);
- SetScrollbars(X_SCROLL_PAGE, Y_SCROLL_PAGE,
- max.x / X_SCROLL_PAGE + 1, max.y / Y_SCROLL_PAGE + 1,
- m_ViewStartX, m_ViewStartY,
- true);
-
- m_hasHScrollbar =
- m_hasVScrollbar = true;
-
- m_maxx = max.x + X_SCROLL_PAGE;
- m_maxy = max.y + Y_SCROLL_PAGE;
- }
-#if 0
- //FIXME: this code is pretty broken, producing "arithmetic
- //exception" crashes (div by 0??)
- else
- {
- // check if the window hasn't become too big, thus making the scrollbars
- // unnecessary
- if ( !exact )
+ bool done = FALSE;
+ if(max.x < X_SCROLL_PAGE)
{
- // add an extra bit to the sizes to avoid future updates
- max.x -= WXLO_ROFFSET;
- max.y -= WXLO_BOFFSET;
+ SetScrollbars(0,-1,0,-1,0,-1,true);
+ m_hasHScrollbar = FALSE;
+ done = TRUE;
}
-
- if ( m_hasHScrollbar && (max.x < m_maxx) )
+ if(max.y < Y_SCROLL_PAGE)
{
- // remove the horizontal scrollbar
- SetScrollbars(0, -1, 0, -1, 0, -1, true);
- m_hasHScrollbar = false;
+ SetScrollbars(-1,0,-1,0,-1,0,true);
+ m_hasVScrollbar = FALSE;
+ done = TRUE;
}
-
- if ( m_hasVScrollbar && (max.y < m_maxy) )
+ if(! done)
{
- // remove the vertical scrollbar
- SetScrollbars(-1, 0, -1, 0, -1, 0, true);
- m_hasVScrollbar = false;
+ ViewStart(&m_ViewStartX, &m_ViewStartY);
+ SetScrollbars(X_SCROLL_PAGE,
+ Y_SCROLL_PAGE,
+ max.x / X_SCROLL_PAGE + 1,
+ max.y / Y_SCROLL_PAGE + 1,
+ m_ViewStartX, m_ViewStartY,
+ true);
+ m_hasHScrollbar =
+ m_hasVScrollbar = true;
}
+
+ m_maxx = max.x + X_SCROLL_PAGE;
+ m_maxy = max.y + Y_SCROLL_PAGE;
}
-#endif
}
// ----------------------------------------------------------------------------
+//
// clipboard operations
//
// ----------------------------------------------------------------------------
void
wxLayoutWindow::Paste(bool primary)
{
+ // this only has an effect under X11:
+ if(primary) wxTheClipboard->UsePrimarySelection();
// Read some text
if (wxTheClipboard->Open())
{
-#if __WXGTK__
- if(primary)
- wxTheClipboard->UsePrimarySelection();
-#endif
#if wxUSE_PRIVATE_CLIPBOARD_FORMAT
wxLayoutDataObject wxldo;
if (wxTheClipboard->IsSupported( wxldo.GetFormat() ))
{
- wxTheClipboard->GetData(&wxldo);
+ if(wxTheClipboard->GetData(wxldo))
{
+ wxString str = wxldo.GetLayoutData();
+ m_llist->Read(str);
+ RequestUpdate();
}
- //FIXME: missing functionality m_llist->Insert(wxldo.GetList());
}
else
#endif
{
-#if 0 //RE_ENABLE FIXME!!
wxTextDataObject data;
- if (wxTheClipboard->IsSupported( data.GetFormat() ))
+ if (wxTheClipboard->IsSupported( data.GetFormat() )
+ && wxTheClipboard->GetData(data) )
{
- wxTheClipboard->GetData(&data);
wxString text = data.GetText();
wxLayoutImportText( m_llist, text);
SetDirty();
}
-#endif
}
wxTheClipboard->Close();
}
m_llist->EndSelection();
}
-#if 0 //FIXME CLIPBOARD
- wxLayoutDataObject wldo;
- wxLayoutList *llist = m_llist->GetSelection(&wldo, invalidate);
+ wxLayoutDataObject *wldo = new wxLayoutDataObject;
+ wxLayoutList *llist = m_llist->GetSelection(wldo, invalidate);
if(! llist)
return FALSE;
// Export selection as text:
text = text.Mid(0,len-1);
}
-
if (wxTheClipboard->Open())
{
wxTextDataObject *data = new wxTextDataObject( text );
- bool rc = wxTheClipboard->SetData( data );
+ bool rc;
+
+ rc = wxTheClipboard->SetData( data );
#if wxUSE_PRIVATE_CLIPBOARD_FORMAT
- rc |= wxTheClipboard->AddData( &wldo );
+ rc |= wxTheClipboard->SetData( wldo );
#endif
wxTheClipboard->Close();
return rc;
}
-#endif //FIXME CLIPBOARD
+ else
+ delete wldo;
return FALSE;
}
// searching
// ----------------------------------------------------------------------------
-#ifdef M_BASEDIR
bool
wxLayoutWindow::Find(const wxString &needle,
wxPoint * fromWhere,
const wxString &configPath)
{
+#ifdef M_BASEDIR
wxPoint found;
if(needle.Length() == 0)
RequestUpdate();
return true;
}
+#endif
return false;
}
bool rc = Find(m_FindString);
return rc;
}
-#endif
// ----------------------------------------------------------------------------
// popup menu stuff