]>
Commit | Line | Data |
---|---|---|
1 | ///////////////////////////////////////////////////////////////////////////// | |
2 | // Name: stc/stc.h | |
3 | // Purpose: interface of wxStyledTextEvent | |
4 | // Author: wxWidgets team | |
5 | // RCS-ID: $Id$ | |
6 | // Licence: wxWindows license | |
7 | ///////////////////////////////////////////////////////////////////////////// | |
8 | ||
9 | /** | |
10 | @class wxStyledTextEvent | |
11 | ||
12 | The type of events sent from wxStyledTextCtrl. | |
13 | ||
14 | @todo list styled text ctrl events. | |
15 | ||
16 | @library{wxbase} | |
17 | @category{events,stc} | |
18 | */ | |
19 | class wxStyledTextEvent : public wxCommandEvent | |
20 | { | |
21 | public: | |
22 | //@{ | |
23 | /** | |
24 | Ctors; used internally by wxWidgets. | |
25 | */ | |
26 | wxStyledTextEvent(wxEventType commandType = 0, int id = 0); | |
27 | wxStyledTextEvent(const wxStyledTextEvent& event); | |
28 | //@} | |
29 | ||
30 | /** | |
31 | ||
32 | */ | |
33 | bool GetAlt() const; | |
34 | ||
35 | /** | |
36 | ||
37 | */ | |
38 | bool GetControl() const; | |
39 | ||
40 | /** | |
41 | ||
42 | */ | |
43 | bool GetDragAllowMove(); | |
44 | ||
45 | /** | |
46 | ||
47 | */ | |
48 | wxDragResult GetDragResult(); | |
49 | ||
50 | /** | |
51 | ||
52 | */ | |
53 | wxString GetDragText(); | |
54 | ||
55 | /** | |
56 | ||
57 | */ | |
58 | int GetFoldLevelNow() const; | |
59 | ||
60 | /** | |
61 | ||
62 | */ | |
63 | int GetFoldLevelPrev() const; | |
64 | ||
65 | /** | |
66 | ||
67 | */ | |
68 | int GetKey() const; | |
69 | ||
70 | /** | |
71 | ||
72 | */ | |
73 | int GetLParam() const; | |
74 | ||
75 | /** | |
76 | ||
77 | */ | |
78 | int GetLength() const; | |
79 | ||
80 | /** | |
81 | ||
82 | */ | |
83 | int GetLine() const; | |
84 | ||
85 | /** | |
86 | ||
87 | */ | |
88 | int GetLinesAdded() const; | |
89 | ||
90 | /** | |
91 | ||
92 | */ | |
93 | int GetListType() const; | |
94 | ||
95 | /** | |
96 | ||
97 | */ | |
98 | int GetMargin() const; | |
99 | ||
100 | /** | |
101 | ||
102 | */ | |
103 | int GetMessage() const; | |
104 | ||
105 | /** | |
106 | ||
107 | */ | |
108 | int GetModificationType() const; | |
109 | ||
110 | /** | |
111 | ||
112 | */ | |
113 | int GetModifiers() const; | |
114 | ||
115 | /** | |
116 | ||
117 | */ | |
118 | int GetPosition() const; | |
119 | ||
120 | /** | |
121 | ||
122 | */ | |
123 | bool GetShift() const; | |
124 | ||
125 | /** | |
126 | ||
127 | */ | |
128 | wxString GetText() const; | |
129 | ||
130 | /** | |
131 | ||
132 | */ | |
133 | int GetWParam() const; | |
134 | ||
135 | /** | |
136 | ||
137 | */ | |
138 | int GetX() const; | |
139 | ||
140 | /** | |
141 | ||
142 | */ | |
143 | int GetY() const; | |
144 | ||
145 | /** | |
146 | ||
147 | */ | |
148 | void SetDragAllowMove(bool val); | |
149 | ||
150 | /** | |
151 | ||
152 | */ | |
153 | void SetDragResult(wxDragResult val); | |
154 | ||
155 | /** | |
156 | ||
157 | */ | |
158 | void SetDragText(const wxString& val); | |
159 | ||
160 | /** | |
161 | ||
162 | */ | |
163 | void SetFoldLevelNow(int val); | |
164 | ||
165 | /** | |
166 | ||
167 | */ | |
168 | void SetFoldLevelPrev(int val); | |
169 | ||
170 | /** | |
171 | ||
172 | */ | |
173 | void SetKey(int k); | |
174 | ||
175 | /** | |
176 | ||
177 | */ | |
178 | void SetLParam(int val); | |
179 | ||
180 | /** | |
181 | ||
182 | */ | |
183 | void SetLength(int len); | |
184 | ||
185 | /** | |
186 | ||
187 | */ | |
188 | void SetLine(int val); | |
189 | ||
190 | /** | |
191 | ||
192 | */ | |
193 | void SetLinesAdded(int num); | |
194 | ||
195 | /** | |
196 | ||
197 | */ | |
198 | void SetListType(int val); | |
199 | ||
200 | /** | |
201 | ||
202 | */ | |
203 | void SetMargin(int val); | |
204 | ||
205 | /** | |
206 | ||
207 | */ | |
208 | void SetMessage(int val); | |
209 | ||
210 | /** | |
211 | ||
212 | */ | |
213 | void SetModificationType(int t); | |
214 | ||
215 | /** | |
216 | ||
217 | */ | |
218 | void SetModifiers(int m); | |
219 | ||
220 | /** | |
221 | ||
222 | */ | |
223 | void SetPosition(int pos); | |
224 | ||
225 | /** | |
226 | ||
227 | */ | |
228 | void SetText(const wxString& t); | |
229 | ||
230 | /** | |
231 | ||
232 | */ | |
233 | void SetWParam(int val); | |
234 | ||
235 | /** | |
236 | ||
237 | */ | |
238 | void SetX(int val); | |
239 | ||
240 | /** | |
241 | ||
242 | */ | |
243 | void SetY(int val); | |
244 | }; | |
245 | ||
246 | ||
247 | ||
248 | /** | |
249 | @class wxStyledTextCtrl | |
250 | ||
251 | A wxWidgets implementation of the Scintilla source code editing component. | |
252 | ||
253 | As well as features found in standard text editing components, Scintilla | |
254 | includes features especially useful when editing and debugging source code. | |
255 | These include support for syntax styling, error indicators, code completion | |
256 | and call tips. | |
257 | ||
258 | The selection margin can contain markers like those used in debuggers to indicate | |
259 | breakpoints and the current line. Styling choices are more open than with many | |
260 | editors, allowing the use of proportional fonts, bold and italics, multiple | |
261 | foreground and background colours and multiple fonts. | |
262 | ||
263 | wxStyledTextCtrl is a 1 to 1 mapping of "raw" scintilla interface, whose | |
264 | documentation can be found in the Scintilla website (http://www.scintilla.org/). | |
265 | ||
266 | @beginEventEmissionTable{wxStyledTextEvent} | |
267 | @event{EVT_STC_CHANGE(id, fn)} | |
268 | TOWRITE | |
269 | @event{EVT_STC_STYLENEEDED(id, fn)} | |
270 | TOWRITE | |
271 | @event{EVT_STC_CHARADDED(id, fn)} | |
272 | TOWRITE | |
273 | @event{EVT_STC_SAVEPOINTREACHED(id, fn)} | |
274 | TOWRITE | |
275 | @event{EVT_STC_SAVEPOINTLEFT(id, fn)} | |
276 | TOWRITE | |
277 | @event{EVT_STC_ROMODIFYATTEMPT(id, fn)} | |
278 | TOWRITE | |
279 | @event{EVT_STC_KEY(id, fn)} | |
280 | TOWRITE | |
281 | @event{EVT_STC_DOUBLECLICK(id, fn)} | |
282 | TOWRITE | |
283 | @event{EVT_STC_UPDATEUI(id, fn)} | |
284 | TOWRITE | |
285 | @event{EVT_STC_MODIFIED(id, fn)} | |
286 | TOWRITE | |
287 | @event{EVT_STC_MACRORECORD(id, fn)} | |
288 | TOWRITE | |
289 | @event{EVT_STC_MARGINCLICK(id, fn)} | |
290 | TOWRITE | |
291 | @event{EVT_STC_NEEDSHOWN(id, fn)} | |
292 | TOWRITE | |
293 | @event{EVT_STC_PAINTED(id, fn)} | |
294 | TOWRITE | |
295 | @event{EVT_STC_USERLISTSELECTION(id, fn)} | |
296 | TOWRITE | |
297 | @event{EVT_STC_URIDROPPED(id, fn)} | |
298 | TOWRITE | |
299 | @event{EVT_STC_DWELLSTART(id, fn)} | |
300 | TOWRITE | |
301 | @event{EVT_STC_DWELLEND(id, fn)} | |
302 | TOWRITE | |
303 | @event{EVT_STC_START_DRAG(id, fn)} | |
304 | TOWRITE | |
305 | @event{EVT_STC_DRAG_OVER(id, fn)} | |
306 | TOWRITE | |
307 | @event{EVT_STC_DO_DROP(id, fn)} | |
308 | TOWRITE | |
309 | @event{EVT_STC_ZOOM(id, fn)} | |
310 | TOWRITE | |
311 | @event{EVT_STC_HOTSPOT_CLICK(id, fn)} | |
312 | TOWRITE | |
313 | @event{EVT_STC_HOTSPOT_DCLICK(id, fn)} | |
314 | TOWRITE | |
315 | @event{EVT_STC_CALLTIP_CLICK(id, fn)} | |
316 | TOWRITE | |
317 | @event{EVT_STC_AUTOCOMP_SELECTION(id, fn)} | |
318 | TOWRITE | |
319 | @endEventTable | |
320 | ||
321 | @library{wxbase} | |
322 | @category{stc} | |
323 | ||
324 | @see wxStyledTextEvent | |
325 | */ | |
326 | class wxStyledTextCtrl : public wxControl | |
327 | { | |
328 | public: | |
329 | /** | |
330 | Ctor. | |
331 | */ | |
332 | wxStyledTextCtrl::wxStyledTextCtrl(wxWindow* parent, | |
333 | wxWindowID id = wxID_ANY, | |
334 | const wxPoint& pos = wxDefaultPosition, | |
335 | const wxSize& size = wxDefaultSize, | |
336 | long style = 0, | |
337 | const wxString& name = wxSTCNameStr); | |
338 | ||
339 | /** | |
340 | Extend life of document. | |
341 | */ | |
342 | void AddRefDocument(void* docPointer); | |
343 | ||
344 | /** | |
345 | Add array of cells to document. | |
346 | */ | |
347 | void AddStyledText(const wxMemoryBuffer& data); | |
348 | ||
349 | /** | |
350 | Add text to the document at current position. | |
351 | */ | |
352 | void AddText(const wxString& text); | |
353 | ||
354 | /** | |
355 | The following methods are nearly equivallent to their similarly named | |
356 | cousins above. The difference is that these methods bypass wxString | |
357 | and always use a char* even if used in a unicode build of wxWidgets. | |
358 | In that case the character data will be utf-8 encoded since that is | |
359 | what is used internally by Scintilla in unicode builds. | |
360 | Add text to the document at current position. | |
361 | */ | |
362 | void AddTextRaw(const char* text); | |
363 | ||
364 | /** | |
365 | Enlarge the document to a particular size of text bytes. | |
366 | */ | |
367 | void Allocate(int bytes); | |
368 | ||
369 | /** | |
370 | Append a string to the end of the document without changing the selection. | |
371 | */ | |
372 | virtual void AppendText(const wxString& text); | |
373 | ||
374 | /** | |
375 | Append a string to the end of the document without changing the selection. | |
376 | */ | |
377 | void AppendTextRaw(const char* text); | |
378 | ||
379 | /** | |
380 | Is there an auto-completion list visible? | |
381 | */ | |
382 | bool AutoCompActive(); | |
383 | ||
384 | /** | |
385 | Remove the auto-completion list from the screen. | |
386 | */ | |
387 | void AutoCompCancel(); | |
388 | ||
389 | /** | |
390 | User has selected an item so remove the list and insert the selection. | |
391 | */ | |
392 | void AutoCompComplete(); | |
393 | ||
394 | /** | |
395 | Retrieve whether or not autocompletion is hidden automatically when nothing | |
396 | matches. | |
397 | */ | |
398 | bool AutoCompGetAutoHide() const; | |
399 | ||
400 | /** | |
401 | Retrieve whether auto-completion cancelled by backspacing before start. | |
402 | */ | |
403 | bool AutoCompGetCancelAtStart() const; | |
404 | ||
405 | /** | |
406 | Retrieve whether a single item auto-completion list automatically choose the | |
407 | item. | |
408 | */ | |
409 | bool AutoCompGetChooseSingle() const; | |
410 | ||
411 | /** | |
412 | Get currently selected item position in the auto-completion list | |
413 | */ | |
414 | int AutoCompGetCurrent(); | |
415 | ||
416 | /** | |
417 | Retrieve whether or not autocompletion deletes any word characters | |
418 | after the inserted text upon completion. | |
419 | */ | |
420 | bool AutoCompGetDropRestOfWord() const; | |
421 | ||
422 | /** | |
423 | Retrieve state of ignore case flag. | |
424 | */ | |
425 | bool AutoCompGetIgnoreCase() const; | |
426 | ||
427 | /** | |
428 | Set the maximum height, in rows, of auto-completion and user lists. | |
429 | */ | |
430 | int AutoCompGetMaxHeight() const; | |
431 | ||
432 | /** | |
433 | Get the maximum width, in characters, of auto-completion and user lists. | |
434 | */ | |
435 | int AutoCompGetMaxWidth() const; | |
436 | ||
437 | /** | |
438 | Retrieve the auto-completion list separator character. | |
439 | */ | |
440 | int AutoCompGetSeparator() const; | |
441 | ||
442 | /** | |
443 | Retrieve the auto-completion list type-separator character. | |
444 | */ | |
445 | int AutoCompGetTypeSeparator() const; | |
446 | ||
447 | /** | |
448 | Retrieve the position of the caret when the auto-completion list was displayed. | |
449 | */ | |
450 | int AutoCompPosStart(); | |
451 | ||
452 | /** | |
453 | Select the item in the auto-completion list that starts with a string. | |
454 | */ | |
455 | void AutoCompSelect(const wxString& text); | |
456 | ||
457 | /** | |
458 | Set whether or not autocompletion is hidden automatically when nothing matches. | |
459 | */ | |
460 | void AutoCompSetAutoHide(bool autoHide); | |
461 | ||
462 | /** | |
463 | Should the auto-completion list be cancelled if the user backspaces to a | |
464 | position before where the box was created. | |
465 | */ | |
466 | void AutoCompSetCancelAtStart(bool cancel); | |
467 | ||
468 | /** | |
469 | Should a single item auto-completion list automatically choose the item. | |
470 | */ | |
471 | void AutoCompSetChooseSingle(bool chooseSingle); | |
472 | ||
473 | /** | |
474 | Set whether or not autocompletion deletes any word characters | |
475 | after the inserted text upon completion. | |
476 | */ | |
477 | void AutoCompSetDropRestOfWord(bool dropRestOfWord); | |
478 | ||
479 | /** | |
480 | Define a set of characters that when typed will cause the autocompletion to | |
481 | choose the selected item. | |
482 | */ | |
483 | void AutoCompSetFillUps(const wxString& characterSet); | |
484 | ||
485 | /** | |
486 | Set whether case is significant when performing auto-completion searches. | |
487 | */ | |
488 | void AutoCompSetIgnoreCase(bool ignoreCase); | |
489 | ||
490 | /** | |
491 | Set the maximum height, in rows, of auto-completion and user lists. | |
492 | The default is 5 rows. | |
493 | */ | |
494 | void AutoCompSetMaxHeight(int rowCount); | |
495 | ||
496 | /** | |
497 | Set the maximum width, in characters, of auto-completion and user lists. | |
498 | Set to 0 to autosize to fit longest item, which is the default. | |
499 | */ | |
500 | void AutoCompSetMaxWidth(int characterCount); | |
501 | ||
502 | /** | |
503 | Change the separator character in the string setting up an auto-completion list. | |
504 | Default is space but can be changed if items contain space. | |
505 | */ | |
506 | void AutoCompSetSeparator(int separatorCharacter); | |
507 | ||
508 | /** | |
509 | Change the type-separator character in the string setting up an auto-completion list. | |
510 | Default is '?' but can be changed if items contain '?'. | |
511 | */ | |
512 | void AutoCompSetTypeSeparator(int separatorCharacter); | |
513 | ||
514 | /** | |
515 | Display a auto-completion list. | |
516 | The lenEntered parameter indicates how many characters before | |
517 | the caret should be used to provide context. | |
518 | */ | |
519 | void AutoCompShow(int lenEntered, const wxString& itemList); | |
520 | ||
521 | /** | |
522 | Define a set of character that when typed cancel the auto-completion list. | |
523 | */ | |
524 | void AutoCompStops(const wxString& characterSet); | |
525 | ||
526 | /** | |
527 | Dedent the selected lines. | |
528 | */ | |
529 | void BackTab(); | |
530 | ||
531 | /** | |
532 | Start a sequence of actions that is undone and redone as a unit. | |
533 | May be nested. | |
534 | */ | |
535 | void BeginUndoAction(); | |
536 | ||
537 | /** | |
538 | Highlight the character at a position indicating there is no matching brace. | |
539 | */ | |
540 | void BraceBadLight(int pos); | |
541 | ||
542 | /** | |
543 | Highlight the characters at two positions. | |
544 | */ | |
545 | void BraceHighlight(int pos1, int pos2); | |
546 | ||
547 | /** | |
548 | Find the position of a matching brace or INVALID_POSITION if no match. | |
549 | */ | |
550 | int BraceMatch(int pos); | |
551 | ||
552 | /** | |
553 | Is there an active call tip? | |
554 | */ | |
555 | bool CallTipActive(); | |
556 | ||
557 | /** | |
558 | Remove the call tip from the screen. | |
559 | */ | |
560 | void CallTipCancel(); | |
561 | ||
562 | /** | |
563 | Retrieve the position where the caret was before displaying the call tip. | |
564 | */ | |
565 | int CallTipPosAtStart(); | |
566 | ||
567 | /** | |
568 | Set the background colour for the call tip. | |
569 | */ | |
570 | void CallTipSetBackground(const wxColour& back); | |
571 | ||
572 | /** | |
573 | Set the foreground colour for the call tip. | |
574 | */ | |
575 | void CallTipSetForeground(const wxColour& fore); | |
576 | ||
577 | /** | |
578 | Set the foreground colour for the highlighted part of the call tip. | |
579 | */ | |
580 | void CallTipSetForegroundHighlight(const wxColour& fore); | |
581 | ||
582 | /** | |
583 | Highlight a segment of the definition. | |
584 | */ | |
585 | void CallTipSetHighlight(int start, int end); | |
586 | ||
587 | /** | |
588 | Show a call tip containing a definition near position pos. | |
589 | */ | |
590 | void CallTipShow(int pos, const wxString& definition); | |
591 | ||
592 | /** | |
593 | Enable use of STYLE_CALLTIP and set call tip tab size in pixels. | |
594 | */ | |
595 | void CallTipUseStyle(int tabSize); | |
596 | ||
597 | /** | |
598 | Will a paste succeed? | |
599 | */ | |
600 | virtual bool CanPaste() const; | |
601 | ||
602 | /** | |
603 | Are there any redoable actions in the undo history? | |
604 | */ | |
605 | virtual bool CanRedo() const; | |
606 | ||
607 | /** | |
608 | Are there any undoable actions in the undo history? | |
609 | */ | |
610 | virtual bool CanUndo() const; | |
611 | ||
612 | /** | |
613 | Cancel any modes such as call tip or auto-completion list display. | |
614 | */ | |
615 | void Cancel(); | |
616 | ||
617 | /** | |
618 | Move caret left one character. | |
619 | */ | |
620 | void CharLeft(); | |
621 | ||
622 | /** | |
623 | Move caret left one character extending selection to new caret position. | |
624 | */ | |
625 | void CharLeftExtend(); | |
626 | ||
627 | /** | |
628 | Move caret left one character, extending rectangular selection to new caret | |
629 | position. | |
630 | */ | |
631 | void CharLeftRectExtend(); | |
632 | ||
633 | /** | |
634 | Move caret right one character. | |
635 | */ | |
636 | void CharRight(); | |
637 | ||
638 | /** | |
639 | Move caret right one character extending selection to new caret position. | |
640 | */ | |
641 | void CharRightExtend(); | |
642 | ||
643 | /** | |
644 | Move caret right one character, extending rectangular selection to new caret | |
645 | position. | |
646 | */ | |
647 | void CharRightRectExtend(); | |
648 | ||
649 | /** | |
650 | Set the last x chosen value to be the caret x position. | |
651 | */ | |
652 | void ChooseCaretX(); | |
653 | ||
654 | /** | |
655 | Clear the selection. | |
656 | */ | |
657 | virtual void Clear(); | |
658 | ||
659 | /** | |
660 | Delete all text in the document. | |
661 | */ | |
662 | void ClearAll(); | |
663 | ||
664 | /** | |
665 | Set all style bytes to 0, remove all folding information. | |
666 | */ | |
667 | void ClearDocumentStyle(); | |
668 | ||
669 | /** | |
670 | Clear all the registered images. | |
671 | */ | |
672 | void ClearRegisteredImages(); | |
673 | ||
674 | /** | |
675 | When key+modifier combination km is pressed perform msg. | |
676 | */ | |
677 | void CmdKeyAssign(int key, int modifiers, int cmd); | |
678 | ||
679 | /** | |
680 | When key+modifier combination km is pressed do nothing. | |
681 | */ | |
682 | void CmdKeyClear(int key, int modifiers); | |
683 | ||
684 | /** | |
685 | Drop all key mappings. | |
686 | */ | |
687 | void CmdKeyClearAll(); | |
688 | ||
689 | /** | |
690 | Perform one of the operations defined by the wxSTC_CMD_* constants. | |
691 | */ | |
692 | void CmdKeyExecute(int cmd); | |
693 | ||
694 | /** | |
695 | Colourise a segment of the document using the current lexing language. | |
696 | */ | |
697 | void Colourise(int start, int end); | |
698 | ||
699 | /** | |
700 | Convert all line endings in the document to one mode. | |
701 | */ | |
702 | void ConvertEOLs(int eolMode); | |
703 | ||
704 | /** | |
705 | Copy the selection to the clipboard. | |
706 | */ | |
707 | virtual void Copy(); | |
708 | ||
709 | /** | |
710 | Copy a range of text to the clipboard. Positions are clipped into the document. | |
711 | */ | |
712 | void CopyRange(int start, int end); | |
713 | ||
714 | /** | |
715 | Copy argument text to the clipboard. | |
716 | */ | |
717 | void CopyText(int length, const wxString& text); | |
718 | ||
719 | /** | |
720 | ||
721 | */ | |
722 | bool Create(wxWindow* parent, wxWindowID id = wxID_ANY, | |
723 | const wxPoint& pos = wxDefaultPosition, | |
724 | const wxSize& size = wxDefaultSize, | |
725 | long style = 0, | |
726 | const wxString& name = wxSTCNameStr); | |
727 | ||
728 | /** | |
729 | Create a new document object. | |
730 | Starts with reference count of 1 and not selected into editor. | |
731 | */ | |
732 | void* CreateDocument(); | |
733 | ||
734 | /** | |
735 | Cut the selection to the clipboard. | |
736 | */ | |
737 | virtual void Cut(); | |
738 | ||
739 | /** | |
740 | Delete back from the current position to the start of the line. | |
741 | */ | |
742 | void DelLineLeft(); | |
743 | ||
744 | /** | |
745 | Delete forwards from the current position to the end of the line. | |
746 | */ | |
747 | void DelLineRight(); | |
748 | ||
749 | /** | |
750 | Delete the word to the left of the caret. | |
751 | */ | |
752 | void DelWordLeft(); | |
753 | ||
754 | /** | |
755 | Delete the word to the right of the caret. | |
756 | */ | |
757 | void DelWordRight(); | |
758 | ||
759 | /** | |
760 | Delete the selection or if no selection, the character before the caret. | |
761 | */ | |
762 | void DeleteBack(); | |
763 | ||
764 | /** | |
765 | Delete the selection or if no selection, the character before the caret. | |
766 | Will not delete the character before at the start of a line. | |
767 | */ | |
768 | void DeleteBackNotLine(); | |
769 | ||
770 | /** | |
771 | Allow for simulating a DnD DragOver | |
772 | */ | |
773 | wxDragResult DoDragOver(wxCoord x, wxCoord y, wxDragResult def); | |
774 | ||
775 | /** | |
776 | Allow for simulating a DnD DropText | |
777 | */ | |
778 | bool DoDropText(long x, long y, const wxString& data); | |
779 | ||
780 | /** | |
781 | Find the document line of a display line taking hidden lines into account. | |
782 | */ | |
783 | int DocLineFromVisible(int lineDisplay); | |
784 | ||
785 | /** | |
786 | Move caret to last position in document. | |
787 | */ | |
788 | void DocumentEnd(); | |
789 | ||
790 | /** | |
791 | Move caret to last position in document extending selection to new caret | |
792 | position. | |
793 | */ | |
794 | void DocumentEndExtend(); | |
795 | ||
796 | /** | |
797 | Move caret to first position in document. | |
798 | */ | |
799 | void DocumentStart(); | |
800 | ||
801 | /** | |
802 | Move caret to first position in document extending selection to new caret | |
803 | position. | |
804 | */ | |
805 | void DocumentStartExtend(); | |
806 | ||
807 | /** | |
808 | Switch from insert to overtype mode or the reverse. | |
809 | */ | |
810 | void EditToggleOvertype(); | |
811 | ||
812 | /** | |
813 | Delete the undo history. | |
814 | */ | |
815 | void EmptyUndoBuffer(); | |
816 | ||
817 | /** | |
818 | End a sequence of actions that is undone and redone as a unit. | |
819 | */ | |
820 | void EndUndoAction(); | |
821 | ||
822 | /** | |
823 | Ensure the caret is visible. | |
824 | */ | |
825 | void EnsureCaretVisible(); | |
826 | ||
827 | /** | |
828 | Ensure a particular line is visible by expanding any header line hiding it. | |
829 | */ | |
830 | void EnsureVisible(int line); | |
831 | ||
832 | /** | |
833 | Ensure a particular line is visible by expanding any header line hiding it. | |
834 | Use the currently set visibility policy to determine which range to display. | |
835 | */ | |
836 | void EnsureVisibleEnforcePolicy(int line); | |
837 | ||
838 | /** | |
839 | Find the position of a column on a line taking into account tabs and | |
840 | multi-byte characters. If beyond end of line, return line end position. | |
841 | */ | |
842 | int FindColumn(int line, int column); | |
843 | ||
844 | /** | |
845 | Find some text in the document. | |
846 | */ | |
847 | int FindText(int minPos, int maxPos, const wxString& text, | |
848 | int flags = 0); | |
849 | ||
850 | /** | |
851 | Insert a Form Feed character. | |
852 | */ | |
853 | void FormFeed(); | |
854 | ||
855 | /** | |
856 | On Windows, will draw the document into a display context such as a printer. | |
857 | */ | |
858 | int FormatRange(bool doDraw, int startPos, int endPos, | |
859 | wxDC* draw, wxDC* target, | |
860 | wxRect renderRect, | |
861 | wxRect pageRect); | |
862 | ||
863 | /** | |
864 | Returns the position of the opposite end of the selection to the caret. | |
865 | */ | |
866 | int GetAnchor() const; | |
867 | ||
868 | /** | |
869 | Does a backspace pressed when caret is within indentation unindent? | |
870 | */ | |
871 | bool GetBackSpaceUnIndents() const; | |
872 | ||
873 | /** | |
874 | Is drawing done first into a buffer or direct to the screen? | |
875 | */ | |
876 | bool GetBufferedDraw() const; | |
877 | ||
878 | /** | |
879 | Get the foreground colour of the caret. | |
880 | */ | |
881 | wxColour GetCaretForeground() const; | |
882 | ||
883 | /** | |
884 | Get the background alpha of the caret line. | |
885 | */ | |
886 | int GetCaretLineBackAlpha() const; | |
887 | ||
888 | /** | |
889 | Get the colour of the background of the line containing the caret. | |
890 | */ | |
891 | wxColour GetCaretLineBackground() const; | |
892 | ||
893 | /** | |
894 | Is the background of the line containing the caret in a different colour? | |
895 | */ | |
896 | bool GetCaretLineVisible() const; | |
897 | ||
898 | /** | |
899 | Get the time in milliseconds that the caret is on and off. | |
900 | */ | |
901 | int GetCaretPeriod() const; | |
902 | ||
903 | /** | |
904 | Can the caret preferred x position only be changed by explicit movement | |
905 | commands? | |
906 | */ | |
907 | bool GetCaretSticky() const; | |
908 | ||
909 | /** | |
910 | Returns the width of the insert mode caret. | |
911 | */ | |
912 | int GetCaretWidth() const; | |
913 | ||
914 | /** | |
915 | Returns the character byte at the position. | |
916 | */ | |
917 | int GetCharAt(int pos) const; | |
918 | ||
919 | /** | |
920 | Get the code page used to interpret the bytes of the document as characters. | |
921 | */ | |
922 | int GetCodePage() const; | |
923 | ||
924 | /** | |
925 | Retrieve the column number of a position, taking tab width into account. | |
926 | */ | |
927 | int GetColumn(int pos) const; | |
928 | ||
929 | /** | |
930 | Get the way control characters are displayed. | |
931 | */ | |
932 | int GetControlCharSymbol() const; | |
933 | ||
934 | /** | |
935 | ||
936 | */ | |
937 | wxString GetCurLine(int* linePos = NULL); | |
938 | ||
939 | /** | |
940 | ||
941 | */ | |
942 | wxCharBuffer GetCurLineRaw(int* linePos = NULL); | |
943 | ||
944 | /** | |
945 | END of generated section | |
946 | Others... | |
947 | Returns the line number of the line with the caret. | |
948 | */ | |
949 | int GetCurrentLine(); | |
950 | ||
951 | /** | |
952 | Returns the position of the caret. | |
953 | */ | |
954 | int GetCurrentPos() const; | |
955 | ||
956 | /** | |
957 | Retrieve a pointer to the document object. | |
958 | */ | |
959 | void* GetDocPointer(); | |
960 | ||
961 | /** | |
962 | Retrieve the current end of line mode - one of CRLF, CR, or LF. | |
963 | */ | |
964 | int GetEOLMode() const; | |
965 | ||
966 | /** | |
967 | Retrieve the colour used in edge indication. | |
968 | */ | |
969 | wxColour GetEdgeColour() const; | |
970 | ||
971 | /** | |
972 | Retrieve the column number which text should be kept within. | |
973 | */ | |
974 | int GetEdgeColumn() const; | |
975 | ||
976 | /** | |
977 | Retrieve the edge highlight mode. | |
978 | */ | |
979 | int GetEdgeMode() const; | |
980 | ||
981 | /** | |
982 | Retrieve whether the maximum scroll position has the last | |
983 | line at the bottom of the view. | |
984 | */ | |
985 | bool GetEndAtLastLine() const; | |
986 | ||
987 | /** | |
988 | Retrieve the position of the last correctly styled character. | |
989 | */ | |
990 | int GetEndStyled() const; | |
991 | ||
992 | /** | |
993 | Retrieve the display line at the top of the display. | |
994 | */ | |
995 | int GetFirstVisibleLine() const; | |
996 | ||
997 | /** | |
998 | Is a header line expanded? | |
999 | */ | |
1000 | bool GetFoldExpanded(int line) const; | |
1001 | ||
1002 | /** | |
1003 | Retrieve the fold level of a line. | |
1004 | */ | |
1005 | int GetFoldLevel(int line) const; | |
1006 | ||
1007 | /** | |
1008 | Find the parent line of a child line. | |
1009 | */ | |
1010 | int GetFoldParent(int line) const; | |
1011 | ||
1012 | /** | |
1013 | Get the highlighted indentation guide column. | |
1014 | */ | |
1015 | int GetHighlightGuide() const; | |
1016 | ||
1017 | /** | |
1018 | Retrieve indentation size. | |
1019 | */ | |
1020 | int GetIndent() const; | |
1021 | ||
1022 | /** | |
1023 | Are the indentation guides visible? | |
1024 | */ | |
1025 | int GetIndentationGuides() const; | |
1026 | ||
1027 | /** | |
1028 | Find the last child line of a header line. | |
1029 | */ | |
1030 | int GetLastChild(int line, int level) const; | |
1031 | ||
1032 | /** | |
1033 | Can be used to prevent the EVT_CHAR handler from adding the char | |
1034 | */ | |
1035 | bool GetLastKeydownProcessed(); | |
1036 | ||
1037 | /** | |
1038 | Retrieve the degree of caching of layout information. | |
1039 | */ | |
1040 | int GetLayoutCache() const; | |
1041 | ||
1042 | /** | |
1043 | Returns the number of characters in the document. | |
1044 | */ | |
1045 | int GetLength() const; | |
1046 | ||
1047 | /** | |
1048 | Retrieve the lexing language of the document. | |
1049 | */ | |
1050 | int GetLexer() const; | |
1051 | ||
1052 | /** | |
1053 | Retrieve the contents of a line. | |
1054 | */ | |
1055 | wxString GetLine(int line) const; | |
1056 | ||
1057 | /** | |
1058 | Returns the number of lines in the document. There is always at least one. | |
1059 | */ | |
1060 | int GetLineCount() const; | |
1061 | ||
1062 | /** | |
1063 | Get the position after the last visible characters on a line. | |
1064 | */ | |
1065 | int GetLineEndPosition(int line) const; | |
1066 | ||
1067 | /** | |
1068 | Retrieve the position before the first non indentation character on a line. | |
1069 | */ | |
1070 | int GetLineIndentPosition(int line) const; | |
1071 | ||
1072 | /** | |
1073 | Retrieve the number of columns that a line is indented. | |
1074 | */ | |
1075 | int GetLineIndentation(int line) const; | |
1076 | ||
1077 | /** | |
1078 | Retrieve the contents of a line. | |
1079 | */ | |
1080 | wxCharBuffer GetLineRaw(int line); | |
1081 | ||
1082 | /** | |
1083 | Retrieve the position of the end of the selection at the given line | |
1084 | (INVALID_POSITION if no selection on this line). | |
1085 | */ | |
1086 | int GetLineSelEndPosition(int line); | |
1087 | ||
1088 | /** | |
1089 | Retrieve the position of the start of the selection at the given line | |
1090 | (INVALID_POSITION if no selection on this line). | |
1091 | */ | |
1092 | int GetLineSelStartPosition(int line); | |
1093 | ||
1094 | /** | |
1095 | Retrieve the extra styling information for a line. | |
1096 | */ | |
1097 | int GetLineState(int line) const; | |
1098 | ||
1099 | /** | |
1100 | Is a line visible? | |
1101 | */ | |
1102 | bool GetLineVisible(int line) const; | |
1103 | ||
1104 | /** | |
1105 | Returns the size in pixels of the left margin. | |
1106 | */ | |
1107 | int GetMarginLeft() const; | |
1108 | ||
1109 | /** | |
1110 | Retrieve the marker mask of a margin. | |
1111 | */ | |
1112 | int GetMarginMask(int margin) const; | |
1113 | ||
1114 | /** | |
1115 | Returns the size in pixels of the right margin. | |
1116 | */ | |
1117 | int GetMarginRight() const; | |
1118 | ||
1119 | /** | |
1120 | Retrieve the mouse click sensitivity of a margin. | |
1121 | */ | |
1122 | bool GetMarginSensitive(int margin) const; | |
1123 | ||
1124 | /** | |
1125 | Retrieve the type of a margin. | |
1126 | */ | |
1127 | int GetMarginType(int margin) const; | |
1128 | ||
1129 | /** | |
1130 | Retrieve the width of a margin in pixels. | |
1131 | */ | |
1132 | int GetMarginWidth(int margin) const; | |
1133 | ||
1134 | /** | |
1135 | Retrieve the last line number that has line state. | |
1136 | */ | |
1137 | int GetMaxLineState() const; | |
1138 | ||
1139 | /** | |
1140 | Get which document modification events are sent to the container. | |
1141 | */ | |
1142 | int GetModEventMask() const; | |
1143 | ||
1144 | /** | |
1145 | Is the document different from when it was last saved? | |
1146 | */ | |
1147 | bool GetModify() const; | |
1148 | ||
1149 | /** | |
1150 | Get whether mouse gets captured. | |
1151 | */ | |
1152 | bool GetMouseDownCaptures() const; | |
1153 | ||
1154 | /** | |
1155 | Retrieve the time the mouse must sit still to generate a mouse dwell event. | |
1156 | */ | |
1157 | int GetMouseDwellTime() const; | |
1158 | ||
1159 | /** | |
1160 | Returns @true if overtype mode is active otherwise @false is returned. | |
1161 | */ | |
1162 | bool GetOvertype() const; | |
1163 | ||
1164 | /** | |
1165 | Get convert-on-paste setting | |
1166 | */ | |
1167 | bool GetPasteConvertEndings() const; | |
1168 | ||
1169 | /** | |
1170 | Returns the print colour mode. | |
1171 | */ | |
1172 | int GetPrintColourMode() const; | |
1173 | ||
1174 | /** | |
1175 | Returns the print magnification. | |
1176 | */ | |
1177 | int GetPrintMagnification() const; | |
1178 | ||
1179 | /** | |
1180 | Is printing line wrapped? | |
1181 | */ | |
1182 | int GetPrintWrapMode() const; | |
1183 | ||
1184 | /** | |
1185 | Retrieve a 'property' value previously set with SetProperty. | |
1186 | */ | |
1187 | wxString GetProperty(const wxString& key); | |
1188 | ||
1189 | /** | |
1190 | Retrieve a 'property' value previously set with SetProperty, | |
1191 | with '$()' variable replacement on returned buffer. | |
1192 | */ | |
1193 | wxString GetPropertyExpanded(const wxString& key); | |
1194 | ||
1195 | /** | |
1196 | Retrieve a 'property' value previously set with SetProperty, | |
1197 | interpreted as an int AFTER any '$()' variable replacement. | |
1198 | */ | |
1199 | int GetPropertyInt(const wxString& key) const; | |
1200 | ||
1201 | /** | |
1202 | In read-only mode? | |
1203 | */ | |
1204 | bool GetReadOnly() const; | |
1205 | ||
1206 | /** | |
1207 | Get cursor type. | |
1208 | */ | |
1209 | int GetSTCCursor() const; | |
1210 | ||
1211 | /** | |
1212 | Get internal focus flag. | |
1213 | */ | |
1214 | bool GetSTCFocus() const; | |
1215 | ||
1216 | /** | |
1217 | Retrieve the document width assumed for scrolling. | |
1218 | */ | |
1219 | int GetScrollWidth() const; | |
1220 | ||
1221 | /** | |
1222 | Get the search flags used by SearchInTarget. | |
1223 | */ | |
1224 | int GetSearchFlags() const; | |
1225 | ||
1226 | /** | |
1227 | Get the alpha of the selection. | |
1228 | */ | |
1229 | int GetSelAlpha() const; | |
1230 | ||
1231 | /** | |
1232 | Retrieve the selected text. | |
1233 | */ | |
1234 | wxString GetSelectedText(); | |
1235 | ||
1236 | /** | |
1237 | Retrieve the selected text. | |
1238 | */ | |
1239 | wxCharBuffer GetSelectedTextRaw(); | |
1240 | ||
1241 | /** | |
1242 | ||
1243 | */ | |
1244 | void GetSelection(int* OUTPUT, int* OUTPUT); | |
1245 | ||
1246 | /** | |
1247 | Returns the position at the end of the selection. | |
1248 | */ | |
1249 | int GetSelectionEnd() const; | |
1250 | ||
1251 | /** | |
1252 | Get the mode of the current selection. | |
1253 | */ | |
1254 | int GetSelectionMode() const; | |
1255 | ||
1256 | /** | |
1257 | Returns the position at the start of the selection. | |
1258 | */ | |
1259 | int GetSelectionStart() const; | |
1260 | ||
1261 | /** | |
1262 | Get error status. | |
1263 | */ | |
1264 | int GetStatus() const; | |
1265 | ||
1266 | /** | |
1267 | Returns the style byte at the position. | |
1268 | */ | |
1269 | int GetStyleAt(int pos) const; | |
1270 | ||
1271 | /** | |
1272 | Retrieve number of bits in style bytes used to hold the lexical state. | |
1273 | */ | |
1274 | int GetStyleBits() const; | |
1275 | ||
1276 | /** | |
1277 | Retrieve the number of bits the current lexer needs for styling. | |
1278 | */ | |
1279 | int GetStyleBitsNeeded() const; | |
1280 | ||
1281 | /** | |
1282 | Retrieve a buffer of cells. | |
1283 | */ | |
1284 | wxMemoryBuffer GetStyledText(int startPos, int endPos); | |
1285 | ||
1286 | /** | |
1287 | Does a tab pressed when caret is within indentation indent? | |
1288 | */ | |
1289 | bool GetTabIndents() const; | |
1290 | ||
1291 | /** | |
1292 | Retrieve the visible size of a tab. | |
1293 | */ | |
1294 | int GetTabWidth() const; | |
1295 | ||
1296 | /** | |
1297 | Get the position that ends the target. | |
1298 | */ | |
1299 | int GetTargetEnd() const; | |
1300 | ||
1301 | /** | |
1302 | Get the position that starts the target. | |
1303 | */ | |
1304 | int GetTargetStart() const; | |
1305 | ||
1306 | /** | |
1307 | Retrieve all the text in the document. | |
1308 | */ | |
1309 | wxString GetText() const; | |
1310 | ||
1311 | /** | |
1312 | Retrieve the number of characters in the document. | |
1313 | */ | |
1314 | int GetTextLength() const; | |
1315 | ||
1316 | /** | |
1317 | Retrieve a range of text. | |
1318 | */ | |
1319 | wxString GetTextRange(int startPos, int endPos); | |
1320 | ||
1321 | /** | |
1322 | Retrieve a range of text. | |
1323 | */ | |
1324 | wxCharBuffer GetTextRangeRaw(int startPos, int endPos); | |
1325 | ||
1326 | /** | |
1327 | Retrieve all the text in the document. | |
1328 | */ | |
1329 | wxCharBuffer GetTextRaw(); | |
1330 | ||
1331 | /** | |
1332 | Is drawing done in two phases with backgrounds drawn before foregrounds? | |
1333 | */ | |
1334 | bool GetTwoPhaseDraw() const; | |
1335 | ||
1336 | /** | |
1337 | Is undo history being collected? | |
1338 | */ | |
1339 | bool GetUndoCollection() const; | |
1340 | ||
1341 | /** | |
1342 | Returns the current UseAntiAliasing setting. | |
1343 | */ | |
1344 | bool GetUseAntiAliasing(); | |
1345 | ||
1346 | /** | |
1347 | Is the horizontal scroll bar visible? | |
1348 | */ | |
1349 | bool GetUseHorizontalScrollBar() const; | |
1350 | ||
1351 | /** | |
1352 | Retrieve whether tabs will be used in indentation. | |
1353 | */ | |
1354 | bool GetUseTabs() const; | |
1355 | ||
1356 | /** | |
1357 | Is the vertical scroll bar visible? | |
1358 | */ | |
1359 | bool GetUseVerticalScrollBar() const; | |
1360 | ||
1361 | /** | |
1362 | Are the end of line characters visible? | |
1363 | */ | |
1364 | bool GetViewEOL() const; | |
1365 | ||
1366 | /** | |
1367 | Are white space characters currently visible? | |
1368 | Returns one of SCWS_* constants. | |
1369 | */ | |
1370 | int GetViewWhiteSpace() const; | |
1371 | ||
1372 | /** | |
1373 | Retrieve whether text is word wrapped. | |
1374 | */ | |
1375 | int GetWrapMode() const; | |
1376 | ||
1377 | /** | |
1378 | Retrive the start indent for wrapped lines. | |
1379 | */ | |
1380 | int GetWrapStartIndent() const; | |
1381 | ||
1382 | /** | |
1383 | Retrive the display mode of visual flags for wrapped lines. | |
1384 | */ | |
1385 | int GetWrapVisualFlags() const; | |
1386 | ||
1387 | /** | |
1388 | Retrive the location of visual flags for wrapped lines. | |
1389 | */ | |
1390 | int GetWrapVisualFlagsLocation() const; | |
1391 | ||
1392 | /** | |
1393 | ||
1394 | */ | |
1395 | int GetXOffset() const; | |
1396 | ||
1397 | /** | |
1398 | Retrieve the zoom level. | |
1399 | */ | |
1400 | int GetZoom() const; | |
1401 | ||
1402 | /** | |
1403 | Set caret to start of a line and ensure it is visible. | |
1404 | */ | |
1405 | void GotoLine(int line); | |
1406 | ||
1407 | /** | |
1408 | Set caret to a position and ensure it is visible. | |
1409 | */ | |
1410 | void GotoPos(int pos); | |
1411 | ||
1412 | /** | |
1413 | Make a range of lines invisible. | |
1414 | */ | |
1415 | void HideLines(int lineStart, int lineEnd); | |
1416 | ||
1417 | /** | |
1418 | Draw the selection in normal style or with selection highlighted. | |
1419 | */ | |
1420 | void HideSelection(bool normal); | |
1421 | ||
1422 | /** | |
1423 | Move caret to first position on line. | |
1424 | */ | |
1425 | void Home(); | |
1426 | ||
1427 | /** | |
1428 | Move caret to first position on display line. | |
1429 | */ | |
1430 | void HomeDisplay(); | |
1431 | ||
1432 | /** | |
1433 | Move caret to first position on display line extending selection to | |
1434 | new caret position. | |
1435 | */ | |
1436 | void HomeDisplayExtend(); | |
1437 | ||
1438 | /** | |
1439 | Move caret to first position on line extending selection to new caret position. | |
1440 | */ | |
1441 | void HomeExtend(); | |
1442 | ||
1443 | /** | |
1444 | Move caret to first position on line, extending rectangular selection to new | |
1445 | caret position. | |
1446 | */ | |
1447 | void HomeRectExtend(); | |
1448 | ||
1449 | /** | |
1450 | These are like their namesakes Home(Extend)?, LineEnd(Extend)?, VCHome(Extend)? | |
1451 | except they behave differently when word-wrap is enabled: | |
1452 | They go first to the start / end of the display line, like (Home|LineEnd)Display | |
1453 | The difference is that, the cursor is already at the point, it goes on to the | |
1454 | start or end of the document line, as appropriate for (Home|LineEnd|VCHome)(Extend)?. | |
1455 | */ | |
1456 | void HomeWrap(); | |
1457 | ||
1458 | /** | |
1459 | ||
1460 | */ | |
1461 | void HomeWrapExtend(); | |
1462 | ||
1463 | /** | |
1464 | Retrieve the foreground colour of an indicator. | |
1465 | */ | |
1466 | wxColour IndicatorGetForeground(int indic) const; | |
1467 | ||
1468 | /** | |
1469 | Retrieve the style of an indicator. | |
1470 | */ | |
1471 | int IndicatorGetStyle(int indic) const; | |
1472 | ||
1473 | /** | |
1474 | Set the foreground colour of an indicator. | |
1475 | */ | |
1476 | void IndicatorSetForeground(int indic, const wxColour& fore); | |
1477 | ||
1478 | /** | |
1479 | Set an indicator to plain, squiggle or TT. | |
1480 | */ | |
1481 | void IndicatorSetStyle(int indic, int style); | |
1482 | ||
1483 | /** | |
1484 | Insert string at a position. | |
1485 | */ | |
1486 | void InsertText(int pos, const wxString& text); | |
1487 | ||
1488 | /** | |
1489 | Insert string at a position. | |
1490 | */ | |
1491 | void InsertTextRaw(int pos, const char* text); | |
1492 | ||
1493 | /** | |
1494 | Copy the line containing the caret. | |
1495 | */ | |
1496 | void LineCopy(); | |
1497 | ||
1498 | /** | |
1499 | Cut the line containing the caret. | |
1500 | */ | |
1501 | void LineCut(); | |
1502 | ||
1503 | /** | |
1504 | Delete the line containing the caret. | |
1505 | */ | |
1506 | void LineDelete(); | |
1507 | ||
1508 | /** | |
1509 | Move caret down one line. | |
1510 | */ | |
1511 | void LineDown(); | |
1512 | ||
1513 | /** | |
1514 | Move caret down one line extending selection to new caret position. | |
1515 | */ | |
1516 | void LineDownExtend(); | |
1517 | ||
1518 | /** | |
1519 | Move caret down one line, extending rectangular selection to new caret position. | |
1520 | */ | |
1521 | void LineDownRectExtend(); | |
1522 | ||
1523 | /** | |
1524 | Duplicate the current line. | |
1525 | */ | |
1526 | void LineDuplicate(); | |
1527 | ||
1528 | /** | |
1529 | Move caret to last position on line. | |
1530 | */ | |
1531 | void LineEnd(); | |
1532 | ||
1533 | /** | |
1534 | Move caret to last position on display line. | |
1535 | */ | |
1536 | void LineEndDisplay(); | |
1537 | ||
1538 | /** | |
1539 | Move caret to last position on display line extending selection to new | |
1540 | caret position. | |
1541 | */ | |
1542 | void LineEndDisplayExtend(); | |
1543 | ||
1544 | /** | |
1545 | Move caret to last position on line extending selection to new caret position. | |
1546 | */ | |
1547 | void LineEndExtend(); | |
1548 | ||
1549 | /** | |
1550 | Move caret to last position on line, extending rectangular selection to new | |
1551 | caret position. | |
1552 | */ | |
1553 | void LineEndRectExtend(); | |
1554 | ||
1555 | /** | |
1556 | ||
1557 | */ | |
1558 | void LineEndWrap(); | |
1559 | ||
1560 | /** | |
1561 | ||
1562 | */ | |
1563 | void LineEndWrapExtend(); | |
1564 | ||
1565 | /** | |
1566 | Retrieve the line containing a position. | |
1567 | */ | |
1568 | int LineFromPosition(int pos) const; | |
1569 | ||
1570 | /** | |
1571 | How many characters are on a line, not including end of line characters? | |
1572 | */ | |
1573 | int LineLength(int line) const; | |
1574 | ||
1575 | /** | |
1576 | Scroll horizontally and vertically. | |
1577 | */ | |
1578 | void LineScroll(int columns, int lines); | |
1579 | ||
1580 | /** | |
1581 | Scroll the document down, keeping the caret visible. | |
1582 | */ | |
1583 | void LineScrollDown(); | |
1584 | ||
1585 | /** | |
1586 | Scroll the document up, keeping the caret visible. | |
1587 | */ | |
1588 | void LineScrollUp(); | |
1589 | ||
1590 | /** | |
1591 | Switch the current line with the previous. | |
1592 | */ | |
1593 | void LineTranspose(); | |
1594 | ||
1595 | /** | |
1596 | Move caret up one line. | |
1597 | */ | |
1598 | void LineUp(); | |
1599 | ||
1600 | /** | |
1601 | Move caret up one line extending selection to new caret position. | |
1602 | */ | |
1603 | void LineUpExtend(); | |
1604 | ||
1605 | /** | |
1606 | Move caret up one line, extending rectangular selection to new caret position. | |
1607 | */ | |
1608 | void LineUpRectExtend(); | |
1609 | ||
1610 | /** | |
1611 | Join the lines in the target. | |
1612 | */ | |
1613 | void LinesJoin(); | |
1614 | ||
1615 | /** | |
1616 | Retrieves the number of lines completely visible. | |
1617 | */ | |
1618 | int LinesOnScreen() const; | |
1619 | ||
1620 | /** | |
1621 | Split the lines in the target into lines that are less wide than pixelWidth | |
1622 | where possible. | |
1623 | */ | |
1624 | void LinesSplit(int pixelWidth); | |
1625 | ||
1626 | /** | |
1627 | Load the contents of filename into the editor | |
1628 | */ | |
1629 | bool LoadFile(const wxString& file, int fileType = wxTEXT_TYPE_ANY); | |
1630 | ||
1631 | /** | |
1632 | Transform the selection to lower case. | |
1633 | */ | |
1634 | void LowerCase(); | |
1635 | ||
1636 | /** | |
1637 | Add a marker to a line, returning an ID which can be used to find or delete the | |
1638 | marker. | |
1639 | */ | |
1640 | int MarkerAdd(int line, int markerNumber); | |
1641 | ||
1642 | /** | |
1643 | Add a set of markers to a line. | |
1644 | */ | |
1645 | void MarkerAddSet(int line, int set); | |
1646 | ||
1647 | /** | |
1648 | Set the symbol used for a particular marker number, | |
1649 | and optionally the fore and background colours. | |
1650 | */ | |
1651 | void MarkerDefine(int markerNumber, int markerSymbol, | |
1652 | const wxColour& foreground = wxNullColour, | |
1653 | const wxColour& background = wxNullColour); | |
1654 | ||
1655 | /** | |
1656 | Define a marker from a bitmap | |
1657 | */ | |
1658 | void MarkerDefineBitmap(int markerNumber, const wxBitmap& bmp); | |
1659 | ||
1660 | /** | |
1661 | Delete a marker from a line. | |
1662 | */ | |
1663 | void MarkerDelete(int line, int markerNumber); | |
1664 | ||
1665 | /** | |
1666 | Delete all markers with a particular number from all lines. | |
1667 | */ | |
1668 | void MarkerDeleteAll(int markerNumber); | |
1669 | ||
1670 | /** | |
1671 | Delete a marker. | |
1672 | */ | |
1673 | void MarkerDeleteHandle(int handle); | |
1674 | ||
1675 | /** | |
1676 | Get a bit mask of all the markers set on a line. | |
1677 | */ | |
1678 | int MarkerGet(int line); | |
1679 | ||
1680 | /** | |
1681 | Retrieve the line number at which a particular marker is located. | |
1682 | */ | |
1683 | int MarkerLineFromHandle(int handle); | |
1684 | ||
1685 | /** | |
1686 | Find the next line after lineStart that includes a marker in mask. | |
1687 | */ | |
1688 | int MarkerNext(int lineStart, int markerMask); | |
1689 | ||
1690 | /** | |
1691 | Find the previous line before lineStart that includes a marker in mask. | |
1692 | */ | |
1693 | int MarkerPrevious(int lineStart, int markerMask); | |
1694 | ||
1695 | /** | |
1696 | Set the alpha used for a marker that is drawn in the text area, not the margin. | |
1697 | */ | |
1698 | void MarkerSetAlpha(int markerNumber, int alpha); | |
1699 | ||
1700 | /** | |
1701 | Set the background colour used for a particular marker number. | |
1702 | */ | |
1703 | void MarkerSetBackground(int markerNumber, const wxColour& back); | |
1704 | ||
1705 | /** | |
1706 | Set the foreground colour used for a particular marker number. | |
1707 | */ | |
1708 | void MarkerSetForeground(int markerNumber, const wxColour& fore); | |
1709 | ||
1710 | /** | |
1711 | Move the caret inside current view if it's not there already. | |
1712 | */ | |
1713 | void MoveCaretInsideView(); | |
1714 | ||
1715 | /** | |
1716 | Insert a new line, may use a CRLF, CR or LF depending on EOL mode. | |
1717 | */ | |
1718 | void NewLine(); | |
1719 | ||
1720 | /** | |
1721 | Move caret one page down. | |
1722 | */ | |
1723 | void PageDown(); | |
1724 | ||
1725 | /** | |
1726 | Move caret one page down extending selection to new caret position. | |
1727 | */ | |
1728 | void PageDownExtend(); | |
1729 | ||
1730 | /** | |
1731 | Move caret one page down, extending rectangular selection to new caret position. | |
1732 | */ | |
1733 | void PageDownRectExtend(); | |
1734 | ||
1735 | /** | |
1736 | Move caret one page up. | |
1737 | */ | |
1738 | void PageUp(); | |
1739 | ||
1740 | /** | |
1741 | Move caret one page up extending selection to new caret position. | |
1742 | */ | |
1743 | void PageUpExtend(); | |
1744 | ||
1745 | /** | |
1746 | Move caret one page up, extending rectangular selection to new caret position. | |
1747 | */ | |
1748 | void PageUpRectExtend(); | |
1749 | ||
1750 | /** | |
1751 | Move caret between paragraphs (delimited by empty lines). | |
1752 | */ | |
1753 | void ParaDown(); | |
1754 | ||
1755 | /** | |
1756 | ||
1757 | */ | |
1758 | void ParaDownExtend(); | |
1759 | ||
1760 | /** | |
1761 | ||
1762 | */ | |
1763 | void ParaUp(); | |
1764 | ||
1765 | /** | |
1766 | ||
1767 | */ | |
1768 | void ParaUpExtend(); | |
1769 | ||
1770 | /** | |
1771 | Paste the contents of the clipboard into the document replacing the selection. | |
1772 | */ | |
1773 | virtual void Paste(); | |
1774 | ||
1775 | /** | |
1776 | Retrieve the point in the window where a position is displayed. | |
1777 | */ | |
1778 | wxPoint PointFromPosition(int pos); | |
1779 | ||
1780 | /** | |
1781 | Given a valid document position, return the next position taking code | |
1782 | page into account. Maximum value returned is the last position in the document. | |
1783 | */ | |
1784 | int PositionAfter(int pos); | |
1785 | ||
1786 | /** | |
1787 | Given a valid document position, return the previous position taking code | |
1788 | page into account. Returns 0 if passed 0. | |
1789 | */ | |
1790 | int PositionBefore(int pos); | |
1791 | ||
1792 | /** | |
1793 | Retrieve the position at the start of a line. | |
1794 | */ | |
1795 | int PositionFromLine(int line) const; | |
1796 | ||
1797 | /** | |
1798 | Find the position from a point within the window. | |
1799 | */ | |
1800 | int PositionFromPoint(wxPoint pt) const; | |
1801 | ||
1802 | /** | |
1803 | Find the position from a point within the window but return | |
1804 | INVALID_POSITION if not close to text. | |
1805 | */ | |
1806 | int PositionFromPointClose(int x, int y); | |
1807 | ||
1808 | /** | |
1809 | Redoes the next action on the undo history. | |
1810 | */ | |
1811 | virtual void Redo(); | |
1812 | ||
1813 | /** | |
1814 | Register an image for use in autocompletion lists. | |
1815 | */ | |
1816 | void RegisterImage(int type, const wxBitmap& bmp); | |
1817 | ||
1818 | /** | |
1819 | Release a reference to the document, deleting document if it fades to black. | |
1820 | */ | |
1821 | void ReleaseDocument(void* docPointer); | |
1822 | ||
1823 | /** | |
1824 | Replace the selected text with the argument text. | |
1825 | */ | |
1826 | void ReplaceSelection(const wxString& text); | |
1827 | ||
1828 | /** | |
1829 | Replace the target text with the argument text. | |
1830 | Text is counted so it can contain NULs. | |
1831 | Returns the length of the replacement text. | |
1832 | */ | |
1833 | int ReplaceTarget(const wxString& text); | |
1834 | ||
1835 | /** | |
1836 | Replace the target text with the argument text after d processing. | |
1837 | Text is counted so it can contain NULs. | |
1838 | ||
1839 | Looks for d where d is between 1 and 9 and replaces these with the strings | |
1840 | matched in the last search operation which were surrounded by ( and ). | |
1841 | ||
1842 | Returns the length of the replacement text including any change | |
1843 | caused by processing the d patterns. | |
1844 | */ | |
1845 | int ReplaceTargetRE(const wxString& text); | |
1846 | ||
1847 | /** | |
1848 | Write the contents of the editor to filename | |
1849 | */ | |
1850 | bool SaveFile(const wxString& file = wxEmptyString, int fileType = wxTEXT_TYPE_ANY); | |
1851 | ||
1852 | /** | |
1853 | Scroll enough to make the given column visible | |
1854 | */ | |
1855 | void ScrollToColumn(int column); | |
1856 | ||
1857 | /** | |
1858 | Scroll enough to make the given line visible | |
1859 | */ | |
1860 | void ScrollToLine(int line); | |
1861 | ||
1862 | /** | |
1863 | Sets the current caret position to be the search anchor. | |
1864 | */ | |
1865 | void SearchAnchor(); | |
1866 | ||
1867 | /** | |
1868 | Search for a counted string in the target and set the target to the found | |
1869 | range. Text is counted so it can contain NULs. | |
1870 | Returns length of range or -1 for failure in which case target is not moved. | |
1871 | */ | |
1872 | int SearchInTarget(const wxString& text); | |
1873 | ||
1874 | /** | |
1875 | Find some text starting at the search anchor. | |
1876 | Does not ensure the selection is visible. | |
1877 | */ | |
1878 | int SearchNext(int flags, const wxString& text); | |
1879 | ||
1880 | /** | |
1881 | Find some text starting at the search anchor and moving backwards. | |
1882 | Does not ensure the selection is visible. | |
1883 | */ | |
1884 | int SearchPrev(int flags, const wxString& text); | |
1885 | ||
1886 | /** | |
1887 | Select all the text in the document. | |
1888 | */ | |
1889 | virtual void SelectAll(); | |
1890 | ||
1891 | /** | |
1892 | Duplicate the selection. If selection empty duplicate the line containing the | |
1893 | caret. | |
1894 | */ | |
1895 | void SelectionDuplicate(); | |
1896 | ||
1897 | /** | |
1898 | Is the selection rectangular? The alternative is the more common stream | |
1899 | selection. | |
1900 | */ | |
1901 | bool SelectionIsRectangle() const; | |
1902 | ||
1903 | /** | |
1904 | Send a message to Scintilla | |
1905 | */ | |
1906 | wxIntPtr SendMsg(int msg, wxUIntPtr wp = 0, wxIntPtr lp = 0) const; | |
1907 | ||
1908 | /** | |
1909 | Set the selection anchor to a position. The anchor is the opposite | |
1910 | end of the selection from the caret. | |
1911 | */ | |
1912 | void SetAnchor(int posAnchor); | |
1913 | ||
1914 | /** | |
1915 | Sets whether a backspace pressed when caret is within indentation unindents. | |
1916 | */ | |
1917 | void SetBackSpaceUnIndents(bool bsUnIndents); | |
1918 | ||
1919 | /** | |
1920 | If drawing is buffered then each line of text is drawn into a bitmap buffer | |
1921 | before drawing it to the screen to avoid flicker. | |
1922 | */ | |
1923 | void SetBufferedDraw(bool buffered); | |
1924 | ||
1925 | /** | |
1926 | Set the foreground colour of the caret. | |
1927 | */ | |
1928 | void SetCaretForeground(const wxColour& fore); | |
1929 | ||
1930 | /** | |
1931 | Set background alpha of the caret line. | |
1932 | */ | |
1933 | void SetCaretLineBackAlpha(int alpha); | |
1934 | ||
1935 | /** | |
1936 | Set the colour of the background of the line containing the caret. | |
1937 | */ | |
1938 | void SetCaretLineBackground(const wxColour& back); | |
1939 | ||
1940 | /** | |
1941 | Display the background of the line containing the caret in a different colour. | |
1942 | */ | |
1943 | void SetCaretLineVisible(bool show); | |
1944 | ||
1945 | /** | |
1946 | Get the time in milliseconds that the caret is on and off. 0 = steady on. | |
1947 | */ | |
1948 | void SetCaretPeriod(int periodMilliseconds); | |
1949 | ||
1950 | /** | |
1951 | Stop the caret preferred x position changing when the user types. | |
1952 | */ | |
1953 | void SetCaretSticky(bool useCaretStickyBehaviour); | |
1954 | ||
1955 | /** | |
1956 | Set the width of the insert mode caret. | |
1957 | */ | |
1958 | void SetCaretWidth(int pixelWidth); | |
1959 | ||
1960 | /** | |
1961 | Reset the set of characters for whitespace and word characters to the defaults. | |
1962 | */ | |
1963 | void SetCharsDefault(); | |
1964 | ||
1965 | /** | |
1966 | Set the code page used to interpret the bytes of the document as characters. | |
1967 | */ | |
1968 | void SetCodePage(int codePage); | |
1969 | ||
1970 | /** | |
1971 | Change the way control characters are displayed: | |
1972 | If symbol is 32, keep the drawn way, else, use the given character. | |
1973 | */ | |
1974 | void SetControlCharSymbol(int symbol); | |
1975 | ||
1976 | /** | |
1977 | Sets the position of the caret. | |
1978 | */ | |
1979 | void SetCurrentPos(int pos); | |
1980 | ||
1981 | /** | |
1982 | Change the document object used. | |
1983 | */ | |
1984 | void SetDocPointer(void* docPointer); | |
1985 | ||
1986 | /** | |
1987 | Set the current end of line mode. | |
1988 | */ | |
1989 | void SetEOLMode(int eolMode); | |
1990 | ||
1991 | /** | |
1992 | Change the colour used in edge indication. | |
1993 | */ | |
1994 | void SetEdgeColour(const wxColour& edgeColour); | |
1995 | ||
1996 | /** | |
1997 | Set the column number of the edge. | |
1998 | If text goes past the edge then it is highlighted. | |
1999 | */ | |
2000 | void SetEdgeColumn(int column); | |
2001 | ||
2002 | /** | |
2003 | The edge may be displayed by a line (EDGE_LINE) or by highlighting text that | |
2004 | goes beyond it (EDGE_BACKGROUND) or not displayed at all (EDGE_NONE). | |
2005 | */ | |
2006 | void SetEdgeMode(int mode); | |
2007 | ||
2008 | /** | |
2009 | Sets the scroll range so that maximum scroll position has | |
2010 | the last line at the bottom of the view (default). | |
2011 | Setting this to @false allows scrolling one page below the last line. | |
2012 | */ | |
2013 | void SetEndAtLastLine(bool endAtLastLine); | |
2014 | ||
2015 | /** | |
2016 | Show the children of a header line. | |
2017 | */ | |
2018 | void SetFoldExpanded(int line, bool expanded); | |
2019 | ||
2020 | /** | |
2021 | Set some style options for folding. | |
2022 | */ | |
2023 | void SetFoldFlags(int flags); | |
2024 | ||
2025 | /** | |
2026 | Set the fold level of a line. | |
2027 | This encodes an integer level along with flags indicating whether the | |
2028 | line is a header and whether it is effectively white space. | |
2029 | */ | |
2030 | void SetFoldLevel(int line, int level); | |
2031 | ||
2032 | /** | |
2033 | Set the colours used as a chequerboard pattern in the fold margin | |
2034 | */ | |
2035 | void SetFoldMarginColour(bool useSetting, const wxColour& back); | |
2036 | ||
2037 | /** | |
2038 | ||
2039 | */ | |
2040 | void SetFoldMarginHiColour(bool useSetting, const wxColour& fore); | |
2041 | ||
2042 | /** | |
2043 | Set the horizontal scrollbar to use instead of the ont that's built-in. | |
2044 | */ | |
2045 | void SetHScrollBar(wxScrollBar* bar); | |
2046 | ||
2047 | /** | |
2048 | Set the highlighted indentation guide column. | |
2049 | 0 = no highlighted guide. | |
2050 | */ | |
2051 | void SetHighlightGuide(int column); | |
2052 | ||
2053 | /** | |
2054 | Set a back colour for active hotspots. | |
2055 | */ | |
2056 | void SetHotspotActiveBackground(bool useSetting, | |
2057 | const wxColour& back); | |
2058 | ||
2059 | /** | |
2060 | Set a fore colour for active hotspots. | |
2061 | */ | |
2062 | void SetHotspotActiveForeground(bool useSetting, | |
2063 | const wxColour& fore); | |
2064 | ||
2065 | /** | |
2066 | Enable / Disable underlining active hotspots. | |
2067 | */ | |
2068 | void SetHotspotActiveUnderline(bool underline); | |
2069 | ||
2070 | /** | |
2071 | Limit hotspots to single line so hotspots on two lines don't merge. | |
2072 | */ | |
2073 | void SetHotspotSingleLine(bool singleLine); | |
2074 | ||
2075 | /** | |
2076 | Set the number of spaces used for one level of indentation. | |
2077 | */ | |
2078 | void SetIndent(int indentSize); | |
2079 | ||
2080 | /** | |
2081 | Show or hide indentation guides. | |
2082 | */ | |
2083 | void SetIndentationGuides(int indentView); | |
2084 | ||
2085 | /** | |
2086 | Set up the key words used by the lexer. | |
2087 | */ | |
2088 | void SetKeyWords(int keywordSet, const wxString& keyWords); | |
2089 | ||
2090 | /** | |
2091 | ||
2092 | */ | |
2093 | void SetLastKeydownProcessed(bool val); | |
2094 | ||
2095 | /** | |
2096 | Sets the degree of caching of layout information. | |
2097 | */ | |
2098 | void SetLayoutCache(int mode); | |
2099 | ||
2100 | /** | |
2101 | Set the lexing language of the document. | |
2102 | */ | |
2103 | void SetLexer(int lexer); | |
2104 | ||
2105 | /** | |
2106 | Set the lexing language of the document based on string name. | |
2107 | */ | |
2108 | void SetLexerLanguage(const wxString& language); | |
2109 | ||
2110 | /** | |
2111 | Change the indentation of a line to a number of columns. | |
2112 | */ | |
2113 | void SetLineIndentation(int line, int indentSize); | |
2114 | ||
2115 | /** | |
2116 | Used to hold extra styling information for each line. | |
2117 | */ | |
2118 | void SetLineState(int line, int state); | |
2119 | ||
2120 | /** | |
2121 | Sets the size in pixels of the left margin. | |
2122 | */ | |
2123 | void SetMarginLeft(int pixelWidth); | |
2124 | ||
2125 | /** | |
2126 | Set a mask that determines which markers are displayed in a margin. | |
2127 | */ | |
2128 | void SetMarginMask(int margin, int mask); | |
2129 | ||
2130 | /** | |
2131 | Sets the size in pixels of the right margin. | |
2132 | */ | |
2133 | void SetMarginRight(int pixelWidth); | |
2134 | ||
2135 | /** | |
2136 | Make a margin sensitive or insensitive to mouse clicks. | |
2137 | */ | |
2138 | void SetMarginSensitive(int margin, bool sensitive); | |
2139 | ||
2140 | /** | |
2141 | Set a margin to be either numeric or symbolic. | |
2142 | */ | |
2143 | void SetMarginType(int margin, int marginType); | |
2144 | ||
2145 | /** | |
2146 | Set the width of a margin to a width expressed in pixels. | |
2147 | */ | |
2148 | void SetMarginWidth(int margin, int pixelWidth); | |
2149 | ||
2150 | /** | |
2151 | Set the left and right margin in the edit area, measured in pixels. | |
2152 | */ | |
2153 | void SetMargins(int left, int right); | |
2154 | ||
2155 | /** | |
2156 | Set which document modification events are sent to the container. | |
2157 | */ | |
2158 | void SetModEventMask(int mask); | |
2159 | ||
2160 | /** | |
2161 | Set whether the mouse is captured when its button is pressed. | |
2162 | */ | |
2163 | void SetMouseDownCaptures(bool captures); | |
2164 | ||
2165 | /** | |
2166 | Sets the time the mouse must sit still to generate a mouse dwell event. | |
2167 | */ | |
2168 | void SetMouseDwellTime(int periodMilliseconds); | |
2169 | ||
2170 | /** | |
2171 | Set to overtype (@true) or insert mode. | |
2172 | */ | |
2173 | void SetOvertype(bool overtype); | |
2174 | ||
2175 | /** | |
2176 | Enable/Disable convert-on-paste for line endings | |
2177 | */ | |
2178 | void SetPasteConvertEndings(bool convert); | |
2179 | ||
2180 | /** | |
2181 | Modify colours when printing for clearer printed text. | |
2182 | */ | |
2183 | void SetPrintColourMode(int mode); | |
2184 | ||
2185 | /** | |
2186 | Sets the print magnification added to the point size of each style for printing. | |
2187 | */ | |
2188 | void SetPrintMagnification(int magnification); | |
2189 | ||
2190 | /** | |
2191 | Set printing to line wrapped (SC_WRAP_WORD) or not line wrapped (SC_WRAP_NONE). | |
2192 | */ | |
2193 | void SetPrintWrapMode(int mode); | |
2194 | ||
2195 | /** | |
2196 | Set up a value that may be used by a lexer for some optional feature. | |
2197 | */ | |
2198 | void SetProperty(const wxString& key, const wxString& value); | |
2199 | ||
2200 | /** | |
2201 | Set to read only or read write. | |
2202 | */ | |
2203 | void SetReadOnly(bool readOnly); | |
2204 | ||
2205 | /** | |
2206 | Sets the cursor to one of the SC_CURSOR* values. | |
2207 | */ | |
2208 | void SetSTCCursor(int cursorType); | |
2209 | ||
2210 | /** | |
2211 | Change internal focus flag. | |
2212 | */ | |
2213 | void SetSTCFocus(bool focus); | |
2214 | ||
2215 | /** | |
2216 | Remember the current position in the undo history as the position | |
2217 | at which the document was saved. | |
2218 | */ | |
2219 | void SetSavePoint(); | |
2220 | ||
2221 | /** | |
2222 | Sets the document width assumed for scrolling. | |
2223 | */ | |
2224 | void SetScrollWidth(int pixelWidth); | |
2225 | ||
2226 | /** | |
2227 | Set the search flags used by SearchInTarget. | |
2228 | */ | |
2229 | void SetSearchFlags(int flags); | |
2230 | ||
2231 | /** | |
2232 | Set the alpha of the selection. | |
2233 | */ | |
2234 | void SetSelAlpha(int alpha); | |
2235 | ||
2236 | /** | |
2237 | Set the background colour of the selection and whether to use this setting. | |
2238 | */ | |
2239 | void SetSelBackground(bool useSetting, const wxColour& back); | |
2240 | ||
2241 | /** | |
2242 | Set the foreground colour of the selection and whether to use this setting. | |
2243 | */ | |
2244 | void SetSelForeground(bool useSetting, const wxColour& fore); | |
2245 | ||
2246 | /** | |
2247 | Select a range of text. | |
2248 | */ | |
2249 | virtual void SetSelection(long from, long to); | |
2250 | ||
2251 | /** | |
2252 | Sets the position that ends the selection - this becomes the currentPosition. | |
2253 | */ | |
2254 | void SetSelectionEnd(int pos); | |
2255 | ||
2256 | /** | |
2257 | Set the selection mode to stream (SC_SEL_STREAM) or rectangular | |
2258 | (SC_SEL_RECTANGLE) or | |
2259 | by lines (SC_SEL_LINES). | |
2260 | */ | |
2261 | void SetSelectionMode(int mode); | |
2262 | ||
2263 | /** | |
2264 | Sets the position that starts the selection - this becomes the anchor. | |
2265 | */ | |
2266 | void SetSelectionStart(int pos); | |
2267 | ||
2268 | /** | |
2269 | Change error status - 0 = OK. | |
2270 | */ | |
2271 | void SetStatus(int statusCode); | |
2272 | ||
2273 | /** | |
2274 | Divide each styling byte into lexical class bits (default: 5) and indicator | |
2275 | bits (default: 3). If a lexer requires more than 32 lexical states, then this | |
2276 | is used to expand the possible states. | |
2277 | */ | |
2278 | void SetStyleBits(int bits); | |
2279 | ||
2280 | /** | |
2281 | Set the styles for a segment of the document. | |
2282 | */ | |
2283 | void SetStyleBytes(int length, char* styleBytes); | |
2284 | ||
2285 | /** | |
2286 | Change style from current styling position for length characters to a style | |
2287 | and move the current styling position to after this newly styled segment. | |
2288 | */ | |
2289 | void SetStyling(int length, int style); | |
2290 | ||
2291 | /** | |
2292 | Sets whether a tab pressed when caret is within indentation indents. | |
2293 | */ | |
2294 | void SetTabIndents(bool tabIndents); | |
2295 | ||
2296 | /** | |
2297 | Change the visible size of a tab to be a multiple of the width of a space | |
2298 | character. | |
2299 | */ | |
2300 | void SetTabWidth(int tabWidth); | |
2301 | ||
2302 | /** | |
2303 | Sets the position that ends the target which is used for updating the | |
2304 | document without affecting the scroll position. | |
2305 | */ | |
2306 | void SetTargetEnd(int pos); | |
2307 | ||
2308 | /** | |
2309 | Sets the position that starts the target which is used for updating the | |
2310 | document without affecting the scroll position. | |
2311 | */ | |
2312 | void SetTargetStart(int pos); | |
2313 | ||
2314 | /** | |
2315 | Replace the contents of the document with the argument text. | |
2316 | */ | |
2317 | void SetText(const wxString& text); | |
2318 | ||
2319 | /** | |
2320 | Replace the contents of the document with the argument text. | |
2321 | */ | |
2322 | void SetTextRaw(const char* text); | |
2323 | ||
2324 | /** | |
2325 | In twoPhaseDraw mode, drawing is performed in two phases, first the background | |
2326 | and then the foreground. This avoids chopping off characters that overlap the | |
2327 | next run. | |
2328 | */ | |
2329 | void SetTwoPhaseDraw(bool twoPhase); | |
2330 | ||
2331 | /** | |
2332 | Choose between collecting actions into the undo | |
2333 | history and discarding them. | |
2334 | */ | |
2335 | void SetUndoCollection(bool collectUndo); | |
2336 | ||
2337 | /** | |
2338 | Specify whether anti-aliased fonts should be used. Will have no effect | |
2339 | on some platforms, but on some (wxMac for example) can greatly improve | |
2340 | performance. | |
2341 | */ | |
2342 | void SetUseAntiAliasing(bool useAA); | |
2343 | ||
2344 | /** | |
2345 | Show or hide the horizontal scroll bar. | |
2346 | */ | |
2347 | void SetUseHorizontalScrollBar(bool show); | |
2348 | ||
2349 | /** | |
2350 | Indentation will only use space characters if useTabs is @false, otherwise | |
2351 | it will use a combination of tabs and spaces. | |
2352 | */ | |
2353 | void SetUseTabs(bool useTabs); | |
2354 | ||
2355 | /** | |
2356 | Show or hide the vertical scroll bar. | |
2357 | */ | |
2358 | void SetUseVerticalScrollBar(bool show); | |
2359 | ||
2360 | /** | |
2361 | Set the vertical scrollbar to use instead of the ont that's built-in. | |
2362 | */ | |
2363 | void SetVScrollBar(wxScrollBar* bar); | |
2364 | ||
2365 | /** | |
2366 | Make the end of line characters visible or invisible. | |
2367 | */ | |
2368 | void SetViewEOL(bool visible); | |
2369 | ||
2370 | /** | |
2371 | Make white space characters invisible, always visible or visible outside | |
2372 | indentation. | |
2373 | */ | |
2374 | void SetViewWhiteSpace(int viewWS); | |
2375 | ||
2376 | /** | |
2377 | Set the way the display area is determined when a particular line | |
2378 | is to be moved to by Find, FindNext, GotoLine, etc. | |
2379 | */ | |
2380 | void SetVisiblePolicy(int visiblePolicy, int visibleSlop); | |
2381 | ||
2382 | /** | |
2383 | Set the background colour of all whitespace and whether to use this setting. | |
2384 | */ | |
2385 | void SetWhitespaceBackground(bool useSetting, | |
2386 | const wxColour& back); | |
2387 | ||
2388 | /** | |
2389 | Set the set of characters making up whitespace for when moving or selecting by | |
2390 | word. | |
2391 | Should be called after SetWordChars. | |
2392 | */ | |
2393 | void SetWhitespaceChars(const wxString& characters); | |
2394 | ||
2395 | /** | |
2396 | Set the foreground colour of all whitespace and whether to use this setting. | |
2397 | */ | |
2398 | void SetWhitespaceForeground(bool useSetting, | |
2399 | const wxColour& fore); | |
2400 | ||
2401 | /** | |
2402 | Set the set of characters making up words for when moving or selecting by word. | |
2403 | First sets deaults like SetCharsDefault. | |
2404 | */ | |
2405 | void SetWordChars(const wxString& characters); | |
2406 | ||
2407 | /** | |
2408 | Sets whether text is word wrapped. | |
2409 | */ | |
2410 | void SetWrapMode(int mode); | |
2411 | ||
2412 | /** | |
2413 | Set the start indent for wrapped lines. | |
2414 | */ | |
2415 | void SetWrapStartIndent(int indent); | |
2416 | ||
2417 | /** | |
2418 | Set the display mode of visual flags for wrapped lines. | |
2419 | */ | |
2420 | void SetWrapVisualFlags(int wrapVisualFlags); | |
2421 | ||
2422 | /** | |
2423 | Set the location of visual flags for wrapped lines. | |
2424 | */ | |
2425 | void SetWrapVisualFlagsLocation(int wrapVisualFlagsLocation); | |
2426 | ||
2427 | /** | |
2428 | Set the way the caret is kept visible when going sideway. | |
2429 | The exclusion zone is given in pixels. | |
2430 | */ | |
2431 | void SetXCaretPolicy(int caretPolicy, int caretSlop); | |
2432 | ||
2433 | /** | |
2434 | Get and Set the xOffset (ie, horizonal scroll position). | |
2435 | */ | |
2436 | void SetXOffset(int newOffset); | |
2437 | ||
2438 | /** | |
2439 | Set the way the line the caret is on is kept visible. | |
2440 | The exclusion zone is given in lines. | |
2441 | */ | |
2442 | void SetYCaretPolicy(int caretPolicy, int caretSlop); | |
2443 | ||
2444 | /** | |
2445 | Set the zoom level. This number of points is added to the size of all fonts. | |
2446 | It may be positive to magnify or negative to reduce. | |
2447 | */ | |
2448 | void SetZoom(int zoom); | |
2449 | ||
2450 | /** | |
2451 | Make a range of lines visible. | |
2452 | */ | |
2453 | void ShowLines(int lineStart, int lineEnd); | |
2454 | ||
2455 | /** | |
2456 | Start notifying the container of all key presses and commands. | |
2457 | */ | |
2458 | void StartRecord(); | |
2459 | ||
2460 | /** | |
2461 | Set the current styling position to pos and the styling mask to mask. | |
2462 | The styling mask can be used to protect some bits in each styling byte from | |
2463 | modification. | |
2464 | */ | |
2465 | void StartStyling(int pos, int mask); | |
2466 | ||
2467 | /** | |
2468 | Stop notifying the container of all key presses and commands. | |
2469 | */ | |
2470 | void StopRecord(); | |
2471 | ||
2472 | /** | |
2473 | Move caret to bottom of page, or one page down if already at bottom of page. | |
2474 | */ | |
2475 | void StutteredPageDown(); | |
2476 | ||
2477 | /** | |
2478 | Move caret to bottom of page, or one page down if already at bottom of page, | |
2479 | extending selection to new caret position. | |
2480 | */ | |
2481 | void StutteredPageDownExtend(); | |
2482 | ||
2483 | /** | |
2484 | Move caret to top of page, or one page up if already at top of page. | |
2485 | */ | |
2486 | void StutteredPageUp(); | |
2487 | ||
2488 | /** | |
2489 | Move caret to top of page, or one page up if already at top of page, extending | |
2490 | selection to new caret position. | |
2491 | */ | |
2492 | void StutteredPageUpExtend(); | |
2493 | ||
2494 | /** | |
2495 | Clear all the styles and make equivalent to the global default style. | |
2496 | */ | |
2497 | void StyleClearAll(); | |
2498 | ||
2499 | /** | |
2500 | Reset the default style to its state at startup | |
2501 | */ | |
2502 | void StyleResetDefault(); | |
2503 | ||
2504 | /** | |
2505 | Set the background colour of a style. | |
2506 | */ | |
2507 | void StyleSetBackground(int style, const wxColour& back); | |
2508 | ||
2509 | /** | |
2510 | Set a style to be bold or not. | |
2511 | */ | |
2512 | void StyleSetBold(int style, bool bold); | |
2513 | ||
2514 | /** | |
2515 | Set a style to be mixed case, or to force upper or lower case. | |
2516 | */ | |
2517 | void StyleSetCase(int style, int caseForce); | |
2518 | ||
2519 | /** | |
2520 | Set a style to be changeable or not (read only). | |
2521 | Experimental feature, currently buggy. | |
2522 | */ | |
2523 | void StyleSetChangeable(int style, bool changeable); | |
2524 | ||
2525 | /** | |
2526 | Set the character set of the font in a style. Converts the Scintilla | |
2527 | character set values to a wxFontEncoding. | |
2528 | */ | |
2529 | void StyleSetCharacterSet(int style, int characterSet); | |
2530 | ||
2531 | /** | |
2532 | Set a style to have its end of line filled or not. | |
2533 | */ | |
2534 | void StyleSetEOLFilled(int style, bool filled); | |
2535 | ||
2536 | /** | |
2537 | Set the font of a style. | |
2538 | */ | |
2539 | void StyleSetFaceName(int style, const wxString& fontName); | |
2540 | ||
2541 | /** | |
2542 | Set style size, face, bold, italic, and underline attributes from | |
2543 | a wxFont's attributes. | |
2544 | */ | |
2545 | void StyleSetFont(int styleNum, wxFont& font); | |
2546 | ||
2547 | /** | |
2548 | Set all font style attributes at once. | |
2549 | */ | |
2550 | void StyleSetFontAttr(int styleNum, int size, | |
2551 | const wxString& faceName, | |
2552 | bool bold, | |
2553 | bool italic, | |
2554 | bool underline, | |
2555 | wxFontEncoding encoding = wxFONTENCODING_DEFAULT); | |
2556 | ||
2557 | /** | |
2558 | Set the font encoding to be used by a style. | |
2559 | */ | |
2560 | void StyleSetFontEncoding(int style, wxFontEncoding encoding); | |
2561 | ||
2562 | /** | |
2563 | Set the foreground colour of a style. | |
2564 | */ | |
2565 | void StyleSetForeground(int style, const wxColour& fore); | |
2566 | ||
2567 | /** | |
2568 | Set a style to be a hotspot or not. | |
2569 | */ | |
2570 | void StyleSetHotSpot(int style, bool hotspot); | |
2571 | ||
2572 | /** | |
2573 | Set a style to be italic or not. | |
2574 | */ | |
2575 | void StyleSetItalic(int style, bool italic); | |
2576 | ||
2577 | /** | |
2578 | Set the size of characters of a style. | |
2579 | */ | |
2580 | void StyleSetSize(int style, int sizePoints); | |
2581 | ||
2582 | /** | |
2583 | Extract style settings from a spec-string which is composed of one or | |
2584 | more of the following comma separated elements: | |
2585 | bold turns on bold | |
2586 | italic turns on italics | |
2587 | fore:[name or \#RRGGBB] sets the foreground colour | |
2588 | back:[name or \#RRGGBB] sets the background colour | |
2589 | face:[facename] sets the font face name to use | |
2590 | size:[num] sets the font size in points | |
2591 | eol turns on eol filling | |
2592 | underline turns on underlining | |
2593 | */ | |
2594 | void StyleSetSpec(int styleNum, const wxString& spec); | |
2595 | ||
2596 | /** | |
2597 | Set a style to be underlined or not. | |
2598 | */ | |
2599 | void StyleSetUnderline(int style, bool underline); | |
2600 | ||
2601 | /** | |
2602 | Set a style to be visible or not. | |
2603 | */ | |
2604 | void StyleSetVisible(int style, bool visible); | |
2605 | ||
2606 | /** | |
2607 | If selection is empty or all on one line replace the selection with a tab | |
2608 | character. | |
2609 | If more than one line selected, indent the lines. | |
2610 | */ | |
2611 | void Tab(); | |
2612 | ||
2613 | /** | |
2614 | Make the target range start and end be the same as the selection range start | |
2615 | and end. | |
2616 | */ | |
2617 | void TargetFromSelection(); | |
2618 | ||
2619 | /** | |
2620 | Retrieve the height of a particular line of text in pixels. | |
2621 | */ | |
2622 | int TextHeight(int line); | |
2623 | ||
2624 | /** | |
2625 | Measure the pixel width of some text in a particular style. | |
2626 | NUL terminated text argument. | |
2627 | Does not handle tab or control characters. | |
2628 | */ | |
2629 | int TextWidth(int style, const wxString& text); | |
2630 | ||
2631 | /** | |
2632 | Switch between sticky and non-sticky: meant to be bound to a key. | |
2633 | */ | |
2634 | void ToggleCaretSticky(); | |
2635 | ||
2636 | /** | |
2637 | Switch a header line between expanded and contracted. | |
2638 | */ | |
2639 | void ToggleFold(int line); | |
2640 | ||
2641 | /** | |
2642 | Undo one action in the undo history. | |
2643 | */ | |
2644 | virtual void Undo(); | |
2645 | ||
2646 | /** | |
2647 | Transform the selection to upper case. | |
2648 | */ | |
2649 | void UpperCase(); | |
2650 | ||
2651 | /** | |
2652 | Set whether a pop up menu is displayed automatically when the user presses | |
2653 | the wrong mouse button. | |
2654 | */ | |
2655 | void UsePopUp(bool allowPopUp); | |
2656 | ||
2657 | /** | |
2658 | Display a list of strings and send notification when user chooses one. | |
2659 | */ | |
2660 | void UserListShow(int listType, const wxString& itemList); | |
2661 | ||
2662 | /** | |
2663 | Move caret to before first visible character on line. | |
2664 | If already there move to first character on line. | |
2665 | */ | |
2666 | void VCHome(); | |
2667 | ||
2668 | /** | |
2669 | Like VCHome but extending selection to new caret position. | |
2670 | */ | |
2671 | void VCHomeExtend(); | |
2672 | ||
2673 | /** | |
2674 | Move caret to before first visible character on line. | |
2675 | If already there move to first character on line. | |
2676 | In either case, extend rectangular selection to new caret position. | |
2677 | */ | |
2678 | void VCHomeRectExtend(); | |
2679 | ||
2680 | /** | |
2681 | ||
2682 | */ | |
2683 | void VCHomeWrap(); | |
2684 | ||
2685 | /** | |
2686 | ||
2687 | */ | |
2688 | void VCHomeWrapExtend(); | |
2689 | ||
2690 | /** | |
2691 | Find the display line of a document line taking hidden lines into account. | |
2692 | */ | |
2693 | int VisibleFromDocLine(int line); | |
2694 | ||
2695 | /** | |
2696 | Get position of end of word. | |
2697 | */ | |
2698 | int WordEndPosition(int pos, bool onlyWordCharacters); | |
2699 | ||
2700 | /** | |
2701 | Move caret left one word. | |
2702 | */ | |
2703 | void WordLeft(); | |
2704 | ||
2705 | /** | |
2706 | Move caret left one word, position cursor at end of word. | |
2707 | */ | |
2708 | void WordLeftEnd(); | |
2709 | ||
2710 | /** | |
2711 | Move caret left one word, position cursor at end of word, extending selection | |
2712 | to new caret position. | |
2713 | */ | |
2714 | void WordLeftEndExtend(); | |
2715 | ||
2716 | /** | |
2717 | Move caret left one word extending selection to new caret position. | |
2718 | */ | |
2719 | void WordLeftExtend(); | |
2720 | ||
2721 | /** | |
2722 | Move to the previous change in capitalisation. | |
2723 | */ | |
2724 | void WordPartLeft(); | |
2725 | ||
2726 | /** | |
2727 | Move to the previous change in capitalisation extending selection | |
2728 | to new caret position. | |
2729 | */ | |
2730 | void WordPartLeftExtend(); | |
2731 | ||
2732 | /** | |
2733 | Move to the change next in capitalisation. | |
2734 | */ | |
2735 | void WordPartRight(); | |
2736 | ||
2737 | /** | |
2738 | Move to the next change in capitalisation extending selection | |
2739 | to new caret position. | |
2740 | */ | |
2741 | void WordPartRightExtend(); | |
2742 | ||
2743 | /** | |
2744 | Move caret right one word. | |
2745 | */ | |
2746 | void WordRight(); | |
2747 | ||
2748 | /** | |
2749 | Move caret right one word, position cursor at end of word. | |
2750 | */ | |
2751 | void WordRightEnd(); | |
2752 | ||
2753 | /** | |
2754 | Move caret right one word, position cursor at end of word, extending selection | |
2755 | to new caret position. | |
2756 | */ | |
2757 | void WordRightEndExtend(); | |
2758 | ||
2759 | /** | |
2760 | Move caret right one word extending selection to new caret position. | |
2761 | */ | |
2762 | void WordRightExtend(); | |
2763 | ||
2764 | /** | |
2765 | Get position of start of word. | |
2766 | */ | |
2767 | int WordStartPosition(int pos, bool onlyWordCharacters); | |
2768 | ||
2769 | /** | |
2770 | The number of display lines needed to wrap a document line | |
2771 | */ | |
2772 | int WrapCount(int line); | |
2773 | ||
2774 | /** | |
2775 | Magnify the displayed text by increasing the sizes by 1 point. | |
2776 | */ | |
2777 | void ZoomIn(); | |
2778 | ||
2779 | /** | |
2780 | Make the displayed text smaller by decreasing the sizes by 1 point. | |
2781 | */ | |
2782 | void ZoomOut(); | |
2783 | }; | |
2784 |