#lang scribble/doc @(require scribble/manual scribble/extract) @(require (for-label framework)) @(require (for-label scheme/gui)) @title{Text} @definterface[text:basic<%> (editor:basic<%> text%)]{ Classes matching this interface are expected to implement the basic functionality needed by the framework. @defmethod*[(((highlight-range (start exact-integer) (end exact-integer) (color (instance color%)) (bitmap (union |#f| (instance bitmap%)) |#f|) (caret-space boolean |#f|) (priority (union (quote high) (quote low)) (quote low))) (-> void)))]{ This function highlights a region of text in the buffer. The range between @scheme[start] and @scheme[end] will be highlighted with the color in color, and @scheme[bitmap] will be painted over the range of text in black and white. If @scheme[bitmap] is @scheme[#f], the range will be inverted, using the platform specific xor. This method is not recommended, because the selection is also displayed using xor. If @scheme[caret-space?] is not @scheme[#f], the left edge of the range will be one pixel short, to leave space for the caret. The caret does not interfere with the right hand side of the range. Note that under X windows the caret is drawn with XOR, which means almost anything can happen. So if the caret is in the middle of the range it may be hard to see, or if it is on the left of the range and @scheme[caret-space?] is @scheme[#f] it may also be hard to see. The @scheme[priority] argument indicates the relative priority for drawing overlapping regions. If two regions overlap and have different priorities, the region with @scheme['high] priority will be drawn second and only it will be visible in the overlapping region. This method returns a thunk, which, when invoked, will turn off the highlighting from this range. See also @method[text:basic<%> unhighlight-range]. } @defmethod*[(((unhighlight-range (start exact-integer) (end exact-integer) (color (instance color%)) (bitmap (union |#f| (instance bitmap%)) |#f|) (caret-space boolean |#f|)) void))]{ This method removes the highlight from a region of text in the buffer. The region must match up to a region specified from an earlier call to @method[text:basic<%> highlight-range]. } @defmethod*[(((get-highlighted-ranges) (listof range)))]{ Returns a list of (opaque) values representing the active ranges in the editor. } @defmethod*[(((get-styles-fixed) boolean))]{ If the result of this function is @scheme[#t], the styles in this @scheme[text:basic<%>] will be fixed. This means that any text inserted to this editor has its style set to this editor's @scheme[style-list%]'s @scheme["Standard"] style. See also @method[text:basic<%> set-styles-fixed]. } @defmethod*[(((get-fixed-style) (is-a?/c style<%>)))]{ Returns the style used by @method[text:basic<%> set-styles-fixed]when setting the styles. } @defmethod*[(((set-styles-fixed (fixed? boolean)) void))]{ Sets the styles fixed parameter of this @scheme[text%]. See also @method[text:basic<%> get-styles-fixed] and @method[text:basic<%> get-fixed-style]. } @defmethod*[(((move/copy-to-edit (dest-text (instance text%)) (start exact-integer) (end exact-integer) (dest-pos exact-integer)) void))]{ This moves or copies text and snips to another edit. Moves or copies from the edit starting at @scheme[start] and ending at @scheme[end]. It puts the copied text and snips in @scheme[dest-text] starting at location @scheme[dest-pos]. If a snip refused to be moved, it will be copied, otherwise it will be moved. A snip may refuse to be moved by returning @scheme[#f] from @method[snip% release-from-owner]. } @defmethod*[(((initial-autowrap-bitmap) (union |#f| (instance bitmap%))))]{ The result of this method is used as the initial autowrap bitmap. Override this method to change the initial @scheme[bitmap%]. See also @method[text% set-autowrap-bitmap] Defaultly returns the result of @scheme[icon:get-autowrap-bitmap] } @defmethod*[(((get-port-name) symbol?))]{ The result of this method is a symbol that identifies this editor and that is used as the port-name of a port that is read from this editor if this editor is used in DrScheme. See also @method[text:basic<%> port-name-matches?]. } @defmethod*[(((port-name-matches? (id (or/c path? symbol?))) boolean))]{ Indicates if @scheme[id] matches the port name of this file. If the file is saved, the port name matches when the save file is the path as @scheme[id]. If the file has not been saved, the port name matches if the symbol is the same as the result of @method[text:basic<%> port-name-matches?]. } } @defmixin[text:basic-mixin (editor:basic<%> text%) (text:basic<%>)]{ This mixin implements the basic functionality needed for @scheme[text%] objects in the framework. The class that this mixin produces uses the same initialization arguments as it's input. @defmethod*[#:mode override (((on-paint (before? any/c) (dc (is-a?/c dc<%>)) (left real?) (top real?) (right real?) (bottom real?) (dx real?) (dy real?) (draw-caret (one-of/c (quote no-caret) (quote show-inactive-caret) (quote show-caret)))) void))]{ Draws the rectangles installed by @method[text:basic<%> highlight-range]. } @defmethod*[#:mode augment (((on-insert (start exact-int) (end exact-int)) void))]{ See @method[text:basic<%> set-styles-fixed]. } @defmethod*[#:mode augment (((after-insert (start nonnegative-exact-integer?) (len nonnegative-exact-integer?)) void))]{ See @method[text:basic<%> set-styles-fixed]. } @defmethod*[#:mode override (((put-file (directory path) (default-name path)) void))]{ Like @method[editor<%> put-file] but uses @scheme[finder:put-file] instead of @scheme[put-file]. } } @definterface[text:foreground-color<%> (text:basic<%> editor:standard-style-list<%>)]{ } @defmixin[text:foreground-color-mixin (text:basic<%> editor:standard-style-list<%>) (text:foreground-color<%>)]{ This mixin changes the default text style to have the foreground color controlled by @scheme[editor:set-default-font-color]. @defmethod*[#:mode override (((default-style-name) string))]{ Returns the result of @scheme[editor:get-default-color-style-name]. } @defmethod*[#:mode override (((get-fixed-style) (is-a?/c style<%>)))]{ Returns the style named by @scheme[editor:get-default-color-style-name]. } } @definterface[text:hide-caret/selection<%> (text:basic<%>)]{ This class hides the caret, except when the selection is active. Instances of this class are useful for editors that used for displaying purposes, but still allow users to copy their text. } @defmixin[text:hide-caret/selection-mixin (text:basic<%>) (text:hide-caret/selection<%>)]{ @defmethod*[#:mode augment (((after-set-position) void))]{ Calls @method[text% hide-caret] to hide the caret when there is only a caret and no selection. } } @definterface[text:nbsp->space<%> (text%)]{ Classes that implement this interface silently change non-breaking spaces, ie the character @scheme[(integer->char 160)], to regular spaces when inserted into the editor. } @defmixin[text:nbsp->space-mixin (text%) (text:nbsp->space<%>)]{ @defmethod*[#:mode augment (((on-insert (start exact-int) (end exact-int)) void))]{ Starts an edit-sequence by calling @method[editor<%> begin-edit-sequence]. } @defmethod*[#:mode augment (((after-insert (start nonnegative-exact-integer?) (len nonnegative-exact-integer?)) void))]{ Replaces all non-breaking space characters @scheme[(integer->char 160)] by @scheme[#\space] characters. Ends the edit sequence (by calling @method[editor<%> end-edit-sequence]) started in @method[text:nbsp->space-mixin on-insert]. } } @definterface[text:searching<%> (editor:keymap<%> text:basic<%>)]{ Any object matching this interface can be searched. } @defmixin[text:searching-mixin (editor:keymap<%> text:basic<%>) (text:searching<%>)]{ This @scheme[text%] can be searched. The result of this mixin uses the same initialization arguments as the mixin's argument. @defmethod*[#:mode override (((get-keymaps) (list-of (instance keymap%))))]{ This returns a list containing the super-class's keymaps, plus the result of @scheme[keymap:get-search] } } @definterface[text:return<%> (text%)]{ Objects supporting this interface were created by @scheme[text:return-mixin]. } @defmixin[text:return-mixin (text%) (text:return<%>)]{ Use this buffer to perform some special action when return is typed. @defconstructor[((return (-> boolean)))]{ } @defmethod*[#:mode override (((on-local-char (event (is-a?/c key-event%))) void))]{ If @scheme[key] is either return or newline, only invoke the @scheme[return] thunk (initialization argument) and do nothing else. } } @definterface[text:wide-snip<%> (text:basic<%>)]{ @defmethod*[(((add-wide-snip (snip (instance snip%))) void))]{ Registers a snip in this editor to be resized when its viewing area changes. Ensures the snip is as wide as the viewing area. This method should only be called by @method[canvas:wide-snip<%> add-tall-snip]. } @defmethod*[(((add-tall-snip (snip (is-a?/c snip%))) void))]{ Registers a snip in this editor. It is resized when the viewing area of the editor changes. This method should only be called by @method[canvas:wide-snip<%> add-tall-snip]. } } @defmixin[text:wide-snip-mixin (text:basic<%>) (text:wide-snip<%>)]{ } @definterface[text:delegate<%> (text:basic<%>)]{ Implementations of this interface copy all of the changes to this editor to the result of @method[text:delegate<%> get-delegate] except instead of regular string and tab snips, instead instances of @scheme[text:1-pixel-string-snip%] and @scheme[text:1-pixel-tab-snip%] are created. The contents of the two editor are kept in sync, as modifications to this object happen. @defmethod*[(((get-delegate) (union |#f| (instanceof text%))))]{ The result of this method is the @scheme[text%] object that the contents of this editor are being delegated to, or @scheme[#f], if there is none. } @defmethod*[(((set-delegate (delegate (union |#f| (instanceof text%)))) void))]{ This method sets the current delegate. When it is set, all of the snips are copied from this object to @scheme[delegate]. Additionally, if this object implements @scheme[scheme:text<%>] the tab settings of @scheme[delegate] are updated to match this objects. } } @defclass[text:1-pixel-string-snip% string-snip% ()]{ This class re-uses the implementation of @scheme[string-snip%] to implement a string snip that just draws a single pixel for each character in the string. See also @scheme[text:1-pixel-tab-snip%] for a similar extension to the @scheme[tab-snip%]class. This snip is used in conjunction with the @scheme[frame:delegate<%>] and @scheme[text:delegate<%>] interfaces. @defmethod*[#:mode override (((split (position exact) (first (box (instanceof snip%))) (second (box (instanceof snip%)))) void))]{ Fills the boxes with instance of @scheme[text:1-pixel-string-snip%]s. } @defmethod*[#:mode override (((copy) (instanceof snip%)))]{ Creates and returns an instance of @scheme[text:1-pixel-string-snip%]. } @defmethod*[#:mode override (((get-extent (dc (instanceof dc<%>)) (x real) (y real) (w (box (union non-negative-real-number |#f|)) |#f|) (h (box (union non-negative-real-number |#f|)) |#f|) (descent (box (union non-negative-real-number |#f|)) |#f|) (space (box (union non-negative-real-number |#f|)) |#f|) (lspace (box (union non-negative-real-number |#f|)) |#f|) (rspace (box (union non-negative-real-number |#f|)) |#f|)) void))]{ Sets the descent, space, lspace, and rspace to zero. Sets the height to 1. Sets the width to the number of characters in the string. } @defmethod*[#:mode override (((insert (s string) (len exact) (pos exact 0)) void))]{ } @defmethod*[#:mode override (((draw (dc (instanceof dc<%>)) (x real) (y real) (left real) (top real) (right real) (bottom real) (dx real) (dy real) (draw-caret (union (quote no-caret) (quote show-inactive-caret) (quote show-caret)))) void))]{ Draws black pixels for non-whitespace characters and draws nothing for whitespace characters. } } @defclass[text:1-pixel-tab-snip% tab-snip% ()]{ This class re-uses the implementation of @scheme[tab-snip%] to implement a string snip that is always one pixel high. See also @scheme[text:1-pixel-string-snip%] for a similar extension to the @scheme[string-snip%]class. This snip is used in conjunction with the @scheme[frame:delegate<%>] and @scheme[text:delegate<%>] interfaces. @defmethod*[#:mode override (((split (position exact) (first (box (instanceof snip%))) (second (box (instanceof snip%)))) void))]{ Fills the boxes with instance of @scheme[text:1-pixel-tab-snip%]s. } @defmethod*[#:mode override (((copy) (instanceof snip%)))]{ Creates and returns an instance of @scheme[text:1-pixel-tab-snip%]. } @defmethod*[#:mode override (((get-extent (dc (instanceof dc<%>)) (x real) (y real) (w (box (union non-negative-real-number |#f|)) |#f|) (h (box (union non-negative-real-number |#f|)) |#f|) (descent (box (union non-negative-real-number |#f|)) |#f|) (space (box (union non-negative-real-number |#f|)) |#f|) (lspace (box (union non-negative-real-number |#f|)) |#f|) (rspace (box (union non-negative-real-number |#f|)) |#f|)) void))]{ Sets the descent, space, lspace, and rspace to zero. Sets the height to 1. Sets the width to the width of tabs as returned in the @scheme[tab-width] parameter of the @method[text% get-tabs] method. } @defmethod*[#:mode override (((draw (dc (instanceof dc<%>)) (x real) (y real) (left real) (top real) (right real) (bottom real) (dx real) (dy real) (draw-caret (union (quote no-caret) (quote show-inactive-caret) (quote show-caret)))) void))]{ Draws nothing. } } @defmixin[text:delegate-mixin (text:basic<%>) (text:delegate<%>)]{ This mixin provides an implementation of the @scheme[text:delegate<%>] interface. @defmethod*[#:mode override (((highlight-range (start exact-integer) (end exact-integer) (color (instance color%)) (bitmap (union |#f| (instance bitmap%))) (caret-space boolean |#f|) (priority (union (quote high) (quote low)) (quote low))) (-> void)))]{ In addition to calling the super method, @method[text:basic<%> highlight-range], this method forwards the highlighting to the delegatee. } @defmethod*[#:mode override (((unhighlight-range (start exact-integer) (end exact-integer) (color (instance color%)) (bitmap (union |#f| (instance bitmap%)) |#f|) (caret-space boolean |#f|)) void))]{ This method propagates the call to the delegate. } @defmethod*[#:mode override (((on-paint (before? any/c) (dc (is-a?/c dc<%>)) (left real?) (top real?) (right real?) (bottom real?) (dx real?) (dy real?) (draw-caret (one-of/c (quote no-caret) (quote show-inactive-caret) (quote show-caret)))) void))]{ Draws a blue region in the delegatee editor that shows where the visible region of the delegate editor is. } @defmethod*[#:mode augment (((on-edit-sequence) void))]{ starts an edit sequence in the delegate. } @defmethod*[#:mode augment (((after-edit-sequence) void))]{ ends an edit sequence in the delegate. } @defmethod*[#:mode override (((resized (snip (is-a?/c snip%)) (redraw-now? boolean)) void))]{ Sends a message to the delegate to update the size of the copied snip, if there is one. } @defmethod*[#:mode augment (((after-insert (start number) (len number)) void))]{ forwards the change to the delegate } @defmethod*[#:mode augment (((after-delete (start number) (len number)) void))]{ forwards the change to the delegate. } @defmethod*[#:mode augment (((after-change-style (start number) (len number)) void))]{ forwards the changed style to the delegate. } @defmethod*[#:mode augment (((on-load-file (filename string) (format symbol?)) void))]{ remembers the filename, for use in @method[text:delegate-mixin after-load-file]. } @defmethod*[#:mode augment (((after-load-file (success? boolean)) void))]{ updates the delegate with the new contents of the text. } } @definterface[text:info<%> (text:basic<%>)]{ Objects supporting this interface are expected to send information about themselves to the frame that is displaying them. } @defmixin[text:info-mixin (editor:keymap<%> text:basic<%>) (text:info<%>)]{ This mixin adds support for supplying information to objects created with @scheme[frame:info-mixin]. When this @scheme[editor:basic<%>] is displayed in a frame, that frame must have been created with @scheme[frame:info-mixin]. @defmethod*[#:mode override (((set-anchor (on? any/c)) void))]{ Calls the @method[frame:text-info<%> anchor-status-changed] method of the frame that is viewing this object. It uses @method[editor<%> get-canvas] to get the canvas for this frame, and uses that canvas's @scheme[top-level-window<%>] as the frame. } @defmethod*[#:mode override (((set-overwrite-mode (on? any/c)) void))]{ Calls the @method[frame:text-info<%> overwrite-status-changed]method of the frame that is viewing this object. It uses @method[editor<%> get-canvas] to get the canvas for this frame, and uses that canvas's @scheme[top-level-window<%>] as the frame. } @defmethod*[#:mode augment (((after-set-position) void))]{ Calls the @method[frame:text-info<%> editor-position-changed] method of the frame that is viewing this object. It uses @method[editor<%> get-canvas] to get the canvas for this frame, and uses that canvas's @scheme[top-level-window<%>] as the frame. } @defmethod*[#:mode augment (((after-insert (start nonnegative-exact-integer?) (len nonnegative-exact-integer?)) void))]{ Calls the @method[frame:text-info<%> editor-position-changed] method of the frame that is viewing this object. It uses @method[editor<%> get-canvas] to get the canvas for this frame, and uses that canvas's @scheme[top-level-window<%>] as the frame. } @defmethod*[#:mode augment (((after-delete (start nonnegative-exact-integer?) (len nonnegative-exact-integer?)) void))]{ Calls the @method[frame:text-info<%> editor-position-changed] method of the frame that is viewing this object. It uses @method[editor<%> get-canvas] to get the canvas for this frame, and uses that canvas's @scheme[top-level-window<%>] as the frame. } } @definterface[text:clever-file-format<%> (text%)]{ Objects supporting this interface are expected to support a clever file format when saving. } @defmixin[text:clever-file-format-mixin (text%) (text:clever-file-format<%>)]{ The result of this mixin uses the same initialization arguments as the mixin's argument. When files are saved from this @scheme[text%], a check is made to see if there are any non-@scheme[string-snip%] objects in the @scheme[text%]. If so, it is saved using the file format @scheme['std]. (see @method[text% set-file-format] for more information. If not, the file format passed to @method[editor<%> save-file] is used. @defmethod*[#:mode augment (((on-save-file (filename path?) (format (one-of/c (quote guess) (quote standard) (quote text) (quote text-force-cr) (quote same) (quote copy)))) void))]{ If the method @method[text% get-file-format] returns @scheme['standard] and the text has only @scheme[string-snip%]s, the file format is set to @scheme['text]. If the method @method[text% get-file-format] returns @scheme['text] and the text has some non @scheme[string-snip%]s, the file format is set to @scheme['standard]. Depending on the user's preferences, the user may also be queried. Also, the changes to the file format only happen if the argument @scheme[file-format] is @scheme['copy] or @scheme['same]. } } @definterface[text:file<%> (editor:file<%> text:basic<%>)]{ Mixins that implement this interface lock themselves when the file they are editing is read only. @defmethod*[(((get-read-write?) boolean))]{ Indicates whether or not this editor is in read-write mode. } @defmethod*[(((while-unlocked (thunk (-> any/c))) any/c))]{ Unlocks the editor, calls the thunk, and then relocks the editor, all using a @scheme[dynamic-wind]. } } @defmixin[text:file-mixin (editor:file<%> text:basic<%>) (text:file<%>)]{ @defmethod*[#:mode augment (((can-insert? (start number) (len number)) boolean))]{ Returns false if the result of @method[text:file<%> get-read-write?] is true, otherwise returns the result of calling @scheme[inner]. } @defmethod*[#:mode augment (((can-delete? (start number) (len number)) boolean))]{ Returns false if the result of @method[text:file<%> get-read-write?] is true, otherwise returns the result of calling @scheme[inner]. } @defmethod*[#:mode augment (((after-save-file) void))]{ Checks if the newly saved file is write-only in the filesystem. If so, locks the editor with the @method[editor<%> lock] method. Otherwise unlocks the buffer For each canvas returned from @method[editor<%> get-canvases] it checks to see if the @scheme[canvas%]'s @method[area<%> get-top-level-window] matches the @scheme[frame:editor<%>] interface. If so, it calls @method[frame:editor-mixin set-label] with the last part of the filename (ie, the name of the file, not the directory the file is in). } @defmethod*[#:mode augment (((after-load-file) void))]{ Checks if the newly loaded file is write-only in the filesystem. If so, locks the editor with the @method[editor<%> lock] method. Otherwise unlocks the buffer For each canvas returned from @method[editor<%> get-canvases] it checks to see if the @scheme[canvas%]'s @method[area<%> get-top-level-window] matches the @scheme[frame:editor<%>] interface. If so, it calls @method[frame:editor-mixin set-label] with the last part of the filename (ie, the name of the file, not the directory the file is in). } } @definterface[text:ports<%> ()]{ Classes implementing this interface (via the associated mixin) support input and output ports that read from the editor. There are two input ports: the normal input port just reads from the editor's contents directly and the box input port inserts an editor snip into this text and uses input typed into the box as input into the port. They create three threads to mediate access to the input and output ports (one for each input port and one for all of the output ports). @defmethod*[(((delete/io (start exact-integer) (end exact-integer)) void))]{ Deletes the text between @scheme[start] and @scheme[end] without changing the behavior of the ports (otherwise, deleting the text would break internal invariants of the port). Both @scheme[start] and @scheme[end] must be less than @method[text:ports<%> get-insertion-point] (or else it is safe to delete them so you don't need this method). } @defmethod*[(((get-insertion-point) exact-integer))]{ Returns the position where characters put into the output port will appear. } @defmethod*[(((set-insertion-point (ip exact-integer)) void))]{ Sets the position where the output port will insert characters. See also @method[text:ports<%> get-insertion-point]. } @defmethod*[(((get-unread-start-point) exact-integer))]{ Returns the position where input will be taken into the input port (after the next time return is typed). } @defmethod*[(((set-unread-start-point (usp exact-integer)) void))]{ Sets the position where input will be taken into the input port (after the next time return is typed). See also @method[text:ports<%> get-unread-start-point]. } @defmethod*[(((set-allow-edits (allow-edits? boolean)) void))]{ Enables or disables editing in the buffer. Be sure to update the unread start point (via @method[text:ports<%> set-unread-start-point]) and the insertion point (via @method[text:ports<%> set-insertion-point]) after making changes to the buffer. } @defmethod*[(((get-allow-edits) boolean))]{ Indicates if editing is allowed in the buffer at this point. } @defmethod*[(((insert-between (str (union snip% string))) void))]{ Inserts some text between the unread start point and the insertion point (and updates them properly). To insert before the two points, see @method[text:ports<%> insert-before]. See also @method[text:ports<%> set-unread-start-point] and @method[text:ports<%> set-insertion-point]. } @defmethod*[(((insert-before (str (union snip% string))) void))]{ Inserts some text before the unread start point and updates it and the insertion point properly. To insert between the two points, see @method[text:ports<%> insert-between]. See also @method[text:ports<%> set-unread-start-point] and @method[text:ports<%> set-insertion-point]. } @defmethod*[(((submit-to-port? (key char)) boolean))]{ Augment this method to help control when characters should be submitted to the input port. Return @scheme[#t] or the result of calling @scheme[inner]. } @defmethod*[(((on-submit) void))]{ This method is called when text is sent into the input port. Does nothing. } @defmethod*[(((send-eof-to-in-port) void))]{ This method puts an eof into the input port. } @defmethod*[(((send-eof-to-box-in-port) void))]{ This method puts an eof into the box input port. } @defmethod*[(((reset-input-box) void))]{ This method removes the current input box from the editor (and all input in it is lost). } @defmethod*[(((clear-output-ports) void))]{ Flushes all of the data in all of the output ports that hasn't appeared in the editor yet. } @defmethod*[(((clear-input-port) void))]{ Flushes all of the data in the input port that hasn't yet been read. Reading will now block. } @defmethod*[(((clear-box-input-port) void))]{ Flushes all of the data in the box input port that hasn't yet been read. Reading will now block. } @defmethod*[(((get-out-style-delta) (or/c (is-a?/c style-delta%) string?)))]{ The result of this method is the style that is used to color text submitted to the result of @method[text:ports<%> get-out-port]. If the result is a string that is not mapped in the editor's style list, the style named @scheme["Standard"] is used and if that isn't mapped, the style named @scheme["Basic"] is used. This method is called during the initialization of the class. Defaultly returns @scheme["text:ports out"] which is mapped to a blue style in the style list returned by @scheme[editor:get-standard-style-list]. } @defmethod*[(((get-err-style-delta) (or/c (is-a?/c style-delta%) string?)))]{ The result of this method is the style that is used to color text submitted to the result of @method[text:ports<%> get-err-port]. If the result is a string that is not mapped in the editor's style list, the style named @scheme["Standard"] is used and if that isn't mapped, the style named @scheme["Basic"] is used. This method is called during the initialization of the class. Defaultly returns @scheme["text:ports err"] which is mapped to a red italic style in the style list returned by @scheme[editor:get-standard-style-list]. } @defmethod*[(((get-value-style-delta) (or/c (is-a?/c style-delta%) string?)))]{ The result of this method is the style (or the name of the style) that is used to color text submitted to the result of @method[text:ports<%> get-value-port]. If the result is a string that is not mapped in the editor's style list, the style named @scheme["Standard"] is used and if that isn't mapped, the style named @scheme["Basic"] is used. This method is called during the initialization of the class. Defaultly returns @scheme["text:ports value"] which is mapped to a blue style in the style list returned by @scheme[editor:get-standard-style-list]. } @defmethod*[(((get-in-port) input-port))]{ Returns the input port that data in this editor is sent to. } @defmethod*[(((get-in-box-port) input-port))]{ Returns the box input port that data in this editor is sent to. } @defmethod*[(((get-out-port) output-port))]{ Returns an output port that writes into this editor. The only difference between this port and the ports returned by @method[text:ports<%> get-err-port] and @method[text:ports<%> get-value-port] is the font style and color. } @defmethod*[(((get-err-port) output-port))]{ Returns an output port that writes into this editor. The only difference between this port and the ports returned by @method[text:ports<%> get-err-port] and @method[text:ports<%> get-out-port] is the font style and color. } @defmethod*[(((get-value-port) output-port))]{ Returns an output port that writes into this editor. The only difference between this port and the ports returned by @method[text:ports<%> get-err-port] and @method[text:ports<%> get-out-port] is the font style and color. } @defmethod*[(((after-io-insertion) void))]{ This method is called after an insertion due to IO occurs. } @defmethod*[(((get-box-input-editor-snip%) (subclass editor-snip%)))]{ The result of this method is used as the class of editor snips that is inserted by the box port in this editor. } @defmethod*[(((get-box-input-text%) (is-a?/c text:input-box)))]{ The result of this method is instantiated and placed inside the result of @method[text:ports<%> get-box-input-editor-snip%]. } } @defmixin[text:ports-mixin (text:wide-snip<%>) (text:ports<%>)]{ @defmethod*[#:mode augment (((can-insert? (start exact-integer) (len exact-integer)) boolean))]{ Returns the results of the @scheme[inner] call, unless @method[text:ports<%> get-allow-edits] returns @scheme[#f]. } @defmethod*[#:mode augment (((can-delete? (start exact-integer) (len exact-integer)) boolean))]{ Returns the results of the @scheme[inner] call, unless @method[text:ports<%> get-allow-edits] returns @scheme[#f]. } @defmethod*[#:mode override (((on-local-char (event (is-a?/c key-event%))) void))]{ Sends the data between the last position and the result of @method[text:ports<%> get-unread-start-point] to the input port, unless @method[text:ports<%> submit-to-port?] returns @scheme[#f]. Also calls @method[text:ports<%> on-submit]. } @defmethod*[#:mode augment (((on-display-size) void))]{ Adjusts the embedded editor-snip (used for reading input to the @method[text:ports<%> get-in-box-port]) to match the width of the editor. } } @definterface[text:input-box<%> (text%)]{ Classes that implement this interface are used as the editors for the box input port in @scheme[text:ports%]. } @defmixin[text:input-box-mixin (text%) (text:input-box<%>)]{ This mixin provides an implementation of @scheme[text:input-box<%>] for use with @scheme[text:ports<%>]. @defmethod*[#:mode override (((on-default-char (event key-event%)) void))]{ Notifies the @scheme[text:ports<%>] enclosing this editor that a new line of input has been provided. } } @definterface[text:autocomplete<%> (text%)]{ The mixin implementing this interface provides an unintrusive autocompletion menu when a particular (configurable) keystroke is pressed. @defmethod*[(((auto-complete) void))]{ Starts a completion. } @defmethod*[(((get-autocomplete-border-color) (or/c string? (is-a?/c color%))))]{ The border color for the autocomplete menu. Defaults to @scheme["black"]. } @defmethod*[(((get-autocomplete-background-color) (or/c string? (is-a?/c color%))))]{ The background color for the non-selected menu items. Defaults to @scheme["lavender"]. } @defmethod*[(((get-autocomplete-selected-color) (or/c string? (is-a?/c color%))))]{ The background color for the selected menu item. Defaults to @scheme[(make-object color% 204 153 255)]. } @defmethod*[(((completion-mode-key-event? (key-event key-event%)) boolean))]{ Returns true when the key event passed to it should initiate the completions menu. } @defmethod*[(((get-all-words) (listof string)))]{ Returns the list of the words that autocompletion should choose from. } @defmethod*[(((get-word-at (pos positive-exact-integer)) string))]{ Given an editor location, returns the prefix ending at that location that autocompletion should try to complete. } } @defmixin[text:autocomplete-mixin (text%) (text:autocomplete<%>)]{ @defmethod*[#:mode override (((on-paint) void))]{ Draws the completion menu (when it is popped up). } @defmethod*[#:mode override (((on-char) void))]{ Takes over the handling of key events when the completions menu is visible. Also, when the completions menu is not visible, it calls the @method[text:completion<%> completion-mode-key-event?] method to see if it should start completing. } @defmethod*[#:mode override (((on-event) void))]{ This method is overridden to allow mouse access of the completions menu. It only handles events when there is a menu open and the mouse is in the menu, in which case it makes the menu trace the mouse. The only time it does not call the super method is when the mouse is button is pushed. } } @defclass[text:basic% (text:basic-mixin (editor:basic-mixin text%)) ()]{} @defclass[text:hide-caret/selection% (text:hide-caret/selection-mixin text:basic%) ()]{} @defclass[text:nbsp->space% (text:nbsp->space-mixin text:basic%) ()]{} @defclass[text:delegate% (text:delegate-mixin text:basic%) ()]{} @defclass[text:wide-snip% (text:wide-snip-mixin text:basic%) ()]{} @defclass[text:standard-style-list% (editor:standard-style-list-mixin text:wide-snip%) ()]{} @defclass[text:input-box% (text:input-box-mixin text:standard-style-list%) ()]{} @defclass[text:keymap% (editor:keymap-mixin text:standard-style-list%) ()]{} @defclass[text:return% (text:return-mixin text:keymap%) ()]{} @defclass[text:autowrap% (editor:autowrap-mixin text:keymap%) ()]{} @defclass[text:file% (text:file-mixin (editor:file-mixin text:autowrap%)) ()]{} @defclass[text:clever-file-format% (text:clever-file-format-mixin text:file%) ()]{} @defclass[text:backup-autosave% (editor:backup-autosave-mixin text:clever-file-format%) ()]{} @defclass[text:searching% (text:searching-mixin text:backup-autosave%) ()]{} @defclass[text:info% (text:info-mixin (editor:info-mixin text:searching%)) ()]{} @(include-extracted (lib "main.ss" "framework") #rx"^text:")