X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/debe6624c1e9d4bf3243381153d1e173c849bcd8..f305c661926d1686aedad884a4ccb311e1cee6be:/include/wx/gtk/textctrl.h diff --git a/include/wx/gtk/textctrl.h b/include/wx/gtk/textctrl.h index feceacc12e..95161e5246 100644 --- a/include/wx/gtk/textctrl.h +++ b/include/wx/gtk/textctrl.h @@ -3,9 +3,9 @@ // Purpose: // Author: Robert Roebling // Created: 01/02/97 -// Id: +// Id: $Id$ // Copyright: (c) 1998 Robert Roebling, Julian Smart and Markus Holzem -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -21,12 +21,20 @@ #include "wx/string.h" #include "wx/control.h" -#if USE_IOSTREAMH +#if wxUSE_STD_IOSTREAM + +#if wxUSE_IOSTREAMH #include #else #include #endif +#else + +#define NO_TEXT_WINDOW_STREAM + +#endif + //----------------------------------------------------------------------------- // classes //----------------------------------------------------------------------------- @@ -43,53 +51,89 @@ extern const char *wxTextCtrlNameStr; // wxTextCtrl //----------------------------------------------------------------------------- +#ifndef NO_TEXT_WINDOW_STREAM class wxTextCtrl: public wxControl, public streambuf +#else +class wxTextCtrl: public wxControl +#endif { + DECLARE_EVENT_TABLE() DECLARE_DYNAMIC_CLASS(wxTextCtrl); public: - - wxTextCtrl(void); - wxTextCtrl( wxWindow *parent, wxWindowID id, const wxString &value = "", + wxTextCtrl(); + wxTextCtrl( wxWindow *parent, wxWindowID id, const wxString &value = "", const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, - int style = 0, const wxString &name = wxTextCtrlNameStr ); + int style = 0, const wxValidator& validator = wxDefaultValidator, + const wxString &name = wxTextCtrlNameStr ); bool Create( wxWindow *parent, wxWindowID id, const wxString &value = "", const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, - int style = 0, const wxString &name = wxTextCtrlNameStr ); - wxString GetValue(void) const; + int style = 0, const wxValidator& validator = wxDefaultValidator, + const wxString &name = wxTextCtrlNameStr ); + wxString GetValue() const; void SetValue( const wxString &value ); void WriteText( const wxString &text ); - + void AppendText( const wxString &text ); + bool LoadFile( const wxString &file ); bool SaveFile( const wxString &file ); - bool IsModified(void); - void DiscardEdits(void); -/* + bool IsModified() const { return m_modified; } + void SetModified() { m_modified = TRUE; } + void DiscardEdits() { m_modified = FALSE; } wxString GetLineText( long lineNo ) const; void OnDropFiles( wxDropFilesEvent &event ); long PositionToXY( long pos, long *x, long *y ) const; - long XYToPosition( long x, long y ); - int GetNumberOfLines(void); -*/ + long XYToPosition( long x, long y ) const; + int GetLineLength(long lineNo) const; + int GetNumberOfLines() const; virtual void SetInsertionPoint( long pos ); - virtual void SetInsertionPointEnd(void); + virtual void SetInsertionPointEnd(); virtual void SetEditable( bool editable ); virtual void SetSelection( long from, long to ); void ShowPosition( long pos ); - virtual long GetInsertionPoint(void) const; - virtual long GetLastPosition(void) const; + virtual long GetInsertionPoint() const; + virtual long GetLastPosition() const; virtual void Remove( long from, long to ); virtual void Replace( long from, long to, const wxString &value ); - void Cut(void); - void Copy(void); - void Paste(void); - void Delete(void); - + void Cut(); + void Copy(); + void Paste(); + void Clear(); + + virtual bool CanCopy() const; + virtual bool CanCut() const; + virtual bool CanPaste() const; + + // Undo/redo + virtual void Undo(); + virtual void Redo(); + + virtual bool CanUndo() const; + virtual bool CanRedo() const; + + // If the return values from and to are the same, there is no + // selection. + virtual void GetSelection(long* from, long* to) const; + virtual bool IsEditable() const ; + void OnChar( wxKeyEvent &event ); - + + void OnCut(wxCommandEvent& event); + void OnCopy(wxCommandEvent& event); + void OnPaste(wxCommandEvent& event); + void OnUndo(wxCommandEvent& event); + void OnRedo(wxCommandEvent& event); + + void OnUpdateCut(wxUpdateUIEvent& event); + void OnUpdateCopy(wxUpdateUIEvent& event); + void OnUpdatePaste(wxUpdateUIEvent& event); + void OnUpdateUndo(wxUpdateUIEvent& event); + void OnUpdateRedo(wxUpdateUIEvent& event); + +#ifndef NO_TEXT_WINDOW_STREAM int overflow(int i); - int sync(void); - int underflow(void); + int sync(); + int underflow(); wxTextCtrl& operator<<(const wxString& s); wxTextCtrl& operator<<(int i); @@ -97,13 +141,25 @@ class wxTextCtrl: public wxControl, public streambuf wxTextCtrl& operator<<(float f); wxTextCtrl& operator<<(double d); wxTextCtrl& operator<<(const char c); - - public: - - bool m_modified; +#endif - DECLARE_EVENT_TABLE() + bool SetFont( const wxFont &font ); + bool SetForegroundColour(const wxColour &colour); + bool SetBackgroundColour(const wxColour &colour); + + // implementation + + GtkWidget* GetConnectWidget(); + bool IsOwnGtkWindow( GdkWindow *window ); + void ApplyWidgetStyle(); + void CalculateScrollbar(); + private: + + bool m_modified; + GtkWidget *m_text; + GtkWidget *m_vScrollbar; + bool m_vScrollbarVisible; }; #endif // __GTKTEXTCTRLH__