Функциональность компонента редактирования KatePart возможно расширить с помощью написания сценариев. Для этого используется язык ECMAScript (широко известен как JavaScript). KatePart поддерживает два вида сценариев: сценарии расстановки отступов и сценарии командной строки.
Сценарии расстановки отступов — также их называют средствами расстановки отступов — выполняют автоматическую расстановку отступов в исходном коде по мере набора текста. Например, после нажатия клавиши Enter программа обычно увеличивает отступ в следующей строке.
В следующих разделах приведены пошаговые инструкции по созданию основы простого средства расстановки отступов. На первом этапе следует создать файл *.js с названием, например, javascript.js в локальной домашней папке $. Здесь переменная среды XDG_DATA_HOME/katepart5/script/indentationXDG_DATA_HOME обычно имеет значение ~/.local или ~/.local/share.
В Windows® эти файлы расположены в каталоге %USERPROFILE%\AppData\Local\katepart5\script\indentation. %USERPROFILE% обычно имеет значение C:\\Users\\.пользователь
Заголовок файла javascript.js внедряется как JSON в начало документа и имеет следующую форму:
var katescript = {
"name": "JavaScript",
"author": "Example Name <example.name@some.address.org>",
"license": "BSD License",
"revision": 1,
"kate-version": "5.1",
"required-syntax-style": "javascript",
"indent-languages": ["javascript"],
"priority": 0,
}; // kate-script-header, must be at the start of the file without comments
Далее приводится подробное описание каждой из записей заголовка:
name[обязательная запись]: название средства расстановки отступов, которое будет показано в меню → и диалоге настройки.author[необязательная запись]: имя и контактные данные автора.license[необязательная запись]: краткая форма условий лицензирования, например BSD или LGPLv3.revision[обязательная запись]: версия сценария. Не забывайте увеличивать номер версии при каждом внесении изменений в файл.kate-version[обязательная запись]: минимальное значение версии KatePart, необходимой для работы сценария.required-syntax-style[необязательная запись]: нужный стиль синтаксиса, который соответствует указанному значениюstyleв файлах определения подсветки синтаксических конструкций. Эта запись важна для средств расстановки отступов, которые работают на основе определённых данных о подсветке в документе. Если указан стиль синтаксиса, средством расстановки отступов будет возможно воспользоваться только в том случае, если будет задействовано соответствующее средство подсветки текста. Это позволяет предотвратить «неопределённое поведение», вызванное использованием средства расстановки отступов без необходимой для его работы схемы подсветки. Например, таким образом настроено средство расстановки отступов в файлахruby.jsиruby.xml.indent-languages[необязательная запись]: массив JSON стилей синтаксических конструкций, которые может обрабатывать средство расстановки отступов, например:["c++", "java"].priority[необязательная запись]: если какому-либо файлу с определённой подсветкой соответствуют несколько средств расстановки отступов, значение приоритета определяет, какое средство расстановки отступов будет использоваться по умолчанию.
Выше был рассмотрен формате заголовка. Теперь возможно перейти к изучению того, как же работает сам сценарий расстановки отступов. Основа подобного сценария выглядит так:
// необходимые библиотеки JS katepart, например range.js, если используется Range
require ("range.js");
triggerCharacters = "{}/:;";
function indent(line, indentWidth, ch)
{
// сценарий будет вызываться при обработке каждого символа новой строки (ch == '\n') и всех символов, указанных в
// глобальной переменной triggerCharacters. При выборе пункта меню →
// переменная ch будет иметь пустое значение, то есть ch == ''.
//
// смотрите также раздел: «Программный интерфейс (API) работы со сценариями»
return -2;
}
В функции indent() предусмотрено три параметра:
line: строка, в которой следует установить отступindentWidth: ширина отступа (в пробелах)ch: символ новой строки (ch == '\n'), символ переключения, указанный вtriggerCharacters, или пустая строка, если пользователем был выбран пункт меню → .
Значение, возвращённое функцией indent(), определяет способ установки отступа в строке. Если возвращённое функцией значение является простым целым числом, оно обрабатывается следующим образом:
возвращено значение
-2: ничего не делатьвозвращено значение
-1: сохранить отступ (он будет определён на основе предыдущей непустой строки)возвращено значение
0: числа >= 0 определяют глубину отступа в пробелах
Либо может быть возвращён массив из двух элементов:
возвращено [ отступ, выравнивание ];
Первым элементом такого массива является глубина отступа, похожая на значение, о котором говорилось ранее. Другой же элемент является абсолютным значением, которое соответствует столбцу «выравнивания». Если это значение превышает значение отступа, то после создания отступа согласно первому параметру к этому отступу будет добавлена разница между ними (в пробелах). В ином случае второе число игнорируется. Одновременное использование символов табуляции и пробелов для расстановки отступов часто называют «смешанным режимом».
Рассмотрим следующий пример: предположим, что для создания отступов используются символы табуляции и значение ширины табуляции равняется 4. Здесь <tab> — символ табуляции, а '.' — пробел:
1: <tab><tab>foobar("привет",
2: <tab><tab>......."мир");
При создании отступа для строки 2 функция indent() возвращает [8, 15]. В результате два символа табуляции будут вставлены для создания отступа в столбце 8, а затем будет добавлено 7 пробелов для выравнивания по второму параметру, следовательно, строка останется выровненной во время просмотра файла при любой ширине табуляции.
По умолчанию в пакете KatePart KDE поставляются несколько средств расстановки отступов. Код этих средств на языке JavaScript расположен в каталоге $.XDG_DATA_DIRS/katepart5/script/indentation
В Windows® эти файлы расположены в каталоге %USERPROFILE%\AppData\Local\katepart5\script\indentation. %USERPROFILE% обычно имеет значение C:\\Users\\. пользователь
При разработке средства расстановки отступов сценарии требуется перезагружать для проверки корректности поведения во время установки отступов. Вместо перезапуска приложения достаточно просто перейти в командную строку и выполнить команду reload-scripts.
Чтобы сообщить о созданном полезном сценарии разработчикам KatePart, отправьте письмо в список рассылки.
Поскольку у всех пользователей разные потребности, в KatePart предусмотрена поддержка небольших вспомогательных инструментов для ускорения работы с фрагментами текста с помощью встроенной командной строки. Например, команда sort (упорядочить) реализована именно с помощью такого инструмента. В этом разделе содержится описание способа создания файлов *.js, которые позволят расширить возможности KatePart путём добавления вспомогательных сценариев.
Сценарии командной строки расположены в той же папке, что и сценарии расстановки отступов. Поэтому на первом этапе следует создать файл *.js с именем myutils.js в локальной домашней папке $. Здесь переменная среды XDG_DATA_HOME/katepart5/script/commandsXDG_DATA_HOME обычно имеет значение ~/.local или ~/.local/share.
В Windows® эти файлы расположены в каталоге %USERPROFILE%\AppData\Local\katepart5\script\commands. %USERPROFILE% обычно имеет значение C:\\Users\\. пользователь
Заголовок каждого сценария командной строки встраивается в JSON в начале сценария следующим образом:
var katescript = {
"author": "Example Name <example.name@some.address.org>",
"license": "LGPLv2+",
"revision": 1,
"kate-version": "5.1",
"functions": ["sort", "moveLinesDown"],
"actions": [
{ "function": "sort",
"name": "Sort Selected Text",
"category": "Editing",
"interactive": "false"
},
{ "function": "moveLinesDown",
"name": "Move Lines Down",
"category": "Editing",
"shortcut": "Ctrl+Shift+Down",
"interactive": "false"
}
]
}; // kate-script-header, must be at the start of the file without comments
Далее приводится подробное описание каждой из записей заголовка:
author[необязательная запись]: имя и контактные данные автора.license[необязательная запись]: краткая форма условий лицензирования, например BSD или LGPLv2.revision[обязательная запись]: версия сценария. Не забывайте увеличивать номер версии при каждом внесении изменений в файл.kate-version[обязательная запись]: минимальное значение версии KatePart, необходимой для работы сценария.functions[обязательная запись]: массив JSON команд сценария.actions[необязательная запись]: массив JSON объектов JSON, определяющий действия, которые будут доступны в меню приложения. Подробные сведения доступны в разделе Привязки клавиш.
Так как значением functions является массив JSON, отдельный сценарий может содержать произвольное количество команд командной строки. Доступ к каждой из функций возможно получить с помощью встроенной командной строки KatePart.
Все функции, указанные в заголовке, должны быть реализованы в сценарии. Таким образом, файл сценария из вышеприведённого примера должен реализовывать две функции: sort и moveLinesDown. Все функции должны быть записаны в следующем виде:
// необходимые библиотеки JS katepart, например range.js, если используется Range
require ("range.js");
function <name>(параметр1, параметр2, ...)
{
// ... реализация, смотрите также раздел: «Программный интерфейс (API) работы со сценариями»
}
Параметры в командной строке передаются функции как параметр1, параметр2 и так далее. Чтобы документировать каждую команду, просто реализуйте функцию 'help' следующим образом:
function help(cmd)
{
if (cmd == "sort") {
return i18n("Sort the selected text.");
} else if (cmd == "...") {
// ...
}
}
После этого выполнение команды help sort приведёт к вызову соответствующей функции справки (help) с параметром cmd в значении названия указанной команды, то есть cmd == "sort". В ответ на команду в KatePart будет показан заданный текст справки. Обязательно выполните перевод строк.
При разработке сценария командной строки этот сценарий требуется перезагружать для проверки корректности поведения. Вместо перезапуска приложения достаточно просто перейти в командную строку и выполнить команду reload-scripts.
Чтобы доступ к сценарию было возможно осуществлять с помощью меню приложения и с помощью комбинаций клавиш, он должен содержать соответствующий заголовок. В приведённом выше примере обе функции — sort и moveLinesDown — отображаются как соответствующие пункты меню благодаря этой части заголовка сценария:
var katescript = {
...
"actions": [
{ "function": "sort",
"name": "Sort Selected Text",
"icon": "",
"category": "Editing",
"interactive": "false"
},
{ "function": "moveLinesDown",
"name": "Move Lines Down",
"icon": "",
"category": "Editing",
"shortcut": "Ctrl+Shift+Down",
"interactive": "false"
}
]
};
Поля для одного действия таковы:
function[обязательная запись]: функция, пункт которой должен отображаться в меню → .name[обязательная запись]: текст пункта, который показан в меню сценариев.icon[необязательная запись]: значок, который отображается рядом с текстом в меню. Возможно указать название одного из значков KDE.category[необязательная запись]: если указана категория, сценарий будет отображаться в соответствующем вложенном меню.shortcut[необязательная запись]: здесь указывается комбинация клавиш, которая будет использоваться по умолчанию. Например:Ctrl+Alt+t. Дополнительные сведения доступны в документации Qt™.interactive[необязательная запись]: если для работы сценария требуются введённые пользователем данные, установите этот параметр в значениеtrue.
Чтобы сообщить о созданном полезном сценарии разработчикам KatePart, отправьте письмо в список рассылки.
Программный интерфейс работы со сценариями, основы которого представлены здесь, возможно использовать для любых сценариев, в том числе сценариев расстановки отступов и сценариев командной строки. Классы Cursor и Range определяются библиотечными файлами в $. Если требуется воспользоваться ими в определённом сценарии, чтобы задействовать какие-либо функции XDG_DATA_DIRS/katepart5/librariesDocument или View, включите в сценарий необходимую библиотеку с помощью следующей команды:
// необходимые библиотеки JS katepart, например range.js, если используется Range
require ("range.js");
Чтобы расширить стандартный программный интерфейс (API) работы со сценариями собственными функциями и прототипами, просто создайте файл в локальной папке файлов настройки KDE $ и включите его в файл сценария с помощью следующего кода: XDG_DATA_HOME/katepart5/libraries
require ("myscriptnamehere.js");
В Windows® эти файлы расположены в каталоге %USERPROFILE%\AppData\Local\katepart5\libraries. %USERPROFILE% обычно имеет значение C:\\Users\\.пользователь
Рекомендованным способом расширения возможностей существующих прототипов, например Cursor или Range, не является внесение изменений в глобальные файлы *.js. Вместо этого следует изменить прототип Cursor в JavaScript после включения cursor.js в сценарий с помощью команды require.
Поскольку KatePart является текстовым редактором, весь программный интерфейс по возможности основан на курсорах и диапазонах текста. Объект «Cursor» (курсор) является простым кортежем (line, column) (строка, столбец), который определяет позицию в тексте документа. Объект «Range» (диапазон) — это фрагмент текста от начальной до конечной позиции курсора. Подробное описание программного интерфейса приводится в следующих разделах.
Cursor();
Конструктор. Возвращает объект «Cursor» (курсор) в позиции
(0, 0).Пример:
var cursor = new Cursor();Cursor(
int,строкаint);столбецКонструктор. Возвращает объект «Cursor» (курсор) в позиции (строка, столбец).
Пример:
var cursor = new Cursor(3, 42);Cursor(Cursor);другойКонструктор копирования. Возвращает копию курсора
другой.Пример:
var copy = new Cursor(другой);Cursor Cursor.clone();
Возвращает клон курсора.
Пример:
var clone = cursor.clone();Cursor.setPosition(
int,строкаint);столбецУстанавливает курсор в место, указанное параметрами
строкаистолбец.Начиная с KDE 4.11
bool Cursor.isValid();
Проверка корректности курсора. Курсор является некорректным, если строка и/или столбец установлены в значение
-1.Пример:
var valid = cursor.isValid();Cursor Cursor.invalid();
Возвращает новый некорректный курсор, размещённый в позиции
(-1, -1).Пример:
var invalidCursor = cursor.invalid();int Cursor.compareTo(Cursor);другойСравнивает текущий курсор с курсором
другой. Возвращает-1, если текущий курсор расположен перед курсоромдругой0, если курсоры находятся в одинаковых позициях+1, если текущий курсор расположен после курсорадругой
bool Cursor.equals(Cursor);другойВозвращает
true, если текущий курсор и курсордругойнаходятся в одинаковых позициях, в ином случае —false.String Cursor.toString();
Возвращает курсор как строку вида «
Cursor(строка, столбец)».
Range();
Конструктор. Вызов
new Range()возвращает диапазон в позиции (0, 0) - (0, 0).Range(
Cursor,началоCursor);конецКонструктор. Вызов
new Range(возвращает диапазон (начало,конец)начало,конец).Range(
int,начальнаяСтрокаint,начальныйСтолбецint,конечнаяСтрокаint);конечныйСтолбецКонструктор. Вызов
new Range(возвращает диапазон с позиции (начальнаяСтрока,начальныйСтолбец,конечнаяСтрока,конечныйСтолбец)начальнаяСтрока,начальныйСтолбец) до позиции (конечнаяСтрока,конечныйСтолбец).Range(Range);другойКонструктор копирования. Возвращает копию диапазона
другой.Range Range.clone();
Возвращает клон диапазона.
Пример:
var clone = range.clone();bool Range.isEmpty();
Возвращает
true, если начальная и конечная позиции курсора совпадают.Пример:
var empty = range.isEmpty();Начиная с KDE 4.11
bool Range.isValid();
Возвращает
true, если начальная и конечная позиции курсора являются корректными, в ином случае —false.Пример:
var valid = range.isValid();Range Range.invalid();
Возвращает диапазон от (-1, -1) до (-1, -1).
bool Range.contains(Cursor);курсорВозвращает
true, если позиция курсора находится в этом диапазоне, в ином случае —false.bool Range.contains(Range);другойВозвращает
true, если текущий диапазон содержит диапазондругой, в ином случае —false.bool Range.containsColumn(int);столбецВозвращает
true, еслистолбецпринадлежит полуоткрытому интервалу[начальный.столбец, конечный.столбец), в ином случае —false.bool Range.containsLine(int);строкаВозвращает
true, еслистрокапринадлежит полуоткрытому интервалу[начальная.строка, конечная.строка), в ином случае —false.bool Range.overlaps(Range);другойВозвращает
true, если текущий диапазон и диапазондругойимеют ненулевое пересечение, в ином случае —false.bool Range.overlapsLine(int);строкаВозвращает
true, еслистрокапринадлежит интервалу[начальная.строка, конечная.строка], в ином случае —false.bool Range.overlapsColumn(int);столбецВозвращает
true, еслистолбецпринадлежит интервалу[начальный.столбец, конечный.столбец], в ином случае —false.bool Range.onSingleLine();
Возвращает
true, если диапазон начинается и заканчивается в одной и той же строке, то есть еслиRange.начальная.строка == Range.конечная.строка.Начиная с KDE 4.9
bool Range.equals(Range);другойВозвращает
true, если текущий диапазон и диапазондругойсовпадают, в ином случае —false.String Range.toString();
Возвращает диапазон как строку вида «
Range(Cursor(строка, столбец), Cursor(строка, столбец))».
В этом разделе перечислены все глобальные функции.
String read(String);название файлаНайти указанный
файлв каталогеkatepart5/script/filesи вернуть его содержимое в виде строки.
void require(String);название файлаНайти указанный
файлв каталогеkatepart5/script/librariesи обработать его код. Вrequireпредусмотрена встроенная защита от повторного включения одного и того жефайла.Начиная с KDE 4.10
void debug(String);текстВывести
текствstdoutв консоль, с помощью которой запущено приложение.
Полноценная локализация станет возможной только при использовании нескольких функций, предназначенных для перевода строк, а именно: i18n, i18nc, i18np и i18ncp. Поведение этих функций в точности соответствует поведению функций перевода строк KDE.
С помощью функций перевода и системы перевода KDE встроенные в сценарий строки сообщений возможно перевести на язык интерфейса приложения. Строки в сценариях, которые являются частью официальной сборки KatePart, автоматически извлекаются и представляются для перевода командам переводчиков KDE. Другими словами, разработчикам основной ветви KatePart не приходится заниматься извлечением сообщений и их переводом. Впрочем, следует отметить, что перевод будет работать только в пределах инфраструктуры KDE, то есть перевод новых строк сценариев, разработанных за пределами KDE, невозможен. Поэтому созданные сценарии следует отправлять в основную ветвь разработки Kate, чтобы сделать возможным надлежащий перевод.
void i18n(
String,текстпараметр1, ...);Перевести
текстна язык интерфейса приложения. Параметрыпараметр1, ... являются необязательными. Они позволяют заменить строки%1,%2и так далее.void i18nc(
String,контекстString,текстпараметр1, ...);Перевести
текстна язык интерфейса приложения. При этом переводчикам будет показана строкаконтекст, что облегчает перевод. Параметрыпараметр1, ... являются необязательными. Они позволяют заменить строки%1,%2и так далее.void i18np(
String,единственноеString,множественноеint,количествопараметр1, ...);Перевести
единственноеилимножественноечисло сообщения на язык интерфейса приложения, в зависимости от указанного значения параметраколичество. Параметрыпараметр1, ... являются необязательными. Они позволяют заменить строки%1,%2и так далее.void i18ncp(
String,контекстString,единственноеString,множественноеint,количествопараметр1, ...);Перевести
единственноеилимножественноечисло сообщения на язык интерфейса приложения, в зависимости от указанного значения параметраколичество. При этом переводчикам будет показана строкаконтекст, что облегчает перевод. Параметрыпараметр1, ... являются необязательными. Они позволяют заменить строки%1,%2и так далее.
Каким бы образом ни был запущен сценарий, он всегда будет использовать глобальную переменную «view», которая соответствует текущей активной области просмотра. Далее приводится список всех доступных функций объекта «View».
void view.copy()Копировать выбранный фрагмент, если таковой имеется. Когда ничего не выбрано, копировать текущую строку, если указан параметр
[ ] Вырезать или копировать текущую строку, если ничего не выделено.Начиная с KDE Frameworks™ 5.79
void view.cut()Вырезать выбранный фрагмент, если таковой имеется. Когда ничего не выбрано, вырезать текущую строку, если указан параметр
[ ] Вырезать или копировать текущую строку, если ничего не выделено.Начиная с KDE Frameworks™ 5.79
void view.paste()Вставить содержимое буфера обмена.
Начиная с KDE Frameworks™ 5.79
Cursor view.cursorPosition()Возвращает текущую позицию курсора в области просмотра.
void view.setCursorPosition(
int,строкаint); void view.setCursorPosition(столбецCursor);курсорУстанавливает для текущего курсора позицию (строка, столбец) или позицию указанного курсора.
Cursor view.virtualCursorPosition();
Возвращает позицию виртуального курсора. Все символы табуляции будут учтены с помощью соответствующего количества пробелов, которое будет зависеть от текущей ширины табуляции.
void view.setVirtualCursorPosition(
int,строкаint); void view.setVirtualCursorPosition(столбецCursor);курсорУстанавливает для текущего виртуального курсора позицию (строка, столбец) или позицию указанного курсора.
String view.selectedText();
Возвращает выделенный фрагмент текст. Если выделенного фрагмента текста нет, возвращается пустая строка.
bool view.hasSelection();
Возвращает
true, если выделенный фрагмент текст находится в области просмотра, в ином случае —false.Range view.selection();
Возвращает диапазон выделенного фрагмента текста. Если выделенного фрагмента текста нет, возвращается некорректный диапазон.
void view.setSelection(Range);диапазонУстанавливает выделение текста по указанному диапазону.
void view.removeSelectedText();
Удаляет выделенный текст. Если в области просмотра отстутствует выделенный текст, никаких действий не выполняется.
void view.selectAll();
Выделяет весь текст в документе.
void view.clearSelection();
Снимает выделение с текста, не удаляя сам текст.
object view.executeCommand(
String,командаString,параметрыRange);диапазонВыполняет команду командной строки
командас дополнительными параметрамипараметрыи необязательным диапазономдиапазон. Возвращённый объектobjectимеет логическое свойствоobject.ok, которое указывает на то, было ли успешным выполнение командыкоманда. В случае ошибки строкаobject.statusбудет содержать сообщение об ошибке.Начиная с KDE Frameworks™ 5.50
Каким бы образом ни был запущен сценарий, он всегда будет использовать глобальную переменную «document», которая соответствует текущему активному документу. Далее приводится список всех доступных функций объекта «Document».
String document.fileName();
Возвращает название файла документа или пустую строку для несохранённых буферов с текстом.
String document.url();
Возвращает полный URL-адрес документа или пустую строку для несохранённых буферов с текстом.
String document.mimeType();
Возвращает тип MIME документа или тип MIME
application/octet-stream, если не удалось найти соответствующий тип MIME.String document.encoding();
Возвращает текущую кодировку, которая будет использована для сохранения файла .
String document.highlightingMode();
Возвращает глобальный режим подсветки, используемый во всём документе.
String document.highlightingModeAt(Cursor);позицияВозвращает режим подсветки, используемый в указанной позиции в документе.
Array document.embeddedHighlightingModes();
Возвращает массив режимов подсветки, встроенных в текущий документ.
bool document.isModified();
Возвращает
true, если в документе имеются несохранённые изменения, в ином случае —false.String document.text();
Возвращает всё содержимое документа в виде единой текстовой строки. Разрывы строк обозначаются символом перехода на новую строку «
\n».String document.text(
int,соСтрокиint,соСтолбцаint,доСтрокиint); String document.text(доСтолбцаCursor,сCursor); String document.text(доRange);диапазонВозвращает текст в указанном диапазоне. Чтобы код было легче читать, рекомендуется использовать основанную на объектах Cursor и Range версию функции.
String document.line(int);строкаВозвращает строку по её номеру в тексте. Если указанный номер находится вне диапазона номеров строк документа, возвращается пустая строка.
String document.wordAt(
int,строкаint); String document.wordAt(столбецCursor);курсорВозвращает слово в указанной позиции курсора.
-
Range document.wordRangeAt(
int,строкаint); Range document.wordRangeAt(столбецCursor);курсор Возвращает диапазон слова в указанной позиции курсора. Возвращённое значение диапазона будет некорректным (смотрите Range.isValid()), если текст находится за концом строки. Если в указанной позиции курсора отсутствует слово, возвращается пустой диапазон.
Начиная с KDE 4.9
String document.charAt(
int,строкаint); String document.charAt(столбецCursor);курсорВозвращает символ в указанной позиции курсора.
String document.firstChar(int);строкаВозвращает первый отличный от пробела символ в указанной
строке. Первым символом строки считается символ в столбце 0. Если строка является пустой или состоит только из пробелов, функция возвращает пустую строку.String document.lastChar(int);строкаВозвращает последний отличный от пробела символ в указанной
строке. Если строка является пустой или состоит только из пробелов, функция возвращает пустую строку.bool document.isSpace(
int,строкаint); bool document.isSpace(столбецCursor);курсорВозвращает
true, если символ в указанной позиции курсора является пробелом, в ином случае —false.bool document.matchesAt(
int,строкаint,столбецString); bool document.matchesAt(текстCursor,курсорString);текстВозвращает
true, если указанныйтекстрасположен в соответствующей позиции курсора, в ином случае —false.bool document.startsWith(
int,строкаString,текстbool);skipWhiteSpacesВозвращает
true, если строка с указанным номером начинается с фрагмента текстатекст, в ином случае —false. ПараметрskipWhiteSpacesпозволяет указать программе, следует ли игнорировать пробелы в начале строки.bool document.endsWith(
int,строкаString,текстbool);skipWhiteSpacesВозвращает
true, если строка с указанным номером заканчивается фрагментом текстатекст, в ином случае —false. ПараметрskipWhiteSpacesпозволяет указать программе, следует ли игнорировать пробелы в конце строки.bool document.setText(String);текстЗаменяет всё содержимое документа на указанный текст.
bool document.clear();
Удаляет весь текст в документе.
bool document.truncate(
int,строкаint); bool document.truncate(столбецCursor);курсорОбрезает строку с указанным номером на указанном столбце или в указанной позиции курсора. Возвращает
trueв случае успеха илиfalse, если строка с указанным номером находится вне диапазона номеров строк документа.bool document.insertText(
int,строкаint,столбецString); bool document.insertText(текстCursor,курсорString);текстВставляет указанный
текств указанной позиции курсора. Возвращаетtrueв случае успеха илиfalse, если документ доступен только для чтения.bool document.removeText(
int,соСтрокиint,соСтолбцаint,доСтрокиint); bool document.removeText(доСтолбцаCursor,сCursor); bool document.removeText(доRange);диапазонУдаляет текст в указанном диапазоне. Возвращает
trueв случае успеха илиfalse, если документ доступен только для чтения.bool document.insertLine(
int,строкаString);текстВставляет текст в указанной строке. Возвращает
trueв случае успеха илиfalse, если документ доступен только для чтения или указанная строка находится вне диапазона номеров строк документа.bool document.removeLine(int);строкаУдаляет строку с указанным номером. Возвращает
trueв случае успеха илиfalse, если документ доступен только для чтения или указанная строка находится вне диапазона номеров строк документа.bool document.wrapLine(
int,строкаint); bool document.wrapLine(столбецCursor);курсорПереносит строку по указанной позиции курсора. Возвращает
trueв случае успеха илиfalse(например, если номер строки < 0).Начиная с KDE 4.9
void document.joinLines(
int,начальнаяСтрокаint);конечнаяСтрокаСоединяет строки в диапазоне от
начальнаяСтрокадоконечнаяСтрока. Две последовательные текстовые строки всегда разделяются одиночным пробелом.int document.lines();
Возвращает число строк в документе.
bool document.isLineModified(int);строкаВозвращает
true, еслистрокав настоящее время содержит несохранённые данные.Начиная с KDE 5.0
bool document.isLineSaved(int);строкаВозвращает
true, еслистрокабыла изменена и затем документ был сохранён. Следовательно, в настоящее время строка не содержит какие-либо несохранённые данные.Начиная с KDE 5.0
bool document.isLineTouched(int);строкаВозвращает
true, еслистрокав настоящее время содержит несохранённые данные или была изменена ранее.Начиная с KDE 5.0
bool document.findTouchedLine(
int,начальнаяСтрокаbool);downПоиск следующей изменённой строки, начиная со строки
начальнаяСтрока. Поиск выполняется в направлении «вверх» (к началу документа) или «вниз» (к концу документа), в зависимости от значения параметраdown.Начиная с KDE 5.0
int document.length();
Возвращает число символов в документе.
int document.lineLength(int);строкаВозвращает длину строки с номером
строка.void document.editBegin();
Начинает группу редактирования для упорядочения операций отмены или повтора действий. Не забывайте, что вызывать
editEnd()следует именно столько раз, сколько вызываетсяeditBegin(). ВызовыeditBegin()используют встроенный счётчик, следовательно, их возможно вкладывать один в другой.void document.editEnd();
Завершает группу редактирования. Последний вызов
editEnd()(то есть соответствие первого вызоваeditBegin()) завершает шаг по редактированию.int document.firstColumn(int);строкаВозвращает первый отличный от пробела столбец в указанной с помощью параметра
строкастроке. Если в строке будут только пробелы, функция вернёт значение-1.int document.lastColumn(int);строкаВозвращает последний отличный от пробела столбец в указанной с помощью параметра
строкастроке. Если в строке будут только пробелы, функция вернёт значение-1.int document.prevNonSpaceColumn(
int,строкаint); int document.prevNonSpaceColumn(столбецCursor);курсорВозвращает номер столбца с символом, отличным от пробела. Поиск будет выполнен в направлении начала документа, начиная с указанной позиции курсора.
int document.nextNonSpaceColumn(
int,строкаint); int document.nextNonSpaceColumn(столбецCursor);курсорВозвращает номер столбца с символом, отличным от пробела. Поиск будет выполнен в направлении конца документа, начиная с указанной позиции курсора.
int document.prevNonEmptyLine(int);строкаВозвращает следующую непустую строку, содержащую отличные от пробелов символы. Поиск будет выполнен в направлении начала документа.
int document.nextNonEmptyLine(int);строкаВозвращает следующую непустую строку, содержащую отличные от пробелов символы. Поиск будет выполнен в направлении конца документа.
bool document.isInWord(
String,символint);атрибутВозвращает
true, если указанныйсимволс указанным параметроматрибутможет быть частью слова, в ином случае —false.bool document.canBreakAt(
String,символint);атрибутВозвращает
true, если указанныйсимволс указанным параметроматрибутможет быть использован как место переноса строки, в ином случае —false.bool document.canComment(
int,начальныйАтрибутint);конечныйАтрибутВозвращает
true, если диапазон, начало и конец которого определяются на основе указанных атрибутов, может быть закомментирован, в ином случае —false.String document.commentMarker(int);атрибутВозвращает метку комментария для однострочных комментариев для указанного параметра
атрибут.String document.commentStart(int);атрибутВозвращает метку комментария для начала многострочных комментариев для указанного параметра
атрибут.String document.commentEnd(int);атрибутВозвращает метку комментария для завершения многострочных комментариев для указанного параметра
атрибут.Range document.documentRange();
Возвращает диапазон, который включает весь документ.
Cursor documentEnd();
Возвращает курсор, расположенный в последнем столбце последней строки в документе.
bool isValidTextPosition(
int,строкаint); bool isValidTextPosition(столбецCursor);курсорВозвращает
true, если курсор находится в корректной позиции в тексте. Позиция в тексте является корректной, только если курсор находится в начале, в середине или в конце корректной строки текста. Кроме того, позиция в тексте является некорректной, если курсор находится в заменителе символа Юникода.Начиная с KDE 5.0
int document.attribute(
int,строкаint); int document.attribute(столбецCursor);курсорВозвращает атрибут в указанной позиции курсора.
bool document.isAttribute(
int,строкаint,столбецint); bool document.isAttribute(атрибутCursor,курсорint);атрибутВозвращает
true, если атрибут в указанной позиции курсора совпадает со значением параметраатрибут, в ином случае —false.String document.attributeName(
int,строкаint); String document.attributeName(столбецCursor);курсорВозвращает название атрибута как удобочитаемый текст. Соответствует названию
itemDataв файлах подсветки синтаксиса.bool document.isAttributeName(
int,строкаint,столбецString); bool document.isAttributeName(названиеCursor,курсорString);названиеВозвращает
true, если название атрибута в определённой позиции курсора соответствует указанному значению параметраназвание, в ином случае —false.String document.variable(String);ключВозвращает значение запрашиваемой переменной документа
ключ. Если переменной документа с указанным названием не существует, возвращается пустая строка.void document.setVariable(
String,ключString);значениеУстанавливает значение соответствующей переменной документа
ключ.Смотрите также переменные документа Kate
Начиная с KDE 4.8
int document.firstVirtualColumn(int);строкаВозвращает виртуальный столбец первого отличного от пробела символа в указанной строке или
-1, если строка является пустой или содержит только пробелы.int document.lastVirtualColumn(int);строкаВозвращает виртуальный столбец последнего отличного от пробела символа в указанной строке или
-1, если строка является пустой или содержит только пробелы.int document.toVirtualColumn(
int,строкаint); int document.toVirtualColumn(столбецCursor); Cursor document.toVirtualCursor(курсорCursor);курсорПреобразует указанную «реальную» позицию курсора в виртуальную позицию курсора, возвращая либо целое значение (int), либо объект «Cursor».
int document.fromVirtualColumn(
int,строкаint); int document.fromVirtualColumn(виртуальныйСтолбецCursor); Cursor document.fromVirtualCursor(виртуальныйКурсорCursor);виртуальныйКурсорПреобразует указанную виртуальную позицию курсора в «реальную» позицию курсора, возвращая либо целое значение (int), либо объект «Cursor».
Cursor document.anchor(
int,строкаint,столбецChar); Cursor document.anchor(символCursor,курсорChar);символВыполняет поиск указанного символа в направлении начала документа, начиная в указанной позиции курсора. Например, если функции будет передан символ «(», она вернёт позицию открывающей скобки «(». Выполняется подсчёт ссылок, то есть другие «(...)» будут проигнорированы.
Cursor document.rfind(
int,строкаint,столбецString,текстint); Cursor document.rfind(атрибут= -1Cursor,курсорString,текстint);атрибут= -1Выполняет поиск указанного текста с соответствующим значением параметра
атрибутв направлении начала текста. Параметратрибутигнорируется, если он установлен в значение-1. Возвращает некорректный курсор, если текст не удалось найти.int document.defStyleNum(
int,строкаint); int document.defStyleNum(столбецCursor);курсорВозвращает стиль по умолчанию, используемый в указанной позиции курсора.
bool document.isCode(
int,строкаint); bool document.isCode(столбецCursor);курсорВозвращает
true, если атрибут в указанной позиции курсора не совпадает ни с одним из следующих значений стилей:dsComment,dsString,dsRegionMarker,dsChar,dsOthers.bool document.isComment(
int,строкаint); bool document.isComment(столбецCursor);курсорВозвращает
true, если значением атрибута символа в позиции курсора являетсяdsComment, в ином случае —false.bool document.isString(
int,строкаint); bool document.isString(столбецCursor);курсорВозвращает
true, если значением атрибута символа в позиции курсора являетсяdsString, в ином случае —false.bool document.isRegionMarker(
int,строкаint); bool document.isRegionMarker(столбецCursor);курсорВозвращает
true, если значением атрибута символа в позиции курсора являетсяdsRegionMarker, в ином случае —false.bool document.isChar(
int,строкаint); bool document.isChar(столбецCursor);курсорВозвращает
true, если значением атрибута символа в позиции курсора являетсяdsChar, в ином случае —false.bool document.isOthers(
int,строкаint); bool document.isOthers(столбецCursor);курсорВозвращает
true, если значением атрибута символа в позиции курсора являетсяdsOthers, в ином случае —false.
Кроме программного интерфейса документа и области просмотра, существует и общий программный интерфейс редактора, который предоставляет доступ к общим функциям управления редактором с помощью сценариев.
String editor.clipboardText();
Возвращает текст, который в настоящее время находится в глобальном буфере обмена.
Начиная с KDE Frameworks™ 5.50
String editor.clipboardHistory();
Редактор сохраняет журнал буфера обмена, который содержит до 10 записей. Эта функция возвращает все записи, которые в настоящее время находятся в журнале буфера обмена.
Начиная с KDE Frameworks™ 5.50
void editor.setClipboardText(String);текстУстанавливает для содержимого буфера обмена значение
текст. Записьтекстбудет добавлена в журнал буфера обмена.Начиная с KDE Frameworks™ 5.50