]> git.saurik.com Git - wxWidgets.git/blame - wxPython/src/_textctrl.i
wxUSE_PANGO is always 0 for wxGTK1 so there is no need to use #if wxUSE_PANGO in...
[wxWidgets.git] / wxPython / src / _textctrl.i
CommitLineData
d14a1e28
RD
1/////////////////////////////////////////////////////////////////////////////
2// Name: _textctrl.i
3// Purpose: SWIG interface defs for wxTextCtrl and related classes
4//
5// Author: Robin Dunn
6//
7// Created: 10-June-1998
8// RCS-ID: $Id$
9// Copyright: (c) 2003 by Total Control Software
10// Licence: wxWindows license
11/////////////////////////////////////////////////////////////////////////////
12
13// Not a %module
14
15
16//---------------------------------------------------------------------------
17
b2dc1044 18MAKE_CONST_WXSTRING(TextCtrlNameStr);
d14a1e28
RD
19
20//---------------------------------------------------------------------------
21%newgroup
22
23enum {
24 // Style flags
25 wxTE_NO_VSCROLL,
26 wxTE_AUTO_SCROLL,
27
28 wxTE_READONLY,
29 wxTE_MULTILINE,
30 wxTE_PROCESS_TAB,
31
32 // alignment flags
33 wxTE_LEFT,
34 wxTE_CENTER,
35 wxTE_RIGHT,
36 wxTE_CENTRE,
37
38 // this style means to use RICHEDIT control and does something only under
39 // wxMSW and Win32 and is silently ignored under all other platforms
40 wxTE_RICH,
41
42 wxTE_PROCESS_ENTER,
43 wxTE_PASSWORD,
44
45 // automatically detect the URLs and generate the events when mouse is
46 // moved/clicked over an URL
47 //
48 // this is for Win32 richedit controls only so far
49 wxTE_AUTO_URL,
50
51 // by default, the Windows text control doesn't show the selection when it
52 // doesn't have focus - use this style to force it to always show it
53 wxTE_NOHIDESEL,
54
c4c1e8d6
RD
55 // use wxHSCROLL (wxTE_DONTWRAP) to not wrap text at all, wxTE_CHARWRAP to
56 // wrap it at any position and wxTE_WORDWRAP to wrap at words boundary
57 //
58 // if no wrapping style is given at all, the control wraps at word boundary
d14a1e28 59 wxTE_DONTWRAP,
c4c1e8d6 60 wxTE_CHARWRAP,
d14a1e28 61 wxTE_WORDWRAP,
c4c1e8d6
RD
62 wxTE_BESTWRAP,
63
d14a1e28
RD
64 // force using RichEdit version 2.0 or 3.0 instead of 1.0 (default) for
65 // wxTE_RICH controls - can be used together with or instead of wxTE_RICH
66 wxTE_RICH2,
4fee07f2
RD
67
68 wxTE_CAPITALIZE,
d14a1e28
RD
69};
70
15648073
RD
71%pythoncode { TE_LINEWRAP = TE_CHARWRAP }
72
73
d14a1e28
RD
74
75enum wxTextAttrAlignment
76{
77 wxTEXT_ALIGNMENT_DEFAULT,
78 wxTEXT_ALIGNMENT_LEFT,
79 wxTEXT_ALIGNMENT_CENTRE,
80 wxTEXT_ALIGNMENT_CENTER = wxTEXT_ALIGNMENT_CENTRE,
81 wxTEXT_ALIGNMENT_RIGHT,
82 wxTEXT_ALIGNMENT_JUSTIFIED
83};
84
85enum {
86 // Flags to indicate which attributes are being applied
87 wxTEXT_ATTR_TEXT_COLOUR,
88 wxTEXT_ATTR_BACKGROUND_COLOUR,
89 wxTEXT_ATTR_FONT_FACE,
90 wxTEXT_ATTR_FONT_SIZE,
91 wxTEXT_ATTR_FONT_WEIGHT,
92 wxTEXT_ATTR_FONT_ITALIC,
93 wxTEXT_ATTR_FONT_UNDERLINE,
94 wxTEXT_ATTR_FONT,
95 wxTEXT_ATTR_ALIGNMENT,
96 wxTEXT_ATTR_LEFT_INDENT,
97 wxTEXT_ATTR_RIGHT_INDENT,
98 wxTEXT_ATTR_TABS
99};
100
1e53cf51
RD
101enum wxTextCtrlHitTestResult
102{
103 wxTE_HT_UNKNOWN = -2, // this means HitTest() is simply not implemented
104 wxTE_HT_BEFORE, // either to the left or upper
105 wxTE_HT_ON_TEXT, // directly on
106 wxTE_HT_BELOW, // below [the last line]
107 wxTE_HT_BEYOND // after [the end of line]
108};
109
aeee37c3
RD
110
111enum {
112 wxOutOfRangeTextCoord,
113 wxInvalidTextCoord
114};
115
d14a1e28
RD
116//---------------------------------------------------------------------------
117
118// wxTextAttr: a structure containing the visual attributes of a text
119class wxTextAttr
120{
121public:
015256c0 122 wxTextAttr(const wxColour& colText = wxNullColour,
d14a1e28
RD
123 const wxColour& colBack = wxNullColour,
124 const wxFont& font = wxNullFont,
125 wxTextAttrAlignment alignment = wxTEXT_ALIGNMENT_DEFAULT);
2b9048c5
RD
126 ~wxTextAttr();
127
d14a1e28
RD
128 // operations
129 void Init();
130
68d76e73
RD
131 // merges the attributes of the base and the overlay objects and returns
132 // the result; the parameter attributes take precedence
133 //
134 // WARNING: the order of arguments is the opposite of Combine()
135 static wxTextAttr Merge(const wxTextAttr& base, const wxTextAttr& overlay);
136
137// // merges the attributes of this object and overlay
138// void Merge(const wxTextAttr& overlay);
139
140
d14a1e28
RD
141 // setters
142 void SetTextColour(const wxColour& colText);
143 void SetBackgroundColour(const wxColour& colBack);
144 void SetFont(const wxFont& font, long flags = wxTEXT_ATTR_FONT);
145 void SetAlignment(wxTextAttrAlignment alignment);
146 void SetTabs(const wxArrayInt& tabs);
6d2e144a 147 void SetLeftIndent(int indent, int subIndent=0);
d14a1e28
RD
148 void SetRightIndent(int indent);
149 void SetFlags(long flags);
150
151 // accessors
152 bool HasTextColour() const;
153 bool HasBackgroundColour() const;
154 bool HasFont() const;
155 bool HasAlignment() const;
156 bool HasTabs() const;
157 bool HasLeftIndent() const;
158 bool HasRightIndent() const;
159 bool HasFlag(long flag) const;
160
161 const wxColour& GetTextColour() const;
162 const wxColour& GetBackgroundColour() const;
163 const wxFont& GetFont() const;
164 wxTextAttrAlignment GetAlignment() const;
165 const wxArrayInt& GetTabs() const;
166 long GetLeftIndent() const;
6d2e144a 167 long GetLeftSubIndent() const;
d14a1e28
RD
168 long GetRightIndent() const;
169 long GetFlags() const;
170
dd9f7fea 171 // returns False if we have any attributes set, True otherwise
d14a1e28
RD
172 bool IsDefault() const;
173
174 // return the attribute having the valid font and colours: it uses the
175 // attributes set in attr and falls back first to attrDefault and then to
176 // the text control font/colours for those attributes which are not set
177 static wxTextAttr Combine(const wxTextAttr& attr,
178 const wxTextAttr& attrDef,
179 const wxTextCtrl *text);
180};
181
182//---------------------------------------------------------------------------
183
184// wxTextCtrl: a single or multiple line text zone where user can enter and
185// edit text
ab1f7d2a 186MustHaveApp(wxTextCtrl);
d14a1e28
RD
187class wxTextCtrl : public wxControl
188{
189public:
2b9048c5
RD
190 %pythonAppend wxTextCtrl "self._setOORInfo(self)"
191 %pythonAppend wxTextCtrl() ""
b39c3fa0 192 %typemap(out) wxTextCtrl*; // turn off this typemap
d14a1e28 193
d5573410 194 wxTextCtrl(wxWindow* parent, wxWindowID id=-1,
d14a1e28
RD
195 const wxString& value = wxPyEmptyString,
196 const wxPoint& pos = wxDefaultPosition,
197 const wxSize& size = wxDefaultSize,
198 long style = 0,
199 const wxValidator& validator = wxDefaultValidator,
200 const wxString& name = wxPyTextCtrlNameStr);
1b8c7ba6 201 %RenameCtor(PreTextCtrl, wxTextCtrl());
d14a1e28 202
b39c3fa0
RD
203 // Turn it back on again
204 %typemap(out) wxTextCtrl* { $result = wxPyMake_wxObject($1, $owner); }
205
d5573410 206 bool Create(wxWindow* parent, wxWindowID id=-1,
d14a1e28
RD
207 const wxString& value = wxPyEmptyString,
208 const wxPoint& pos = wxDefaultPosition,
209 const wxSize& size = wxDefaultSize,
210 long style = 0,
211 const wxValidator& validator = wxDefaultValidator,
212 const wxString& name = wxPyTextCtrlNameStr);
213
214
215 virtual wxString GetValue() const;
216 virtual void SetValue(const wxString& value);
217
218 virtual wxString GetRange(long from, long to) const;
219
220 virtual int GetLineLength(long lineNo) const;
221 virtual wxString GetLineText(long lineNo) const;
222 virtual int GetNumberOfLines() const;
223
224 virtual bool IsModified() const;
225 virtual bool IsEditable() const;
226
227 // more readable flag testing methods
228 bool IsSingleLine() const;
229 bool IsMultiLine() const;
230
322913ce
RD
231
232 DocDeclAStr(
233 virtual void, GetSelection(long* OUTPUT, long* OUTPUT) const,
234 "GetSelection() -> (from, to)",
d07d2bc9 235 "If the return values from and to are the same, there is no selection.", "");
d14a1e28
RD
236
237 virtual wxString GetStringSelection() const;
238
239
240 // editing
241 virtual void Clear();
242 virtual void Replace(long from, long to, const wxString& value);
243 virtual void Remove(long from, long to);
244
245 // load/save the controls contents from/to the file
246 virtual bool LoadFile(const wxString& file);
247 virtual bool SaveFile(const wxString& file = wxPyEmptyString);
248
249 // sets/clears the dirty flag
250 virtual void MarkDirty();
251 virtual void DiscardEdits();
48e71d8a
RD
252 void SetModified(bool modified);
253
d14a1e28
RD
254 // set the max number of characters which may be entered in a single line
255 // text control
256 virtual void SetMaxLength(unsigned long len);
257
258 // writing text inserts it at the current position, appending always
259 // inserts it at the end
260 virtual void WriteText(const wxString& text);
261 virtual void AppendText(const wxString& text);
262
263 // insert the character which would have resulted from this key event,
dd9f7fea 264 // return True if anything has been inserted
d14a1e28
RD
265 virtual bool EmulateKeyPress(const wxKeyEvent& event);
266
267 // text control under some platforms supports the text styles: these
268 // methods allow to apply the given text style to the given selection or to
269 // set/get the style which will be used for all appended text
270 virtual bool SetStyle(long start, long end, const wxTextAttr& style);
271 virtual bool GetStyle(long position, wxTextAttr& style);
272 virtual bool SetDefaultStyle(const wxTextAttr& style);
273 virtual const wxTextAttr& GetDefaultStyle() const;
274
275 // translate between the position (which is just an index in the text ctrl
276 // considering all its contents as a single strings) and (x, y) coordinates
277 // which represent column and line.
278 virtual long XYToPosition(long x, long y) const;
322913ce
RD
279 DocDeclA(
280 virtual /*bool*/ void, PositionToXY(long pos, long *OUTPUT, long *OUTPUT) const,
281 "PositionToXY(long pos) -> (x, y)");
d14a1e28
RD
282
283 virtual void ShowPosition(long pos);
284
1e53cf51
RD
285
286 DocDeclAStr(
287 virtual wxTextCtrlHitTestResult, HitTest(const wxPoint& pt,
288 long* OUTPUT, long* OUTPUT) const,
50ed1e35 289 "HitTest(Point pt) -> (result, col, row)",
1e61c543
RD
290 "Find the row, col coresponding to the character at the point given in
291pixels. NB: pt is in device coords but is not adjusted for the client
292area origin nor scrolling.", "");
1e53cf51
RD
293
294
1e61c543
RD
295 DocDeclAStrName(
296 virtual wxTextCtrlHitTestResult , HitTest(const wxPoint& pt, long *OUTPUT) const,
297 "HitTestPos(Point pt) -> (result, position)",
298 "Find the character position in the text coresponding to the point
299given in pixels. NB: pt is in device coords but is not adjusted for
300the client area origin nor scrolling. ", "",
301 HitTestPos);
302
303
304
d14a1e28
RD
305 // Clipboard operations
306 virtual void Copy();
307 virtual void Cut();
308 virtual void Paste();
309
310 virtual bool CanCopy() const;
311 virtual bool CanCut() const;
312 virtual bool CanPaste() const;
313
314 // Undo/redo
315 virtual void Undo();
316 virtual void Redo();
317
318 virtual bool CanUndo() const;
319 virtual bool CanRedo() const;
320
321 // Insertion point
322 virtual void SetInsertionPoint(long pos);
323 virtual void SetInsertionPointEnd();
324 virtual long GetInsertionPoint() const;
325 virtual long GetLastPosition() const;
326
327 virtual void SetSelection(long from, long to);
328 virtual void SelectAll();
329 virtual void SetEditable(bool editable);
330
331#ifdef __WXMSW__
332 // Caret handling (Windows only)
a72f4631 333 bool ShowNativeCaret(bool show = true);
d14a1e28
RD
334 bool HideNativeCaret();
335#endif
336
337 %extend {
338 // TODO: Add more file-like methods
339 void write(const wxString& text) {
340 self->AppendText(text);
341 }
342 }
343
344 // TODO: replace this when the method is really added to wxTextCtrl
345 %extend {
346 wxString GetString(long from, long to) {
347 return self->GetValue().Mid(from, to - from);
348 }
349 }
350
880715c9
RD
351 static wxVisualAttributes
352 GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
d14a1e28
RD
353};
354
355//---------------------------------------------------------------------------
356
357
358%constant wxEventType wxEVT_COMMAND_TEXT_UPDATED;
359%constant wxEventType wxEVT_COMMAND_TEXT_ENTER;
360%constant wxEventType wxEVT_COMMAND_TEXT_URL;
361%constant wxEventType wxEVT_COMMAND_TEXT_MAXLEN;
362
363
364class wxTextUrlEvent : public wxCommandEvent
365{
366public:
367 wxTextUrlEvent(int winid, const wxMouseEvent& evtMouse,
368 long start, long end);
369
370 // get the mouse event which happend over the URL
371 const wxMouseEvent& GetMouseEvent();
372
373 // get the start of the URL
374 long GetURLStart() const;
375
376 // get the end of the URL
377 long GetURLEnd() const;
378};
379
380
381%pythoncode {
382EVT_TEXT = wx.PyEventBinder( wxEVT_COMMAND_TEXT_UPDATED, 1)
383EVT_TEXT_ENTER = wx.PyEventBinder( wxEVT_COMMAND_TEXT_ENTER, 1)
384EVT_TEXT_URL = wx.PyEventBinder( wxEVT_COMMAND_TEXT_URL, 1)
385EVT_TEXT_MAXLEN = wx.PyEventBinder( wxEVT_COMMAND_TEXT_MAXLEN, 1)
386}
387
388
389
390
391//---------------------------------------------------------------------------
392