2009-04-25 01:35:41 +02:00
## First line may be used for shbang
## This file defines the interface to Scintilla
## Copyright 2000-2003 by Neil Hodgson <neilh@scintilla.org>
## The License.txt file describes the conditions under which this software may be distributed.
## A line starting with ## is a pure comment and should be stripped by readers.
## A line starting with #! is for future shbang use
## A line starting with # followed by a space is a documentation comment and refers
## to the next feature definition.
2019-07-21 15:26:02 +02:00
## Each feature is defined by a line starting with fun, get, set, val, evt, enu, lex, or ali.
2009-04-25 01:35:41 +02:00
## cat -> start a category
## fun -> a function
## get -> a property get function
## set -> a property set function
## val -> definition of a constant
## evt -> an event
## enu -> associate an enumeration with a set of vals with a prefix
## lex -> associate a lexer with the lexical classes it produces
2019-07-21 15:26:02 +02:00
## ali -> add an alias for a val, commonly adding '_' to separate words
2009-04-25 01:35:41 +02:00
##
## All other feature names should be ignored. They may be defined in the future.
## A property may have a set function, a get function or both. Each will have
## "Get" or "Set" in their names and the corresponding name will have the obvious switch.
## A property may be subscripted, in which case the first parameter is the subscript.
## fun, get, and set features have a strict syntax:
## <featureType><ws><returnType><ws><name>[=<number](<param>,<param>)
## where <ws> stands for white space.
## param may be empty (null value) or is <paramType><ws><paramName>[=<value>]
## Additional white space is allowed between elements.
## The syntax for evt is <featureType><ws><returnType><ws><name>[=<number]([<param>[,<param>]*])
## Feature names that contain an underscore are defined by Windows, so in these
## cases, using the Windows definition is preferred where available.
## The feature numbers are stable so features will not be renumbered.
## Features may be removed but they will go through a period of deprecation
## before removal which is signalled by moving them into the Deprecated category.
##
## enu has the syntax enu<ws><enumeration>=<prefix>[<ws><prefix>]* where all the val
## features in this file starting with a given <prefix> are considered part of the
## enumeration.
##
## lex has the syntax lex<ws><name>=<lexerVal><ws><prefix>[<ws><prefix>]*
## where name is a reasonably capitalised (Python, XML) identifier or UI name,
## lexerVal is the val used to specify the lexer, and the list of prefixes is similar
## to enu. The name may not be the same as that used within the lexer so the lexerVal
## should be used to tie these entities together.
2019-07-21 15:26:02 +02:00
## Types: Never start with a capital letter
2009-04-25 01:35:41 +02:00
## void
## int
## bool -> integer, 1=true, 0=false
2019-07-21 15:26:02 +02:00
## position -> intptr_t position in a document
## line -> intptr_t line in a document
2022-01-05 00:07:50 +01:00
## colour -> colour integer containing red, green, and blue bytes with red as least-significant and blue as most.
## colouralpha -> colour integer containing red, green, blue, and alpha bytes with red as least-significant and alpha as most.
2009-04-25 01:35:41 +02:00
## string -> pointer to const character
## stringresult -> pointer to character, NULL-> return size of result
## cells -> pointer to array of cells, each cell containing a style byte and character byte
2019-07-21 15:26:02 +02:00
## pointer -> void* pointer that may point to a document, loader, internal text storage or similar
2009-04-25 01:35:41 +02:00
## textrange -> range of a min and a max position with an output string
2022-05-25 22:16:39 +02:00
## textrangefull -> range of a min and a max position with an output string - supports 64-bit
2009-04-25 01:35:41 +02:00
## findtext -> searchrange, text -> foundposition
2022-05-25 22:16:39 +02:00
## findtextfull -> searchrange, text -> foundposition
2009-04-25 01:35:41 +02:00
## keymod -> integer containing key in low half and modifiers in high half
## formatrange
2022-05-25 22:16:39 +02:00
## formatrangefull
2019-07-21 15:26:02 +02:00
## Enumeration types always start with a capital letter
2009-04-25 01:35:41 +02:00
## Types no longer used:
## findtextex -> searchrange
## charrange -> range of a min and a max position
## charrangeresult -> like charrange, but output param
## countedstring
## point -> x,y
## pointresult -> like point, but output param
## rectangle -> left,top,right,bottom
## Client code should ignore definitions containing types it does not understand, except
## for possibly #defining the constants
## Line numbers and positions start at 0.
## String arguments may contain NUL ('\0') characters where the calls provide a length
2015-06-07 23:19:26 +02:00
## argument and retrieve NUL characters. APIs marked as NUL-terminated also have a
## NUL appended but client code should calculate the size that will be returned rather
## than relying upon the NUL whenever possible. Allow for the extra NUL character when
## allocating buffers. The size to allocate for a stringresult (not including NUL) can be
## determined by calling with a NULL (0) pointer.
2009-04-25 01:35:41 +02:00
cat Basics
################################################
## For Scintilla.h
val INVALID_POSITION=-1
# Define start of Scintilla messages to be greater than all Windows edit (EM_*) messages
# as many EM_ messages can be used although that use is deprecated.
val SCI_START=2000
val SCI_OPTIONAL_START=3000
val SCI_LEXER_START=4000
# Add text to the document at current position.
2019-07-21 15:26:02 +02:00
fun void AddText=2001(position length, string text)
2009-04-25 01:35:41 +02:00
# Add array of cells to document.
2019-07-21 15:26:02 +02:00
fun void AddStyledText=2002(position length, cells c)
2009-04-25 01:35:41 +02:00
# Insert string at a position.
fun void InsertText=2003(position pos, string text)
2015-06-07 23:19:26 +02:00
# Change the text that is being inserted in response to SC_MOD_INSERTCHECK
2019-07-21 15:26:02 +02:00
fun void ChangeInsertion=2672(position length, string text)
2015-06-07 23:19:26 +02:00
2009-04-25 01:35:41 +02:00
# Delete all text in the document.
fun void ClearAll=2004(,)
2013-08-28 02:44:27 +02:00
# Delete a range of text in the document.
2019-07-21 15:26:02 +02:00
fun void DeleteRange=2645(position start, position lengthDelete)
2013-08-28 02:44:27 +02:00
2009-04-25 01:35:41 +02:00
# Set all style bytes to 0, remove all folding information.
fun void ClearDocumentStyle=2005(,)
2009-04-26 01:38:15 +02:00
# Returns the number of bytes in the document.
2019-07-21 15:26:02 +02:00
get position GetLength=2006(,)
2009-04-25 01:35:41 +02:00
# Returns the character byte at the position.
get int GetCharAt=2007(position pos,)
# Returns the position of the caret.
get position GetCurrentPos=2008(,)
# Returns the position of the opposite end of the selection to the caret.
get position GetAnchor=2009(,)
# Returns the style byte at the position.
get int GetStyleAt=2010(position pos,)
2022-04-13 13:10:12 +02:00
# Returns the unsigned style byte at the position.
get int GetStyleIndexAt=2038(position pos,)
2009-04-25 01:35:41 +02:00
# Redoes the next action on the undo history.
fun void Redo=2011(,)
# Choose between collecting actions into the undo
# history and discarding them.
set void SetUndoCollection=2012(bool collectUndo,)
# Select all the text in the document.
fun void SelectAll=2013(,)
# Remember the current position in the undo history as the position
# at which the document was saved.
fun void SetSavePoint=2014(,)
# Retrieve a buffer of cells.
# Returns the number of bytes in the buffer not including terminating NULs.
2019-07-21 15:26:02 +02:00
fun position GetStyledText=2015(, textrange tr)
2009-04-25 01:35:41 +02:00
2022-12-10 13:35:16 +01:00
# Retrieve a buffer of cells that can be past 2GB.
# Returns the number of bytes in the buffer not including terminating NULs.
fun position GetStyledTextFull=2778(, textrangefull tr)
2009-04-25 01:35:41 +02:00
# Are there any redoable actions in the undo history?
fun bool CanRedo=2016(,)
# Retrieve the line number at which a particular marker is located.
2021-02-21 05:53:09 +01:00
fun line MarkerLineFromHandle=2017(int markerHandle,)
2009-04-25 01:35:41 +02:00
# Delete a marker.
2019-05-04 20:14:48 +02:00
fun void MarkerDeleteHandle=2018(int markerHandle,)
2009-04-25 01:35:41 +02:00
2021-02-21 05:53:09 +01:00
# Retrieve marker handles of a line
fun int MarkerHandleFromLine=2732(line line, int which)
# Retrieve marker number of a marker handle
fun int MarkerNumberFromLine=2733(line line, int which)
2009-04-25 01:35:41 +02:00
# Is undo history being collected?
get bool GetUndoCollection=2019(,)
enu WhiteSpace=SCWS_
val SCWS_INVISIBLE=0
val SCWS_VISIBLEALWAYS=1
val SCWS_VISIBLEAFTERINDENT=2
2019-05-04 20:14:48 +02:00
val SCWS_VISIBLEONLYININDENT=3
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SCWS_VISIBLEALWAYS=VISIBLE_ALWAYS
ali SCWS_VISIBLEAFTERINDENT=VISIBLE_AFTER_INDENT
ali SCWS_VISIBLEONLYININDENT=VISIBLE_ONLY_IN_INDENT
2009-04-25 01:35:41 +02:00
# Are white space characters currently visible?
# Returns one of SCWS_* constants.
2019-07-21 15:26:02 +02:00
get WhiteSpace GetViewWS=2020(,)
2009-04-25 01:35:41 +02:00
# Make white space characters invisible, always visible or visible outside indentation.
2019-07-21 15:26:02 +02:00
set void SetViewWS=2021(WhiteSpace viewWS,)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
enu TabDrawMode=SCTD_
val SCTD_LONGARROW=0
val SCTD_STRIKEOUT=1
2019-07-21 15:26:02 +02:00
ali SCTD_LONGARROW=LONG_ARROW
ali SCTD_STRIKEOUT=STRIKE_OUT
2019-05-04 20:14:48 +02:00
# Retrieve the current tab draw mode.
# Returns one of SCTD_* constants.
2019-07-21 15:26:02 +02:00
get TabDrawMode GetTabDrawMode=2698(,)
2019-05-04 20:14:48 +02:00
# Set how tabs are drawn when visible.
2019-07-21 15:26:02 +02:00
set void SetTabDrawMode=2699(TabDrawMode tabDrawMode,)
2019-05-04 20:14:48 +02:00
2009-04-25 01:35:41 +02:00
# Find the position from a point within the window.
fun position PositionFromPoint=2022(int x, int y)
# Find the position from a point within the window but return
# INVALID_POSITION if not close to text.
fun position PositionFromPointClose=2023(int x, int y)
# Set caret to start of a line and ensure it is visible.
2019-07-21 15:26:02 +02:00
fun void GotoLine=2024(line line,)
2009-04-25 01:35:41 +02:00
# Set caret to a position and ensure it is visible.
2019-05-04 20:14:48 +02:00
fun void GotoPos=2025(position caret,)
2009-04-25 01:35:41 +02:00
# Set the selection anchor to a position. The anchor is the opposite
# end of the selection from the caret.
2019-05-04 20:14:48 +02:00
set void SetAnchor=2026(position anchor,)
2009-04-25 01:35:41 +02:00
# Retrieve the text of the line containing the caret.
# Returns the index of the caret on the line.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2019-07-21 15:26:02 +02:00
fun position GetCurLine=2027(position length, stringresult text)
2009-04-25 01:35:41 +02:00
# Retrieve the position of the last correctly styled character.
get position GetEndStyled=2028(,)
enu EndOfLine=SC_EOL_
val SC_EOL_CRLF=0
val SC_EOL_CR=1
val SC_EOL_LF=2
2019-07-21 15:26:02 +02:00
ali SC_EOL_CRLF=CR_LF
2009-04-25 01:35:41 +02:00
# Convert all line endings in the document to one mode.
2019-07-21 15:26:02 +02:00
fun void ConvertEOLs=2029(EndOfLine eolMode,)
2009-04-25 01:35:41 +02:00
# Retrieve the current end of line mode - one of CRLF, CR, or LF.
2019-07-21 15:26:02 +02:00
get EndOfLine GetEOLMode=2030(,)
2009-04-25 01:35:41 +02:00
# Set the current end of line mode.
2019-07-21 15:26:02 +02:00
set void SetEOLMode=2031(EndOfLine eolMode,)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# Set the current styling position to start.
# The unused parameter is no longer used and should be set to 0.
fun void StartStyling=2032(position start, int unused)
2009-04-25 01:35:41 +02:00
# Change style from current styling position for length characters to a style
# and move the current styling position to after this newly styled segment.
2019-07-21 15:26:02 +02:00
fun void SetStyling=2033(position length, int style)
2009-04-25 01:35:41 +02:00
# Is drawing done first into a buffer or direct to the screen?
get bool GetBufferedDraw=2034(,)
# If drawing is buffered then each line of text is drawn into a bitmap buffer
# before drawing it to the screen to avoid flicker.
set void SetBufferedDraw=2035(bool buffered,)
# Change the visible size of a tab to be a multiple of the width of a space character.
set void SetTabWidth=2036(int tabWidth,)
# Retrieve the visible size of a tab.
get int GetTabWidth=2121(,)
2021-02-21 05:53:09 +01:00
# Set the minimum visual width of a tab.
set void SetTabMinimumWidth=2724(int pixels,)
# Get the minimum visual width of a tab.
get int GetTabMinimumWidth=2725(,)
2015-06-07 23:19:26 +02:00
# Clear explicit tabstops on a line.
2019-07-21 15:26:02 +02:00
fun void ClearTabStops=2675(line line,)
2015-06-07 23:19:26 +02:00
# Add an explicit tab stop for a line.
2019-07-21 15:26:02 +02:00
fun void AddTabStop=2676(line line, int x)
2015-06-07 23:19:26 +02:00
# Find the next explicit tab stop position on a line after a position.
2019-07-21 15:26:02 +02:00
fun int GetNextTabStop=2677(line line, int x)
2015-06-07 23:19:26 +02:00
2009-04-25 01:35:41 +02:00
# The SC_CP_UTF8 value can be used to enter Unicode mode.
# This is the same value as CP_UTF8 in Windows
val SC_CP_UTF8=65001
# Set the code page used to interpret the bytes of the document as characters.
# The SC_CP_UTF8 value can be used to enter Unicode mode.
set void SetCodePage=2037(int codePage,)
2022-01-05 00:07:50 +01:00
# Set the locale for displaying text.
set void SetFontLocale=2760(, string localeName)
# Get the locale for displaying text.
get int GetFontLocale=2761(, stringresult localeName)
2015-06-07 23:19:26 +02:00
enu IMEInteraction=SC_IME_
val SC_IME_WINDOWED=0
val SC_IME_INLINE=1
2019-05-04 20:14:48 +02:00
# Is the IME displayed in a window or inline?
2019-07-21 15:26:02 +02:00
get IMEInteraction GetIMEInteraction=2678(,)
2015-06-07 23:19:26 +02:00
2021-02-21 05:53:09 +01:00
# Choose to display the IME in a window or inline.
2019-07-21 15:26:02 +02:00
set void SetIMEInteraction=2679(IMEInteraction imeInteraction,)
2015-06-07 23:19:26 +02:00
2021-02-21 05:53:09 +01:00
enu Alpha=SC_ALPHA_
val SC_ALPHA_TRANSPARENT=0
val SC_ALPHA_OPAQUE=255
val SC_ALPHA_NOALPHA=256
ali SC_ALPHA_NOALPHA=NO_ALPHA
enu CursorShape=SC_CURSOR
val SC_CURSORNORMAL=-1
val SC_CURSORARROW=2
val SC_CURSORWAIT=4
val SC_CURSORREVERSEARROW=7
ali SC_CURSORREVERSEARROW=REVERSE_ARROW
2009-04-25 01:35:41 +02:00
enu MarkerSymbol=SC_MARK_
val MARKER_MAX=31
val SC_MARK_CIRCLE=0
val SC_MARK_ROUNDRECT=1
val SC_MARK_ARROW=2
val SC_MARK_SMALLRECT=3
val SC_MARK_SHORTARROW=4
val SC_MARK_EMPTY=5
val SC_MARK_ARROWDOWN=6
val SC_MARK_MINUS=7
val SC_MARK_PLUS=8
# Shapes used for outlining column.
val SC_MARK_VLINE=9
val SC_MARK_LCORNER=10
val SC_MARK_TCORNER=11
val SC_MARK_BOXPLUS=12
val SC_MARK_BOXPLUSCONNECTED=13
val SC_MARK_BOXMINUS=14
val SC_MARK_BOXMINUSCONNECTED=15
val SC_MARK_LCORNERCURVE=16
val SC_MARK_TCORNERCURVE=17
val SC_MARK_CIRCLEPLUS=18
val SC_MARK_CIRCLEPLUSCONNECTED=19
val SC_MARK_CIRCLEMINUS=20
val SC_MARK_CIRCLEMINUSCONNECTED=21
2011-03-22 01:16:49 +01:00
# Invisible mark that only sets the line background colour.
2009-04-25 01:35:41 +02:00
val SC_MARK_BACKGROUND=22
val SC_MARK_DOTDOTDOT=23
val SC_MARK_ARROWS=24
val SC_MARK_PIXMAP=25
val SC_MARK_FULLRECT=26
val SC_MARK_LEFTRECT=27
2009-06-24 21:09:31 +02:00
val SC_MARK_AVAILABLE=28
2009-08-23 04:24:48 +02:00
val SC_MARK_UNDERLINE=29
2013-08-28 02:44:27 +02:00
val SC_MARK_RGBAIMAGE=30
2015-06-07 23:19:26 +02:00
val SC_MARK_BOOKMARK=31
2019-07-21 15:26:02 +02:00
val SC_MARK_VERTICALBOOKMARK=32
2022-08-27 09:35:52 +02:00
val SC_MARK_BAR=33
2009-04-25 01:35:41 +02:00
val SC_MARK_CHARACTER=10000
2019-07-21 15:26:02 +02:00
ali SC_MARK_ROUNDRECT=ROUND_RECT
ali SC_MARK_SMALLRECT=SMALL_RECT
ali SC_MARK_SHORTARROW=SHORT_ARROW
ali SC_MARK_ARROWDOWN=ARROW_DOWN
ali SC_MARK_VLINE=V_LINE
ali SC_MARK_LCORNER=L_CORNER
ali SC_MARK_TCORNER=T_CORNER
ali SC_MARK_BOXPLUS=BOX_PLUS
ali SC_MARK_BOXPLUSCONNECTED=BOX_PLUS_CONNECTED
ali SC_MARK_BOXMINUS=BOX_MINUS
ali SC_MARK_BOXMINUSCONNECTED=BOX_MINUS_CONNECTED
ali SC_MARK_LCORNERCURVE=L_CORNER_CURVE
ali SC_MARK_TCORNERCURVE=T_CORNER_CURVE
ali SC_MARK_CIRCLEPLUS=CIRCLE_PLUS
ali SC_MARK_CIRCLEPLUSCONNECTED=CIRCLE_PLUS_CONNECTED
ali SC_MARK_CIRCLEMINUS=CIRCLE_MINUS
ali SC_MARK_CIRCLEMINUSCONNECTED=CIRCLE_MINUS_CONNECTED
ali SC_MARK_DOTDOTDOT=DOT_DOT_DOT
ali SC_MARK_FULLRECT=FULL_RECT
ali SC_MARK_LEFTRECT=LEFT_RECT
ali SC_MARK_RGBAIMAGE=RGBA_IMAGE
ali SC_MARK_VERTICALBOOKMARK=VERTICAL_BOOKMARK
2009-04-25 01:35:41 +02:00
enu MarkerOutline=SC_MARKNUM_
2022-08-27 09:35:52 +02:00
# Markers used for outlining and change history columns.
val SC_MARKNUM_HISTORY_REVERTED_TO_ORIGIN=21
val SC_MARKNUM_HISTORY_SAVED=22
val SC_MARKNUM_HISTORY_MODIFIED=23
val SC_MARKNUM_HISTORY_REVERTED_TO_MODIFIED=24
2009-04-25 01:35:41 +02:00
val SC_MARKNUM_FOLDEREND=25
val SC_MARKNUM_FOLDEROPENMID=26
val SC_MARKNUM_FOLDERMIDTAIL=27
val SC_MARKNUM_FOLDERTAIL=28
val SC_MARKNUM_FOLDERSUB=29
val SC_MARKNUM_FOLDER=30
val SC_MARKNUM_FOLDEROPEN=31
2019-07-21 15:26:02 +02:00
ali SC_MARKNUM_FOLDEREND=FOLDER_END
ali SC_MARKNUM_FOLDEROPENMID=FOLDER_OPEN_MID
ali SC_MARKNUM_FOLDERMIDTAIL=FOLDER_MID_TAIL
ali SC_MARKNUM_FOLDERTAIL=FOLDER_TAIL
ali SC_MARKNUM_FOLDERSUB=FOLDER_SUB
ali SC_MARKNUM_FOLDEROPEN=FOLDER_OPEN
# SC_MASK_FOLDERS doesn't go in an enumeration as larger than max 32-bit positive integer
2009-04-25 01:35:41 +02:00
val SC_MASK_FOLDERS=0xFE000000
# Set the symbol used for a particular marker number.
2019-07-21 15:26:02 +02:00
fun void MarkerDefine=2040(int markerNumber, MarkerSymbol markerSymbol)
2009-04-25 01:35:41 +02:00
# Set the foreground colour used for a particular marker number.
2013-08-28 02:44:27 +02:00
set void MarkerSetFore=2041(int markerNumber, colour fore)
2009-04-25 01:35:41 +02:00
# Set the background colour used for a particular marker number.
2013-08-28 02:44:27 +02:00
set void MarkerSetBack=2042(int markerNumber, colour back)
2009-04-25 01:35:41 +02:00
2011-07-18 00:30:49 +02:00
# Set the background colour used for a particular marker number when its folding block is selected.
2013-08-28 02:44:27 +02:00
set void MarkerSetBackSelected=2292(int markerNumber, colour back)
2011-07-18 00:30:49 +02:00
2022-01-05 00:07:50 +01:00
# Set the foreground colour used for a particular marker number.
set void MarkerSetForeTranslucent=2294(int markerNumber, colouralpha fore)
# Set the background colour used for a particular marker number.
set void MarkerSetBackTranslucent=2295(int markerNumber, colouralpha back)
# Set the background colour used for a particular marker number when its folding block is selected.
set void MarkerSetBackSelectedTranslucent=2296(int markerNumber, colouralpha back)
# Set the width of strokes used in .01 pixels so 50 = 1/2 pixel width.
set void MarkerSetStrokeWidth=2297(int markerNumber, int hundredths)
2021-02-21 05:53:09 +01:00
# Enable/disable highlight for current folding block (smallest one that contains the caret)
2011-07-18 00:30:49 +02:00
fun void MarkerEnableHighlight=2293(bool enabled,)
2009-04-25 01:35:41 +02:00
# Add a marker to a line, returning an ID which can be used to find or delete the marker.
2019-07-21 15:26:02 +02:00
fun int MarkerAdd=2043(line line, int markerNumber)
2009-04-25 01:35:41 +02:00
# Delete a marker from a line.
2019-07-21 15:26:02 +02:00
fun void MarkerDelete=2044(line line, int markerNumber)
2009-04-25 01:35:41 +02:00
# Delete all markers with a particular number from all lines.
fun void MarkerDeleteAll=2045(int markerNumber,)
# Get a bit mask of all the markers set on a line.
2019-07-21 15:26:02 +02:00
fun int MarkerGet=2046(line line,)
2009-04-25 01:35:41 +02:00
2011-03-22 01:16:49 +01:00
# Find the next line at or after lineStart that includes a marker in mask.
# Return -1 when no more lines.
2019-07-21 15:26:02 +02:00
fun line MarkerNext=2047(line lineStart, int markerMask)
2009-04-25 01:35:41 +02:00
# Find the previous line before lineStart that includes a marker in mask.
2019-07-21 15:26:02 +02:00
fun line MarkerPrevious=2048(line lineStart, int markerMask)
2009-04-25 01:35:41 +02:00
# Define a marker from a pixmap.
fun void MarkerDefinePixmap=2049(int markerNumber, string pixmap)
# Add a set of markers to a line.
2019-07-21 15:26:02 +02:00
fun void MarkerAddSet=2466(line line, int markerSet)
2009-04-25 01:35:41 +02:00
# Set the alpha used for a marker that is drawn in the text area, not the margin.
2019-07-21 15:26:02 +02:00
set void MarkerSetAlpha=2476(int markerNumber, Alpha alpha)
2013-08-28 02:44:27 +02:00
2022-01-05 00:07:50 +01:00
# Get the layer used for a marker that is drawn in the text area, not the margin.
get Layer MarkerGetLayer=2734(int markerNumber,)
# Set the layer used for a marker that is drawn in the text area, not the margin.
set void MarkerSetLayer=2735(int markerNumber, Layer layer)
2013-08-28 02:44:27 +02:00
val SC_MAX_MARGIN=4
2009-04-25 01:35:41 +02:00
enu MarginType=SC_MARGIN_
val SC_MARGIN_SYMBOL=0
val SC_MARGIN_NUMBER=1
val SC_MARGIN_BACK=2
val SC_MARGIN_FORE=3
2009-06-24 21:09:31 +02:00
val SC_MARGIN_TEXT=4
val SC_MARGIN_RTEXT=5
2019-05-04 20:14:48 +02:00
val SC_MARGIN_COLOUR=6
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SC_MARGIN_RTEXT=R_TEXT
2009-04-25 01:35:41 +02:00
# Set a margin to be either numeric or symbolic.
2019-07-21 15:26:02 +02:00
set void SetMarginTypeN=2240(int margin, MarginType marginType)
2009-04-25 01:35:41 +02:00
# Retrieve the type of a margin.
2019-07-21 15:26:02 +02:00
get MarginType GetMarginTypeN=2241(int margin,)
2009-04-25 01:35:41 +02:00
# Set the width of a margin to a width expressed in pixels.
set void SetMarginWidthN=2242(int margin, int pixelWidth)
# Retrieve the width of a margin in pixels.
get int GetMarginWidthN=2243(int margin,)
# Set a mask that determines which markers are displayed in a margin.
set void SetMarginMaskN=2244(int margin, int mask)
# Retrieve the marker mask of a margin.
get int GetMarginMaskN=2245(int margin,)
# Make a margin sensitive or insensitive to mouse clicks.
set void SetMarginSensitiveN=2246(int margin, bool sensitive)
# Retrieve the mouse click sensitivity of a margin.
get bool GetMarginSensitiveN=2247(int margin,)
2011-03-22 01:16:49 +01:00
# Set the cursor shown when the mouse is inside a margin.
2019-07-21 15:26:02 +02:00
set void SetMarginCursorN=2248(int margin, CursorShape cursor)
2011-03-22 01:16:49 +01:00
# Retrieve the cursor shown in a margin.
2019-07-21 15:26:02 +02:00
get CursorShape GetMarginCursorN=2249(int margin,)
2011-03-22 01:16:49 +01:00
2019-05-04 20:14:48 +02:00
# Set the background colour of a margin. Only visible for SC_MARGIN_COLOUR.
set void SetMarginBackN=2250(int margin, colour back)
# Retrieve the background colour of a margin
get colour GetMarginBackN=2251(int margin,)
# Allocate a non-standard number of margins.
set void SetMargins=2252(int margins,)
# How many margins are there?.
get int GetMargins=2253(,)
# Styles in range 32..39 are predefined for parts of the UI and are not used as normal styles.
2009-04-25 01:35:41 +02:00
enu StylesCommon=STYLE_
val STYLE_DEFAULT=32
val STYLE_LINENUMBER=33
val STYLE_BRACELIGHT=34
val STYLE_BRACEBAD=35
val STYLE_CONTROLCHAR=36
val STYLE_INDENTGUIDE=37
val STYLE_CALLTIP=38
2019-05-04 20:14:48 +02:00
val STYLE_FOLDDISPLAYTEXT=39
2009-04-25 01:35:41 +02:00
val STYLE_LASTPREDEFINED=39
val STYLE_MAX=255
2019-07-21 15:26:02 +02:00
ali STYLE_LINENUMBER=LINE_NUMBER
ali STYLE_BRACELIGHT=BRACE_LIGHT
ali STYLE_BRACEBAD=BRACE_BAD
ali STYLE_CONTROLCHAR=CONTROL_CHAR
ali STYLE_INDENTGUIDE=INDENT_GUIDE
ali STYLE_CALLTIP=CALL_TIP
ali STYLE_FOLDDISPLAYTEXT=FOLD_DISPLAY_TEXT
ali STYLE_LASTPREDEFINED=LAST_PREDEFINED
2009-04-25 01:35:41 +02:00
# Character set identifiers are used in StyleSetCharacterSet.
# The values are the same as the Windows *_CHARSET values.
enu CharacterSet=SC_CHARSET_
val SC_CHARSET_ANSI=0
val SC_CHARSET_DEFAULT=1
val SC_CHARSET_BALTIC=186
val SC_CHARSET_CHINESEBIG5=136
val SC_CHARSET_EASTEUROPE=238
val SC_CHARSET_GB2312=134
val SC_CHARSET_GREEK=161
val SC_CHARSET_HANGUL=129
val SC_CHARSET_MAC=77
val SC_CHARSET_OEM=255
val SC_CHARSET_RUSSIAN=204
2019-05-04 20:14:48 +02:00
val SC_CHARSET_OEM866=866
2009-04-25 01:35:41 +02:00
val SC_CHARSET_CYRILLIC=1251
val SC_CHARSET_SHIFTJIS=128
val SC_CHARSET_SYMBOL=2
val SC_CHARSET_TURKISH=162
val SC_CHARSET_JOHAB=130
val SC_CHARSET_HEBREW=177
val SC_CHARSET_ARABIC=178
val SC_CHARSET_VIETNAMESE=163
val SC_CHARSET_THAI=222
val SC_CHARSET_8859_15=1000
2019-07-21 15:26:02 +02:00
ali SC_CHARSET_CHINESEBIG5=CHINESE_BIG5
ali SC_CHARSET_EASTEUROPE=EAST_EUROPE
ali SC_CHARSET_GB2312=G_B_2312
ali SC_CHARSET_OEM866=OEM_866
ali SC_CHARSET_SHIFTJIS=SHIFT_JIS
ali SC_CHARSET_8859_15=ISO_8859_15
2009-04-25 01:35:41 +02:00
# Clear all the styles and make equivalent to the global default style.
2013-08-28 02:44:27 +02:00
fun void StyleClearAll=2050(,)
2009-04-25 01:35:41 +02:00
# Set the foreground colour of a style.
set void StyleSetFore=2051(int style, colour fore)
# Set the background colour of a style.
set void StyleSetBack=2052(int style, colour back)
# Set a style to be bold or not.
set void StyleSetBold=2053(int style, bool bold)
# Set a style to be italic or not.
set void StyleSetItalic=2054(int style, bool italic)
# Set the size of characters of a style.
set void StyleSetSize=2055(int style, int sizePoints)
# Set the font of a style.
set void StyleSetFont=2056(int style, string fontName)
# Set a style to have its end of line filled or not.
2019-05-04 20:14:48 +02:00
set void StyleSetEOLFilled=2057(int style, bool eolFilled)
2009-04-25 01:35:41 +02:00
# Reset the default style to its state at startup
fun void StyleResetDefault=2058(,)
# Set a style to be underlined or not.
set void StyleSetUnderline=2059(int style, bool underline)
enu CaseVisible=SC_CASE_
val SC_CASE_MIXED=0
val SC_CASE_UPPER=1
val SC_CASE_LOWER=2
2019-05-04 20:14:48 +02:00
val SC_CASE_CAMEL=3
2009-04-25 01:35:41 +02:00
# Get the foreground colour of a style.
get colour StyleGetFore=2481(int style,)
# Get the background colour of a style.
get colour StyleGetBack=2482(int style,)
# Get is a style bold or not.
get bool StyleGetBold=2483(int style,)
# Get is a style italic or not.
get bool StyleGetItalic=2484(int style,)
# Get the size of characters of a style.
get int StyleGetSize=2485(int style,)
# Get the font of a style.
# Returns the length of the fontName
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2013-08-28 02:44:27 +02:00
get int StyleGetFont=2486(int style, stringresult fontName)
2009-04-25 01:35:41 +02:00
# Get is a style to have its end of line filled or not.
get bool StyleGetEOLFilled=2487(int style,)
# Get is a style underlined or not.
get bool StyleGetUnderline=2488(int style,)
# Get is a style mixed case, or to force upper or lower case.
2019-07-21 15:26:02 +02:00
get CaseVisible StyleGetCase=2489(int style,)
2009-04-25 01:35:41 +02:00
# Get the character get of the font in a style.
2019-07-21 15:26:02 +02:00
get CharacterSet StyleGetCharacterSet=2490(int style,)
2009-04-25 01:35:41 +02:00
# Get is a style visible or not.
get bool StyleGetVisible=2491(int style,)
# Get is a style changeable or not (read only).
# Experimental feature, currently buggy.
get bool StyleGetChangeable=2492(int style,)
# Get is a style a hotspot or not.
get bool StyleGetHotSpot=2493(int style,)
# Set a style to be mixed case, or to force upper or lower case.
2019-07-21 15:26:02 +02:00
set void StyleSetCase=2060(int style, CaseVisible caseVisible)
2009-04-25 01:35:41 +02:00
2013-08-28 02:44:27 +02:00
val SC_FONT_SIZE_MULTIPLIER=100
# Set the size of characters of a style. Size is in points multiplied by 100.
2019-05-04 20:14:48 +02:00
set void StyleSetSizeFractional=2061(int style, int sizeHundredthPoints)
2013-08-28 02:44:27 +02:00
# Get the size of characters of a style in points multiplied by 100
get int StyleGetSizeFractional=2062(int style,)
enu FontWeight=SC_WEIGHT_
val SC_WEIGHT_NORMAL=400
val SC_WEIGHT_SEMIBOLD=600
val SC_WEIGHT_BOLD=700
2019-07-21 15:26:02 +02:00
ali SC_WEIGHT_SEMIBOLD=SEMI_BOLD
2013-08-28 02:44:27 +02:00
# Set the weight of characters of a style.
2019-07-21 15:26:02 +02:00
set void StyleSetWeight=2063(int style, FontWeight weight)
2013-08-28 02:44:27 +02:00
# Get the weight of characters of a style.
2019-07-21 15:26:02 +02:00
get FontWeight StyleGetWeight=2064(int style,)
2013-08-28 02:44:27 +02:00
2009-04-25 01:35:41 +02:00
# Set the character set of the font in a style.
2019-07-21 15:26:02 +02:00
set void StyleSetCharacterSet=2066(int style, CharacterSet characterSet)
2009-04-25 01:35:41 +02:00
# Set a style to be a hotspot or not.
set void StyleSetHotSpot=2409(int style, bool hotspot)
2022-01-05 00:07:50 +01:00
# Indicate that a style may be monospaced over ASCII graphics characters which enables optimizations.
set void StyleSetCheckMonospaced=2254(int style, bool checkMonospaced)
# Get whether a style may be monospaced.
get bool StyleGetCheckMonospaced=2255(int style,)
2022-10-12 20:45:40 +02:00
# Set the invisible representation for a style.
set void StyleSetInvisibleRepresentation=2256(int style, string representation)
# Get the invisible representation for a style.
get int StyleGetInvisibleRepresentation=2257(int style, stringresult representation)
2022-01-05 00:07:50 +01:00
enu Element=SC_ELEMENT_
val SC_ELEMENT_LIST=0
val SC_ELEMENT_LIST_BACK=1
val SC_ELEMENT_LIST_SELECTED=2
val SC_ELEMENT_LIST_SELECTED_BACK=3
val SC_ELEMENT_SELECTION_TEXT=10
val SC_ELEMENT_SELECTION_BACK=11
val SC_ELEMENT_SELECTION_ADDITIONAL_TEXT=12
val SC_ELEMENT_SELECTION_ADDITIONAL_BACK=13
val SC_ELEMENT_SELECTION_SECONDARY_TEXT=14
val SC_ELEMENT_SELECTION_SECONDARY_BACK=15
val SC_ELEMENT_SELECTION_INACTIVE_TEXT=16
val SC_ELEMENT_SELECTION_INACTIVE_BACK=17
val SC_ELEMENT_CARET=40
val SC_ELEMENT_CARET_ADDITIONAL=41
val SC_ELEMENT_CARET_LINE_BACK=50
val SC_ELEMENT_WHITE_SPACE=60
val SC_ELEMENT_WHITE_SPACE_BACK=61
val SC_ELEMENT_HOT_SPOT_ACTIVE=70
val SC_ELEMENT_HOT_SPOT_ACTIVE_BACK=71
val SC_ELEMENT_FOLD_LINE=80
val SC_ELEMENT_HIDDEN_LINE=81
# Set the colour of an element. Translucency (alpha) may or may not be significant
# and this may depend on the platform. The alpha byte should commonly be 0xff for opaque.
set void SetElementColour=2753(Element element, colouralpha colourElement)
# Get the colour of an element.
get colouralpha GetElementColour=2754(Element element,)
# Use the default or platform-defined colour for an element.
fun void ResetElementColour=2755(Element element,)
# Get whether an element has been set by SetElementColour.
# When false, a platform-defined or default colour is used.
get bool GetElementIsSet=2756(Element element,)
# Get whether an element supports translucency.
get bool GetElementAllowsTranslucent=2757(Element element,)
# Get the colour of an element.
get colouralpha GetElementBaseColour=2758(Element element,)
2009-08-23 04:24:48 +02:00
# Set the foreground colour of the main and additional selections and whether to use this setting.
2009-04-25 01:35:41 +02:00
fun void SetSelFore=2067(bool useSetting, colour fore)
2009-08-23 04:24:48 +02:00
# Set the background colour of the main and additional selections and whether to use this setting.
2009-04-25 01:35:41 +02:00
fun void SetSelBack=2068(bool useSetting, colour back)
# Get the alpha of the selection.
2019-07-21 15:26:02 +02:00
get Alpha GetSelAlpha=2477(,)
2009-04-25 01:35:41 +02:00
# Set the alpha of the selection.
2019-07-21 15:26:02 +02:00
set void SetSelAlpha=2478(Alpha alpha,)
2009-04-25 01:35:41 +02:00
# Is the selection end of line filled?
get bool GetSelEOLFilled=2479(,)
# Set the selection to have its end of line filled or not.
set void SetSelEOLFilled=2480(bool filled,)
2022-01-05 00:07:50 +01:00
enu Layer=SC_LAYER_
val SC_LAYER_BASE=0
val SC_LAYER_UNDER_TEXT=1
val SC_LAYER_OVER_TEXT=2
# Get the layer for drawing selections
get Layer GetSelectionLayer=2762(,)
# Set the layer for drawing selections: either opaquely on base layer or translucently over text
set void SetSelectionLayer=2763(Layer layer,)
# Get the layer of the background of the line containing the caret.
get Layer GetCaretLineLayer=2764(,)
# Set the layer of the background of the line containing the caret.
set void SetCaretLineLayer=2765(Layer layer,)
# Get only highlighting subline instead of whole line.
get bool GetCaretLineHighlightSubLine=2773(,)
# Set only highlighting subline instead of whole line.
set void SetCaretLineHighlightSubLine=2774(bool subLine,)
2009-04-25 01:35:41 +02:00
# Set the foreground colour of the caret.
set void SetCaretFore=2069(colour fore,)
2019-05-04 20:14:48 +02:00
# When key+modifier combination keyDefinition is pressed perform sciCommand.
fun void AssignCmdKey=2070(keymod keyDefinition, int sciCommand)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# When key+modifier combination keyDefinition is pressed do nothing.
fun void ClearCmdKey=2071(keymod keyDefinition,)
2009-04-25 01:35:41 +02:00
# Drop all key mappings.
fun void ClearAllCmdKeys=2072(,)
# Set the styles for a segment of the document.
2019-07-21 15:26:02 +02:00
fun void SetStylingEx=2073(position length, string styles)
2009-04-25 01:35:41 +02:00
# Set a style to be visible or not.
set void StyleSetVisible=2074(int style, bool visible)
# Get the time in milliseconds that the caret is on and off.
get int GetCaretPeriod=2075(,)
# Get the time in milliseconds that the caret is on and off. 0 = steady on.
set void SetCaretPeriod=2076(int periodMilliseconds,)
# Set the set of characters making up words for when moving or selecting by word.
2009-04-26 01:38:15 +02:00
# First sets defaults like SetCharsDefault.
2009-04-25 01:35:41 +02:00
set void SetWordChars=2077(, string characters)
2013-08-28 02:44:27 +02:00
# Get the set of characters making up words for when moving or selecting by word.
2015-06-07 23:19:26 +02:00
# Returns the number of characters
2013-08-28 02:44:27 +02:00
get int GetWordChars=2646(, stringresult characters)
2019-07-21 15:26:02 +02:00
# Set the number of characters to have directly indexed categories
set void SetCharacterCategoryOptimization=2720(int countCharacters,)
# Get the number of characters to have directly indexed categories
get int GetCharacterCategoryOptimization=2721(,)
2009-04-25 01:35:41 +02:00
# Start a sequence of actions that is undone and redone as a unit.
# May be nested.
fun void BeginUndoAction=2078(,)
# End a sequence of actions that is undone and redone as a unit.
fun void EndUndoAction=2079(,)
Updated to Scintilla 5.4.2 & Lexilla 5.3.1
https://www.scintilla.org/scintilla542.zip
Release 5.4.2
Released 5 March 2024.
Significantly reduce memory used for undo actions, often to a half or quarter of previous versions. Feature #1458.
Add APIs for saving and restoring undo history.
For GTK, when laying out text, detect runs with both left-to-right and right-to-left ranges and divide into an ASCII prefix and more complex suffix. Lay out the ASCII prefix in the standard manner but, for the suffix, measure the whole width and spread that over the suffix bytes. This produces more usable results where the caret moves over the ASCII prefix correctly and over the suffix reasonably but not accurately.
For ScintillaEdit on Qt, fix reference from ScintillaDocument to Document to match change in 5.4.1 using IDocumentEditable for SCI_GETDOCPOINTER and SCI_SETDOCPOINTER.
For Direct2D on Win32, use the multi-threaded option to avoid crashes when Scintilla instances created on different threads. There may be more problems with this scenario so it should be avoided. Bug #2420.
For Win32, ensure keyboard-initiated context menu appears in multi-screen situations.
https://www.scintilla.org/lexilla531.zip
Release 5.3.1
Released 5 March 2024.
Assembler: After comments, treat \r\n line ends the same as \n. This makes testing easier.
Bash: Fix folding when line changed to/from comment and previous line is comment. Issue #224.
Batch: Fix handling ':' next to keywords. Issue #222.
JavaScript: in cpp lexer, add lexer.cpp.backquoted.strings=2 mode to treat ` back-quoted strings as template literals which allow embedded ${expressions}. Issue #94.
Python: fix lexing of rb'' and rf'' strings. Issue #223, Pull request #227.
Ruby: fix lexing of methods on numeric literals like '3.times' so the '.' and method name do not appear in numeric style. Issue #225.
2024-03-06 22:05:54 +01:00
# How many undo actions are in the history?
get int GetUndoActions=2790(,)
# Set action as the save point
set void SetUndoSavePoint=2791(int action,)
# Which action is the save point?
get int GetUndoSavePoint=2792(,)
# Set action as the detach point
set void SetUndoDetach=2793(int action,)
# Which action is the detach point?
get int GetUndoDetach=2794(,)
# Set action as the tentative point
set void SetUndoTentative=2795(int action,)
# Which action is the tentative point?
get int GetUndoTentative=2796(,)
# Set action as the current point
set void SetUndoCurrent=2797(int action,)
# Which action is the current point?
get int GetUndoCurrent=2798(,)
# Push one action onto undo history with no text
fun void PushUndoActionType=2800(int type, position pos)
# Set the text and length of the most recently pushed action
fun void ChangeLastUndoActionText=2801(position length, string text)
# What is the type of an action?
get int GetUndoActionType=2802(int action,)
# What is the position of an action?
get position GetUndoActionPosition=2803(int action,)
# What is the text of an action?
get int GetUndoActionText=2804(int action, stringresult text)
2009-04-25 01:35:41 +02:00
# Indicator style enumeration and some constants
enu IndicatorStyle=INDIC_
val INDIC_PLAIN=0
val INDIC_SQUIGGLE=1
val INDIC_TT=2
val INDIC_DIAGONAL=3
val INDIC_STRIKE=4
val INDIC_HIDDEN=5
val INDIC_BOX=6
val INDIC_ROUNDBOX=7
2011-07-18 00:30:49 +02:00
val INDIC_STRAIGHTBOX=8
val INDIC_DASH=9
val INDIC_DOTS=10
val INDIC_SQUIGGLELOW=11
2013-08-28 02:44:27 +02:00
val INDIC_DOTBOX=12
val INDIC_SQUIGGLEPIXMAP=13
val INDIC_COMPOSITIONTHICK=14
2015-06-07 23:19:26 +02:00
val INDIC_COMPOSITIONTHIN=15
val INDIC_FULLBOX=16
val INDIC_TEXTFORE=17
2019-05-04 20:14:48 +02:00
val INDIC_POINT=18
val INDIC_POINTCHARACTER=19
val INDIC_GRADIENT=20
val INDIC_GRADIENTCENTRE=21
2022-08-27 09:35:52 +02:00
val INDIC_POINT_TOP=22
2019-07-21 15:26:02 +02:00
# INDIC_CONTAINER, INDIC_IME, INDIC_IME_MAX, and INDIC_MAX are indicator numbers,
# not IndicatorStyles so should not really be in the INDIC_ enumeration.
# They are redeclared in IndicatorNumbers INDICATOR_.
val INDIC_CONTAINER=8
2015-06-07 23:19:26 +02:00
val INDIC_IME=32
val INDIC_IME_MAX=35
val INDIC_MAX=35
2019-07-21 15:26:02 +02:00
enu IndicatorNumbers=INDICATOR_
val INDICATOR_CONTAINER=8
val INDICATOR_IME=32
val INDICATOR_IME_MAX=35
2022-08-27 09:35:52 +02:00
val INDICATOR_HISTORY_REVERTED_TO_ORIGIN_INSERTION=36
val INDICATOR_HISTORY_REVERTED_TO_ORIGIN_DELETION=37
val INDICATOR_HISTORY_SAVED_INSERTION=38
val INDICATOR_HISTORY_SAVED_DELETION=39
val INDICATOR_HISTORY_MODIFIED_INSERTION=40
val INDICATOR_HISTORY_MODIFIED_DELETION=41
val INDICATOR_HISTORY_REVERTED_TO_MODIFIED_INSERTION=42
val INDICATOR_HISTORY_REVERTED_TO_MODIFIED_DELETION=43
val INDICATOR_MAX=43
2019-07-21 15:26:02 +02:00
ali INDIC_TT=T_T
ali INDIC_ROUNDBOX=ROUND_BOX
ali INDIC_STRAIGHTBOX=STRAIGHT_BOX
ali INDIC_SQUIGGLELOW=SQUIGGLE_LOW
ali INDIC_DOTBOX=DOT_BOX
ali INDIC_SQUIGGLEPIXMAP=SQUIGGLE_PIXMAP
ali INDIC_COMPOSITIONTHICK=COMPOSITION_THICK
ali INDIC_COMPOSITIONTHIN=COMPOSITION_THIN
ali INDIC_FULLBOX=FULL_BOX
ali INDIC_TEXTFORE=TEXT_FORE
ali INDIC_POINTCHARACTER=POINT_CHARACTER
ali INDIC_GRADIENTCENTRE=GRADIENT_CENTRE
2009-04-25 01:35:41 +02:00
# Set an indicator to plain, squiggle or TT.
2019-07-21 15:26:02 +02:00
set void IndicSetStyle=2080(int indicator, IndicatorStyle indicatorStyle)
2009-04-25 01:35:41 +02:00
# Retrieve the style of an indicator.
2019-07-21 15:26:02 +02:00
get IndicatorStyle IndicGetStyle=2081(int indicator,)
2009-04-25 01:35:41 +02:00
# Set the foreground colour of an indicator.
2019-05-04 20:14:48 +02:00
set void IndicSetFore=2082(int indicator, colour fore)
2009-04-25 01:35:41 +02:00
# Retrieve the foreground colour of an indicator.
2019-05-04 20:14:48 +02:00
get colour IndicGetFore=2083(int indicator,)
2009-04-25 01:35:41 +02:00
# Set an indicator to draw under text or over(default).
2019-05-04 20:14:48 +02:00
set void IndicSetUnder=2510(int indicator, bool under)
2009-04-25 01:35:41 +02:00
# Retrieve whether indicator drawn under or over text.
2019-05-04 20:14:48 +02:00
get bool IndicGetUnder=2511(int indicator,)
2009-04-25 01:35:41 +02:00
2015-06-07 23:19:26 +02:00
# Set a hover indicator to plain, squiggle or TT.
2019-07-21 15:26:02 +02:00
set void IndicSetHoverStyle=2680(int indicator, IndicatorStyle indicatorStyle)
2015-06-07 23:19:26 +02:00
# Retrieve the hover style of an indicator.
2019-07-21 15:26:02 +02:00
get IndicatorStyle IndicGetHoverStyle=2681(int indicator,)
2015-06-07 23:19:26 +02:00
# Set the foreground hover colour of an indicator.
2019-05-04 20:14:48 +02:00
set void IndicSetHoverFore=2682(int indicator, colour fore)
2015-06-07 23:19:26 +02:00
# Retrieve the foreground hover colour of an indicator.
2019-05-04 20:14:48 +02:00
get colour IndicGetHoverFore=2683(int indicator,)
2015-06-07 23:19:26 +02:00
2019-07-21 15:26:02 +02:00
enu IndicValue=SC_INDICVALUE
2015-06-07 23:19:26 +02:00
val SC_INDICVALUEBIT=0x1000000
val SC_INDICVALUEMASK=0xFFFFFF
enu IndicFlag=SC_INDICFLAG_
2022-01-05 00:07:50 +01:00
val SC_INDICFLAG_NONE=0
2015-06-07 23:19:26 +02:00
val SC_INDICFLAG_VALUEFORE=1
2019-07-21 15:26:02 +02:00
ali SC_INDICFLAG_VALUEFORE=VALUE_FORE
2015-06-07 23:19:26 +02:00
# Set the attributes of an indicator.
2019-07-21 15:26:02 +02:00
set void IndicSetFlags=2684(int indicator, IndicFlag flags)
2015-06-07 23:19:26 +02:00
# Retrieve the attributes of an indicator.
2019-07-21 15:26:02 +02:00
get IndicFlag IndicGetFlags=2685(int indicator,)
2015-06-07 23:19:26 +02:00
2022-01-05 00:07:50 +01:00
# Set the stroke width of an indicator in hundredths of a pixel.
set void IndicSetStrokeWidth=2751(int indicator, int hundredths)
# Retrieve the stroke width of an indicator.
get int IndicGetStrokeWidth=2752(int indicator,)
2009-04-25 01:35:41 +02:00
# Set the foreground colour of all whitespace and whether to use this setting.
fun void SetWhitespaceFore=2084(bool useSetting, colour fore)
# Set the background colour of all whitespace and whether to use this setting.
fun void SetWhitespaceBack=2085(bool useSetting, colour back)
2010-07-13 00:19:51 +02:00
# Set the size of the dots used to mark space characters.
set void SetWhitespaceSize=2086(int size,)
# Get the size of the dots used to mark space characters.
get int GetWhitespaceSize=2087(,)
2009-04-25 01:35:41 +02:00
# Used to hold extra styling information for each line.
2019-07-21 15:26:02 +02:00
set void SetLineState=2092(line line, int state)
2009-04-25 01:35:41 +02:00
# Retrieve the extra styling information for a line.
2019-07-21 15:26:02 +02:00
get int GetLineState=2093(line line,)
2009-04-25 01:35:41 +02:00
# Retrieve the last line number that has line state.
get int GetMaxLineState=2094(,)
# Is the background of the line containing the caret in a different colour?
get bool GetCaretLineVisible=2095(,)
# Display the background of the line containing the caret in a different colour.
set void SetCaretLineVisible=2096(bool show,)
# Get the colour of the background of the line containing the caret.
get colour GetCaretLineBack=2097(,)
# Set the colour of the background of the line containing the caret.
set void SetCaretLineBack=2098(colour back,)
2019-05-04 20:14:48 +02:00
# Retrieve the caret line frame width.
# Width = 0 means this option is disabled.
get int GetCaretLineFrame=2704(,)
# Display the caret line framed.
# Set width != 0 to enable this option and width = 0 to disable it.
set void SetCaretLineFrame=2705(int width,)
2009-04-25 01:35:41 +02:00
# Set a style to be changeable or not (read only).
# Experimental feature, currently buggy.
set void StyleSetChangeable=2099(int style, bool changeable)
# Display a auto-completion list.
2019-05-04 20:14:48 +02:00
# The lengthEntered parameter indicates how many characters before
2009-04-25 01:35:41 +02:00
# the caret should be used to provide context.
2019-07-21 15:26:02 +02:00
fun void AutoCShow=2100(position lengthEntered, string itemList)
2009-04-25 01:35:41 +02:00
# Remove the auto-completion list from the screen.
fun void AutoCCancel=2101(,)
# Is there an auto-completion list visible?
fun bool AutoCActive=2102(,)
# Retrieve the position of the caret when the auto-completion list was displayed.
fun position AutoCPosStart=2103(,)
# User has selected an item so remove the list and insert the selection.
fun void AutoCComplete=2104(,)
# Define a set of character that when typed cancel the auto-completion list.
fun void AutoCStops=2105(, string characterSet)
# Change the separator character in the string setting up an auto-completion list.
# Default is space but can be changed if items contain space.
set void AutoCSetSeparator=2106(int separatorCharacter,)
# Retrieve the auto-completion list separator character.
get int AutoCGetSeparator=2107(,)
# Select the item in the auto-completion list that starts with a string.
2019-05-04 20:14:48 +02:00
fun void AutoCSelect=2108(, string select)
2009-04-25 01:35:41 +02:00
# Should the auto-completion list be cancelled if the user backspaces to a
# position before where the box was created.
set void AutoCSetCancelAtStart=2110(bool cancel,)
# Retrieve whether auto-completion cancelled by backspacing before start.
get bool AutoCGetCancelAtStart=2111(,)
# Define a set of characters that when typed will cause the autocompletion to
# choose the selected item.
set void AutoCSetFillUps=2112(, string characterSet)
# Should a single item auto-completion list automatically choose the item.
set void AutoCSetChooseSingle=2113(bool chooseSingle,)
# Retrieve whether a single item auto-completion list automatically choose the item.
get bool AutoCGetChooseSingle=2114(,)
# Set whether case is significant when performing auto-completion searches.
set void AutoCSetIgnoreCase=2115(bool ignoreCase,)
# Retrieve state of ignore case flag.
get bool AutoCGetIgnoreCase=2116(,)
# Display a list of strings and send notification when user chooses one.
fun void UserListShow=2117(int listType, string itemList)
# Set whether or not autocompletion is hidden automatically when nothing matches.
set void AutoCSetAutoHide=2118(bool autoHide,)
# Retrieve whether or not autocompletion is hidden automatically when nothing matches.
get bool AutoCGetAutoHide=2119(,)
2022-01-05 00:07:50 +01:00
# Define option flags for autocompletion lists
enu AutoCompleteOption=SC_AUTOCOMPLETE_
val SC_AUTOCOMPLETE_NORMAL=0
# Win32 specific:
val SC_AUTOCOMPLETE_FIXED_SIZE=1
Update to scintilla 5.4.3 (from 5.4.1) & Lexilla 5.3.1
Sintilla [Release 5.4.3](https://www.scintilla.org/scintilla543.zip)
* Release 5.4.3: Released 9 March 2024
1. Fix redo failure introduced with 5.4.2. [Bug #2432](https://sourceforge.net/p/scintilla/bugs/2432/).
2. Add SC_AUTOCOMPLETE_SELECT_FIRST_ITEM option to always selects the first item in the autocompletion list. [Bug #2403](https://sourceforge.net/p/scintilla/bugs/2403/).
* Release 5.4.2: Released 5 March 2024
1. Significantly reduce memory used for undo actions, often to a half or quarter of previous versions. Feature #1458.
2. Add APIs for saving and restoring undo history.
3. For GTK, when laying out text, detect runs with both left-to-right and right-to-left ranges and divide into an ASCII prefix and more complex suffix. Lay out the ASCII prefix in the standard manner but, for the suffix, measure the whole width and spread that over the suffix bytes. This produces more usable results where the caret moves over the ASCII prefix correctly and over the suffix reasonably but not accurately.
4. For ScintillaEdit on Qt, fix reference from ScintillaDocument to Document to match change in 5.4.1 using IDocumentEditable for SCI_GETDOCPOINTER and SCI_SETDOCPOINTER.
5. For Direct2D on Win32, use the multi-threaded option to avoid crashes when Scintilla instances created on different threads. There may be more problems with this scenario so it should be avoided. Bug #2420.
6. For Win32, ensure keyboard-initiated context menu appears in multi-screen situations.
Lexilla [Release 5.3.1](https://www.scintilla.org/lexilla531.zip)
* Release 5.3.1: Released 5 March 2024
1. Assembler: After comments, treat \r\n line ends the same as \n. This makes testing easier.
2. Bash: Fix folding when line changed to/from comment and previous line is comment. Issue #224.
3. Batch: Fix handling ':' next to keywords. Issue #222.
4. JavaScript: in cpp lexer, add lexer.cpp.backquoted.strings=2 mode to treat ` back-quoted strings as template literals which allow embedded ${expressions}. Issue #94.
5. Python: fix lexing of rb'' and rf'' strings. Issue #223, Pull request #227.
6. Ruby: fix lexing of methods on numeric literals like '3.times' so the '.' and method name do not appear in numeric style. Issue #225.
Close #14834
2024-03-10 23:19:01 +01:00
# Always select the first item in the autocompletion list:
val SC_AUTOCOMPLETE_SELECT_FIRST_ITEM=2
2022-01-05 00:07:50 +01:00
# Set autocompletion options.
set void AutoCSetOptions=2638(AutoCompleteOption options,)
# Retrieve autocompletion options.
get AutoCompleteOption AutoCGetOptions=2639(,)
2009-04-25 01:35:41 +02:00
# Set whether or not autocompletion deletes any word characters
# after the inserted text upon completion.
set void AutoCSetDropRestOfWord=2270(bool dropRestOfWord,)
# Retrieve whether or not autocompletion deletes any word characters
# after the inserted text upon completion.
get bool AutoCGetDropRestOfWord=2271(,)
# Register an XPM image for use in autocompletion lists.
fun void RegisterImage=2405(int type, string xpmData)
# Clear all the registered XPM images.
fun void ClearRegisteredImages=2408(,)
# Retrieve the auto-completion list type-separator character.
get int AutoCGetTypeSeparator=2285(,)
# Change the type-separator character in the string setting up an auto-completion list.
# Default is '?' but can be changed if items contain '?'.
set void AutoCSetTypeSeparator=2286(int separatorCharacter,)
# Set the maximum width, in characters, of auto-completion and user lists.
# Set to 0 to autosize to fit longest item, which is the default.
set void AutoCSetMaxWidth=2208(int characterCount,)
# Get the maximum width, in characters, of auto-completion and user lists.
get int AutoCGetMaxWidth=2209(,)
# Set the maximum height, in rows, of auto-completion and user lists.
# The default is 5 rows.
set void AutoCSetMaxHeight=2210(int rowCount,)
# Set the maximum height, in rows, of auto-completion and user lists.
get int AutoCGetMaxHeight=2211(,)
# Set the number of spaces used for one level of indentation.
set void SetIndent=2122(int indentSize,)
# Retrieve indentation size.
get int GetIndent=2123(,)
# Indentation will only use space characters if useTabs is false, otherwise
# it will use a combination of tabs and spaces.
set void SetUseTabs=2124(bool useTabs,)
# Retrieve whether tabs will be used in indentation.
get bool GetUseTabs=2125(,)
# Change the indentation of a line to a number of columns.
2019-07-21 15:26:02 +02:00
set void SetLineIndentation=2126(line line, int indentation)
2009-04-25 01:35:41 +02:00
# Retrieve the number of columns that a line is indented.
2019-07-21 15:26:02 +02:00
get int GetLineIndentation=2127(line line,)
2009-04-25 01:35:41 +02:00
# Retrieve the position before the first non indentation character on a line.
2019-07-21 15:26:02 +02:00
get position GetLineIndentPosition=2128(line line,)
2009-04-25 01:35:41 +02:00
# Retrieve the column number of a position, taking tab width into account.
2019-07-21 15:26:02 +02:00
get position GetColumn=2129(position pos,)
2009-04-25 01:35:41 +02:00
2013-08-28 02:44:27 +02:00
# Count characters between two positions.
2019-07-21 15:26:02 +02:00
fun position CountCharacters=2633(position start, position end)
2019-05-04 20:14:48 +02:00
# Count code units between two positions.
2019-07-21 15:26:02 +02:00
fun position CountCodeUnits=2715(position start, position end)
2013-08-28 02:44:27 +02:00
2009-04-25 01:35:41 +02:00
# Show or hide the horizontal scroll bar.
2019-05-04 20:14:48 +02:00
set void SetHScrollBar=2130(bool visible,)
2009-04-25 01:35:41 +02:00
# Is the horizontal scroll bar visible?
get bool GetHScrollBar=2131(,)
enu IndentView=SC_IV_
val SC_IV_NONE=0
val SC_IV_REAL=1
val SC_IV_LOOKFORWARD=2
val SC_IV_LOOKBOTH=3
2019-07-21 15:26:02 +02:00
ali SC_IV_LOOKFORWARD=LOOK_FORWARD
ali SC_IV_LOOKBOTH=LOOK_BOTH
2009-04-25 01:35:41 +02:00
# Show or hide indentation guides.
2019-07-21 15:26:02 +02:00
set void SetIndentationGuides=2132(IndentView indentView,)
2009-04-25 01:35:41 +02:00
# Are the indentation guides visible?
2019-07-21 15:26:02 +02:00
get IndentView GetIndentationGuides=2133(,)
2009-04-25 01:35:41 +02:00
# Set the highlighted indentation guide column.
# 0 = no highlighted guide.
2019-07-21 15:26:02 +02:00
set void SetHighlightGuide=2134(position column,)
2009-04-25 01:35:41 +02:00
# Get the highlighted indentation guide column.
2019-07-21 15:26:02 +02:00
get position GetHighlightGuide=2135(,)
2009-04-25 01:35:41 +02:00
# Get the position after the last visible characters on a line.
2019-07-21 15:26:02 +02:00
get position GetLineEndPosition=2136(line line,)
2009-04-25 01:35:41 +02:00
# Get the code page used to interpret the bytes of the document as characters.
get int GetCodePage=2137(,)
# Get the foreground colour of the caret.
get colour GetCaretFore=2138(,)
# In read-only mode?
get bool GetReadOnly=2140(,)
# Sets the position of the caret.
2019-05-04 20:14:48 +02:00
set void SetCurrentPos=2141(position caret,)
2009-04-25 01:35:41 +02:00
# Sets the position that starts the selection - this becomes the anchor.
2019-05-04 20:14:48 +02:00
set void SetSelectionStart=2142(position anchor,)
2009-04-25 01:35:41 +02:00
# Returns the position at the start of the selection.
get position GetSelectionStart=2143(,)
2019-05-04 20:14:48 +02:00
# Sets the position that ends the selection - this becomes the caret.
set void SetSelectionEnd=2144(position caret,)
2009-04-25 01:35:41 +02:00
# Returns the position at the end of the selection.
get position GetSelectionEnd=2145(,)
2011-07-18 00:30:49 +02:00
# Set caret to a position, while removing any existing selection.
2019-05-04 20:14:48 +02:00
fun void SetEmptySelection=2556(position caret,)
2011-07-18 00:30:49 +02:00
2009-04-25 01:35:41 +02:00
# Sets the print magnification added to the point size of each style for printing.
set void SetPrintMagnification=2146(int magnification,)
# Returns the print magnification.
get int GetPrintMagnification=2147(,)
enu PrintOption=SC_PRINT_
# PrintColourMode - use same colours as screen.
2019-05-04 20:14:48 +02:00
# with the exception of line number margins, which use a white background
2009-04-25 01:35:41 +02:00
val SC_PRINT_NORMAL=0
# PrintColourMode - invert the light value of each style for printing.
val SC_PRINT_INVERTLIGHT=1
# PrintColourMode - force black text on white background for printing.
val SC_PRINT_BLACKONWHITE=2
# PrintColourMode - text stays coloured, but all background is forced to be white for printing.
val SC_PRINT_COLOURONWHITE=3
# PrintColourMode - only the default-background is forced to be white for printing.
val SC_PRINT_COLOURONWHITEDEFAULTBG=4
2019-05-04 20:14:48 +02:00
# PrintColourMode - use same colours as screen, including line number margins.
val SC_PRINT_SCREENCOLOURS=5
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SC_PRINT_INVERTLIGHT=INVERT_LIGHT
ali SC_PRINT_BLACKONWHITE=BLACK_ON_WHITE
ali SC_PRINT_COLOURONWHITE=COLOUR_ON_WHITE
ali SC_PRINT_COLOURONWHITEDEFAULTBG=COLOUR_ON_WHITE_DEFAULT_B_G
ali SC_PRINT_SCREENCOLOURS=SCREEN_COLOURS
2009-04-25 01:35:41 +02:00
# Modify colours when printing for clearer printed text.
2019-07-21 15:26:02 +02:00
set void SetPrintColourMode=2148(PrintOption mode,)
2009-04-25 01:35:41 +02:00
# Returns the print colour mode.
2019-07-21 15:26:02 +02:00
get PrintOption GetPrintColourMode=2149(,)
2009-04-25 01:35:41 +02:00
enu FindOption=SCFIND_
2019-07-21 15:26:02 +02:00
val SCFIND_NONE=0x0
2015-06-07 23:19:26 +02:00
val SCFIND_WHOLEWORD=0x2
val SCFIND_MATCHCASE=0x4
2009-04-25 01:35:41 +02:00
val SCFIND_WORDSTART=0x00100000
val SCFIND_REGEXP=0x00200000
2015-06-07 23:19:26 +02:00
val SCFIND_POSIX=0x00400000
val SCFIND_CXX11REGEX=0x00800000
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SCFIND_WHOLEWORD=WHOLE_WORD
ali SCFIND_MATCHCASE=MATCH_CASE
ali SCFIND_WORDSTART=WORD_START
ali SCFIND_REGEXP=REG_EXP
ali SCFIND_CXX11REGEX=CXX11_REG_EX
2009-04-25 01:35:41 +02:00
# Find some text in the document.
2019-07-21 15:26:02 +02:00
fun position FindText=2150(FindOption searchFlags, findtext ft)
2009-04-25 01:35:41 +02:00
2022-05-25 22:16:39 +02:00
# Find some text in the document.
fun position FindTextFull=2196(FindOption searchFlags, findtextfull ft)
# Draw the document into a display context such as a printer.
2009-04-25 01:35:41 +02:00
fun position FormatRange=2151(bool draw, formatrange fr)
2022-05-25 22:16:39 +02:00
# Draw the document into a display context such as a printer.
fun position FormatRangeFull=2777(bool draw, formatrangefull fr)
2022-08-27 09:35:52 +02:00
enu ChangeHistoryOption=SC_CHANGE_HISTORY_
val SC_CHANGE_HISTORY_DISABLED=0
val SC_CHANGE_HISTORY_ENABLED=1
val SC_CHANGE_HISTORY_MARKERS=2
val SC_CHANGE_HISTORY_INDICATORS=4
# Enable or disable change history.
set void SetChangeHistory=2780(ChangeHistoryOption changeHistory,)
# Report change history status.
get ChangeHistoryOption GetChangeHistory=2781(,)
2009-04-25 01:35:41 +02:00
# Retrieve the display line at the top of the display.
2019-07-21 15:26:02 +02:00
get line GetFirstVisibleLine=2152(,)
2009-04-25 01:35:41 +02:00
# Retrieve the contents of a line.
# Returns the length of the line.
2019-07-21 15:26:02 +02:00
fun position GetLine=2153(line line, stringresult text)
2009-04-25 01:35:41 +02:00
# Returns the number of lines in the document. There is always at least one.
2019-07-21 15:26:02 +02:00
get line GetLineCount=2154(,)
2009-04-25 01:35:41 +02:00
2022-01-05 00:07:50 +01:00
# Enlarge the number of lines allocated.
set void AllocateLines=2089(line lines,)
2009-04-25 01:35:41 +02:00
# Sets the size in pixels of the left margin.
set void SetMarginLeft=2155(, int pixelWidth)
# Returns the size in pixels of the left margin.
get int GetMarginLeft=2156(,)
# Sets the size in pixels of the right margin.
set void SetMarginRight=2157(, int pixelWidth)
# Returns the size in pixels of the right margin.
get int GetMarginRight=2158(,)
# Is the document different from when it was last saved?
get bool GetModify=2159(,)
# Select a range of text.
2019-05-04 20:14:48 +02:00
fun void SetSel=2160(position anchor, position caret)
2009-04-25 01:35:41 +02:00
# Retrieve the selected text.
# Return the length of the text.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2019-07-21 15:26:02 +02:00
fun position GetSelText=2161(, stringresult text)
2009-04-25 01:35:41 +02:00
# Retrieve a range of text.
# Return the length of the text.
2019-07-21 15:26:02 +02:00
fun position GetTextRange=2162(, textrange tr)
2009-04-25 01:35:41 +02:00
2022-05-25 22:16:39 +02:00
# Retrieve a range of text that can be past 2GB.
# Return the length of the text.
fun position GetTextRangeFull=2039(, textrangefull tr)
2019-05-04 20:14:48 +02:00
# Draw the selection either highlighted or in normal (non-highlighted) style.
fun void HideSelection=2163(bool hide,)
2009-04-25 01:35:41 +02:00
2022-08-27 09:35:52 +02:00
#Is the selection visible or hidden?
get bool GetSelectionHidden=2088(,)
2009-04-25 01:35:41 +02:00
# Retrieve the x value of the point in the window where a position is displayed.
fun int PointXFromPosition=2164(, position pos)
# Retrieve the y value of the point in the window where a position is displayed.
fun int PointYFromPosition=2165(, position pos)
# Retrieve the line containing a position.
2019-07-21 15:26:02 +02:00
fun line LineFromPosition=2166(position pos,)
2009-04-25 01:35:41 +02:00
# Retrieve the position at the start of a line.
2019-07-21 15:26:02 +02:00
fun position PositionFromLine=2167(line line,)
2009-04-25 01:35:41 +02:00
# Scroll horizontally and vertically.
2019-07-21 15:26:02 +02:00
fun void LineScroll=2168(position columns, line lines)
2009-04-25 01:35:41 +02:00
# Ensure the caret is visible.
fun void ScrollCaret=2169(,)
2013-08-28 02:44:27 +02:00
# Scroll the argument positions and the range between them into view giving
# priority to the primary position then the secondary position.
# This may be used to make a search match visible.
fun void ScrollRange=2569(position secondary, position primary)
2009-04-25 01:35:41 +02:00
# Replace the selected text with the argument text.
fun void ReplaceSel=2170(, string text)
# Set to read only or read write.
set void SetReadOnly=2171(bool readOnly,)
# Null operation.
fun void Null=2172(,)
# Will a paste succeed?
fun bool CanPaste=2173(,)
# Are there any undoable actions in the undo history?
fun bool CanUndo=2174(,)
# Delete the undo history.
fun void EmptyUndoBuffer=2175(,)
# Undo one action in the undo history.
fun void Undo=2176(,)
# Cut the selection to the clipboard.
fun void Cut=2177(,)
# Copy the selection to the clipboard.
fun void Copy=2178(,)
# Paste the contents of the clipboard into the document replacing the selection.
fun void Paste=2179(,)
# Clear the selection.
fun void Clear=2180(,)
# Replace the contents of the document with the argument text.
fun void SetText=2181(, string text)
# Retrieve all the text in the document.
# Returns number of characters retrieved.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2019-07-21 15:26:02 +02:00
fun position GetText=2182(position length, stringresult text)
2009-04-25 01:35:41 +02:00
# Retrieve the number of characters in the document.
2019-07-21 15:26:02 +02:00
get position GetTextLength=2183(,)
2009-04-25 01:35:41 +02:00
# Retrieve a pointer to a function that processes messages for this Scintilla.
2019-07-21 15:26:02 +02:00
get pointer GetDirectFunction=2184(,)
2009-04-25 01:35:41 +02:00
2022-01-05 00:07:50 +01:00
# Retrieve a pointer to a function that processes messages for this Scintilla and returns status.
get pointer GetDirectStatusFunction=2772(,)
2009-04-25 01:35:41 +02:00
# Retrieve a pointer value to use as the first argument when calling
# the function returned by GetDirectFunction.
2019-07-21 15:26:02 +02:00
get pointer GetDirectPointer=2185(,)
2009-04-25 01:35:41 +02:00
# Set to overtype (true) or insert mode.
2019-05-04 20:14:48 +02:00
set void SetOvertype=2186(bool overType,)
2009-04-25 01:35:41 +02:00
# Returns true if overtype mode is active otherwise false is returned.
get bool GetOvertype=2187(,)
# Set the width of the insert mode caret.
set void SetCaretWidth=2188(int pixelWidth,)
# Returns the width of the insert mode caret.
get int GetCaretWidth=2189(,)
# Sets the position that starts the target which is used for updating the
# document without affecting the scroll position.
2019-05-04 20:14:48 +02:00
set void SetTargetStart=2190(position start,)
2009-04-25 01:35:41 +02:00
# Get the position that starts the target.
get position GetTargetStart=2191(,)
2021-02-21 05:53:09 +01:00
# Sets the virtual space of the target start
set void SetTargetStartVirtualSpace=2728(position space,)
# Get the virtual space of the target start
get position GetTargetStartVirtualSpace=2729(,)
2009-04-25 01:35:41 +02:00
# Sets the position that ends the target which is used for updating the
# document without affecting the scroll position.
2019-05-04 20:14:48 +02:00
set void SetTargetEnd=2192(position end,)
2009-04-25 01:35:41 +02:00
# Get the position that ends the target.
get position GetTargetEnd=2193(,)
2021-02-21 05:53:09 +01:00
# Sets the virtual space of the target end
set void SetTargetEndVirtualSpace=2730(position space,)
# Get the virtual space of the target end
get position GetTargetEndVirtualSpace=2731(,)
2015-06-07 23:19:26 +02:00
# Sets both the start and end of the target in one call.
fun void SetTargetRange=2686(position start, position end)
# Retrieve the text in the target.
2019-07-21 15:26:02 +02:00
get position GetTargetText=2687(, stringresult text)
2019-05-04 20:14:48 +02:00
# Make the target range start and end be the same as the selection range start and end.
fun void TargetFromSelection=2287(,)
# Sets the target to the whole document.
fun void TargetWholeDocument=2690(,)
2015-06-07 23:19:26 +02:00
2009-04-25 01:35:41 +02:00
# Replace the target text with the argument text.
# Text is counted so it can contain NULs.
# Returns the length of the replacement text.
2019-07-21 15:26:02 +02:00
fun position ReplaceTarget=2194(position length, string text)
2009-04-25 01:35:41 +02:00
# Replace the target text with the argument text after \d processing.
# Text is counted so it can contain NULs.
# Looks for \d where d is between 1 and 9 and replaces these with the strings
# matched in the last search operation which were surrounded by \( and \).
# Returns the length of the replacement text including any change
# caused by processing the \d patterns.
2019-07-21 15:26:02 +02:00
fun position ReplaceTargetRE=2195(position length, string text)
2009-04-25 01:35:41 +02:00
2022-12-10 13:35:16 +01:00
# Replace the target text with the argument text but ignore prefix and suffix that
# are the same as current.
fun position ReplaceTargetMinimal=2779(position length, string text)
2009-04-25 01:35:41 +02:00
# Search for a counted string in the target and set the target to the found
# range. Text is counted so it can contain NULs.
2019-07-21 15:26:02 +02:00
# Returns start of found range or -1 for failure in which case target is not moved.
fun position SearchInTarget=2197(position length, string text)
2009-04-25 01:35:41 +02:00
# Set the search flags used by SearchInTarget.
2019-07-21 15:26:02 +02:00
set void SetSearchFlags=2198(FindOption searchFlags,)
2009-04-25 01:35:41 +02:00
# Get the search flags used by SearchInTarget.
2019-07-21 15:26:02 +02:00
get FindOption GetSearchFlags=2199(,)
2009-04-25 01:35:41 +02:00
# Show a call tip containing a definition near position pos.
fun void CallTipShow=2200(position pos, string definition)
# Remove the call tip from the screen.
fun void CallTipCancel=2201(,)
# Is there an active call tip?
fun bool CallTipActive=2202(,)
# Retrieve the position where the caret was before displaying the call tip.
fun position CallTipPosStart=2203(,)
2015-06-07 23:19:26 +02:00
# Set the start position in order to change when backspacing removes the calltip.
2019-07-21 15:26:02 +02:00
set void CallTipSetPosStart=2214(position posStart,)
2015-06-07 23:19:26 +02:00
2009-04-25 01:35:41 +02:00
# Highlight a segment of the definition.
2021-02-21 05:53:09 +01:00
fun void CallTipSetHlt=2204(position highlightStart, position highlightEnd)
2009-04-25 01:35:41 +02:00
# Set the background colour for the call tip.
set void CallTipSetBack=2205(colour back,)
# Set the foreground colour for the call tip.
set void CallTipSetFore=2206(colour fore,)
# Set the foreground colour for the highlighted part of the call tip.
set void CallTipSetForeHlt=2207(colour fore,)
# Enable use of STYLE_CALLTIP and set call tip tab size in pixels.
set void CallTipUseStyle=2212(int tabSize,)
2013-08-28 02:44:27 +02:00
# Set position of calltip, above or below text.
set void CallTipSetPosition=2213(bool above,)
2009-04-25 01:35:41 +02:00
# Find the display line of a document line taking hidden lines into account.
2019-07-21 15:26:02 +02:00
fun line VisibleFromDocLine=2220(line docLine,)
2009-04-25 01:35:41 +02:00
# Find the document line of a display line taking hidden lines into account.
2019-07-21 15:26:02 +02:00
fun line DocLineFromVisible=2221(line displayLine,)
2009-04-25 01:35:41 +02:00
# The number of display lines needed to wrap a document line
2019-07-21 15:26:02 +02:00
fun line WrapCount=2235(line docLine,)
2009-04-25 01:35:41 +02:00
enu FoldLevel=SC_FOLDLEVEL
2022-01-05 00:07:50 +01:00
val SC_FOLDLEVELNONE=0x0
2009-04-25 01:35:41 +02:00
val SC_FOLDLEVELBASE=0x400
val SC_FOLDLEVELWHITEFLAG=0x1000
val SC_FOLDLEVELHEADERFLAG=0x2000
val SC_FOLDLEVELNUMBERMASK=0x0FFF
2019-07-21 15:26:02 +02:00
ali SC_FOLDLEVELWHITEFLAG=WHITE_FLAG
ali SC_FOLDLEVELHEADERFLAG=HEADER_FLAG
ali SC_FOLDLEVELNUMBERMASK=NUMBER_MASK
2009-04-25 01:35:41 +02:00
# Set the fold level of a line.
# This encodes an integer level along with flags indicating whether the
# line is a header and whether it is effectively white space.
2019-07-21 15:26:02 +02:00
set void SetFoldLevel=2222(line line, FoldLevel level)
2009-04-25 01:35:41 +02:00
# Retrieve the fold level of a line.
2019-07-21 15:26:02 +02:00
get FoldLevel GetFoldLevel=2223(line line,)
2009-04-25 01:35:41 +02:00
# Find the last child line of a header line.
2019-07-21 15:26:02 +02:00
get line GetLastChild=2224(line line, FoldLevel level)
2009-04-25 01:35:41 +02:00
# Find the parent line of a child line.
2019-07-21 15:26:02 +02:00
get line GetFoldParent=2225(line line,)
2009-04-25 01:35:41 +02:00
# Make a range of lines visible.
2019-07-21 15:26:02 +02:00
fun void ShowLines=2226(line lineStart, line lineEnd)
2009-04-25 01:35:41 +02:00
# Make a range of lines invisible.
2019-07-21 15:26:02 +02:00
fun void HideLines=2227(line lineStart, line lineEnd)
2009-04-25 01:35:41 +02:00
# Is a line visible?
2019-07-21 15:26:02 +02:00
get bool GetLineVisible=2228(line line,)
2009-04-25 01:35:41 +02:00
2013-08-28 02:44:27 +02:00
# Are all lines visible?
get bool GetAllLinesVisible=2236(,)
2009-04-25 01:35:41 +02:00
# Show the children of a header line.
2019-07-21 15:26:02 +02:00
set void SetFoldExpanded=2229(line line, bool expanded)
2009-04-25 01:35:41 +02:00
# Is a header line expanded?
2019-07-21 15:26:02 +02:00
get bool GetFoldExpanded=2230(line line,)
2009-04-25 01:35:41 +02:00
# Switch a header line between expanded and contracted.
2019-07-21 15:26:02 +02:00
fun void ToggleFold=2231(line line,)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# Switch a header line between expanded and contracted and show some text after the line.
2019-07-21 15:26:02 +02:00
fun void ToggleFoldShowText=2700(line line, string text)
2019-05-04 20:14:48 +02:00
enu FoldDisplayTextStyle=SC_FOLDDISPLAYTEXT_
val SC_FOLDDISPLAYTEXT_HIDDEN=0
val SC_FOLDDISPLAYTEXT_STANDARD=1
val SC_FOLDDISPLAYTEXT_BOXED=2
2019-07-21 15:26:02 +02:00
# Set the style of fold display text.
set void FoldDisplayTextSetStyle=2701(FoldDisplayTextStyle style,)
# Get the style of fold display text.
get FoldDisplayTextStyle FoldDisplayTextGetStyle=2707(,)
# Set the default fold display text.
fun void SetDefaultFoldDisplayText=2722(, string text)
# Get the default fold display text.
fun int GetDefaultFoldDisplayText=2723(, stringresult text)
2019-05-04 20:14:48 +02:00
enu FoldAction=SC_FOLDACTION_
2013-08-28 02:44:27 +02:00
val SC_FOLDACTION_CONTRACT=0
val SC_FOLDACTION_EXPAND=1
val SC_FOLDACTION_TOGGLE=2
2022-08-27 09:35:52 +02:00
val SC_FOLDACTION_CONTRACT_EVERY_LEVEL=4
2013-08-28 02:44:27 +02:00
# Expand or contract a fold header.
2019-07-21 15:26:02 +02:00
fun void FoldLine=2237(line line, FoldAction action)
2013-08-28 02:44:27 +02:00
# Expand or contract a fold header and its children.
2019-07-21 15:26:02 +02:00
fun void FoldChildren=2238(line line, FoldAction action)
2013-08-28 02:44:27 +02:00
# Expand a fold header and all children. Use the level argument instead of the line's current level.
2019-07-21 15:26:02 +02:00
fun void ExpandChildren=2239(line line, FoldLevel level)
2013-08-28 02:44:27 +02:00
# Expand or contract all fold headers.
2019-07-21 15:26:02 +02:00
fun void FoldAll=2662(FoldAction action,)
2013-08-28 02:44:27 +02:00
2009-04-25 01:35:41 +02:00
# Ensure a particular line is visible by expanding any header line hiding it.
2019-07-21 15:26:02 +02:00
fun void EnsureVisible=2232(line line,)
2009-04-25 01:35:41 +02:00
2013-08-28 02:44:27 +02:00
enu AutomaticFold=SC_AUTOMATICFOLD_
2022-01-05 00:07:50 +01:00
val SC_AUTOMATICFOLD_NONE=0x0000
2013-08-28 02:44:27 +02:00
val SC_AUTOMATICFOLD_SHOW=0x0001
val SC_AUTOMATICFOLD_CLICK=0x0002
val SC_AUTOMATICFOLD_CHANGE=0x0004
# Set automatic folding behaviours.
2019-07-21 15:26:02 +02:00
set void SetAutomaticFold=2663(AutomaticFold automaticFold,)
2013-08-28 02:44:27 +02:00
# Get automatic folding behaviours.
2019-07-21 15:26:02 +02:00
get AutomaticFold GetAutomaticFold=2664(,)
2013-08-28 02:44:27 +02:00
2009-04-25 01:35:41 +02:00
enu FoldFlag=SC_FOLDFLAG_
2022-01-05 00:07:50 +01:00
val SC_FOLDFLAG_NONE=0x0000
2009-04-25 01:35:41 +02:00
val SC_FOLDFLAG_LINEBEFORE_EXPANDED=0x0002
val SC_FOLDFLAG_LINEBEFORE_CONTRACTED=0x0004
val SC_FOLDFLAG_LINEAFTER_EXPANDED=0x0008
val SC_FOLDFLAG_LINEAFTER_CONTRACTED=0x0010
val SC_FOLDFLAG_LEVELNUMBERS=0x0040
2015-06-07 23:19:26 +02:00
val SC_FOLDFLAG_LINESTATE=0x0080
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SC_FOLDFLAG_LINEBEFORE_EXPANDED=LINE_BEFORE_EXPANDED
ali SC_FOLDFLAG_LINEBEFORE_CONTRACTED=LINE_BEFORE_CONTRACTED
ali SC_FOLDFLAG_LINEAFTER_EXPANDED=LINE_AFTER_EXPANDED
ali SC_FOLDFLAG_LINEAFTER_CONTRACTED=LINE_AFTER_CONTRACTED
ali SC_FOLDFLAG_LEVELNUMBERS=LEVEL_NUMBERS
ali SC_FOLDFLAG_LINESTATE=LINE_STATE
2009-04-25 01:35:41 +02:00
# Set some style options for folding.
2019-07-21 15:26:02 +02:00
set void SetFoldFlags=2233(FoldFlag flags,)
2009-04-25 01:35:41 +02:00
# Ensure a particular line is visible by expanding any header line hiding it.
# Use the currently set visibility policy to determine which range to display.
2019-07-21 15:26:02 +02:00
fun void EnsureVisibleEnforcePolicy=2234(line line,)
2009-04-25 01:35:41 +02:00
# Sets whether a tab pressed when caret is within indentation indents.
set void SetTabIndents=2260(bool tabIndents,)
# Does a tab pressed when caret is within indentation indent?
get bool GetTabIndents=2261(,)
# Sets whether a backspace pressed when caret is within indentation unindents.
set void SetBackSpaceUnIndents=2262(bool bsUnIndents,)
# Does a backspace pressed when caret is within indentation unindent?
get bool GetBackSpaceUnIndents=2263(,)
val SC_TIME_FOREVER=10000000
# Sets the time the mouse must sit still to generate a mouse dwell event.
set void SetMouseDwellTime=2264(int periodMilliseconds,)
# Retrieve the time the mouse must sit still to generate a mouse dwell event.
get int GetMouseDwellTime=2265(,)
# Get position of start of word.
2019-07-21 15:26:02 +02:00
fun position WordStartPosition=2266(position pos, bool onlyWordCharacters)
2009-04-25 01:35:41 +02:00
# Get position of end of word.
2019-07-21 15:26:02 +02:00
fun position WordEndPosition=2267(position pos, bool onlyWordCharacters)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# Is the range start..end considered a word?
fun bool IsRangeWord=2691(position start, position end)
enu IdleStyling=SC_IDLESTYLING_
val SC_IDLESTYLING_NONE=0
val SC_IDLESTYLING_TOVISIBLE=1
val SC_IDLESTYLING_AFTERVISIBLE=2
val SC_IDLESTYLING_ALL=3
2019-07-21 15:26:02 +02:00
ali SC_IDLESTYLING_TOVISIBLE=TO_VISIBLE
ali SC_IDLESTYLING_AFTERVISIBLE=AFTER_VISIBLE
2019-05-04 20:14:48 +02:00
# Sets limits to idle styling.
2019-07-21 15:26:02 +02:00
set void SetIdleStyling=2692(IdleStyling idleStyling,)
2019-05-04 20:14:48 +02:00
# Retrieve the limits to idle styling.
2019-07-21 15:26:02 +02:00
get IdleStyling GetIdleStyling=2693(,)
2019-05-04 20:14:48 +02:00
2009-04-25 01:35:41 +02:00
enu Wrap=SC_WRAP_
val SC_WRAP_NONE=0
val SC_WRAP_WORD=1
val SC_WRAP_CHAR=2
2015-06-07 23:19:26 +02:00
val SC_WRAP_WHITESPACE=3
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SC_WRAP_WHITESPACE=WHITE_SPACE
2009-04-25 01:35:41 +02:00
# Sets whether text is word wrapped.
2019-07-21 15:26:02 +02:00
set void SetWrapMode=2268(Wrap wrapMode,)
2009-04-25 01:35:41 +02:00
# Retrieve whether text is word wrapped.
2019-07-21 15:26:02 +02:00
get Wrap GetWrapMode=2269(,)
2009-04-25 01:35:41 +02:00
enu WrapVisualFlag=SC_WRAPVISUALFLAG_
val SC_WRAPVISUALFLAG_NONE=0x0000
val SC_WRAPVISUALFLAG_END=0x0001
val SC_WRAPVISUALFLAG_START=0x0002
2013-08-28 02:44:27 +02:00
val SC_WRAPVISUALFLAG_MARGIN=0x0004
2009-04-25 01:35:41 +02:00
# Set the display mode of visual flags for wrapped lines.
2019-07-21 15:26:02 +02:00
set void SetWrapVisualFlags=2460(WrapVisualFlag wrapVisualFlags,)
2009-04-25 01:35:41 +02:00
# Retrive the display mode of visual flags for wrapped lines.
2019-07-21 15:26:02 +02:00
get WrapVisualFlag GetWrapVisualFlags=2461(,)
2009-04-25 01:35:41 +02:00
enu WrapVisualLocation=SC_WRAPVISUALFLAGLOC_
val SC_WRAPVISUALFLAGLOC_DEFAULT=0x0000
val SC_WRAPVISUALFLAGLOC_END_BY_TEXT=0x0001
val SC_WRAPVISUALFLAGLOC_START_BY_TEXT=0x0002
# Set the location of visual flags for wrapped lines.
2019-07-21 15:26:02 +02:00
set void SetWrapVisualFlagsLocation=2462(WrapVisualLocation wrapVisualFlagsLocation,)
2009-04-25 01:35:41 +02:00
# Retrive the location of visual flags for wrapped lines.
2019-07-21 15:26:02 +02:00
get WrapVisualLocation GetWrapVisualFlagsLocation=2463(,)
2009-04-25 01:35:41 +02:00
# Set the start indent for wrapped lines.
set void SetWrapStartIndent=2464(int indent,)
# Retrive the start indent for wrapped lines.
get int GetWrapStartIndent=2465(,)
2009-08-23 04:24:48 +02:00
enu WrapIndentMode=SC_WRAPINDENT_
val SC_WRAPINDENT_FIXED=0
val SC_WRAPINDENT_SAME=1
val SC_WRAPINDENT_INDENT=2
2019-05-04 20:14:48 +02:00
val SC_WRAPINDENT_DEEPINDENT=3
2009-08-23 04:24:48 +02:00
2019-07-21 15:26:02 +02:00
ali SC_WRAPINDENT_DEEPINDENT=DEEP_INDENT
2009-08-23 04:24:48 +02:00
# Sets how wrapped sublines are placed. Default is fixed.
2019-07-21 15:26:02 +02:00
set void SetWrapIndentMode=2472(WrapIndentMode wrapIndentMode,)
2009-08-23 04:24:48 +02:00
# Retrieve how wrapped sublines are placed. Default is fixed.
2019-07-21 15:26:02 +02:00
get WrapIndentMode GetWrapIndentMode=2473(,)
2009-08-23 04:24:48 +02:00
2009-04-25 01:35:41 +02:00
enu LineCache=SC_CACHE_
val SC_CACHE_NONE=0
val SC_CACHE_CARET=1
val SC_CACHE_PAGE=2
val SC_CACHE_DOCUMENT=3
# Sets the degree of caching of layout information.
2019-07-21 15:26:02 +02:00
set void SetLayoutCache=2272(LineCache cacheMode,)
2009-04-25 01:35:41 +02:00
# Retrieve the degree of caching of layout information.
2019-07-21 15:26:02 +02:00
get LineCache GetLayoutCache=2273(,)
2009-04-25 01:35:41 +02:00
# Sets the document width assumed for scrolling.
set void SetScrollWidth=2274(int pixelWidth,)
# Retrieve the document width assumed for scrolling.
get int GetScrollWidth=2275(,)
# Sets whether the maximum width line displayed is used to set scroll width.
set void SetScrollWidthTracking=2516(bool tracking,)
# Retrieve whether the scroll width tracks wide lines.
get bool GetScrollWidthTracking=2517(,)
# Measure the pixel width of some text in a particular style.
# NUL terminated text argument.
# Does not handle tab or control characters.
fun int TextWidth=2276(int style, string text)
# Sets the scroll range so that maximum scroll position has
# the last line at the bottom of the view (default).
# Setting this to false allows scrolling one page below the last line.
set void SetEndAtLastLine=2277(bool endAtLastLine,)
# Retrieve whether the maximum scroll position has the last
# line at the bottom of the view.
get bool GetEndAtLastLine=2278(,)
# Retrieve the height of a particular line of text in pixels.
2019-07-21 15:26:02 +02:00
fun int TextHeight=2279(line line,)
2009-04-25 01:35:41 +02:00
# Show or hide the vertical scroll bar.
2019-05-04 20:14:48 +02:00
set void SetVScrollBar=2280(bool visible,)
2009-04-25 01:35:41 +02:00
# Is the vertical scroll bar visible?
get bool GetVScrollBar=2281(,)
# Append a string to the end of the document without changing the selection.
2019-07-21 15:26:02 +02:00
fun void AppendText=2282(position length, string text)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
enu PhasesDraw=SC_PHASES_
2015-06-07 23:19:26 +02:00
val SC_PHASES_ONE=0
val SC_PHASES_TWO=1
val SC_PHASES_MULTIPLE=2
# How many phases is drawing done in?
2019-07-21 15:26:02 +02:00
get PhasesDraw GetPhasesDraw=2673(,)
2015-06-07 23:19:26 +02:00
# In one phase draw, text is drawn in a series of rectangular blocks with no overlap.
# In two phase draw, text is drawn in a series of lines allowing runs to overlap horizontally.
# In multiple phase draw, each element is drawn over the whole drawing area, allowing text
# to overlap from one line to the next.
2019-07-21 15:26:02 +02:00
set void SetPhasesDraw=2674(PhasesDraw phases,)
2015-06-07 23:19:26 +02:00
2010-07-13 00:19:51 +02:00
# Control font anti-aliasing.
enu FontQuality=SC_EFF_
val SC_EFF_QUALITY_MASK=0xF
val SC_EFF_QUALITY_DEFAULT=0
val SC_EFF_QUALITY_NON_ANTIALIASED=1
val SC_EFF_QUALITY_ANTIALIASED=2
val SC_EFF_QUALITY_LCD_OPTIMIZED=3
# Choose the quality level for text from the FontQuality enumeration.
2019-07-21 15:26:02 +02:00
set void SetFontQuality=2611(FontQuality fontQuality,)
2010-07-13 00:19:51 +02:00
# Retrieve the quality level for text.
2019-07-21 15:26:02 +02:00
get FontQuality GetFontQuality=2612(,)
2010-07-13 00:19:51 +02:00
# Scroll so that a display line is at the top of the display.
2019-07-21 15:26:02 +02:00
set void SetFirstVisibleLine=2613(line displayLine,)
2010-07-13 00:19:51 +02:00
enu MultiPaste=SC_MULTIPASTE_
val SC_MULTIPASTE_ONCE=0
val SC_MULTIPASTE_EACH=1
# Change the effect of pasting when there are multiple selections.
2019-07-21 15:26:02 +02:00
set void SetMultiPaste=2614(MultiPaste multiPaste,)
2010-07-13 00:19:51 +02:00
2019-05-04 20:14:48 +02:00
# Retrieve the effect of pasting when there are multiple selections.
2019-07-21 15:26:02 +02:00
get MultiPaste GetMultiPaste=2615(,)
2010-07-13 00:19:51 +02:00
# Retrieve the value of a tag from a regular expression search.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2013-08-28 02:44:27 +02:00
get int GetTag=2616(int tagNumber, stringresult tagValue)
2010-07-13 00:19:51 +02:00
2009-04-25 01:35:41 +02:00
# Join the lines in the target.
fun void LinesJoin=2288(,)
# Split the lines in the target into lines that are less wide than pixelWidth
# where possible.
fun void LinesSplit=2289(int pixelWidth,)
2019-05-04 20:14:48 +02:00
# Set one of the colours used as a chequerboard pattern in the fold margin
2009-04-25 01:35:41 +02:00
fun void SetFoldMarginColour=2290(bool useSetting, colour back)
2019-05-04 20:14:48 +02:00
# Set the other colour used as a chequerboard pattern in the fold margin
2009-04-25 01:35:41 +02:00
fun void SetFoldMarginHiColour=2291(bool useSetting, colour fore)
2019-05-04 20:14:48 +02:00
enu Accessibility=SC_ACCESSIBILITY_
val SC_ACCESSIBILITY_DISABLED=0
val SC_ACCESSIBILITY_ENABLED=1
# Enable or disable accessibility.
2019-07-21 15:26:02 +02:00
set void SetAccessibility=2702(Accessibility accessibility,)
2019-05-04 20:14:48 +02:00
# Report accessibility status.
2019-07-21 15:26:02 +02:00
get Accessibility GetAccessibility=2703(,)
2019-05-04 20:14:48 +02:00
2009-04-25 01:35:41 +02:00
## New messages go here
## Start of key messages
# Move caret down one line.
fun void LineDown=2300(,)
# Move caret down one line extending selection to new caret position.
fun void LineDownExtend=2301(,)
# Move caret up one line.
fun void LineUp=2302(,)
# Move caret up one line extending selection to new caret position.
fun void LineUpExtend=2303(,)
# Move caret left one character.
fun void CharLeft=2304(,)
# Move caret left one character extending selection to new caret position.
fun void CharLeftExtend=2305(,)
# Move caret right one character.
fun void CharRight=2306(,)
# Move caret right one character extending selection to new caret position.
fun void CharRightExtend=2307(,)
# Move caret left one word.
fun void WordLeft=2308(,)
# Move caret left one word extending selection to new caret position.
fun void WordLeftExtend=2309(,)
# Move caret right one word.
fun void WordRight=2310(,)
# Move caret right one word extending selection to new caret position.
fun void WordRightExtend=2311(,)
# Move caret to first position on line.
fun void Home=2312(,)
# Move caret to first position on line extending selection to new caret position.
fun void HomeExtend=2313(,)
# Move caret to last position on line.
fun void LineEnd=2314(,)
# Move caret to last position on line extending selection to new caret position.
fun void LineEndExtend=2315(,)
# Move caret to first position in document.
fun void DocumentStart=2316(,)
# Move caret to first position in document extending selection to new caret position.
fun void DocumentStartExtend=2317(,)
# Move caret to last position in document.
fun void DocumentEnd=2318(,)
# Move caret to last position in document extending selection to new caret position.
fun void DocumentEndExtend=2319(,)
# Move caret one page up.
fun void PageUp=2320(,)
# Move caret one page up extending selection to new caret position.
fun void PageUpExtend=2321(,)
# Move caret one page down.
fun void PageDown=2322(,)
# Move caret one page down extending selection to new caret position.
fun void PageDownExtend=2323(,)
# Switch from insert to overtype mode or the reverse.
fun void EditToggleOvertype=2324(,)
# Cancel any modes such as call tip or auto-completion list display.
fun void Cancel=2325(,)
# Delete the selection or if no selection, the character before the caret.
fun void DeleteBack=2326(,)
# If selection is empty or all on one line replace the selection with a tab character.
# If more than one line selected, indent the lines.
fun void Tab=2327(,)
# Dedent the selected lines.
fun void BackTab=2328(,)
# Insert a new line, may use a CRLF, CR or LF depending on EOL mode.
fun void NewLine=2329(,)
# Insert a Form Feed character.
fun void FormFeed=2330(,)
# Move caret to before first visible character on line.
# If already there move to first character on line.
fun void VCHome=2331(,)
# Like VCHome but extending selection to new caret position.
fun void VCHomeExtend=2332(,)
# Magnify the displayed text by increasing the sizes by 1 point.
fun void ZoomIn=2333(,)
# Make the displayed text smaller by decreasing the sizes by 1 point.
fun void ZoomOut=2334(,)
# Delete the word to the left of the caret.
fun void DelWordLeft=2335(,)
# Delete the word to the right of the caret.
fun void DelWordRight=2336(,)
# Delete the word to the right of the caret, but not the trailing non-word characters.
fun void DelWordRightEnd=2518(,)
# Cut the line containing the caret.
fun void LineCut=2337(,)
# Delete the line containing the caret.
fun void LineDelete=2338(,)
# Switch the current line with the previous.
fun void LineTranspose=2339(,)
2019-05-04 20:14:48 +02:00
# Reverse order of selected lines.
fun void LineReverse=2354(,)
2009-04-25 01:35:41 +02:00
# Duplicate the current line.
fun void LineDuplicate=2404(,)
# Transform the selection to lower case.
fun void LowerCase=2340(,)
# Transform the selection to upper case.
fun void UpperCase=2341(,)
# Scroll the document down, keeping the caret visible.
fun void LineScrollDown=2342(,)
# Scroll the document up, keeping the caret visible.
fun void LineScrollUp=2343(,)
# Delete the selection or if no selection, the character before the caret.
# Will not delete the character before at the start of a line.
fun void DeleteBackNotLine=2344(,)
# Move caret to first position on display line.
fun void HomeDisplay=2345(,)
# Move caret to first position on display line extending selection to
# new caret position.
fun void HomeDisplayExtend=2346(,)
# Move caret to last position on display line.
fun void LineEndDisplay=2347(,)
# Move caret to last position on display line extending selection to new
# caret position.
fun void LineEndDisplayExtend=2348(,)
2019-05-04 20:14:48 +02:00
# Like Home but when word-wrap is enabled goes first to start of display line
# HomeDisplay, then to start of document line Home.
2009-04-25 01:35:41 +02:00
fun void HomeWrap=2349(,)
2019-05-04 20:14:48 +02:00
# Like HomeExtend but when word-wrap is enabled extends first to start of display line
# HomeDisplayExtend, then to start of document line HomeExtend.
2009-04-25 01:35:41 +02:00
fun void HomeWrapExtend=2450(,)
2019-05-04 20:14:48 +02:00
# Like LineEnd but when word-wrap is enabled goes first to end of display line
# LineEndDisplay, then to start of document line LineEnd.
2009-04-25 01:35:41 +02:00
fun void LineEndWrap=2451(,)
2019-05-04 20:14:48 +02:00
# Like LineEndExtend but when word-wrap is enabled extends first to end of display line
# LineEndDisplayExtend, then to start of document line LineEndExtend.
2009-04-25 01:35:41 +02:00
fun void LineEndWrapExtend=2452(,)
2019-05-04 20:14:48 +02:00
# Like VCHome but when word-wrap is enabled goes first to start of display line
# VCHomeDisplay, then behaves like VCHome.
2009-04-25 01:35:41 +02:00
fun void VCHomeWrap=2453(,)
2019-05-04 20:14:48 +02:00
# Like VCHomeExtend but when word-wrap is enabled extends first to start of display line
# VCHomeDisplayExtend, then behaves like VCHomeExtend.
2009-04-25 01:35:41 +02:00
fun void VCHomeWrapExtend=2454(,)
# Copy the line containing the caret.
fun void LineCopy=2455(,)
# Move the caret inside current view if it's not there already.
fun void MoveCaretInsideView=2401(,)
# How many characters are on a line, including end of line characters?
2019-07-21 15:26:02 +02:00
fun position LineLength=2350(line line,)
2009-04-25 01:35:41 +02:00
# Highlight the characters at two positions.
2019-05-04 20:14:48 +02:00
fun void BraceHighlight=2351(position posA, position posB)
2009-04-25 01:35:41 +02:00
2011-07-18 00:30:49 +02:00
# Use specified indicator to highlight matching braces instead of changing their style.
2019-05-04 20:14:48 +02:00
fun void BraceHighlightIndicator=2498(bool useSetting, int indicator)
2011-07-18 00:30:49 +02:00
2009-04-25 01:35:41 +02:00
# Highlight the character at a position indicating there is no matching brace.
fun void BraceBadLight=2352(position pos,)
2011-07-18 00:30:49 +02:00
# Use specified indicator to highlight non matching brace instead of changing its style.
2019-05-04 20:14:48 +02:00
fun void BraceBadLightIndicator=2499(bool useSetting, int indicator)
2011-07-18 00:30:49 +02:00
2009-04-25 01:35:41 +02:00
# Find the position of a matching brace or INVALID_POSITION if no match.
2019-05-04 20:14:48 +02:00
# The maxReStyle must be 0 for now. It may be defined in a future release.
fun position BraceMatch=2353(position pos, int maxReStyle)
2009-04-25 01:35:41 +02:00
2021-02-21 05:53:09 +01:00
# Similar to BraceMatch, but matching starts at the explicit start position.
fun position BraceMatchNext=2369(position pos, position startPos)
2009-04-25 01:35:41 +02:00
# Are the end of line characters visible?
get bool GetViewEOL=2355(,)
# Make the end of line characters visible or invisible.
set void SetViewEOL=2356(bool visible,)
# Retrieve a pointer to the document object.
2019-07-21 15:26:02 +02:00
get pointer GetDocPointer=2357(,)
2009-04-25 01:35:41 +02:00
# Change the document object used.
2019-07-21 15:26:02 +02:00
set void SetDocPointer=2358(, pointer doc)
2009-04-25 01:35:41 +02:00
# Set which document modification events are sent to the container.
2019-07-21 15:26:02 +02:00
set void SetModEventMask=2359(ModificationFlags eventMask,)
2009-04-25 01:35:41 +02:00
enu EdgeVisualStyle=EDGE_
val EDGE_NONE=0
val EDGE_LINE=1
val EDGE_BACKGROUND=2
2019-05-04 20:14:48 +02:00
val EDGE_MULTILINE=3
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali EDGE_MULTILINE=MULTI_LINE
2009-04-25 01:35:41 +02:00
# Retrieve the column number which text should be kept within.
2019-07-21 15:26:02 +02:00
get position GetEdgeColumn=2360(,)
2009-04-25 01:35:41 +02:00
# Set the column number of the edge.
# If text goes past the edge then it is highlighted.
2019-07-21 15:26:02 +02:00
set void SetEdgeColumn=2361(position column,)
2009-04-25 01:35:41 +02:00
# Retrieve the edge highlight mode.
2019-07-21 15:26:02 +02:00
get EdgeVisualStyle GetEdgeMode=2362(,)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# The edge may be displayed by a line (EDGE_LINE/EDGE_MULTILINE) or by highlighting text that
2009-04-25 01:35:41 +02:00
# goes beyond it (EDGE_BACKGROUND) or not displayed at all (EDGE_NONE).
2019-07-21 15:26:02 +02:00
set void SetEdgeMode=2363(EdgeVisualStyle edgeMode,)
2009-04-25 01:35:41 +02:00
# Retrieve the colour used in edge indication.
get colour GetEdgeColour=2364(,)
# Change the colour used in edge indication.
set void SetEdgeColour=2365(colour edgeColour,)
2019-05-04 20:14:48 +02:00
# Add a new vertical edge to the view.
2019-07-21 15:26:02 +02:00
fun void MultiEdgeAddLine=2694(position column, colour edgeColour)
2019-05-04 20:14:48 +02:00
# Clear all vertical edges.
fun void MultiEdgeClearAll=2695(,)
2021-02-21 05:53:09 +01:00
# Get multi edge positions.
get position GetMultiEdgeColumn=2749(int which,)
2009-04-25 01:35:41 +02:00
# Sets the current caret position to be the search anchor.
fun void SearchAnchor=2366(,)
# Find some text starting at the search anchor.
# Does not ensure the selection is visible.
2019-07-21 15:26:02 +02:00
fun position SearchNext=2367(FindOption searchFlags, string text)
2009-04-25 01:35:41 +02:00
# Find some text starting at the search anchor and moving backwards.
# Does not ensure the selection is visible.
2019-07-21 15:26:02 +02:00
fun position SearchPrev=2368(FindOption searchFlags, string text)
2009-04-25 01:35:41 +02:00
# Retrieves the number of lines completely visible.
2019-07-21 15:26:02 +02:00
get line LinesOnScreen=2370(,)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
enu PopUp=SC_POPUP_
val SC_POPUP_NEVER=0
val SC_POPUP_ALL=1
val SC_POPUP_TEXT=2
2009-04-25 01:35:41 +02:00
# Set whether a pop up menu is displayed automatically when the user presses
2019-05-04 20:14:48 +02:00
# the wrong mouse button on certain areas.
2019-07-21 15:26:02 +02:00
fun void UsePopUp=2371(PopUp popUpMode,)
2009-04-25 01:35:41 +02:00
# Is the selection rectangular? The alternative is the more common stream selection.
get bool SelectionIsRectangle=2372(,)
# Set the zoom level. This number of points is added to the size of all fonts.
# It may be positive to magnify or negative to reduce.
2019-05-04 20:14:48 +02:00
set void SetZoom=2373(int zoomInPoints,)
2009-04-25 01:35:41 +02:00
# Retrieve the zoom level.
get int GetZoom=2374(,)
2019-05-04 20:14:48 +02:00
enu DocumentOption=SC_DOCUMENTOPTION_
val SC_DOCUMENTOPTION_DEFAULT=0
val SC_DOCUMENTOPTION_STYLES_NONE=0x1
val SC_DOCUMENTOPTION_TEXT_LARGE=0x100
2009-04-25 01:35:41 +02:00
# Create a new document object.
# Starts with reference count of 1 and not selected into editor.
2019-07-21 15:26:02 +02:00
fun pointer CreateDocument=2375(position bytes, DocumentOption documentOptions)
2009-04-25 01:35:41 +02:00
# Extend life of document.
2019-07-21 15:26:02 +02:00
fun void AddRefDocument=2376(, pointer doc)
2009-04-25 01:35:41 +02:00
# Release a reference to the document, deleting document if it fades to black.
2019-07-21 15:26:02 +02:00
fun void ReleaseDocument=2377(, pointer doc)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# Get which document options are set.
2019-07-21 15:26:02 +02:00
get DocumentOption GetDocumentOptions=2379(,)
2019-05-04 20:14:48 +02:00
2009-04-25 01:35:41 +02:00
# Get which document modification events are sent to the container.
2019-07-21 15:26:02 +02:00
get ModificationFlags GetModEventMask=2378(,)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# Set whether command events are sent to the container.
set void SetCommandEvents=2717(bool commandEvents,)
# Get whether command events are sent to the container.
get bool GetCommandEvents=2718(,)
2009-04-25 01:35:41 +02:00
# Change internal focus flag.
set void SetFocus=2380(bool focus,)
# Get internal focus flag.
get bool GetFocus=2381(,)
2009-08-23 04:24:48 +02:00
enu Status=SC_STATUS_
val SC_STATUS_OK=0
val SC_STATUS_FAILURE=1
val SC_STATUS_BADALLOC=2
2015-06-07 23:19:26 +02:00
val SC_STATUS_WARN_START=1000
val SC_STATUS_WARN_REGEX=1001
2009-08-23 04:24:48 +02:00
2019-07-21 15:26:02 +02:00
ali SC_STATUS_BADALLOC=BAD_ALLOC
ali SC_STATUS_WARN_REGEX=REG_EX
2009-04-25 01:35:41 +02:00
# Change error status - 0 = OK.
2019-07-21 15:26:02 +02:00
set void SetStatus=2382(Status status,)
2009-04-25 01:35:41 +02:00
# Get error status.
2019-07-21 15:26:02 +02:00
get Status GetStatus=2383(,)
2009-04-25 01:35:41 +02:00
# Set whether the mouse is captured when its button is pressed.
set void SetMouseDownCaptures=2384(bool captures,)
# Get whether mouse gets captured.
get bool GetMouseDownCaptures=2385(,)
2019-05-04 20:14:48 +02:00
# Set whether the mouse wheel can be active outside the window.
set void SetMouseWheelCaptures=2696(bool captures,)
# Get whether mouse wheel can be active outside the window.
get bool GetMouseWheelCaptures=2697(,)
2009-04-25 01:35:41 +02:00
# Sets the cursor to one of the SC_CURSOR* values.
2019-07-21 15:26:02 +02:00
set void SetCursor=2386(CursorShape cursorType,)
2009-04-25 01:35:41 +02:00
# Get cursor type.
2019-07-21 15:26:02 +02:00
get CursorShape GetCursor=2387(,)
2009-04-25 01:35:41 +02:00
# Change the way control characters are displayed:
# If symbol is < 32, keep the drawn way, else, use the given character.
set void SetControlCharSymbol=2388(int symbol,)
# Get the way control characters are displayed.
get int GetControlCharSymbol=2389(,)
# Move to the previous change in capitalisation.
fun void WordPartLeft=2390(,)
# Move to the previous change in capitalisation extending selection
# to new caret position.
fun void WordPartLeftExtend=2391(,)
# Move to the change next in capitalisation.
fun void WordPartRight=2392(,)
# Move to the next change in capitalisation extending selection
# to new caret position.
fun void WordPartRightExtend=2393(,)
# Constants for use with SetVisiblePolicy, similar to SetCaretPolicy.
2019-05-04 20:14:48 +02:00
enu VisiblePolicy=VISIBLE_
2009-04-25 01:35:41 +02:00
val VISIBLE_SLOP=0x01
val VISIBLE_STRICT=0x04
2021-02-21 05:53:09 +01:00
2009-04-25 01:35:41 +02:00
# Set the way the display area is determined when a particular line
# is to be moved to by Find, FindNext, GotoLine, etc.
2019-07-21 15:26:02 +02:00
fun void SetVisiblePolicy=2394(VisiblePolicy visiblePolicy, int visibleSlop)
2009-04-25 01:35:41 +02:00
# Delete back from the current position to the start of the line.
fun void DelLineLeft=2395(,)
# Delete forwards from the current position to the end of the line.
fun void DelLineRight=2396(,)
2019-05-04 20:14:48 +02:00
# Set the xOffset (ie, horizontal scroll position).
set void SetXOffset=2397(int xOffset,)
# Get the xOffset (ie, horizontal scroll position).
2009-04-25 01:35:41 +02:00
get int GetXOffset=2398(,)
# Set the last x chosen value to be the caret x position.
fun void ChooseCaretX=2399(,)
# Set the focus to this Scintilla widget.
fun void GrabFocus=2400(,)
2009-04-26 01:38:15 +02:00
enu CaretPolicy=CARET_
2009-04-25 01:35:41 +02:00
# Caret policy, used by SetXCaretPolicy and SetYCaretPolicy.
# If CARET_SLOP is set, we can define a slop value: caretSlop.
# This value defines an unwanted zone (UZ) where the caret is... unwanted.
# This zone is defined as a number of pixels near the vertical margins,
# and as a number of lines near the horizontal margins.
# By keeping the caret away from the edges, it is seen within its context,
# so it is likely that the identifier that the caret is on can be completely seen,
# and that the current line is seen with some of the lines following it which are
# often dependent on that line.
val CARET_SLOP=0x01
# If CARET_STRICT is set, the policy is enforced... strictly.
# The caret is centred on the display if slop is not set,
# and cannot go in the UZ if slop is set.
val CARET_STRICT=0x04
# If CARET_JUMPS is set, the display is moved more energetically
# so the caret can move in the same direction longer before the policy is applied again.
val CARET_JUMPS=0x10
# If CARET_EVEN is not set, instead of having symmetrical UZs,
# the left and bottom UZs are extended up to right and top UZs respectively.
2019-05-04 20:14:48 +02:00
# This way, we favour the displaying of useful information: the beginning of lines,
2009-04-25 01:35:41 +02:00
# where most code reside, and the lines after the caret, eg. the body of a function.
val CARET_EVEN=0x08
2013-08-28 02:44:27 +02:00
# Set the way the caret is kept visible when going sideways.
2009-04-25 01:35:41 +02:00
# The exclusion zone is given in pixels.
2019-07-21 15:26:02 +02:00
fun void SetXCaretPolicy=2402(CaretPolicy caretPolicy, int caretSlop)
2009-04-25 01:35:41 +02:00
# Set the way the line the caret is on is kept visible.
# The exclusion zone is given in lines.
2019-07-21 15:26:02 +02:00
fun void SetYCaretPolicy=2403(CaretPolicy caretPolicy, int caretSlop)
2009-04-25 01:35:41 +02:00
# Set printing to line wrapped (SC_WRAP_WORD) or not line wrapped (SC_WRAP_NONE).
2019-07-21 15:26:02 +02:00
set void SetPrintWrapMode=2406(Wrap wrapMode,)
2009-04-25 01:35:41 +02:00
# Is printing line wrapped?
2019-07-21 15:26:02 +02:00
get Wrap GetPrintWrapMode=2407(,)
2009-04-25 01:35:41 +02:00
# Set a fore colour for active hotspots.
set void SetHotspotActiveFore=2410(bool useSetting, colour fore)
# Get the fore colour for active hotspots.
get colour GetHotspotActiveFore=2494(,)
# Set a back colour for active hotspots.
set void SetHotspotActiveBack=2411(bool useSetting, colour back)
# Get the back colour for active hotspots.
get colour GetHotspotActiveBack=2495(,)
# Enable / Disable underlining active hotspots.
set void SetHotspotActiveUnderline=2412(bool underline,)
# Get whether underlining for active hotspots.
get bool GetHotspotActiveUnderline=2496(,)
# Limit hotspots to single line so hotspots on two lines don't merge.
set void SetHotspotSingleLine=2421(bool singleLine,)
# Get the HotspotSingleLine property
get bool GetHotspotSingleLine=2497(,)
2019-05-04 20:14:48 +02:00
# Move caret down one paragraph (delimited by empty lines).
2009-04-25 01:35:41 +02:00
fun void ParaDown=2413(,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Extend selection down one paragraph (delimited by empty lines).
2009-04-25 01:35:41 +02:00
fun void ParaDownExtend=2414(,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Move caret up one paragraph (delimited by empty lines).
2009-04-25 01:35:41 +02:00
fun void ParaUp=2415(,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Extend selection up one paragraph (delimited by empty lines).
2009-04-25 01:35:41 +02:00
fun void ParaUpExtend=2416(,)
# Given a valid document position, return the previous position taking code
# page into account. Returns 0 if passed 0.
fun position PositionBefore=2417(position pos,)
# Given a valid document position, return the next position taking code
# page into account. Maximum value returned is the last position in the document.
fun position PositionAfter=2418(position pos,)
2015-06-07 23:19:26 +02:00
# Given a valid document position, return a position that differs in a number
# of characters. Returned value is always between 0 and last position in document.
2019-07-21 15:26:02 +02:00
fun position PositionRelative=2670(position pos, position relative)
2015-06-07 23:19:26 +02:00
2019-05-04 20:14:48 +02:00
# Given a valid document position, return a position that differs in a number
# of UTF-16 code units. Returned value is always between 0 and last position in document.
# The result may point half way (2 bytes) inside a non-BMP character.
2019-07-21 15:26:02 +02:00
fun position PositionRelativeCodeUnits=2716(position pos, position relative)
2019-05-04 20:14:48 +02:00
2009-04-25 01:35:41 +02:00
# Copy a range of text to the clipboard. Positions are clipped into the document.
fun void CopyRange=2419(position start, position end)
# Copy argument text to the clipboard.
2019-07-21 15:26:02 +02:00
fun void CopyText=2420(position length, string text)
2009-04-25 01:35:41 +02:00
enu SelectionMode=SC_SEL_
val SC_SEL_STREAM=0
val SC_SEL_RECTANGLE=1
val SC_SEL_LINES=2
2009-08-23 04:24:48 +02:00
val SC_SEL_THIN=3
2009-04-25 01:35:41 +02:00
2009-08-23 04:24:48 +02:00
# Set the selection mode to stream (SC_SEL_STREAM) or rectangular (SC_SEL_RECTANGLE/SC_SEL_THIN) or
2009-04-25 01:35:41 +02:00
# by lines (SC_SEL_LINES).
2019-07-21 15:26:02 +02:00
set void SetSelectionMode=2422(SelectionMode selectionMode,)
2009-04-25 01:35:41 +02:00
Updated to Scintilla 5.4.1 & Lexilla 5.3.0
Scintilla 5.4.1
https://www.scintilla.org/scintilla541.zip
Released 27 December 2023.
1. Add IDocumentEditable interface to allow efficient interaction with document objects which may not be visible in a Scintilla instance. This feature is provisonal and may change before being declared stable. For better type-safety, the ScintillaCall C++ API uses IDocumentEditable* where void* was used before which may require changes to client code that uses document pointer APIs DocPointer, SetDocPointer, CreateDocument, AddRefDocument, and ReleaseDocument.
2. Ctrl-click on a selection deselects it in multiple selection mode.
3. Add SCI_SELECTIONFROMPOINT for modifying multiple selections.
4. Add SCI_SETMOVEEXTENDSSELECTION and SCI_CHANGESELECTIONMODE to simplify selection mode manipulation.
5. Improve performance of global replace by reducing cache invalidation overhead. [Feature #1502](https://sourceforge.net/p/scintilla/feature-requests/1502/).
6. Fix regular expression search for "\<" matching beginning of search when not beginning of word and for "\>" not matching line end. [Bug #2157](https://sourceforge.net/p/scintilla/bugs/2157/).
7. Fix regular expression search failure when search for "\<" followed by search for "\>". [Bug #2413](https://sourceforge.net/p/scintilla/bugs/2413/).
8. Fix regular expression assertion (^, $, \b. \B) failures when using SCFIND_CXX11REGEX. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
9. Fix regular expression bug in reverse direction where shortened match returned. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
10. Avoid character fragments in regular expression search results. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
11. With a document that does not have the SC_DOCUMENTOPTION_TEXT_LARGE option set, allocating more than 2G (calling SCI_ALLOCATE or similar) will now fail with SC_STATUS_FAILURE.
12. Protect SCI_REPLACETARGET, SCI_REPLACETARGETMINIMAL, and SCI_REPLACETARGETRE from application changing target in notification handlers. [Bug #2289](https://sourceforge.net/p/scintilla/bugs/2289/).
Lexilla 5.3.0
https://www.scintilla.org/lexilla530.zip
Released 27 December 2023.
1. Fix calling AddStaticLexerModule by defining as C++ instead of C which matches header. [Bug #2421](https://sourceforge.net/p/scintilla/bugs/2421/).
2. Bash: Fix shift operator << incorrectly recognized as here-doc. [Issue #215](https://github.com/ScintillaOrg/lexilla/issues/215).
3. Bash: Fix termination of '${' with first unquoted '}' instead of nesting. [Issue #216](https://github.com/ScintillaOrg/lexilla/issues/216).
4. HTML: JavaScript double-quoted strings may escape line end with '\'. [Issue #214](https://github.com/ScintillaOrg/lexilla/issues/214).
5. Lua: recognize --- doc comments. Defined by [LDoc](https://github.com/lunarmodules/ldoc). Does not recognize --[[-- doc comments which seem less common.
Close #14375
2023-11-19 18:46:55 +01:00
# Set the selection mode to stream (SC_SEL_STREAM) or rectangular (SC_SEL_RECTANGLE/SC_SEL_THIN) or
# by lines (SC_SEL_LINES) without changing MoveExtendsSelection.
fun void ChangeSelectionMode=2659(SelectionMode selectionMode,)
2009-04-25 01:35:41 +02:00
# Get the mode of the current selection.
2019-07-21 15:26:02 +02:00
get SelectionMode GetSelectionMode=2423(,)
2009-04-25 01:35:41 +02:00
Updated to Scintilla 5.4.1 & Lexilla 5.3.0
Scintilla 5.4.1
https://www.scintilla.org/scintilla541.zip
Released 27 December 2023.
1. Add IDocumentEditable interface to allow efficient interaction with document objects which may not be visible in a Scintilla instance. This feature is provisonal and may change before being declared stable. For better type-safety, the ScintillaCall C++ API uses IDocumentEditable* where void* was used before which may require changes to client code that uses document pointer APIs DocPointer, SetDocPointer, CreateDocument, AddRefDocument, and ReleaseDocument.
2. Ctrl-click on a selection deselects it in multiple selection mode.
3. Add SCI_SELECTIONFROMPOINT for modifying multiple selections.
4. Add SCI_SETMOVEEXTENDSSELECTION and SCI_CHANGESELECTIONMODE to simplify selection mode manipulation.
5. Improve performance of global replace by reducing cache invalidation overhead. [Feature #1502](https://sourceforge.net/p/scintilla/feature-requests/1502/).
6. Fix regular expression search for "\<" matching beginning of search when not beginning of word and for "\>" not matching line end. [Bug #2157](https://sourceforge.net/p/scintilla/bugs/2157/).
7. Fix regular expression search failure when search for "\<" followed by search for "\>". [Bug #2413](https://sourceforge.net/p/scintilla/bugs/2413/).
8. Fix regular expression assertion (^, $, \b. \B) failures when using SCFIND_CXX11REGEX. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
9. Fix regular expression bug in reverse direction where shortened match returned. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
10. Avoid character fragments in regular expression search results. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
11. With a document that does not have the SC_DOCUMENTOPTION_TEXT_LARGE option set, allocating more than 2G (calling SCI_ALLOCATE or similar) will now fail with SC_STATUS_FAILURE.
12. Protect SCI_REPLACETARGET, SCI_REPLACETARGETMINIMAL, and SCI_REPLACETARGETRE from application changing target in notification handlers. [Bug #2289](https://sourceforge.net/p/scintilla/bugs/2289/).
Lexilla 5.3.0
https://www.scintilla.org/lexilla530.zip
Released 27 December 2023.
1. Fix calling AddStaticLexerModule by defining as C++ instead of C which matches header. [Bug #2421](https://sourceforge.net/p/scintilla/bugs/2421/).
2. Bash: Fix shift operator << incorrectly recognized as here-doc. [Issue #215](https://github.com/ScintillaOrg/lexilla/issues/215).
3. Bash: Fix termination of '${' with first unquoted '}' instead of nesting. [Issue #216](https://github.com/ScintillaOrg/lexilla/issues/216).
4. HTML: JavaScript double-quoted strings may escape line end with '\'. [Issue #214](https://github.com/ScintillaOrg/lexilla/issues/214).
5. Lua: recognize --- doc comments. Defined by [LDoc](https://github.com/lunarmodules/ldoc). Does not recognize --[[-- doc comments which seem less common.
Close #14375
2023-11-19 18:46:55 +01:00
# Set whether or not regular caret moves will extend or reduce the selection.
set void SetMoveExtendsSelection=2719(bool moveExtendsSelection,)
2019-05-04 20:14:48 +02:00
# Get whether or not regular caret moves will extend or reduce the selection.
get bool GetMoveExtendsSelection=2706(,)
2009-04-25 01:35:41 +02:00
# Retrieve the position of the start of the selection at the given line (INVALID_POSITION if no selection on this line).
2019-07-21 15:26:02 +02:00
fun position GetLineSelStartPosition=2424(line line,)
2009-04-25 01:35:41 +02:00
# Retrieve the position of the end of the selection at the given line (INVALID_POSITION if no selection on this line).
2019-07-21 15:26:02 +02:00
fun position GetLineSelEndPosition=2425(line line,)
2009-04-25 01:35:41 +02:00
## RectExtended rectangular selection moves
# Move caret down one line, extending rectangular selection to new caret position.
fun void LineDownRectExtend=2426(,)
# Move caret up one line, extending rectangular selection to new caret position.
fun void LineUpRectExtend=2427(,)
# Move caret left one character, extending rectangular selection to new caret position.
fun void CharLeftRectExtend=2428(,)
# Move caret right one character, extending rectangular selection to new caret position.
fun void CharRightRectExtend=2429(,)
# Move caret to first position on line, extending rectangular selection to new caret position.
fun void HomeRectExtend=2430(,)
# Move caret to before first visible character on line.
# If already there move to first character on line.
# In either case, extend rectangular selection to new caret position.
fun void VCHomeRectExtend=2431(,)
# Move caret to last position on line, extending rectangular selection to new caret position.
fun void LineEndRectExtend=2432(,)
# Move caret one page up, extending rectangular selection to new caret position.
fun void PageUpRectExtend=2433(,)
# Move caret one page down, extending rectangular selection to new caret position.
fun void PageDownRectExtend=2434(,)
# Move caret to top of page, or one page up if already at top of page.
fun void StutteredPageUp=2435(,)
# Move caret to top of page, or one page up if already at top of page, extending selection to new caret position.
fun void StutteredPageUpExtend=2436(,)
# Move caret to bottom of page, or one page down if already at bottom of page.
fun void StutteredPageDown=2437(,)
# Move caret to bottom of page, or one page down if already at bottom of page, extending selection to new caret position.
fun void StutteredPageDownExtend=2438(,)
# Move caret left one word, position cursor at end of word.
fun void WordLeftEnd=2439(,)
# Move caret left one word, position cursor at end of word, extending selection to new caret position.
fun void WordLeftEndExtend=2440(,)
# Move caret right one word, position cursor at end of word.
fun void WordRightEnd=2441(,)
# Move caret right one word, position cursor at end of word, extending selection to new caret position.
fun void WordRightEndExtend=2442(,)
# Set the set of characters making up whitespace for when moving or selecting by word.
# Should be called after SetWordChars.
set void SetWhitespaceChars=2443(, string characters)
2013-08-28 02:44:27 +02:00
# Get the set of characters making up whitespace for when moving or selecting by word.
get int GetWhitespaceChars=2647(, stringresult characters)
# Set the set of characters making up punctuation characters
# Should be called after SetWordChars.
set void SetPunctuationChars=2648(, string characters)
# Get the set of characters making up punctuation characters
get int GetPunctuationChars=2649(, stringresult characters)
2009-04-25 01:35:41 +02:00
# Reset the set of characters for whitespace and word characters to the defaults.
fun void SetCharsDefault=2444(,)
# Get currently selected item position in the auto-completion list
2013-08-28 02:44:27 +02:00
get int AutoCGetCurrent=2445(,)
2009-04-25 01:35:41 +02:00
2010-07-13 00:19:51 +02:00
# Get currently selected item text in the auto-completion list
# Returns the length of the item text
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2019-05-04 20:14:48 +02:00
get int AutoCGetCurrentText=2610(, stringresult text)
2013-08-28 02:44:27 +02:00
enu CaseInsensitiveBehaviour=SC_CASEINSENSITIVEBEHAVIOUR_
val SC_CASEINSENSITIVEBEHAVIOUR_RESPECTCASE=0
val SC_CASEINSENSITIVEBEHAVIOUR_IGNORECASE=1
2019-07-21 15:26:02 +02:00
ali SC_CASEINSENSITIVEBEHAVIOUR_RESPECTCASE=RESPECT_CASE
ali SC_CASEINSENSITIVEBEHAVIOUR_IGNORECASE=IGNORE_CASE
2013-08-28 02:44:27 +02:00
# Set auto-completion case insensitive behaviour to either prefer case-sensitive matches or have no preference.
2019-07-21 15:26:02 +02:00
set void AutoCSetCaseInsensitiveBehaviour=2634(CaseInsensitiveBehaviour behaviour,)
2013-08-28 02:44:27 +02:00
# Get auto-completion case insensitive behaviour.
2019-07-21 15:26:02 +02:00
get CaseInsensitiveBehaviour AutoCGetCaseInsensitiveBehaviour=2635(,)
2013-08-28 02:44:27 +02:00
2015-06-07 23:19:26 +02:00
enu MultiAutoComplete=SC_MULTIAUTOC_
val SC_MULTIAUTOC_ONCE=0
val SC_MULTIAUTOC_EACH=1
# Change the effect of autocompleting when there are multiple selections.
2019-07-21 15:26:02 +02:00
set void AutoCSetMulti=2636(MultiAutoComplete multi,)
2015-06-07 23:19:26 +02:00
2019-05-04 20:14:48 +02:00
# Retrieve the effect of autocompleting when there are multiple selections.
2019-07-21 15:26:02 +02:00
get MultiAutoComplete AutoCGetMulti=2637(,)
2015-06-07 23:19:26 +02:00
2013-08-28 02:44:27 +02:00
enu Ordering=SC_ORDER_
val SC_ORDER_PRESORTED=0
val SC_ORDER_PERFORMSORT=1
val SC_ORDER_CUSTOM=2
2019-07-21 15:26:02 +02:00
ali SC_ORDER_PRESORTED=PRE_SORTED
ali SC_ORDER_PERFORMSORT=PERFORM_SORT
2013-08-28 02:44:27 +02:00
# Set the way autocompletion lists are ordered.
2019-07-21 15:26:02 +02:00
set void AutoCSetOrder=2660(Ordering order,)
2013-08-28 02:44:27 +02:00
# Get the way autocompletion lists are ordered.
2019-07-21 15:26:02 +02:00
get Ordering AutoCGetOrder=2661(,)
2010-07-13 00:19:51 +02:00
2009-04-25 01:35:41 +02:00
# Enlarge the document to a particular size of text bytes.
2019-07-21 15:26:02 +02:00
fun void Allocate=2446(position bytes,)
2009-04-25 01:35:41 +02:00
# Returns the target converted to UTF8.
# Return the length in bytes.
2019-07-21 15:26:02 +02:00
fun position TargetAsUTF8=2447(, stringresult s)
2009-04-25 01:35:41 +02:00
# Set the length of the utf8 argument for calling EncodedFromUTF8.
# Set to -1 and the string will be measured to the first nul.
2019-07-21 15:26:02 +02:00
fun void SetLengthForEncode=2448(position bytes,)
2009-04-25 01:35:41 +02:00
# Translates a UTF8 string into the document encoding.
# Return the length of the result in bytes.
# On error return 0.
2019-07-21 15:26:02 +02:00
fun position EncodedFromUTF8=2449(string utf8, stringresult encoded)
2009-04-25 01:35:41 +02:00
# Find the position of a column on a line taking into account tabs and
# multi-byte characters. If beyond end of line, return line end position.
2019-07-21 15:26:02 +02:00
fun position FindColumn=2456(line line, position column)
2009-04-25 01:35:41 +02:00
2010-08-22 01:59:56 +02:00
enu CaretSticky=SC_CARETSTICKY_
val SC_CARETSTICKY_OFF=0
val SC_CARETSTICKY_ON=1
val SC_CARETSTICKY_WHITESPACE=2
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SC_CARETSTICKY_WHITESPACE=WHITE_SPACE
2021-02-21 05:53:09 +01:00
# Can the caret preferred x position only be changed by explicit movement commands?
get CaretSticky GetCaretSticky=2457(,)
# Stop the caret preferred x position changing when the user types.
set void SetCaretSticky=2458(CaretSticky useCaretStickyBehaviour,)
2009-04-25 01:35:41 +02:00
# Switch between sticky and non-sticky: meant to be bound to a key.
fun void ToggleCaretSticky=2459(,)
# Enable/Disable convert-on-paste for line endings
set void SetPasteConvertEndings=2467(bool convert,)
# Get convert-on-paste setting
get bool GetPasteConvertEndings=2468(,)
2022-01-05 00:07:50 +01:00
# Replace the selection with text like a rectangular paste.
fun void ReplaceRectangular=2771(position length, string text)
2009-04-25 01:35:41 +02:00
# Duplicate the selection. If selection empty duplicate the line containing the caret.
fun void SelectionDuplicate=2469(,)
# Set background alpha of the caret line.
2019-07-21 15:26:02 +02:00
set void SetCaretLineBackAlpha=2470(Alpha alpha,)
2009-04-25 01:35:41 +02:00
# Get the background alpha of the caret line.
2019-07-21 15:26:02 +02:00
get Alpha GetCaretLineBackAlpha=2471(,)
2009-04-25 01:35:41 +02:00
enu CaretStyle=CARETSTYLE_
val CARETSTYLE_INVISIBLE=0
val CARETSTYLE_LINE=1
val CARETSTYLE_BLOCK=2
2019-05-04 20:14:48 +02:00
val CARETSTYLE_OVERSTRIKE_BAR=0
2019-07-21 15:26:02 +02:00
val CARETSTYLE_OVERSTRIKE_BLOCK=0x10
2022-01-05 00:07:50 +01:00
val CARETSTYLE_CURSES=0x20
2019-07-21 15:26:02 +02:00
val CARETSTYLE_INS_MASK=0xF
val CARETSTYLE_BLOCK_AFTER=0x100
2009-04-25 01:35:41 +02:00
# Set the style of the caret to be drawn.
2019-07-21 15:26:02 +02:00
set void SetCaretStyle=2512(CaretStyle caretStyle,)
2009-04-25 01:35:41 +02:00
# Returns the current style of the caret.
2019-07-21 15:26:02 +02:00
get CaretStyle GetCaretStyle=2513(,)
2009-04-25 01:35:41 +02:00
# Set the indicator used for IndicatorFillRange and IndicatorClearRange
set void SetIndicatorCurrent=2500(int indicator,)
# Get the current indicator
get int GetIndicatorCurrent=2501(,)
# Set the value used for IndicatorFillRange
set void SetIndicatorValue=2502(int value,)
2013-08-28 02:44:27 +02:00
# Get the current indicator value
2009-04-25 01:35:41 +02:00
get int GetIndicatorValue=2503(,)
# Turn a indicator on over a range.
2019-07-21 15:26:02 +02:00
fun void IndicatorFillRange=2504(position start, position lengthFill)
2009-04-25 01:35:41 +02:00
# Turn a indicator off over a range.
2019-07-21 15:26:02 +02:00
fun void IndicatorClearRange=2505(position start, position lengthClear)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# Are any indicators present at pos?
fun int IndicatorAllOnFor=2506(position pos,)
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
# What value does a particular indicator have at a position?
fun int IndicatorValueAt=2507(int indicator, position pos)
2009-04-25 01:35:41 +02:00
# Where does a particular indicator start?
2021-02-21 05:53:09 +01:00
fun position IndicatorStart=2508(int indicator, position pos)
2009-04-25 01:35:41 +02:00
# Where does a particular indicator end?
2021-02-21 05:53:09 +01:00
fun position IndicatorEnd=2509(int indicator, position pos)
2009-04-25 01:35:41 +02:00
# Set number of entries in position cache
set void SetPositionCache=2514(int size,)
# How many entries are allocated to the position cache?
get int GetPositionCache=2515(,)
2022-01-05 00:07:50 +01:00
# Set maximum number of threads used for layout
set void SetLayoutThreads=2775(int threads,)
# Get maximum number of threads used for layout
get int GetLayoutThreads=2776(,)
2009-04-25 01:35:41 +02:00
# Copy the selection, if selection empty copy the line with the caret
fun void CopyAllowLine=2519(,)
2009-04-26 01:38:15 +02:00
# Compact the document buffer and return a read-only pointer to the
# characters in the document.
2019-07-21 15:26:02 +02:00
get pointer GetCharacterPointer=2520(,)
2009-04-26 01:38:15 +02:00
2013-08-28 02:44:27 +02:00
# Return a read-only pointer to a range of characters in the document.
# May move the gap so that the range is contiguous, but will only move up
2019-05-04 20:14:48 +02:00
# to lengthRange bytes.
2019-07-21 15:26:02 +02:00
get pointer GetRangePointer=2643(position start, position lengthRange)
2013-08-28 02:44:27 +02:00
# Return a position which, to avoid performance costs, should not be within
# the range of a call to GetRangePointer.
get position GetGapPosition=2644(,)
2009-06-24 21:09:31 +02:00
# Set the alpha fill colour of the given indicator.
2019-07-21 15:26:02 +02:00
set void IndicSetAlpha=2523(int indicator, Alpha alpha)
2009-06-24 21:09:31 +02:00
# Get the alpha fill colour of the given indicator.
2019-07-21 15:26:02 +02:00
get Alpha IndicGetAlpha=2524(int indicator,)
2009-06-24 21:09:31 +02:00
2011-07-18 00:30:49 +02:00
# Set the alpha outline colour of the given indicator.
2019-07-21 15:26:02 +02:00
set void IndicSetOutlineAlpha=2558(int indicator, Alpha alpha)
2011-07-18 00:30:49 +02:00
# Get the alpha outline colour of the given indicator.
2019-07-21 15:26:02 +02:00
get Alpha IndicGetOutlineAlpha=2559(int indicator,)
2011-07-18 00:30:49 +02:00
2009-06-24 21:09:31 +02:00
# Set extra ascent for each line
set void SetExtraAscent=2525(int extraAscent,)
# Get extra ascent for each line
get int GetExtraAscent=2526(,)
# Set extra descent for each line
set void SetExtraDescent=2527(int extraDescent,)
# Get extra descent for each line
get int GetExtraDescent=2528(,)
# Which symbol was defined for markerNumber with MarkerDefine
fun int MarkerSymbolDefined=2529(int markerNumber,)
# Set the text in the text margin for a line
2019-07-21 15:26:02 +02:00
set void MarginSetText=2530(line line, string text)
2009-06-24 21:09:31 +02:00
# Get the text in the text margin for a line
2019-07-21 15:26:02 +02:00
get int MarginGetText=2531(line line, stringresult text)
2009-06-24 21:09:31 +02:00
# Set the style number for the text margin for a line
2019-07-21 15:26:02 +02:00
set void MarginSetStyle=2532(line line, int style)
2009-06-24 21:09:31 +02:00
# Get the style number for the text margin for a line
2019-07-21 15:26:02 +02:00
get int MarginGetStyle=2533(line line,)
2009-06-24 21:09:31 +02:00
# Set the style in the text margin for a line
2019-07-21 15:26:02 +02:00
set void MarginSetStyles=2534(line line, string styles)
2009-06-24 21:09:31 +02:00
# Get the styles in the text margin for a line
2019-07-21 15:26:02 +02:00
get int MarginGetStyles=2535(line line, stringresult styles)
2009-06-24 21:09:31 +02:00
# Clear the margin text on all lines
fun void MarginTextClearAll=2536(,)
# Get the start of the range of style numbers used for margin text
set void MarginSetStyleOffset=2537(int style,)
# Get the start of the range of style numbers used for margin text
get int MarginGetStyleOffset=2538(,)
2011-07-18 00:30:49 +02:00
enu MarginOption=SC_MARGINOPTION_
val SC_MARGINOPTION_NONE=0
val SC_MARGINOPTION_SUBLINESELECT=1
2019-07-21 15:26:02 +02:00
ali SC_MARGINOPTION_SUBLINESELECT=SUB_LINE_SELECT
2011-07-18 00:30:49 +02:00
# Set the margin options.
2019-07-21 15:26:02 +02:00
set void SetMarginOptions=2539(MarginOption marginOptions,)
2011-07-18 00:30:49 +02:00
# Get the margin options.
2019-07-21 15:26:02 +02:00
get MarginOption GetMarginOptions=2557(,)
2011-07-18 00:30:49 +02:00
2009-06-24 21:09:31 +02:00
# Set the annotation text for a line
2019-07-21 15:26:02 +02:00
set void AnnotationSetText=2540(line line, string text)
2009-06-24 21:09:31 +02:00
# Get the annotation text for a line
2019-07-21 15:26:02 +02:00
get int AnnotationGetText=2541(line line, stringresult text)
2009-06-24 21:09:31 +02:00
# Set the style number for the annotations for a line
2019-07-21 15:26:02 +02:00
set void AnnotationSetStyle=2542(line line, int style)
2009-06-24 21:09:31 +02:00
# Get the style number for the annotations for a line
2019-07-21 15:26:02 +02:00
get int AnnotationGetStyle=2543(line line,)
2009-06-24 21:09:31 +02:00
# Set the annotation styles for a line
2019-07-21 15:26:02 +02:00
set void AnnotationSetStyles=2544(line line, string styles)
2009-06-24 21:09:31 +02:00
# Get the annotation styles for a line
2019-07-21 15:26:02 +02:00
get int AnnotationGetStyles=2545(line line, stringresult styles)
2009-06-24 21:09:31 +02:00
# Get the number of annotation lines for a line
2019-07-21 15:26:02 +02:00
get int AnnotationGetLines=2546(line line,)
2009-06-24 21:09:31 +02:00
# Clear the annotations from all lines
fun void AnnotationClearAll=2547(,)
enu AnnotationVisible=ANNOTATION_
val ANNOTATION_HIDDEN=0
val ANNOTATION_STANDARD=1
val ANNOTATION_BOXED=2
2015-06-07 23:19:26 +02:00
val ANNOTATION_INDENTED=3
2009-06-24 21:09:31 +02:00
# Set the visibility for the annotations for a view
2019-07-21 15:26:02 +02:00
set void AnnotationSetVisible=2548(AnnotationVisible visible,)
2009-06-24 21:09:31 +02:00
# Get the visibility for the annotations for a view
2019-07-21 15:26:02 +02:00
get AnnotationVisible AnnotationGetVisible=2549(,)
2009-06-24 21:09:31 +02:00
# Get the start of the range of style numbers used for annotations
set void AnnotationSetStyleOffset=2550(int style,)
# Get the start of the range of style numbers used for annotations
get int AnnotationGetStyleOffset=2551(,)
2013-08-28 02:44:27 +02:00
# Release all extended (>255) style numbers
fun void ReleaseAllExtendedStyles=2552(,)
# Allocate some extended (>255) style numbers and return the start of the range
fun int AllocateExtendedStyles=2553(int numberStyles,)
2019-07-21 15:26:02 +02:00
enu UndoFlags=UNDO_
val UNDO_NONE=0
2009-06-24 21:09:31 +02:00
val UNDO_MAY_COALESCE=1
# Add a container action to the undo stack
2019-07-21 15:26:02 +02:00
fun void AddUndoAction=2560(int token, UndoFlags flags)
2009-06-24 21:09:31 +02:00
2009-08-23 04:24:48 +02:00
# Find the position of a character from a point within the window.
fun position CharPositionFromPoint=2561(int x, int y)
# Find the position of a character from a point within the window.
# Return INVALID_POSITION if not close to text.
fun position CharPositionFromPointClose=2562(int x, int y)
2015-06-07 23:19:26 +02:00
# Set whether switching to rectangular mode while selecting with the mouse is allowed.
set void SetMouseSelectionRectangularSwitch=2668(bool mouseSelectionRectangularSwitch,)
# Whether switching to rectangular mode while selecting with the mouse is allowed.
get bool GetMouseSelectionRectangularSwitch=2669(,)
2009-08-23 04:24:48 +02:00
# Set whether multiple selections can be made
set void SetMultipleSelection=2563(bool multipleSelection,)
# Whether multiple selections can be made
get bool GetMultipleSelection=2564(,)
# Set whether typing can be performed into multiple selections
set void SetAdditionalSelectionTyping=2565(bool additionalSelectionTyping,)
# Whether typing can be performed into multiple selections
get bool GetAdditionalSelectionTyping=2566(,)
# Set whether additional carets will blink
set void SetAdditionalCaretsBlink=2567(bool additionalCaretsBlink,)
# Whether additional carets will blink
get bool GetAdditionalCaretsBlink=2568(,)
2010-07-13 00:19:51 +02:00
# Set whether additional carets are visible
2019-05-04 20:14:48 +02:00
set void SetAdditionalCaretsVisible=2608(bool additionalCaretsVisible,)
2010-07-13 00:19:51 +02:00
# Whether additional carets are visible
get bool GetAdditionalCaretsVisible=2609(,)
2009-08-23 04:24:48 +02:00
# How many selections are there?
get int GetSelections=2570(,)
2013-08-28 02:44:27 +02:00
# Is every selected range empty?
get bool GetSelectionEmpty=2650(,)
2009-08-23 04:24:48 +02:00
# Clear selections to a single empty stream selection
fun void ClearSelections=2571(,)
# Set a simple selection
2019-05-04 20:14:48 +02:00
fun void SetSelection=2572(position caret, position anchor)
2009-08-23 04:24:48 +02:00
# Add a selection
2019-05-04 20:14:48 +02:00
fun void AddSelection=2573(position caret, position anchor)
2009-08-23 04:24:48 +02:00
Updated to Scintilla 5.4.1 & Lexilla 5.3.0
Scintilla 5.4.1
https://www.scintilla.org/scintilla541.zip
Released 27 December 2023.
1. Add IDocumentEditable interface to allow efficient interaction with document objects which may not be visible in a Scintilla instance. This feature is provisonal and may change before being declared stable. For better type-safety, the ScintillaCall C++ API uses IDocumentEditable* where void* was used before which may require changes to client code that uses document pointer APIs DocPointer, SetDocPointer, CreateDocument, AddRefDocument, and ReleaseDocument.
2. Ctrl-click on a selection deselects it in multiple selection mode.
3. Add SCI_SELECTIONFROMPOINT for modifying multiple selections.
4. Add SCI_SETMOVEEXTENDSSELECTION and SCI_CHANGESELECTIONMODE to simplify selection mode manipulation.
5. Improve performance of global replace by reducing cache invalidation overhead. [Feature #1502](https://sourceforge.net/p/scintilla/feature-requests/1502/).
6. Fix regular expression search for "\<" matching beginning of search when not beginning of word and for "\>" not matching line end. [Bug #2157](https://sourceforge.net/p/scintilla/bugs/2157/).
7. Fix regular expression search failure when search for "\<" followed by search for "\>". [Bug #2413](https://sourceforge.net/p/scintilla/bugs/2413/).
8. Fix regular expression assertion (^, $, \b. \B) failures when using SCFIND_CXX11REGEX. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
9. Fix regular expression bug in reverse direction where shortened match returned. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
10. Avoid character fragments in regular expression search results. [Bug #2405](https://sourceforge.net/p/scintilla/bugs/2405/).
11. With a document that does not have the SC_DOCUMENTOPTION_TEXT_LARGE option set, allocating more than 2G (calling SCI_ALLOCATE or similar) will now fail with SC_STATUS_FAILURE.
12. Protect SCI_REPLACETARGET, SCI_REPLACETARGETMINIMAL, and SCI_REPLACETARGETRE from application changing target in notification handlers. [Bug #2289](https://sourceforge.net/p/scintilla/bugs/2289/).
Lexilla 5.3.0
https://www.scintilla.org/lexilla530.zip
Released 27 December 2023.
1. Fix calling AddStaticLexerModule by defining as C++ instead of C which matches header. [Bug #2421](https://sourceforge.net/p/scintilla/bugs/2421/).
2. Bash: Fix shift operator << incorrectly recognized as here-doc. [Issue #215](https://github.com/ScintillaOrg/lexilla/issues/215).
3. Bash: Fix termination of '${' with first unquoted '}' instead of nesting. [Issue #216](https://github.com/ScintillaOrg/lexilla/issues/216).
4. HTML: JavaScript double-quoted strings may escape line end with '\'. [Issue #214](https://github.com/ScintillaOrg/lexilla/issues/214).
5. Lua: recognize --- doc comments. Defined by [LDoc](https://github.com/lunarmodules/ldoc). Does not recognize --[[-- doc comments which seem less common.
Close #14375
2023-11-19 18:46:55 +01:00
# Find the selection index for a point. -1 when not at a selection.
fun int SelectionFromPoint=2474(int x, int y)
2015-06-07 23:19:26 +02:00
# Drop one selection
fun void DropSelectionN=2671(int selection,)
2009-08-23 04:24:48 +02:00
# Set the main selection
set void SetMainSelection=2574(int selection,)
# Which selection is the main selection
get int GetMainSelection=2575(,)
2019-05-04 20:14:48 +02:00
# Set the caret position of the nth selection.
set void SetSelectionNCaret=2576(int selection, position caret)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the caret position of the nth selection.
2009-08-23 04:24:48 +02:00
get position GetSelectionNCaret=2577(int selection,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Set the anchor position of the nth selection.
set void SetSelectionNAnchor=2578(int selection, position anchor)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the anchor position of the nth selection.
2009-08-23 04:24:48 +02:00
get position GetSelectionNAnchor=2579(int selection,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Set the virtual space of the caret of the nth selection.
2019-07-21 15:26:02 +02:00
set void SetSelectionNCaretVirtualSpace=2580(int selection, position space)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the virtual space of the caret of the nth selection.
2019-07-21 15:26:02 +02:00
get position GetSelectionNCaretVirtualSpace=2581(int selection,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Set the virtual space of the anchor of the nth selection.
2019-07-21 15:26:02 +02:00
set void SetSelectionNAnchorVirtualSpace=2582(int selection, position space)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the virtual space of the anchor of the nth selection.
2019-07-21 15:26:02 +02:00
get position GetSelectionNAnchorVirtualSpace=2583(int selection,)
2009-08-23 04:24:48 +02:00
# Sets the position that starts the selection - this becomes the anchor.
2019-05-04 20:14:48 +02:00
set void SetSelectionNStart=2584(int selection, position anchor)
2009-08-23 04:24:48 +02:00
# Returns the position at the start of the selection.
2010-07-13 00:19:51 +02:00
get position GetSelectionNStart=2585(int selection,)
2009-08-23 04:24:48 +02:00
2021-02-21 05:53:09 +01:00
# Returns the virtual space at the start of the selection.
get position GetSelectionNStartVirtualSpace=2726(int selection,)
2009-08-23 04:24:48 +02:00
# Sets the position that ends the selection - this becomes the currentPosition.
2019-05-04 20:14:48 +02:00
set void SetSelectionNEnd=2586(int selection, position caret)
2009-08-23 04:24:48 +02:00
2021-02-21 05:53:09 +01:00
# Returns the virtual space at the end of the selection.
get position GetSelectionNEndVirtualSpace=2727(int selection,)
2009-08-23 04:24:48 +02:00
# Returns the position at the end of the selection.
2010-07-13 00:19:51 +02:00
get position GetSelectionNEnd=2587(int selection,)
2009-08-23 04:24:48 +02:00
2019-05-04 20:14:48 +02:00
# Set the caret position of the rectangular selection.
set void SetRectangularSelectionCaret=2588(position caret,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the caret position of the rectangular selection.
2009-08-23 04:24:48 +02:00
get position GetRectangularSelectionCaret=2589(,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Set the anchor position of the rectangular selection.
set void SetRectangularSelectionAnchor=2590(position anchor,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the anchor position of the rectangular selection.
2009-08-23 04:24:48 +02:00
get position GetRectangularSelectionAnchor=2591(,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Set the virtual space of the caret of the rectangular selection.
2019-07-21 15:26:02 +02:00
set void SetRectangularSelectionCaretVirtualSpace=2592(position space,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the virtual space of the caret of the rectangular selection.
2019-07-21 15:26:02 +02:00
get position GetRectangularSelectionCaretVirtualSpace=2593(,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Set the virtual space of the anchor of the rectangular selection.
2019-07-21 15:26:02 +02:00
set void SetRectangularSelectionAnchorVirtualSpace=2594(position space,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return the virtual space of the anchor of the rectangular selection.
2019-07-21 15:26:02 +02:00
get position GetRectangularSelectionAnchorVirtualSpace=2595(,)
2009-08-23 04:24:48 +02:00
enu VirtualSpace=SCVS_
val SCVS_NONE=0
val SCVS_RECTANGULARSELECTION=1
val SCVS_USERACCESSIBLE=2
2019-05-04 20:14:48 +02:00
val SCVS_NOWRAPLINESTART=4
2009-08-23 04:24:48 +02:00
2019-07-21 15:26:02 +02:00
ali SCVS_RECTANGULARSELECTION=RECTANGULAR_SELECTION
ali SCVS_USERACCESSIBLE=USER_ACCESSIBLE
ali SCVS_NOWRAPLINESTART=NO_WRAP_LINE_START
2019-05-04 20:14:48 +02:00
# Set options for virtual space behaviour.
2019-07-21 15:26:02 +02:00
set void SetVirtualSpaceOptions=2596(VirtualSpace virtualSpaceOptions,)
2021-02-21 05:53:09 +01:00
2019-05-04 20:14:48 +02:00
# Return options for virtual space behaviour.
2019-07-21 15:26:02 +02:00
get VirtualSpace GetVirtualSpaceOptions=2597(,)
2009-08-23 04:24:48 +02:00
2019-07-21 15:26:02 +02:00
# On GTK, allow selecting the modifier key to use for mouse-based
2009-08-23 04:24:48 +02:00
# rectangular selection. Often the window manager requires Alt+Mouse Drag
# for moving windows.
# Valid values are SCMOD_CTRL(default), SCMOD_ALT, or SCMOD_SUPER.
set void SetRectangularSelectionModifier=2598(int modifier,)
# Get the modifier key used for rectangular selection.
get int GetRectangularSelectionModifier=2599(,)
# Set the foreground colour of additional selections.
# Must have previously called SetSelFore with non-zero first argument for this to have an effect.
set void SetAdditionalSelFore=2600(colour fore,)
# Set the background colour of additional selections.
# Must have previously called SetSelBack with non-zero first argument for this to have an effect.
set void SetAdditionalSelBack=2601(colour back,)
# Set the alpha of the selection.
2019-07-21 15:26:02 +02:00
set void SetAdditionalSelAlpha=2602(Alpha alpha,)
2009-08-23 04:24:48 +02:00
# Get the alpha of the selection.
2019-07-21 15:26:02 +02:00
get Alpha GetAdditionalSelAlpha=2603(,)
2009-08-23 04:24:48 +02:00
# Set the foreground colour of additional carets.
set void SetAdditionalCaretFore=2604(colour fore,)
# Get the foreground colour of additional carets.
get colour GetAdditionalCaretFore=2605(,)
# Set the main selection to the next selection.
fun void RotateSelection=2606(,)
# Swap that caret and anchor of the main selection.
fun void SwapMainAnchorCaret=2607(,)
2019-05-04 20:14:48 +02:00
# Add the next occurrence of the main selection to the set of selections as main.
# If the current selection is empty then select word around caret.
fun void MultipleSelectAddNext=2688(,)
# Add each occurrence of the main selection in the target to the set of selections.
# If the current selection is empty then select word around caret.
fun void MultipleSelectAddEach=2689(,)
2010-08-22 01:59:56 +02:00
# Indicate that the internal state of a lexer has changed over a range and therefore
# there may be a need to redraw.
fun int ChangeLexerState=2617(position start, position end)
2011-03-22 01:16:49 +01:00
# Find the next line at or after lineStart that is a contracted fold header line.
# Return -1 when no more lines.
2019-07-21 15:26:02 +02:00
fun line ContractedFoldNext=2618(line lineStart,)
2011-03-22 01:16:49 +01:00
# Centre current line in window.
fun void VerticalCentreCaret=2619(,)
2011-07-18 00:30:49 +02:00
# Move the selected lines up one line, shifting the line above after the selection
fun void MoveSelectedLinesUp=2620(,)
# Move the selected lines down one line, shifting the line below before the selection
fun void MoveSelectedLinesDown=2621(,)
# Set the identifier reported as idFrom in notification messages.
set void SetIdentifier=2622(int identifier,)
# Get the identifier.
get int GetIdentifier=2623(,)
2013-08-28 02:44:27 +02:00
# Set the width for future RGBA image data.
set void RGBAImageSetWidth=2624(int width,)
# Set the height for future RGBA image data.
set void RGBAImageSetHeight=2625(int height,)
# Set the scale factor in percent for future RGBA image data.
set void RGBAImageSetScale=2651(int scalePercent,)
# Define a marker from RGBA data.
# It has the width and height from RGBAImageSetWidth/Height
fun void MarkerDefineRGBAImage=2626(int markerNumber, string pixels)
# Register an RGBA image for use in autocompletion lists.
# It has the width and height from RGBAImageSetWidth/Height
fun void RegisterRGBAImage=2627(int type, string pixels)
# Scroll to start of document.
fun void ScrollToStart=2628(,)
# Scroll to end of document.
fun void ScrollToEnd=2629(,)
2019-05-04 20:14:48 +02:00
enu Technology=SC_TECHNOLOGY_
2013-08-28 02:44:27 +02:00
val SC_TECHNOLOGY_DEFAULT=0
val SC_TECHNOLOGY_DIRECTWRITE=1
2015-06-07 23:19:26 +02:00
val SC_TECHNOLOGY_DIRECTWRITERETAIN=2
val SC_TECHNOLOGY_DIRECTWRITEDC=3
2013-08-28 02:44:27 +02:00
2019-07-21 15:26:02 +02:00
ali SC_TECHNOLOGY_DIRECTWRITE=DIRECT_WRITE
ali SC_TECHNOLOGY_DIRECTWRITERETAIN=DIRECT_WRITE_RETAIN
ali SC_TECHNOLOGY_DIRECTWRITEDC=DIRECT_WRITE_D_C
2013-08-28 02:44:27 +02:00
# Set the technology used.
2019-07-21 15:26:02 +02:00
set void SetTechnology=2630(Technology technology,)
2013-08-28 02:44:27 +02:00
# Get the tech.
2019-07-21 15:26:02 +02:00
get Technology GetTechnology=2631(,)
2013-08-28 02:44:27 +02:00
# Create an ILoader*.
2019-07-21 15:26:02 +02:00
fun pointer CreateLoader=2632(position bytes, DocumentOption documentOptions)
2013-08-28 02:44:27 +02:00
2022-01-05 00:07:50 +01:00
# On macOS, show a find indicator.
2013-08-28 02:44:27 +02:00
fun void FindIndicatorShow=2640(position start, position end)
2022-01-05 00:07:50 +01:00
# On macOS, flash a find indicator, then fade out.
2013-08-28 02:44:27 +02:00
fun void FindIndicatorFlash=2641(position start, position end)
2022-01-05 00:07:50 +01:00
# On macOS, hide the find indicator.
2013-08-28 02:44:27 +02:00
fun void FindIndicatorHide=2642(,)
# Move caret to before first visible character on display line.
# If already there move to first character on display line.
fun void VCHomeDisplay=2652(,)
# Like VCHomeDisplay but extending selection to new caret position.
fun void VCHomeDisplayExtend=2653(,)
# Is the caret line always visible?
get bool GetCaretLineVisibleAlways=2654(,)
# Sets the caret line to always visible.
set void SetCaretLineVisibleAlways=2655(bool alwaysVisible,)
2015-06-07 23:19:26 +02:00
# Line end types which may be used in addition to LF, CR, and CRLF
# SC_LINE_END_TYPE_UNICODE includes U+2028 Line Separator,
# U+2029 Paragraph Separator, and U+0085 Next Line
enu LineEndType=SC_LINE_END_TYPE_
val SC_LINE_END_TYPE_DEFAULT=0
val SC_LINE_END_TYPE_UNICODE=1
# Set the line end types that the application wants to use. May not be used if incompatible with lexer or encoding.
2019-07-21 15:26:02 +02:00
set void SetLineEndTypesAllowed=2656(LineEndType lineEndBitSet,)
2015-06-07 23:19:26 +02:00
# Get the line end types currently allowed.
2019-07-21 15:26:02 +02:00
get LineEndType GetLineEndTypesAllowed=2657(,)
2015-06-07 23:19:26 +02:00
# Get the line end types currently recognised. May be a subset of the allowed types due to lexer limitation.
2019-07-21 15:26:02 +02:00
get LineEndType GetLineEndTypesActive=2658(,)
2015-06-07 23:19:26 +02:00
# Set the way a character is drawn.
set void SetRepresentation=2665(string encodedCharacter, string representation)
2022-01-05 00:07:50 +01:00
# Get the way a character is drawn.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
get int GetRepresentation=2666(string encodedCharacter, stringresult representation)
# Remove a character representation.
fun void ClearRepresentation=2667(string encodedCharacter,)
2022-01-05 00:07:50 +01:00
# Clear representations to default.
fun void ClearAllRepresentations=2770(,)
# Can draw representations in various ways
enu RepresentationAppearance=SC_REPRESENTATION
val SC_REPRESENTATION_PLAIN=0
val SC_REPRESENTATION_BLOB=1
val SC_REPRESENTATION_COLOUR=0x10
# Set the appearance of a representation.
set void SetRepresentationAppearance=2766(string encodedCharacter, RepresentationAppearance appearance)
# Get the appearance of a representation.
get RepresentationAppearance GetRepresentationAppearance=2767(string encodedCharacter,)
# Set the colour of a representation.
set void SetRepresentationColour=2768(string encodedCharacter, colouralpha colour)
# Get the colour of a representation.
get colouralpha GetRepresentationColour=2769(string encodedCharacter,)
2021-02-21 05:53:09 +01:00
# Set the end of line annotation text for a line
set void EOLAnnotationSetText=2740(line line, string text)
# Get the end of line annotation text for a line
get int EOLAnnotationGetText=2741(line line, stringresult text)
# Set the style number for the end of line annotations for a line
set void EOLAnnotationSetStyle=2742(line line, int style)
# Get the style number for the end of line annotations for a line
get int EOLAnnotationGetStyle=2743(line line,)
# Clear the end of annotations from all lines
fun void EOLAnnotationClearAll=2744(,)
enu EOLAnnotationVisible=EOLANNOTATION_
2022-01-05 00:07:50 +01:00
val EOLANNOTATION_HIDDEN=0x0
val EOLANNOTATION_STANDARD=0x1
val EOLANNOTATION_BOXED=0x2
val EOLANNOTATION_STADIUM=0x100
val EOLANNOTATION_FLAT_CIRCLE=0x101
val EOLANNOTATION_ANGLE_CIRCLE=0x102
val EOLANNOTATION_CIRCLE_FLAT=0x110
val EOLANNOTATION_FLATS=0x111
val EOLANNOTATION_ANGLE_FLAT=0x112
val EOLANNOTATION_CIRCLE_ANGLE=0x120
val EOLANNOTATION_FLAT_ANGLE=0x121
val EOLANNOTATION_ANGLES=0x122
2021-02-21 05:53:09 +01:00
# Set the visibility for the end of line annotations for a view
set void EOLAnnotationSetVisible=2745(EOLAnnotationVisible visible,)
# Get the visibility for the end of line annotations for a view
get EOLAnnotationVisible EOLAnnotationGetVisible=2746(,)
# Get the start of the range of style numbers used for end of line annotations
set void EOLAnnotationSetStyleOffset=2747(int style,)
# Get the start of the range of style numbers used for end of line annotations
get int EOLAnnotationGetStyleOffset=2748(,)
2022-01-05 00:07:50 +01:00
enu Supports=SC_SUPPORTS_
val SC_SUPPORTS_LINE_DRAWS_FINAL=0
val SC_SUPPORTS_PIXEL_DIVISIONS=1
val SC_SUPPORTS_FRACTIONAL_STROKE_WIDTH=2
val SC_SUPPORTS_TRANSLUCENT_STROKE=3
val SC_SUPPORTS_PIXEL_MODIFICATION=4
val SC_SUPPORTS_THREAD_SAFE_MEASURE_WIDTHS=5
# Get whether a feature is supported
get bool SupportsFeature=2750(Supports feature,)
enu LineCharacterIndexType=SC_LINECHARACTERINDEX_
val SC_LINECHARACTERINDEX_NONE=0
val SC_LINECHARACTERINDEX_UTF32=1
val SC_LINECHARACTERINDEX_UTF16=2
# Retrieve line character index state.
get LineCharacterIndexType GetLineCharacterIndex=2710(,)
# Request line character index be created or its use count increased.
fun void AllocateLineCharacterIndex=2711(LineCharacterIndexType lineCharacterIndex,)
# Decrease use count of line character index and remove if 0.
fun void ReleaseLineCharacterIndex=2712(LineCharacterIndexType lineCharacterIndex,)
# Retrieve the document line containing a position measured in index units.
fun line LineFromIndexPosition=2713(position pos, LineCharacterIndexType lineCharacterIndex)
# Retrieve the position measured in index units at the start of a document line.
fun position IndexPositionFromLine=2714(line line, LineCharacterIndexType lineCharacterIndex)
2009-04-25 01:35:41 +02:00
# Start notifying the container of all key presses and commands.
fun void StartRecord=3001(,)
# Stop notifying the container of all key presses and commands.
fun void StopRecord=3002(,)
# Retrieve the lexing language of the document.
get int GetLexer=4002(,)
# Colourise a segment of the document using the current lexing language.
fun void Colourise=4003(position start, position end)
# Set up a value that may be used by a lexer for some optional feature.
set void SetProperty=4004(string key, string value)
# Maximum value of keywordSet parameter of SetKeyWords.
val KEYWORDSET_MAX=8
# Set up the key words used by the lexer.
2019-05-04 20:14:48 +02:00
set void SetKeyWords=4005(int keyWordSet, string keyWords)
2009-04-25 01:35:41 +02:00
# Retrieve a "property" value previously set with SetProperty.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2019-05-04 20:14:48 +02:00
get int GetProperty=4008(string key, stringresult value)
2009-04-25 01:35:41 +02:00
# Retrieve a "property" value previously set with SetProperty,
# with "$()" variable replacement on returned buffer.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2019-05-04 20:14:48 +02:00
get int GetPropertyExpanded=4009(string key, stringresult value)
2009-04-25 01:35:41 +02:00
# Retrieve a "property" value previously set with SetProperty,
# interpreted as an int AFTER any "$()" variable replacement.
2019-05-04 20:14:48 +02:00
get int GetPropertyInt=4010(string key, int defaultValue)
2009-04-25 01:35:41 +02:00
2010-07-13 00:19:51 +02:00
# Retrieve the name of the lexer.
# Return the length of the text.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2019-05-04 20:14:48 +02:00
get int GetLexerLanguage=4012(, stringresult language)
2010-07-13 00:19:51 +02:00
2010-08-22 01:59:56 +02:00
# For private communication between an application and a known lexer.
2019-07-21 15:26:02 +02:00
fun pointer PrivateLexerCall=4013(int operation, pointer pointer)
2010-08-22 01:59:56 +02:00
# Retrieve a '\n' separated list of properties understood by the current lexer.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2010-08-22 01:59:56 +02:00
fun int PropertyNames=4014(, stringresult names)
enu TypeProperty=SC_TYPE_
val SC_TYPE_BOOLEAN=0
val SC_TYPE_INTEGER=1
val SC_TYPE_STRING=2
# Retrieve the type of a property.
2019-07-21 15:26:02 +02:00
fun TypeProperty PropertyType=4015(string name,)
2010-08-22 01:59:56 +02:00
# Describe a property.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2010-08-22 01:59:56 +02:00
fun int DescribeProperty=4016(string name, stringresult description)
# Retrieve a '\n' separated list of descriptions of the keyword sets understood by the current lexer.
2015-06-07 23:19:26 +02:00
# Result is NUL-terminated.
2010-08-22 01:59:56 +02:00
fun int DescribeKeyWordSets=4017(, stringresult descriptions)
2015-06-07 23:19:26 +02:00
# Bit set of LineEndType enumertion for which line ends beyond the standard
# LF, CR, and CRLF are supported by the lexer.
2022-01-05 00:07:50 +01:00
get LineEndType GetLineEndTypesSupported=4018(,)
2015-06-07 23:19:26 +02:00
# Allocate a set of sub styles for a particular base style, returning start of range
fun int AllocateSubStyles=4020(int styleBase, int numberStyles)
# The starting style number for the sub styles associated with a base style
get int GetSubStylesStart=4021(int styleBase,)
# The number of sub styles associated with a base style
get int GetSubStylesLength=4022(int styleBase,)
# For a sub style, return the base style, else return the argument.
get int GetStyleFromSubStyle=4027(int subStyle,)
# For a secondary style, return the primary style, else return the argument.
get int GetPrimaryStyleFromStyle=4028(int style,)
# Free allocated sub styles
fun void FreeSubStyles=4023(,)
# Set the identifiers that are shown in a particular style
set void SetIdentifiers=4024(int style, string identifiers)
# Where styles are duplicated by a feature such as active/inactive code
# return the distance between the two types.
get int DistanceToSecondaryStyles=4025(,)
# Get the set of base styles that can be extended with sub styles
# Result is NUL-terminated.
get int GetSubStyleBases=4026(, stringresult styles)
2019-05-04 20:14:48 +02:00
# Retrieve the number of named styles for the lexer.
get int GetNamedStyles=4029(,)
# Retrieve the name of a style.
# Result is NUL-terminated.
fun int NameOfStyle=4030(int style, stringresult name)
# Retrieve a ' ' separated list of style tags like "literal quoted string".
# Result is NUL-terminated.
fun int TagsOfStyle=4031(int style, stringresult tags)
# Retrieve a description of a style.
# Result is NUL-terminated.
fun int DescriptionOfStyle=4032(int style, stringresult description)
2021-02-21 05:53:09 +01:00
# Set the lexer from an ILexer*.
set void SetILexer=4033(, pointer ilexer)
2009-04-25 01:35:41 +02:00
# Notifications
# Type of modification and the action which caused the modification.
# These are defined as a bit mask to make it easy to specify which notifications are wanted.
# One bit is set from each of SC_MOD_* and SC_PERFORMED_*.
2013-08-28 02:44:27 +02:00
enu ModificationFlags=SC_MOD_ SC_PERFORMED_ SC_MULTISTEPUNDOREDO SC_LASTSTEPINUNDOREDO SC_MULTILINEUNDOREDO SC_STARTACTION SC_MODEVENTMASKALL
2019-07-21 15:26:02 +02:00
val SC_MOD_NONE=0x0
2009-04-25 01:35:41 +02:00
val SC_MOD_INSERTTEXT=0x1
val SC_MOD_DELETETEXT=0x2
val SC_MOD_CHANGESTYLE=0x4
val SC_MOD_CHANGEFOLD=0x8
val SC_PERFORMED_USER=0x10
val SC_PERFORMED_UNDO=0x20
val SC_PERFORMED_REDO=0x40
val SC_MULTISTEPUNDOREDO=0x80
val SC_LASTSTEPINUNDOREDO=0x100
val SC_MOD_CHANGEMARKER=0x200
val SC_MOD_BEFOREINSERT=0x400
val SC_MOD_BEFOREDELETE=0x800
val SC_MULTILINEUNDOREDO=0x1000
val SC_STARTACTION=0x2000
val SC_MOD_CHANGEINDICATOR=0x4000
val SC_MOD_CHANGELINESTATE=0x8000
2009-06-24 21:09:31 +02:00
val SC_MOD_CHANGEMARGIN=0x10000
val SC_MOD_CHANGEANNOTATION=0x20000
val SC_MOD_CONTAINER=0x40000
2010-08-22 01:59:56 +02:00
val SC_MOD_LEXERSTATE=0x80000
2015-06-07 23:19:26 +02:00
val SC_MOD_INSERTCHECK=0x100000
val SC_MOD_CHANGETABSTOPS=0x200000
2021-02-21 05:53:09 +01:00
val SC_MOD_CHANGEEOLANNOTATION=0x400000
val SC_MODEVENTMASKALL=0x7FFFFF
2009-04-25 01:35:41 +02:00
2019-07-21 15:26:02 +02:00
ali SC_MOD_INSERTTEXT=INSERT_TEXT
ali SC_MOD_DELETETEXT=DELETE_TEXT
ali SC_MOD_CHANGESTYLE=CHANGE_STYLE
ali SC_MOD_CHANGEFOLD=CHANGE_FOLD
ali SC_MULTISTEPUNDOREDO=MULTI_STEP_UNDO_REDO
ali SC_LASTSTEPINUNDOREDO=LAST_STEP_IN_UNDO_REDO
ali SC_MOD_CHANGEMARKER=CHANGE_MARKER
ali SC_MOD_BEFOREINSERT=BEFORE_INSERT
ali SC_MOD_BEFOREDELETE=BEFORE_DELETE
ali SC_MULTILINEUNDOREDO=MULTILINE_UNDO_REDO
ali SC_STARTACTION=START_ACTION
ali SC_MOD_CHANGEINDICATOR=CHANGE_INDICATOR
ali SC_MOD_CHANGELINESTATE=CHANGE_LINE_STATE
ali SC_MOD_CHANGEMARGIN=CHANGE_MARGIN
ali SC_MOD_CHANGEANNOTATION=CHANGE_ANNOTATION
ali SC_MOD_LEXERSTATE=LEXER_STATE
ali SC_MOD_INSERTCHECK=INSERT_CHECK
ali SC_MOD_CHANGETABSTOPS=CHANGE_TAB_STOPS
2021-02-21 05:53:09 +01:00
ali SC_MOD_CHANGEEOLANNOTATION=CHANGE_E_O_L_ANNOTATION
2019-07-21 15:26:02 +02:00
ali SC_MODEVENTMASKALL=EVENT_MASK_ALL
2011-03-22 01:16:49 +01:00
enu Update=SC_UPDATE_
2022-01-05 00:07:50 +01:00
val SC_UPDATE_NONE=0x0
2011-03-22 01:16:49 +01:00
val SC_UPDATE_CONTENT=0x1
val SC_UPDATE_SELECTION=0x2
val SC_UPDATE_V_SCROLL=0x4
val SC_UPDATE_H_SCROLL=0x8
2009-04-25 01:35:41 +02:00
# For compatibility, these go through the COMMAND notification rather than NOTIFY
# and should have had exactly the same values as the EN_* constants.
# Unfortunately the SETFOCUS and KILLFOCUS are flipped over from EN_*
# As clients depend on these constants, this will not be changed.
2022-01-05 00:07:50 +01:00
enu FocusChange=SCEN_
2009-04-25 01:35:41 +02:00
val SCEN_CHANGE=768
val SCEN_SETFOCUS=512
val SCEN_KILLFOCUS=256
# Symbolic key codes and modifier flags.
# ASCII and other printable characters below 256.
# Extended keys above 300.
enu Keys=SCK_
val SCK_DOWN=300
val SCK_UP=301
val SCK_LEFT=302
val SCK_RIGHT=303
val SCK_HOME=304
val SCK_END=305
val SCK_PRIOR=306
val SCK_NEXT=307
val SCK_DELETE=308
val SCK_INSERT=309
val SCK_ESCAPE=7
val SCK_BACK=8
val SCK_TAB=9
val SCK_RETURN=13
val SCK_ADD=310
val SCK_SUBTRACT=311
val SCK_DIVIDE=312
val SCK_WIN=313
val SCK_RWIN=314
val SCK_MENU=315
2019-07-21 15:26:02 +02:00
ali SCK_RWIN=R_WIN
2009-04-25 01:35:41 +02:00
enu KeyMod=SCMOD_
val SCMOD_NORM=0
val SCMOD_SHIFT=1
val SCMOD_CTRL=2
val SCMOD_ALT=4
2009-08-23 04:24:48 +02:00
val SCMOD_SUPER=8
2011-07-18 00:30:49 +02:00
val SCMOD_META=16
2009-04-25 01:35:41 +02:00
2019-05-04 20:14:48 +02:00
enu CompletionMethods=SC_AC_
val SC_AC_FILLUP=1
val SC_AC_DOUBLECLICK=2
val SC_AC_TAB=3
val SC_AC_NEWLINE=4
val SC_AC_COMMAND=5
2022-12-10 13:35:16 +01:00
val SC_AC_SINGLE_CHOICE=6
2019-05-04 20:14:48 +02:00
2019-07-21 15:26:02 +02:00
ali SC_AC_FILLUP=FILL_UP
ali SC_AC_DOUBLECLICK=DOUBLE_CLICK
# characterSource for SCN_CHARADDED
enu CharacterSource=SC_CHARACTERSOURCE_
# Direct input characters.
val SC_CHARACTERSOURCE_DIRECT_INPUT=0
# IME (inline mode) or dead key tentative input characters.
val SC_CHARACTERSOURCE_TENTATIVE_INPUT=1
# IME (either inline or windowed mode) full composited string.
val SC_CHARACTERSOURCE_IME_RESULT=2
2009-04-25 01:35:41 +02:00
# Events
evt void StyleNeeded=2000(int position)
2019-07-21 15:26:02 +02:00
evt void CharAdded=2001(int ch, int characterSource)
2009-04-25 01:35:41 +02:00
evt void SavePointReached=2002(void)
evt void SavePointLeft=2003(void)
evt void ModifyAttemptRO=2004(void)
2019-07-21 15:26:02 +02:00
# GTK Specific to work around focus and accelerator problems:
2009-04-25 01:35:41 +02:00
evt void Key=2005(int ch, int modifiers)
2011-07-18 00:30:49 +02:00
evt void DoubleClick=2006(int modifiers, int position, int line)
evt void UpdateUI=2007(int updated)
evt void Modified=2008(int position, int modificationType, string text, int length, int linesAdded, int line, int foldLevelNow, int foldLevelPrev, int token, int annotationLinesAdded)
2009-04-25 01:35:41 +02:00
evt void MacroRecord=2009(int message, int wParam, int lParam)
evt void MarginClick=2010(int modifiers, int position, int margin)
evt void NeedShown=2011(int position, int length)
evt void Painted=2013(void)
2019-05-04 20:14:48 +02:00
evt void UserListSelection=2014(int listType, string text, int position, int ch, CompletionMethods listCompletionMethod)
2009-04-25 01:35:41 +02:00
evt void URIDropped=2015(string text)
2011-07-18 00:30:49 +02:00
evt void DwellStart=2016(int position, int x, int y)
evt void DwellEnd=2017(int position, int x, int y)
2009-04-25 01:35:41 +02:00
evt void Zoom=2018(void)
evt void HotSpotClick=2019(int modifiers, int position)
evt void HotSpotDoubleClick=2020(int modifiers, int position)
evt void CallTipClick=2021(int position)
2019-05-04 20:14:48 +02:00
evt void AutoCSelection=2022(string text, int position, int ch, CompletionMethods listCompletionMethod)
2009-04-25 01:35:41 +02:00
evt void IndicatorClick=2023(int modifiers, int position)
evt void IndicatorRelease=2024(int modifiers, int position)
2009-04-26 01:38:15 +02:00
evt void AutoCCancelled=2025(void)
2009-06-24 21:09:31 +02:00
evt void AutoCCharDeleted=2026(void)
2011-03-22 01:16:49 +01:00
evt void HotSpotReleaseClick=2027(int modifiers, int position)
2015-06-07 23:19:26 +02:00
evt void FocusIn=2028(void)
evt void FocusOut=2029(void)
2019-05-04 20:14:48 +02:00
evt void AutoCCompleted=2030(string text, int position, int ch, CompletionMethods listCompletionMethod)
evt void MarginRightClick=2031(int modifiers, int position, int margin)
evt void AutoCSelectionChange=2032(int listType, string text, int position)
2013-08-28 02:44:27 +02:00
2015-06-07 23:19:26 +02:00
cat Provisional
2013-08-28 02:44:27 +02:00
2019-05-04 20:14:48 +02:00
enu Bidirectional=SC_BIDIRECTIONAL_
val SC_BIDIRECTIONAL_DISABLED=0
val SC_BIDIRECTIONAL_L2R=1
val SC_BIDIRECTIONAL_R2L=2
2010-09-06 00:56:27 +02:00
2019-05-04 20:14:48 +02:00
# Retrieve bidirectional text display state.
2019-07-21 15:26:02 +02:00
get Bidirectional GetBidirectional=2708(,)
2013-08-28 02:44:27 +02:00
2019-05-04 20:14:48 +02:00
# Set bidirectional text display state.
2019-07-21 15:26:02 +02:00
set void SetBidirectional=2709(Bidirectional bidirectional,)
2013-08-28 02:44:27 +02:00
2019-05-04 20:14:48 +02:00
cat Deprecated
# Divide each styling byte into lexical class bits (default: 5) and indicator
# bits (default: 3). If a lexer requires more than 32 lexical states, then this
# is used to expand the possible states.
set void SetStyleBits=2090(int bits,)
# Retrieve number of bits in style bytes used to hold the lexical state.
get int GetStyleBits=2091(,)
# Retrieve the number of bits the current lexer needs for styling.
get int GetStyleBitsNeeded=4011(,)
2015-06-07 23:19:26 +02:00
# Deprecated in 3.5.5
# Always interpret keyboard input as Unicode
set void SetKeysUnicode=2521(bool keysUnicode,)
# Are keys always interpreted as Unicode?
get bool GetKeysUnicode=2522(,)
2019-05-04 20:14:48 +02:00
# Is drawing done in two phases with backgrounds drawn before foregrounds?
get bool GetTwoPhaseDraw=2283(,)
# In twoPhaseDraw mode, drawing is performed in two phases, first the background
# and then the foreground. This avoids chopping off characters that overlap the next run.
set void SetTwoPhaseDraw=2284(bool twoPhase,)
2019-07-21 15:26:02 +02:00
val INDIC0_MASK=0x20
val INDIC1_MASK=0x40
val INDIC2_MASK=0x80
val INDICS_MASK=0xE0