#ifndef __GTKTEXTCTRLH__
#define __GTKTEXTCTRLH__
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
- #pragma interface "textctrl.h"
-#endif
-
//-----------------------------------------------------------------------------
// wxTextCtrl
//-----------------------------------------------------------------------------
-class wxTextCtrl: public wxTextCtrlBase
+class WXDLLIMPEXP_CORE wxTextCtrl: public wxTextCtrlBase
{
public:
wxTextCtrl() { Init(); }
const wxValidator& validator = wxDefaultValidator,
const wxString &name = wxTextCtrlNameStr);
+ ~wxTextCtrl();
+
bool Create(wxWindow *parent,
wxWindowID id,
const wxString &value = wxEmptyString,
virtual void ShowPosition(long pos);
+ virtual wxTextCtrlHitTestResult HitTest(const wxPoint& pt, long *pos) const;
+ virtual wxTextCtrlHitTestResult HitTest(const wxPoint& pt,
+ wxTextCoord *col,
+ wxTextCoord *row) const
+ {
+ return wxTextCtrlBase::HitTest(pt, col, row);
+ }
+
// Clipboard operations
virtual void Copy();
virtual void Cut();
virtual void SetInsertionPoint(long pos);
virtual void SetInsertionPointEnd();
virtual long GetInsertionPoint() const;
- virtual long GetLastPosition() const;
+ virtual wxTextPos GetLastPosition() const;
virtual void SetSelection(long from, long to);
virtual void SetEditable(bool editable);
- virtual bool Enable( bool enable = TRUE );
+ virtual bool Enable( bool enable = true );
// Implementation from now on
void OnDropFiles( wxDropFilesEvent &event );
bool SetBackgroundColour(const wxColour& colour);
GtkWidget* GetConnectWidget();
- bool IsOwnGtkWindow( GdkWindow *window );
- void ApplyWidgetStyle();
void CalculateScrollbar();
- void OnInternalIdle();
- void UpdateFontIfNeeded();
- void SetModified() { m_modified = TRUE; }
+ void SetUpdateFont(bool WXUNUSED(update)) { }
// GTK+ textctrl is so dumb that you need to freeze/thaw it manually to
// avoid horrible flicker/scrolling back and forth
virtual void Freeze();
virtual void Thaw();
- // textctrl specific scrolling
- virtual bool ScrollLines(int lines);
- virtual bool ScrollPages(int pages);
-
// implementation only from now on
// wxGTK-specific: called recursively by Enable,
virtual void OnParentEnable( bool enable ) ;
// tell the control to ignore next text changed signal
- void IgnoreNextTextUpdate();
+ void IgnoreNextTextUpdate() { m_ignoreNextUpdate = true; }
// should we ignore the changed signal? always resets the flag
bool IgnoreTextUpdate();
+ // call this to indicate that the control is about to be changed
+ // programmatically and so m_modified flag shouldn't be set
+ void DontMarkDirtyOnNextChange() { m_dontMarkDirty = true; }
+
+ // should we mark the control as dirty? always resets the flag
+ bool MarkDirtyOnChange();
+
+
static wxVisualAttributes
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
-
+
protected:
virtual wxSize DoGetBestSize() const;
+ virtual void DoApplyWidgetStyle(GtkRcStyle *style);
+ virtual GdkWindow *GTKGetWindow(wxArrayGdkWindows& windows) const;
// common part of all ctors
void Init();
- // get the vertical adjustment, if any, NULL otherwise
- GtkAdjustment *GetVAdj() const;
-
- // scroll the control by the given number of pixels, return true if the
- // scroll position changed
- bool DoScroll(GtkAdjustment *adj, int diff);
-
// Widgets that use the style->base colour for the BG colour should
// override this and return true.
virtual bool UseGTKStyleBase() const { return true; }
+ // has the control been frozen by Freeze()?
+ bool IsFrozen() const { return m_frozenness > 0; }
+
private:
// change the font for everything in this control
void ChangeFontGlobally();
+ // get the encoding which is used in this control: this looks at our font
+ // and default style but not the current style (i.e. the style for the
+ // current position); returns wxFONTENCODING_SYSTEM if we have no specific
+ // encoding
+ wxFontEncoding GetTextEncoding() const;
+
+
GtkWidget *m_text;
- GtkWidget *m_vScrollbar;
bool m_modified:1;
- bool m_vScrollbarVisible:1;
- bool m_updateFont:1;
bool m_ignoreNextUpdate:1;
+ bool m_dontMarkDirty:1;
+
+ // Our text buffer. Convenient, and holds the buffer while using
+ // a dummy one when m_frozenness > 0
+ GtkTextBuffer *m_buffer;
+
+ // number of calls to Freeze() minus number of calls to Thaw()
+ unsigned int m_frozenness;
+
+ // For wxTE_AUTO_URL
+ void OnUrlMouseEvent(wxMouseEvent&);
+ GdkCursor *m_gdkHandCursor;
+ GdkCursor *m_gdkXTermCursor;
DECLARE_EVENT_TABLE()
- DECLARE_DYNAMIC_CLASS(wxTextCtrl);
+ DECLARE_DYNAMIC_CLASS(wxTextCtrl)
};
#endif // __GTKTEXTCTRLH__