Документация SciTE |
Документация FAQ Регулярные выражения SciTE Extension LUA SciTE Director Команды SciTE и Scintilla Сборка Ru-Board Ядро SciTE-Ru Shell SciTE Helper История |
Перед вами не просто перевод оригинальной документации SciTE.
Данный документ раскрывает многие вопросы гораздо шире и полнее оригинала. Исправлены многочисленные неточности и несуразности. Часть определений переписана заново.
Надеемся, что изучение этого документа принесет вам множество новых открытий!
Текст содержит элементы, выделенные форматированием, например:
"Настройки | Консоль - сбоку" - команда меню SciTE
command.subsystem: - параметр (переменная) из файла настроек SciTE
windows - значение параметра
-open:my file.txt - примеры кода
Данная возможность... - функции, работающие только в Windows
Данная возможность... - функции, работающие только в GTK+
Данная возможность... - функции, имеющиеся только в SciTE-Ru
[т.е. команда будет выполнена...] - примечания переводчика
Дадим определения некоторым специфическим терминам, часто встречающимся в тексте документации:
Лексер (lexer) - программный модуль для анализа и обработки конкретного языка программирования. Лексеры подобны плагинам, и пишутся, в основном, независимыми разработчиками. После компиляции код лексера размещается в файле SciLexer.dll
, а все его настройки обычно выносятся в отдельный файл свойств. Процесс добавления нового лексера описан в "Add a lexer to Scintilla and SciTE".
В SciTE редактирование текста осуществляется так же, как и в большинстве редакторов Windows или Macintosh. При этом в SciTE добавлена функция автоматической подсветки синтаксиса. Одновременно в SciTE может быть открыто множество файлов, однако на экране будет отображен только один из них. Исходная конфигурация SciTE не разрешает открывать более одного файла одновременно, однако эту особенность можно обойти, изменив значение свойства buffers. Прямоугольные области текста в SciTE можно выделить с помощью мыши, удерживая при этом клавишу Alt (в Windows) или Ctrl (в GTK+).
SciTE имеет две панели - панель редактирования и панель вывода. Панель вывода находится либо снизу панели редактирования, либо справа от от нее. По умолчанию размер панели вывода равен нулю, однако путем перетаскивания разделителя между двумя панелями его можно увеличить. Панель вывода можно вызвать используя команду "Вид | Окно консоли" (View | Output - F8). Для того чтобы поместить панель вывода сбоку от панели редактирования, можно использовать команду "Настройки | Консоль - сбоку" (Options | Vertical Split).
SciTE может исполнять команды для компиляции или запуска редактируемых файлов, перенаправляя вывод этих команд на панель вывода.
К примеру, если у вас на компьютере установлен Python, откройте новый документ и напечатайте там:
print "Hi"
Сохраните документ как printhi.py.
Теперь к открытому во вкладке файлу будет применена подсветка синтаксиса, поскольку SciTE использует расширение файла при выборе стиля его оформления [если задан параметр default.file.ext, то вновь созданный файл будет подсвечиваться и до сохранения, в соответствии с заданным расширением]:
print "hi"
Запустите команду "Tools | Выполнить" (Tools | Go - F5).
На экране появится панель вывода (если её до этого не было) со следующим текстом:
>python -u printhi.py hi >Exit code: 0
В первой синей строке SciTE показывает, какую команду он использовал для запуска программы. Вторая чёрная строка представляет собой результат исполнения программы на Питоне. В последней же синей строке SciTE сообщает о завершении программы и отображает код ее завершения. Если код завершения программы равен нулю, это значит, что исполнение программы прошло успешно.
SciTE частично понимает те сообщения об ошибках, которые выдают Python, GCC, Visual C++, Borland C++, PHP и другие инструменты, имеющие такой же формат вывода сообщений, как вышеперечисленные. Для того чтобы убедиться в этом, сделайте в написанном на Питоне файле ошибку, добавив вторую строку и получив следующее:
print "hi" mistake
Запустите команду "Tools | Выполнить" (Tools | Go - F5). Результат будет выглядеть примерно так:
>python -u printhi.py hi Traceback (innermost last): File "printhi.py", line 2, in ? mistake NameError: mistake >Exit code: 1
В таком простом примере, как этот, найти ошибку несложно, однако в более крупном файле можно использовать команду "Tools | Следующее сообщение" (Tools | Next Message - F4). При выполнении этой команды первое сообщение об ошибке на панели вывода выделяется желтым фоном, а в окне редактирования для соответствующей строки отображается индикатор ошибки. Курсор перемещается на эту строку в окне редактирования. При этом содержимое окна редактирования при необходимости прокручивается, с тем, чтобы отобразить нужную строку. Теперь SciTE выглядит таким образом:
В большинстве случаев SciTE обрабатывает как имя файла, так и номер строки в сообщении об ошибке, поэтому, если ошибки произошли в другом файле (например, в заголовочном файле), он может открыть и его. Эта функция не работает, если в имени файла содержатся пробелы или "..".
Если исполнение команды оказалось неудачным и занимает слишком много времени, для её завершения можно воспользоваться командой "Tools | Остановить выполнение" (Tools | Stop Executing - Ctrl+Break).
Команды меню "Tools" могут быть выполнены в различных режимах SciTE, которые определяются параметром command.subsystem. Различные подсистемы поддерживаются на Windows, GTK+ и OS X. При запуске команды без параметра command.subsystem, используется заданная по умолчанию подсистема - 0.
Windows | ||
---|---|---|
0 | console | Это - значение по умолчанию и предназначено для запуска консольных программ. В результате запуска системное окно консоли не появляется, а весь вывод программы перенаправляется во встроенную консоль (панель вывода) SciTE. Возможно, что для отдельных приложений вам потребуется перенаправить весь ввод в программу, и добавить к выводу в консоль SciTE сообщения об ошибках. Это можно осуществить с помощью перенаправления стандартных потоков StdIn и StdErr :
command.5.*=CMD /C ruby $(FileNameExt) < con: > con: 2>&1 |
1 | windows | Запуск приложений в этом режиме приводит к открытию их собственного окна (или открытию системного окна консоли для консольных приложений). Если вы хотите анализировать вывод консольного приложения, то вам необходимо что-то предпринять для предотвращения автоматического закрытия окна при завершении работы команды (Обычно это осуществляется коррекцией pif -файла или добавлением команды pause в конец пакетного файла). |
2 | shellexec | Запуск программы осуществляется с помощью функции Windows ShellExecute (т.е. с помощью программы, ассоциированной с заданным расширением).Функция ShellExecute является хорошим способом для открытия HTML и подобных файлов, поскольку обрабатывает их так же, как если бы они были открыты пользователем из ОС (т.е. использует именну ту программу, которую назначил для открытия этих файлов пользователь). |
3 | lua director |
В данном случае, строка запуска трактуется как команда Lua и ее запуск осуществляется посредством вызова встроенного в SciTE обработчика LUA-скриптов.
Параметр sybsystem:director предназначен для отправки комманд SciTE Director Interface. command.5.*=quit: не вызовет закрытие SciTE, как ожидалось.command.mode.5.*=subsystem:director Ee выполнение вызовет появление строки с ошибкой в окне консоли "Lua: error checking global scope for command". Однако SciTE всетаки отправит команду " quit: ", которую сможет прочесть любая программа, понимающая SciTE Director Interface. |
4 | htmlhelp | Строка запуска обрабатывается подобно тому, как это осуществляет программа HtmlHelp (hh.exe ), служащая для запуска справочных файлов в формате CHM (*). |
5 | winhelp | Строка запуска обрабатывается подобно тому, как это осуществляет программа WinHelp (winhlp32.exe ), служащая для запуска справочных файлов в формате HLP (*). |
7 | immediate | Внутренний скрипт, который выполняется немедленно, а не встаёт в очередь. |
* При использовании значений 4 и 5 SciTE не вызывает непосредственно программу hh.exe (winhlp32.exe ), а открывает файлы справки собственными средствами, позволяющими в командной строке задать не только имя файла справки, но и искомое ключевое слово. При этом команда будет состоять из 2 частей, разделенных символом "! ", где первая часть представляет собой искомое ключевое слово, а вторая - имя файла справки. Например, так:
command.3.*=$(CurrentWord)!$(SciteDefaultHome)\help\script56.chm Естественно, поиск по ключевомоу слову будет работать только с теми файлами справки, в которых присутствует индекс.
|
GTK+ и OS X | ||
---|---|---|
0 | console | Исполняет программу и ожидает ее завершения, перенаправляя результат в панель вывода. |
2 | shellexec | Выполняет программу в фоновом режиме. |
3 | lua director | Internal extension or director extension. |
7 | immediate | Internal script that is executed immediately instead of being queued. |
Параметры командной строки для запуска SciTE включают имена файлов, команды и значения, которые будут присвоены свойствам SciTE. Команды и свойства начинаются с символа "-"
. В свойствах используется тот же синтаксис, что и в файлах настроек. Кроме того, значения свойств, заданные в командной строке, перекрывают соответствующие значения в файлах настроек. Если свойству не было присвоено никакого значения, то по умолчанию оно равняется 1. Параметры, значения которых содержат пробелы, необходимо заключать в двойные кавычки, однако кавычки должны обрамлять весь параметр, а не только значение. Поэтому параметр в таком виде: "-open:my file.txt"
будет работать, а в таком: open:"my file.txt"
- нет. В Linux доступно стандартное использование кавычек в оболочке. Параметр "-p"
заставляет SciTE печатать файл, а затем завершать работу.
Под Windows:
Функция параметров командной строки "-"
и "--"
(без кавычек) заключается в том, чтобы считывать поток stdin
в последнюю вкладку ("-"
) или в панель консоли ("--"
) SciTE.
C помощью параметра командной строки "-@"
(без кавычек) можно считывать имена файлов из stdin
и открывать эти файлы.
Примечание: Если при считывании потока stdin
в панель вывода значение свойства split.vertical равно 0, высота панели вывода увеличивается до максимального размера. Если значение свойства split.vertical равно 1, панель вывода увеличивается примерно до половины ширины экрана.
Примечание: Если поток stdin
не был перенаправлен в SciTE, все приведенные выше параметры игнорируются.
Пример использования ввода по stdin
(содержимое файла test.txt
считывается в окно консоли SciTE):
SciTE открывает все файлы, указанные в списке filelist.txt
:
Такой пример:
запускает SciTE, открывает файл ScintillaGTK.cxx
, присваивает параметру save.recent значение 1, а в качестве основного шрифта использует MS Gothic размером 11.
Группу свойств можно сохранить в качестве файла настроек (с расширением ".properties"), а в командной строке использовать команду import:
В настоящее время доступно очень мало команд, однако в будущем их число увеличится:
Команда | Аргумент |
---|---|
close: | |
cwd: | изменение рабочего каталога |
find: | искомый текст |
goto: | номер строки [,номер столбца] |
open: | имя файла |
loadsession: | имя файла |
quit: | |
replaceall: | search text\000replacement text |
saveas: | имя файла |
В командах можно использовать escape
-последовательности в стиле C:
Escape-последовательность | Значение |
---|---|
\\ | обратный слеш |
\a | сигнал |
\b | забой |
\f | прогон страницы |
\n | новая строка |
\r | возврат каретки |
\t | табуляция |
\v | вертикальная табуляция |
\<ooo> | восьмеричное значение, оформленное одной, двумя или тремя цифрами |
\x<hh> | шестнадцатеричное значение, оформленное двумя цифрами или буквами от A до F |
Открывает файл /big/icon.txt
:
C:\Program Files\SciTE\SciTEDoc.html
и переходит к 123-й строке:Параметры командной строки обрабатываются слева направо в два приема, поскольку, во-первых, для открытия файлов необходим пользовательский интерфейс, а во-вторых, пользовательский интерфейс отобразится только после того, как для него будет задан ряд свойств. На первом этапе обработка аргументов продолжается до того, как будет открыт первый файл. Во время второго этапа обрабатываются остальные аргументы.
Таким образом, если есть необходимость применить к файлу, например, команду find:
или goto:
, нужно поместить ее после имени файла, и SciTE откроет файл перед тем, как выполнить команду.
Под Windows:
Если какое-нибудь имя файла в командной строке совпадает с названием каталога, появляется диалог "Открыть файл" (появление диалога зависит от значения свойства "open.dialog.in.file.directory").
Если значение свойства "buffers" больше единицы, а имя файла совпадает либо с существующим файлом, либо, посредством поиска по групповому символу, с одним или более файлами, количество загружаемых совпадающих файлов не может быть больше заданного в свойствах "buffers" значения. Каталоги в этом случае совпадением не считаются.
Если имя файла содержит расширение, перед которым опционально указан путь к этому файлу, и ни один из существующих файлов не удовлетворяет этому условию, появляется диалог "Открыть файл", в котором заданное расширение используется в качестве фильтра.
Если имя файла не содержит расширения, то для того, чтобы найти существующий файл, этому файлу при помощи свойства "source.default.extensions" присваивается расширение по умолчанию.
SciTE может использовать от 1 до 100 вкладок, каждая из которых содержит файл. По умолчанию количество вкладок равно 1, при этом вкладки полностью отключаются. Если вкладок несколько, то для переключения между ними можно использовать меню "Вкладки" (Buffers), либо выбрать определенное имя файла, либо использовать команды "Предыдущая" (Previous - F6) и "Следующая" (Next - Shift+F6). [В Windows также можно использовать Ctrl+Tab/Ctrl+Shift+Tab]. Для доступа к первым десяти вкладкам можно использовать сочетания клавиш Alt+[номер вкладки]
, где [номер вкладки]
- числа от 0 до 9 (0 соответствует десятой вкладке).
Вкладки отображается для каждого буфера в панели вкладок, хотя это может быть отключено через пункт меню "Вид | Вкладки". Вкладка может быть закрыта, щелчком по ней средней кнопкой мыши.
Использование большого количества вкладок может создать определенные проблемы, так как количество файлов, которые могут отобразить некоторые меню, ограничено, и файлы, превышающие эту планку, будут недоступны.
Когда все доступные вкладки заняты файлами, то при открытии новых файлов вкладки будут использоваться повторно, для чего может потребоваться сохранение ранее содержащихся в этих вкладках файлов. В этом случае на экран будет выведено предупреждение для подтверждения действий пользователем.
Сессия представляет собой список файлов. Все вкладки, отображенные на экране, можно сохранить как сессию, чтобы в будущем их можно было быстро загрузить. Сессии сохраняются как файлы настроек с расширением ".session".
Для загрузки/сохранения сессий используются команды меню "Файл | Загрузить сессию" (File | Load Session) и "Файл | Сохранить сессию" (File | Save Session). При помощи свойства SciTE save.session можно включить/отключить автозагрузку последней сессии.
При установке save.session=1 SciTE при закрытии автоматически сохраняет список открытых в текущей сессии файлов в файле SciTE.session, расположенном по умолчанию в каталоге, определяемом переменной окружения %USERPROFILE%
(обычно это c:\Documents and Settings\username\SciTE.session
).
По этому же пути SciTE и загружает сессию при следующем старте (при save.session=1).
Файл сессии хранит информацию об имени файла и позиции курсора, а также (при session.bookmarks=1) о расположении меток и (session.folds=1) о состоянии фолдинга (сворачивания кода).
Свойство buffers, равное 0, отключает управление сессиями.
Загрузка ранее сохраненной сессии закрывает открытые вкладки, однако при этом вы не потеряете отредактированные вами данные, поскольку программа вначале предложит сохранить измененные файлы.
Открытие файла из командной строки аннулирует действие свойства save.session. Если вы запускаете SciTE посредством загрузки файла из командной строки, прошлая сессия не восстановится, даже если свойство save.session равно 1. Таким образом, свойство save.session является безопасным для использования в том смысле, что вы не откроете несколько файлов, если хотите открыть только один.
Файл, открываемый с помощью командной строки, уничтожает предыдущую сессию. Чтобы этого не происходило, можно поступить следующим способом: сначала запустить SciTE (SciTE при save.session=1 автоматически откроет предыдущую сессию), а затем уже добавить в SciTE файл любым удобным способом (перетаскиванием, через меню "Файл" или с помощью командной стоки). В этом случае открываемый файл не уничтожит текущую сессию, а добавится к ней.
При установке session.bookmarks=1 и session.folds=1 бумарки и состояние фолдинга всех открытых файлов будут сохранены в файле SciTE.session
, откуда затем будут восстановлены при следующем старте.
В настоящий момент SciTE поддерживает подсветку синтаксиса в следующих языках (* означает поддержку сворачивания кода):
Для некоторых из вышеприведенных языков были настроены команды запуска и компиляции. Однако целесообразно пересмотреть установленные настройки, с тем чтобы изменить их в соответствии с вашими предпочтениями.
Некоторые языки были включены, но закомментированы в глобальных опциях. Это позволило ограничить длину меню до разумных пределов. Для того чтобы воспользоваться этими языками, необходимо удалить символы комментариев '#
'.
Язык файла определяется по расширению этого файла, однако с помощью меню "Подсветка" (Language) можно установить другой язык. В свою очередь, меню "Подсветка" (Language) можно изменить с помощью свойства menu.language.
Either dialogs or strips may be used for find and replace, with dialogs being the default. Strips are similar to find in web browsers, appearing at the bottom of the window and are smaller and less distracting than dialogs. They are specified with the find.use.strip and replace.use.strip properties.
В SciTE возможен поиск и замена текста как в текущем, так и во всех открытых документах. Есть возможность выбрать направление поиска, учитывать регистр, использовать регулярные выражения.
Переход по результатам поиска можно осуществлять с помощью клавиши F3 (Shift+F3 - в обратном направлении). При достижении конца документа поиск автоматически продолжится с его начала (и наоборот - в зависимости от направления).
Для поиска и замены управляющих символов можно использовать си-подобные escape-последовательности.
При использовании регулярных выражений можно использовать нумерованные подстроки, которые в шаблоне поиска выделяются с помощью круглых скобок, а в шаблоне замены подставляются в виде \0..\9
.
Регулярные выражения в SciTE поддерживают все основные метасимволы, но не поддерживают символ новой строки \n
[решение для выхода из этой ситуации описано в FAQ].
On Windows, pressing Shift+Enter when the focus is in a text entry field will search in the opposite of the current direction, so will normally search backwards.
SciTE использует как собственные, так и заданные в движке Scintilla клавиатурные команды. Полный список команд и соответствующих им шорткатов вы можете увидеть в этом документе.
SciTE по большей части придерживается установленных в Windows и GTK+ стандартов. Клавиши навигации (стрелки, page up/down, home и end) поддерживают расширение или сужение области выделения при удержании Shift, а также выделение прямоугольных областей при удержании Shift и Alt. Некоторые клавиши могут быть недоступны в ряде национальных раскладок или в том случае, когда они контролируются системой (например, менеджером окон в GTK+).
Для задания собственной клавиатурной комбинации можно использовать параметр user.shortcuts, параметры command.shortcut (для назначения горячей клавиши на пункт меню Tools) или параметр menu.language (для назначения горячей клавиши на пункт меню Подсветка). Обратите внимание, что функции клавиши Home настраиваются при помощи опции vc.home.key.
Клавиатурные эквиваленты команд меню указаны в самом меню. Далее перечислены команды, не имеющие эквивалента в меню:
Увеличить размер текста | Ctrl+Keypad+ |
Уменьшить размер текста | Ctrl+Keypad- |
Восстановить размер текста по умолчанию | Ctrl+Keypad/ |
Цикличное переключение между открытими файлами | Ctrl+Tab |
Добавить отступ | Tab |
Убрать отступ | Shift+Tab |
Удалить слово слева от курсора | Ctrl+BackSpace |
Удалить слово справа от курсора | Ctrl+Delete |
Удалить строку слева от курсора | Ctrl+Shift+BackSpace |
Удалить строку справа от курсора | Ctrl+Shift+Delete |
Перейти к началу документа | Ctrl+Home |
Выделить фрагмент от курсора до начала документа | Ctrl+Shift+Home |
Перейти к началу строки | Alt+Home |
Выделить фрагмент текста до начала строки | Alt+Shift+Home |
Перейти к концу документа | Ctrl+End |
Выделить фрагмент от курсора до конца документа | Ctrl+Shift+End |
Перейти к концу строки | Alt+End |
Выделить фрагмент текста до конца строки | Alt+Shift+End |
Свернуть/Развернуть код | Ctrl+Keypad* |
Установить/Удалить метку | Ctrl+F2 |
Перейти к следующей метке | F2 |
Выделить до следующей метки | Alt+F2 |
Найти выделенное | Ctrl+F3 |
Найти выделенное в обратном порядке | Ctrl+Shift+F3 |
Прокрутить вверх | Ctrl+Up |
Прокрутить вниз | Ctrl+Down |
Вырезать строку | Ctrl+L |
Скопировать строку | Ctrl+Shift+T |
Удалить строку | Ctrl+Shift+L |
Поменять строки местами | Ctrl+T |
Дублировать текущую строку или выделенный текст | Ctrl+D |
Найти следующее вхождение директивы препроцессора, пропуская вложенные | Ctrl+K |
Выделить содержимое до следующей директивы препроцессора | Ctrl+Shift+K |
Найти предыдущее вхождение директивы препроцессора, пропуская вложенные | Ctrl+J |
Выделить содержимое до предыдущей директивы препроцессора | Ctrl+Shift+J |
Предыдущий абзац. Удерживание клавиши Shift активирует выделение | Ctrl+[ |
Следующий абзац. Удерживание клавиши Shift активирует выделение | Ctrl+] |
Предыдущее слово. Удерживание клавиши Shift активирует выделение | Ctrl+Left |
Следующее слово. Удерживание клавиши Shift активирует выделение | Ctrl+Right |
Предыдущая часть слова. Удерживание клавиши Shift активирует выделение | Ctrl+/ |
Следующая часть слова. Удерживание клавиши Shift активирует выделение | Ctrl+\ |
Выделение прямоугольного блока | Alt+Shift+курсорные |
On Windows, a search can be performed in the opposite direction by using Shift+Enter in the Find or Replace strips or dialogs.
В SciTE можно осуществить быструю замену коротких сокращений (аббревиатур) на строку текста или даже на целый блок кода. Чтобы использовать аббревиатуру, надо набрать ее, а затем выполнить команду меню "Правка | Расшифровать сокращение" (Ctrl+B) (для моментальной замены) или "Вставить сокращение..." (Ctrl+Shift+R) (для выбора из раскрывающегося списка). Аббревиатура заменяется расшифровкой, заданной в файле аббревиатур abbrev.properties
. Файл аббревиатур можно открыть с помощью команды меню "Настройки | Открыть файл настройки сокращений" и добавить туда свои аббревиатуры. Помимо файла аббревиатур, заданного по умолчанию, для определенных расширений файлов можно создать свои файлы аббревиатур.
Каждая строка в файле аббревиатур выглядит следующим образом: "аббревиатура=расшифровка
".
Аббревиатуры
могут содержать любые символы, включая символы верхней половины ASCII. Исключаются лишь управляющие символы и, конечно, символы возврата каретки (CR) и перевода строки (LF). У аббревиатур есть такие же ограничения, как и в файлах настроек: они не могут начинаться с решетки #
(т.к. такая строка будет истолкована как комментарий), пробела (хотя могут содержать пробелы внутри) и табуляции, а также не могут содержать внутри символ "=
".
Длина аббревиатур ограничена 32 символами, которых, надо полагать, вполне достаточно для аббревиатур. Длина расшифровок не ограничена.
Расшифровки
могут содержать символы новой строки "\n
" и позиции каретки "|". Чтобы использовать буквальный символ "|
", нужно набрать "||
". Вместе со SciTE поставляется файл аббревиатур, в котором содержится несколько простых примеров.
При расшифровке аббревиатуру не обязательно отделять от ранее набранного текста.
Т.е. если вы в файле сокращений задали e=é, и в тексте "eve|nt
" нажали Ctrl+B (символ | указывает позицию курсора), то "event
" превратится в "evént
".
Если одна из аббревиатур является окончанием второй, то расшифрована будет только более короткая последняя часть.
Т.е. если вы задали 2 сокращения text=TextFile и rtext=ReadingText, то после набора слова "rtext|
" (символ | указывает позицию курсора) и нажатия на Ctrl+B "rtext
" превратится в "rTextFile
", а не в "ReadingText
", как ожидалось.
SciTE-Ru предоставляет пользователям на порядок больше возможностей по работе с аббревиатурами. В списки сокращений можно добавлять пользовательские переменные: %SEL%
(выделенный текст), %CLP%
(текст из буфера обмена), %[имя_переменной]%
(значение внутренней переменной SciTE, например, CurrentWord
, FileNameExt
, SciteDefaultHome
и т.п.), %GUID%
(уникальный GUID нового объекта), что позволяет создавать высокоинтеллектуальные шаблоны замены.
Другая доработка позволяет использовать директиву import
в файлах аббревиатур.
Подробное описание этих доработок можно прочесть на этой странице.
SciTE поддерживает свертку кода для многих языков (см. выше список языков, которые поддерживает SciTE). Свертка основывается на отступах в коде Питона и на операторных скобках в других языках. [Операторные скобки - это буквальные скобки или команды, определяющие в языке программирования блок команд или составную инструкцию, воспринимаемую как единое целое, как одна команда. Например, If
и End If
в VBScript.]
Для того чтобы свернуть или развернуть код, необходимо щелкнуть мышкой по маркеру в местах сворачивания:
Совет: Чтобы открыть большой родительский блок со всеми свёрнутыми дочерними блоками, закройте его с Ctrl+щелчок мышью (на крестике свёртки), после чего откройте его обычным кликом. Открывая дочерний блок, вы увидите, что подблок дочернего блока свёрнут; если хотите, чтобы он при этом был открыт – откройте его, зажав Shift.
Большую часть возможностей SciTE можно перенастроить посредством редактирования файлов настроек.
Существует четыре вида файлов настроек. В порядке убывания приоритета:
SciTE.properties
. Этот файл может быть расположен в том же каталоге, что и редактируемый файл.SciTEDirectory.properties
, который может находиться в том же каталоге, что и редактируемый файл, или в родительском каталоге.SciTEUser.properties
(под Windows) и .SciTEUser.properties
(под GTK+).SciTEGlobal.properties
.Настройки локального файла настроек имеют преимущество перед настройками файла каталога, которые, в свою очередь, перекрывают настройки, содержащиеся в пользовательском файле, а последние перекрывают настройки глобальных файлов.
В Windows файл глобальных настроек расположен в папке, где находится исполняемый файл. Файл пользовательских настроек разыскивается в каталоге профиля пользователя, как задано в переменной окружения USERPROFILE
. Если переменная USERPROFILE
не задана, поиск ведется в каталоге, где расположен исполняемый файл. В GTK+ файл пользовательских настроек находится в домашнем каталоге пользователя, а глобальные настройки - в каталоге, заданном в момент сборки (обычно /usr/share/scite
). Если задана переменная окружения SciTE_HOME
, то и в Windows, и в GTK+ глобальный файл и файл пользовательских настроек находятся именно там.
Файл настроек каталога можно использовать в качестве файла опций проекта там, где пользовательские команды и команды compile и build должны функционировать аналогичным образом как в корневом каталоге, так и в подкаталогах проекта. Преимущество такого решения состоит в том, что таким образом локальные файлы настроек в подкаталогах можно заменить всего лишь одним файлом настроек, расположив его в корне проекта. Анализ файла настроек каталога отключается по умолчанию. Для того чтобы им можно было пользоваться, необходимо в пользовательском или глобальном файле настроек установить переменную properties.directory.enable в 12.
Настройки по умолчанию "зашиты" в код SciTE и редактор может работать вообще без единого файла настроек. В SciTEGlobal.properties
находятся настройки, рекомендуемые распостранителем пакета для всех пользователей. Если пользователя не устраивают рекомендуемые настройки или он хочет их дополнить, то он может либо изменить их, либо создать файл SciTEUser.properties
со своими настройками, которые автоматически перекроют одноименные параметры в SciTEGlobal.properties
. Более подробно про файлы настроек можно прочитать здесь. Основной функцией локальных файлов настроек является настройка команд Compile, Build и Go для работы с файлами каталога. К примеру, если в большинстве случаев пользователь использует компилятор javac
из Java Development Kit, в файле SciTEGlobal.properties
задается команда для компиляции файлов .java
в javac
. Если же для файлов одного из каталогов ему нужен компилятор jvc
, тогда в файле SciTE.properties
, расположенном в этом каталоге, задается компилятор jvc
.
В меню Настройки (Options) есть команды для открытия каждого файла настроек.
Файлы настроек имеют примерно тот же формат, что и файлы настроек языка Java, в которых используется простой текстовый формат. Строки, начинающиеся с символа '#
' являются комментариями и игнорируются, также как и пустые строки. Остальные строки имеют форму
переменная=
значение.
При длинных значениях в конце строки ставится символ '\', указывающий, что продолжение этого значения находится на следующей строке. Необходимо обращать внимание на пробелы. Так, x =1 задает переменную из двух символов "x ".
При помощи конструкции $(variablename) можно подставить значение переменной, где variablename
- имя переменной, в значение которой можно включить значение другой переменной. В качестве переменных в этой конструкции помимо заданных ранее в файле(-ах) можно использовать переменные окружения, а также внутренние переменные SciTE:
Имя | Значение |
---|---|
FilePath | полный путь к текущему файлу |
FileDir | папка текущего файла без замыкающего слеша |
FileName | базовое имя (без расширения) текущего файла |
FileExt | расширение текущего файла |
FileNameExt | $(FileName).$(FileExt) |
Language | имя текущего лексера |
BufferNumber | номер буфера текущего файла |
SessionPath | полный путь к текущей сессии |
CurrentSelection | выделенный текст |
CurrentWord | слово с кареткой внутри слова или около него |
CurrentWordCharacters | перечень символов из которых строятся слова текущего языка |
Replacements | количество замен, сделанное последней командой Replace |
SelectionStartColumn | столбец, с которого начато выделение |
SelectionStartLine | строка, с которой начато выделение |
SelectionEndColumn | столбец, где завершается выделение |
SelectionEndLine | строка, где завершается выделение |
CurrentMessage | последнее выделенное выходное сообщение |
SciteDefaultHome | папка с файлом глобальных настроек и файлом локализации интерфейса (обычно совпадает с местоположением scite.exe) |
SciteUserHome | папка с файлом пользовательских настроек |
SciteDirectoryHome | папка с файлом настроек каталога |
APIPath | путь к текущему api файлу |
AbbrevPath | путь к текущему файлу сокращений |
В качестве значения определенных параметров может использоваться маска имени файла или групповой шаблон для файлов с различными расширениями. Например, переменная lexer может быть задана как для определенного файла, так и для группы файлов на основании группового символа:
lexer.makefile=makefile означает то, что lexer под названием "makefile" должен использоваться для файлов с именем "makefile".
lexer.*.cxx=cpp означает то, что lexer под названием "cpp" должен использоваться для файлов с расширением "cxx".
Подстановка переменной происходит с левой стороны от файлового шаблона и выглядит подобным образом:
Групповой шаблон действует только когда он находится слева от определения группы файлов, то есть "*.mak" подойдёт для "proj.mak", но "Makefile*" не подойдёт для "Makefile.in".
Файлы ".properties" могут быть в любой кодировке, однако определённые значения свойств могут подразумевать определённую кодировку. Для имён файлов, команд и текста пользовательского интерфейса – это UTF-8, так что вероятно гораздо легче редактировать файлы ".properties" как UTF-8, вставляя строки кода как будет описано далее. Другие свойства могут подразумевать последовательность байтов (например, word.characters.filepattern) или неявную кодировку (напр., keywords.filepattern для совпадения с кодировкой документа), так что может быть лучше редактировать эти настройки используя не UTF-8 кодировку. Там, где нужны оба, и UTF-8, и не UTF-8 значения, можно использовать два файла и выражение import для включения содержимого одного из файлов в другой.
Более подробно о паттернах в файлах настроек можно прочитать в этой статье.
Оператор import подключает файл настроек, как если бы в данное место был вставлен текст. Путь к импортируемому файлу настроек может быть задан как абсолютный либо как относителный к базовому файлу, и иметь расширение properties
. Следовательно, оператор import Lua в файле c:\os\scite\bin\SciTEGlobal.properties
импортирует файл c:\os\scite\bin\Lua.properties
.
Любой оператор import в импортируемом файле будет брать путь относительно каталога исходного (а не текущего) файла.
Imported files are not scope walls: properties may be redefined in another file.
Thus, if a file contains both import cplusplus, import java, and style.cpp.1=fore:$(comment.colour)
then
cplusplus.properties contains comment.colour=#800000
and java.properties contains
comment.colour=#008000
then the last definition wins and is active for the definitions in the base
file as well as any definitions in cplusplus.properties and java.properties.
C помощью оператора if можно выборочно применять отдельные параметры настройки. Условие if MY_VALUE
считается выполненным, если параметру MY_VALUE
было присвоено значение 1. Если условие выполнено, то идущим далее с отступом от начала строки параметрам настройки присваиваются заданные значения. Действие условия распостраняется до первого параметра, записанного с начала строки без отступа.
Обычно оператор if используется для подключения определенных блоков в файлах настроек в зависимости от значения переменных PLAT_GTK, PLAT_WIN или PLAT_MAC, с помощью которых SciTE идентифицирует используемую ОС. При использовании оператора if в своих файлах настроек, учтите, что проверка условия происходит только при загрузке файла настроек, а не во время работы программы.
SciTE автоматически определяет схему кодирования, используемую для файлов в кодировке Юникод, которые начинаются с метки порядка байтов (Byte Order Mark, BOM). Распознаются также кодировки UTF-8
и UTF-16
, в том числе и варианты кодировки UTF-16 - Little Endian
и Big Endian
.
Файлы в кодировке UTF-8
распознаются и тогда, когда они содержат маркер кодирования (coding cookie
) в одной из первых двух строк. Маркер кодирования имеет вид "coding: utf-8
" ("coding
", вслед за которым следуют символ ':
' или '=
', символ пробела (опционально), кавычки (опционально), "utf-8
") и обычно располагается в комментариях:
Если кодировка текущего файла не распознана как Юникод, то SciTE отображает текст в соответствии с установками параметров code.page и character.set.
Некоторые свойства доступны только под Windows или GTK+.
position.left position.top position.width position.height position.maximize |
Задают первоначальный размер и позицию окна. Если эти переменные не заданы, первоначальный размер и позиция окна определяются системой. Если position.width=-1 или position.height=-1 или position.maximize=1 - окно развернуто до максимального размера. | ||||||||||||||||||||||||||||||||||
position.tile | При установке position.tile=1 левая граница нового окна будет равна position.left + position.width первого окна (т.е. новое окно будет касаться правого края первого окна). Таким образом окна не будут перекрывать друг друга. Если position.left=0, а position.width равна половине ширины экрана, то два окна SciTE перекроют экран целиком, разделив его ширину между собой ровно пополам. |
||||||||||||||||||||||||||||||||||
buffers | Задает количество вкладок, каждая из которых может содержать открытый файл. Может принимать значение от 1 до 100. Значения, не входящие в этот диапазон, устанавливаются в его граничные значения. По умолчанию значение равно 1. При этом значении вкладки не отображаются. Данное значение считывается только из файлов глобальных настроек (т.е. из SciTEGlobal.properties , SciTEUser.properties , а также всех остальных файлов настроек, подключенных к названным с помощью директивы import). Поскольку данное значение считывается только один раз при запуске программы, необходимо перезапустить SciTE, чтобы изменение вступило в силу. |
||||||||||||||||||||||||||||||||||
buffers.zorder.switching | Данная настройка задает порядок переключения между вкладками при нажатии комбинации Ctrl+Tab . Если задать значение 1, переключение будет происходить в том порядке, в котором вкладки открывались ранее. В противном случае переключение будет происходить по порядку номеров вкладок. |
||||||||||||||||||||||||||||||||||
are.you.sure are.you.sure.for.build |
Если задать переменной are.you.sure значение 0, файл при закрытии будет сохраняться автоматически, не беспокоя пользователя вопросом о сохранении изменений. В этом случае отказаться от сохранения изменений можно, только если параметр buffers у вас отстутствует. Тогда, выбрав из меню команду для создания нового файла, можно заставить SciTE показать диалоговое окно с запросом о сохранении текущего (поскольку новый файл займет его место). SciTE автоматически сохраняет текущий файл перед выполнением, компиляцией или запуском других команд из меню "Tools". Установка are.you.sure.for.build=1 будет вызывать диалоговое окно с запросом о сохранении при выполнении этих команд. |
||||||||||||||||||||||||||||||||||
save.all.for.build | Обычно перед выполнением команд "Compile", "Build" или "Go" SciTE сохраняет текущую вкладку. Чтобы сохранять все вкладки, задайте save.all.for.build=1. | ||||||||||||||||||||||||||||||||||
view.whitespace view.indentation.whitespace |
При view.whitespace=1 будут видимы пробелы и знаки табуляции. При view.indentation.whitespace=1 будут видимы пробелы и знаки табуляции, используемые в отступах строк. |
||||||||||||||||||||||||||||||||||
whitespace.fore whitespace.back |
Задает цвета символов и фона для всех видимых пробелов и знаков табуляци, отменяя при этом цвета, заданные текущим лексером. | ||||||||||||||||||||||||||||||||||
view.indentation.guides view.indentation.examine view.indentation.examine.filepattern highlight.indentation.guides |
При view.indentation.guides=1 отображаются пунктирные вертикальные линии в пределах отступа, заданного командой indent.size. При highlight.indentation.guides=1 выделяется относящаяся к скобке направляющая отступа (indentation guide), когда эта скобка выделена. При установке highlight.indentation.guides=1, и braces.check=1 установка курсора на одну из парных скобок будет окрашивать не только скобки, но и направляющую отступа, относящуюся к ним. Setting view.indentation.guides to 1 displays dotted vertical lines within indentation white space every indent.size columns. Setting view.indentation.examine to 1 to display guides within real indentation whitespace only, 2 according to the next non-empty line (good for Python) or 3 according to both the next and previous non-empty lines (good for most languages). Setting highlight.indentation.guides to 1 highlights the indentation guide associated with a brace when that brace is highlighted. |
||||||||||||||||||||||||||||||||||
view.eol | Задайте этой переменной значение 1 с тем, чтобы отобразить символы конца строки, которые будут выглядеть как (CR ), (LF ) или (CR )(LF ). Полезно при использовании файлов, созданных на другой операционной системе, с программным обеспечением, чувствительным к оформлению концов строк. |
||||||||||||||||||||||||||||||||||
eol.mode |
Режим EOL по умолчанию (символы конца строки) зависит от платформы. Можно изменить этот режим, задав:
LF для формата UNIX и OS XCR для формата Macintosh до OS XCRLF для формата DOS/Windows
|
||||||||||||||||||||||||||||||||||
eol.auto | Эта настройка перекрывает значение, заданное переменной eol.mode и выбирает последовательность символов конца строки на основании текущего содержимого открытого файла. При этом отдается предпочтение символу, который чаще всего используется в этом файле. | ||||||||||||||||||||||||||||||||||
blank.margin.left blank.margin.right |
С обеих сторон текста расположен пустой отступ, цвет которого совпадает с цветом фона текста. По умолчанию, размер этого отступа равен одному пикселю как для правой, так и для левой стороны. Однако с помощью данной настройки размер отступов можно изменить. | ||||||||||||||||||||||||||||||||||
margin.width | Эта переменная задает ширину в пикселях левой вертикальной колонки для меток (bookmarks). | ||||||||||||||||||||||||||||||||||
full.screen.hides.menu | Задайте этой переменной значение 1 с тем, чтобы скрыть строку меню при полноэкранном режиме в Windows. В GTK+ это меню отображается всегда. | ||||||||||||||||||||||||||||||||||
minimize.to.tray | Задайте этой переменной значение 1 с тем, чтобы сворачивать SciTE в трей, а не на панель задач. | ||||||||||||||||||||||||||||||||||
line.margin.visible line.margin.width |
SciTE может отображать слева от колонки меток колонку с номерами строк. Если задать переменной line.margin.visible значение 1, эта колонка будет видна при запуске редактора. Свойство line.margin.width резервирует ширину колонки, исходя из заданного в этом параметре количества отображаемых цифр. Чтобы колонка могла расширяться при увеличении количества цифр, после значения, определяющего количество цифр, добавьте '+ ', например: line.margin.width=3+.Данные переменные являются заменой свойства line.numbers которое использовалось раньше и выполняло функции обоих переменных, описанных выше. В настоящее время свойство line.numbers в программе больше не используется. |
||||||||||||||||||||||||||||||||||
tabbar.visible | Задайте переменной tabbar.visible значение 1, чтобы сделать видимой панель файловых вкладок (tab bar). Чтобы эта опция работала, необходимо свойству buffers присвоить значение, превышающее 1. |
||||||||||||||||||||||||||||||||||
tabbar.hide.one | Задайте переменной tabbar.hide.one значение 1, чтобы спрятать панель файловых вкладок до тех пор, пока не появится больше одной вкладки. |
||||||||||||||||||||||||||||||||||
tabbar.multiline | Переменная tabbar.multiline позволяет расположить панель файловых вкладок на нескольких строках |
||||||||||||||||||||||||||||||||||
toolbar.visible | Задайте данной переменной значение 1, чтобы сделать видимой панель инструментов. | ||||||||||||||||||||||||||||||||||
toolbar.usestockicons | В SciTE имеются встроенные иконки для панели инструментов. Если задать данной переменной значение 1, будут использоваться иконки темы, заданной в данный момент для рабочего стола GNOME. | ||||||||||||||||||||||||||||||||||
pathbar.visible | PathBar - линия текста под файловыми вкладками, показывающая полный путь текущей вкладки. Установка pathbar.visible=1 делает эту информационную линию видимой на GTK+. | ||||||||||||||||||||||||||||||||||
undo.redo.lazy | Кнопки "Undo (Отменить)" и "Redo (Вернуть)" не активны до тех пор, пока в текст не вносили никаких изменений. Например, как только внесены изменения, становится активна "Undo" (т.е. можно отменить свое действие). Задайте данной переменной значение 1 для того, чтобы поменять метод, который определяет, когда сделать доступными или недоступными эти кнопки панели инструментов. Значение 1 может увеличить быстродействие на медленных машинах. |
||||||||||||||||||||||||||||||||||
statusbar.visible | Задайте данной переменной значение 1 для того, чтобы сделать видимой строку состояния. | ||||||||||||||||||||||||||||||||||
statusbar.number statusbar.text.number |
С помощью опции statusbar.text.1 задается информация, по умолчанию отображаемая в строке состояния. Опция поддерживается всеми платформами. В значениях свойств может быть использован синтаксис $() . Среди наиболее часто используемых свойств - ReadOnly , EOLMode , BufferLength , NbOfLines (во вкладках), SelLength (символы), SelHeight (строки). Кроме того, для строки состояния задаются дополнительные свойства: LineNumber , ColumnNumber и OverType , которая принимает значение "OVR" или "INS", в зависимости от состояния способа вставки (overtype status). Можно также использовать свойства файлов, которые, в отличие от вышеназванных, не обновляются при каждом нажатии клавиши: FileName или FileNameExt , FileDate и FileTime и FileAttr . А также CurrentDate и CurrentTime .Под Windows (только) можно задать дополнительный текст как statusbar.text.2 и т.д. Тогда между заданными текстами можно циклически переключаться, щелкая по строке состояния.Переменная statusbar.number определяет, между каким количеством текстов будет происходить это переключение. |
||||||||||||||||||||||||||||||||||
use.palette | Задайте данной переменной значение 1 для того, чтобы разрешить SciTE использовать на 8-битных дисплеях цветовую палитру с большим количеством цветов. Без этой опции SciTE будет использовать системную палитру Windows, состоящую из 20 цветов. Недостатком этой опции является то, что при активации окон возникает некоторое мигание. Данная опция не используется на GTK+, где цветовая палитра всегда подключена. | ||||||||||||||||||||||||||||||||||
buffered.draw | Если задать этой переменной значение 0 (по умолчанию 1), SciTE выводит выходные данные непосредственно на экран, в отличие от обычного режима, когда данные вначале помещаются в буфер и только затем выводятся на экран. Буферизованный вывод предотвращает мерцание экрана, но на слабых компьютерах работает медленнее. | ||||||||||||||||||||||||||||||||||
two.phase.draw | Двухфазовый вывод данных - более удачный способ отрисовки текста, но при этом более медленный. При однофазовом способе каждая последовательность символов, имеющих один стиль, отрисовываются вместе с фоном. Если конец одного символа "нависает" над началом другого символа, например: "V_ " где стиль "V " отличается от стиля "_ ", то правая часть символа "V " будет перекрыта фоном "_ ". В двухфазовом способе эта проблема устраняется тем, что вначале отрисовывается фон, а затем, в прозрачном режиме, текст. При двухфазовом способе отрисовки мерцание экрана может проявляться в большей степени, чем при однофазовом, если только не включена опция buffered.draw. По умолчанию используется двухфазовый способ. |
||||||||||||||||||||||||||||||||||
load.on.activate save.on.deactivate |
Задайте переменную load.on.activate, чтобы SciTE при выборе вкладки с открытым файлом проверял, не был ли тот изменен другой программой. Эта опция полезна в том случае, если совместно со SciTE используется другой редактор (например, WYSIWYG HTML). Задайте переменную save.on.deactivate, чтобы SciTE сохранял файл каждый раз, когда приложение SciTE теряет фокус. Это удобно, когда в процессе разработки web-страниц нужно часто контролировать внешний вид страницы в браузере |
||||||||||||||||||||||||||||||||||
are.you.sure.on.reload | Если данной переменной и переменной load.on.activate одновременно задано значение 1, SciTE будет спрашивать, действительно ли вы хотите обновить измененный файл, давая вам возможность сохранить файл таким, какой он есть. По умолчанию эта опция отключена и SciTE обновляет файл, не беспокоя при этом пользователя. | ||||||||||||||||||||||||||||||||||
reload.preserves.undo | Задайте этой переменной значение 1, чтобы при обновлении файла не уничтожалась вся история команд для отмены (undo). Это позволяет отменить изменения, автоматически внесенные другой программой при установленной опции load.on.activate=1. | ||||||||||||||||||||||||||||||||||
check.if.already.open | Данная опция позволяет открывать файлы в существующем экземпляре SciTE, не запуская каждый раз новый экземпляр. При check.if.already.open=1 новый файл, асоциированный со SciTE, открывается не в новом окне программы, а в том экземпляре, в котором отмечен галочкой пункт меню "Настройки" - "Открывать только одну копию программы" (Options - Open Files Here). Под GTK+ файл открывается в произвольном экземпляре. | ||||||||||||||||||||||||||||||||||
read.only | При read.only=1 все открытые документы недоступны для редактирования (до явной отмены этой опции через меню "Настройки" - "Только для чтения"). Данная настройка не действует для новых файлов. | ||||||||||||||||||||||||||||||||||
temp.files.sync.load | Files dropped on SciTE on Windows are normally opened asynchronously
as there may be a long list. However, files dragged from some applications
such as 7-Zip may only exist for a moment in the temporary directory and
be deleted once the drop has occurred. Setting this to 1 makes SciTE open dropped files in the temporary directory immediately. |
||||||||||||||||||||||||||||||||||
quit.on.close.last | Если задана эта переменная, при закрытии последней вкладки (напр. с помощью "File | Close") закрывается весь SciTE. (Если данная опция не задана, по умолчанию, после закрытия последней вкладки, SciTE не завершает работу, а создает пустой документ.) | ||||||||||||||||||||||||||||||||||
highlight.current.word | Когда установлено в 1, все вхождения выделенного слова выделяются цветом, заданным параметром highlight.current.word.colour. По умолчанию эта опция отключена. (См. indicators.alpha и indicators.under) | ||||||||||||||||||||||||||||||||||
highlight.current.word.colour highlight.current.word.by.style |
Опция highlight.current.word.colour определяет цвет подсветки. Значение по умолчанию равно #A0A000. Если опция highlight.current.word.by.style установлена, то выделены будут только слова с тем же стилем (например, если выбрано слово в комментарии, то будут выделены только все вхождения этого слова в комментариях). |
||||||||||||||||||||||||||||||||||
rectangular.selection.modifier |
On GTK+, the modifier key used to make rectangular selections can be set with this
property. Valid options are 2 (Ctrl), 4 (Alt) or 8 (Super). Super is often assigned to the
Windows/Start key on Windows keyboards or the Command key on Mac keyboards.
Since the Alt key is often used by window managers to move windows, this will need to be configured off to use the combination in SciTE. This can be done for Metacity using gconf-editor to modify the /apps/metacity/general/mouse_button_modifier. A valid value here is <Super>. |
||||||||||||||||||||||||||||||||||
selection.fore selection.back selection.alpha |
Задают цвета, используемые для отображения выделенного текста. По умолчанию, фон выделенного текста - светло-серый, а передний план остается таким же, как до выделения. Опция selection.alpha задает степень прозрачности выделенного текста. Значение 256 соответствует полной непрозрачности. |
||||||||||||||||||||||||||||||||||
caret.fore | Задает цвет курсора вставки. | ||||||||||||||||||||||||||||||||||
selection.additional.fore selection.additional.back selection.additional.alpha |
Действует подобно selection.fore, selection.back, selection.alpha для задания цветов и прозрачности при многократном выделении или при выделении прямоугольной области. | ||||||||||||||||||||||||||||||||||
caret.additional.blinks | При установке 0 мерцает только главный значок каретки. При установке 1 мерцают все символы каретки во всех выделенных областях. Установка по умолчанию - 1. | ||||||||||||||||||||||||||||||||||
caret.line.back | Задает цвет фона для строки, в которой стоит курсор. | ||||||||||||||||||||||||||||||||||
caret.line.back.alpha | Задает степень прозрачности для строки, в которой стоит курсор. Степень прозрачности изменяется от 0 (полная прозрачность) до 255 (полная непрозрачность). Значение 256 означает полную прозрачность строки для символов при наличии наиболее яркого выделения строки цветом. Учтите, что caret.line.back.alpha=256 будет сказываться на производительности SciTE, тогда как простое комментирование этого параметра, приводя к такому же эффекту, не будет замедлять работу. | ||||||||||||||||||||||||||||||||||
caret.period | Задает частоту, с которой мерцает курсор вставки. Значение данной переменной представляет собой время в миллисекундах, в течение которого курсор виден. Затем курсор исчезает из поля зрения на тот же самый промежуток времени. Для того чтобы курсор не мигал, задайте этой переменной значение 0. | ||||||||||||||||||||||||||||||||||
caret.width | Задает ширину курсора вставки в пикселях. Возможны значения 1, 2 и 3. | ||||||||||||||||||||||||||||||||||
selection.multiple selection.additional.typing |
Установка selection.multiple позволяет делать многкратные выделения мышью, удерживая клавишу Ctrl При selection.additional.typing=1 печать текста, нажатие на клавиши BackSpace или Delete будет одновременно применятся на все выделенные части текста.При selection.additional.typing=0 эффект будет распостранятся только на главное выделение. |
||||||||||||||||||||||||||||||||||
virtual.space |
Позволяет перемещать каретку дальше последнего символа на линии (в т.н. "виртуальное пространство"). Установка параметра на 1 разрешает виртуальные пробелы при прямоугольном выделении. 2 - разрешает использовать курсорные клавиши или мышь для перемещения каретки в виртуальное пространство. 3 - разрешает и то и другое. |
||||||||||||||||||||||||||||||||||
caret.policy.xslop caret.policy.width caret.policy.xstrict caret.policy.xeven caret.policy.xjumps caret.policy.yslop caret.policy.lines caret.policy.ystrict caret.policy.yeven caret.policy.yjumps |
Данные параметры задают поведение программы при приближении текстового курсора к краю окна. Например, если текст по высоте намного длиннее окна редактора, бывает необходимо всегда видеть несколько строк выше или ниже редактируемой строки, чтобы не использовать прокрутку вручную каждый раз, когда курсор подходит к краю. |
||||||||||||||||||||||||||||||||||
visible.policy.strict visible.policy.slop visible.policy.lines |
Определяют, как прокручивать область экрана после команд "Go", "Build", "Compile" или таких, как "Find" или "Next Message". Данные опции похожи на опции caret.policy.*. | ||||||||||||||||||||||||||||||||||
edge.mode edge.column edge.colour |
Эти параметры определяют способ отображения "слишком" длинных строк. Параметр edge.column определяет максимальную длину "нормальной" строки. Если значение переменной edge.mode равно 0 (по умолчанию), длинные строки никак не помечаются. Если значение равно 1, отображается специальная вертикальная линия, которая показывает границу строки "нормальной" длины. При значении 2 изменяется цвет фона символов той части строки, которая превышает заданную максимальную длину. Параметр edge.colour определяет цвет фона символов той части строки, которая превышает заданную максимальную длину, или цвет вертикальной линии, которая показывает границу (в зависимости от значения параметра edge.mode). |
||||||||||||||||||||||||||||||||||
control.char.symbol | Задает символ, используемый для отображения непечатаемых символов (например, переводов строк). Если данная переменная не задана, такие символы отображаются с помощью специальных мнемоник (например, нажмите Ctrl+Shift+9 , чтобы отобразить символы переводов строк). |
||||||||||||||||||||||||||||||||||
error.marker.fore error.marker.back |
Задают цвета для указания на ошибку в панели редактирования (после того щелчка по строке с ошибкой, появившейся в панели вывода). Если в панели есть поле (колонка) для меток, то на нем будет отображаться символ, который указывает на строку с ошибкой. Переменная error.marker.back используется для того, чтобы задать для символа заполняющий цвет, а переменная error.marker.fore - цвет контура. Если поля (колонки) меток нет, фон строки задает переменная error.marker.back. Примечание: поле (колонку) для меток можно убрать, установив line.margin.visible=0 или margin.width=0, или через меню "Вид" - "Метки". (В SciTE-Ru параметром error.line.back также можно задать цвет фона строки с текстом ошибки в окне консоли, отличный от цвета, заданного значением error.marker.back) |
||||||||||||||||||||||||||||||||||
bookmark.fore bookmark.back bookmark.alpha |
Параметр bookmark.back задает цвет метки. Если поле с метками убрано (line.margin.visible=0 или margin.width=0, или через меню "Вид | Поля"), то этим фоном будет подсвечиваться строка. С помощью bookmark.alpha можно задать степень прозрачности этой строки. Если переменная bookmark.fore не задана, то в качестве метки используется объемный синий шарик. |
||||||||||||||||||||||||||||||||||
find.mark | Задайте эту переменную, чтобы команда "Пометить все" (Mark All) в диалоге "Найти" поверх каждого найденного вхождения отобразила полупрозрачные прямоугольники. (See indicators.alpha and indicators.under) [Значение переменной - цвет полупрозрачного маркера выделения]. | ||||||||||||||||||||||||||||||||||
indicators.alpha | This property defines the alpha level for indicators (default value is 30). The alpha value can range from 0 (completely transparent) to 255 (no transparency). A value out of this range is ignored and the default one is used. | ||||||||||||||||||||||||||||||||||
indicators.under | If set, the indicators are drawn under text or over (by default, it is over). | ||||||||||||||||||||||||||||||||||
error.select.line | Если при исполнении кода в окно консоли выводится сообщение об ошибке и производится нажатие на F4 (или двойной клик на строке с ошибкой), то курсор в окне редактора перемещается на строку с ошибкой.Установка error.select.line=1 кроме этого, дополнительно выделяет строку с ошибкой. В тех случаях, когда сообщение об ошибке дополнительно содержит позицию ошибки в строке, выделение начинается с этой позиции. Сообщение, содержащее позицию ошибки в строке, должно быть понятным для SciTE (в настоящее время это поддерживается только для HTML Tidy - консольной утилиты для проверки корректности синтаксиса и автоматического форматирования HTML кода). Для корректного определения позиции ширина символа табуляции, используемая внешней утилитой, должна совпадать с шириной символа табуляции в вашем файле. |
||||||||||||||||||||||||||||||||||
openpath.filepattern |
Задает путь к файлу при выполнении команды "Открыть выделенный файл" (Open Selected Filename) в меню "Файл". Поиск пути ведется в том случае, если выбранное имя файла не содержит абсолютный путь или файл не найден в каталоге "Мои документы ". В openpath каталоги разделяются точкой с запятой в Windows и двоеточием в OS X и GTK+.Переменная openpath может выглядеть следующим образом:
openpath.*.txt=c:\dos\;f:\;
openpath.$(file.patterns.cpp)=$(cpp_includes) |
||||||||||||||||||||||||||||||||||
open.suffix.filepattern |
Задает расширение, которое команда "Открыть выделенный файл" (Open Selected Filename) в меню "Файл" добавит к выбранному имени файла. Используется в языках, в которых при обращении к файлу расширение не задается. Например, в Питоне import xlib чаще всего означает "импортировать из файла под названием xlib.py ".Пример переменной open.suffix:
open.suffix.*.py=.py
|
||||||||||||||||||||||||||||||||||
strip.trailing.spaces | При сохранении удаляет пробелы на концах строк. | ||||||||||||||||||||||||||||||||||
ensure.final.line.end | При сохранении добавляет в конец файла перенос строки. | ||||||||||||||||||||||||||||||||||
ensure.consistent.line.ends | При сохранении добавляет (если нужно) в конец каждой строки текущий символ окончания строки. | ||||||||||||||||||||||||||||||||||
abbreviations.filepattern |
Загружает файл аббревиатур конкретного языка, который заменяет файл аббревиатур, установленный по умолчанию. Например:
abbreviations.*.c=$(SciteUserHome)/c_abbrev.properties
|
||||||||||||||||||||||||||||||||||
api.filepattern |
Загружает API-файлы конкретного языка. Если API-файлов несколько, имена файлов разделяются точкой с запятой. API-файлы содержат отсортированный список идентификаторов и прототипов функций, по одному на каждую строку. Команда Завершить символ ("Complete Symbol", Ctrl+I ) выводит список вариантов завершения набранного слова, просматривая строки API-файла. При введении открывающей скобки или другого символа, заданного в параметре calltip.lexer.parameters.start, в файле ищется текст, который предшествует курсору ввода. Если обнаруживается прототип функции, он отображается как всплывающая подсказка (calltip). Например, опцию
api.*.c=w.api можно использовать с файлом w.api , содержащим
fclose(FILE* fileClose) с тем, чтобы для некоторых из функций C-файла предусмотреть автозавершение и всплывающие подсказки. Теперь, создав C-файл, написав в нем "FILE fopen(const char* szFileName, const char* szMode) fpos_t fread(void* buf, size_t size, size_t count, FILE* file) fseek(FILE* file, long lnOffset, int nOrigin) f " и нажав Ctrl+Space , мы увидим список вариантов завершения слова (т.е. те функции, что мы записали в w.api ). Выбрав из списка "fread " и открыв круглую скобку, увидим всплывающую подсказку с параметрами этой функции.Обратите внимание: когда вы введете очередной параметр функции и поставте разделитель (запятую), подсветка на всплывающей подсказке переместится на следующий параметр. API-файл может содержать не только функции с их параметрами; любую строку можно дополнить развернутым описанием, которое так же будет показываться в всплывающей подсказке. (В SciTE-Ru в API-файлах хранятся ещё и списки с методами/свойствами объектов). В этом параметре SciTE лучше использовать полный путь к API-файлу, поскольку иначе будет использован текущий каталог. Чтобы узнать, как создавать API-файлы, см. раздел "Создание API-файлов". |
||||||||||||||||||||||||||||||||||
autocomplete.choose.single | Если значение этой переменной равно 1, то при использовании автоматического завершения и при наличии единственного варианта завершения слова, этот вариант подставляется автоматически, без отображения списка вариантов. | ||||||||||||||||||||||||||||||||||
autocomplete.lexer.ignorecase autocomplete.*.ignorecase |
Если значение этой переменной равно 1, поиск элементов автодополнения в API-файле производится без учета регистра. В противном случае учитывается регистр. Форма * используется для всех остальных лексеров, у которых данный параметр не задан явно. |
||||||||||||||||||||||||||||||||||
autocomplete.lexer.start.characters autocomplete.*.start.characters |
Набор любого из символов, перечисленных как значения данной переменной, вызовет запуск функции автозавершения. Например, если autocomplete.python.start.characters=. и API-файл для Питона содержит "string.rjust " и "string.replace ", то если напечатать "string. ", автозавершение отобразит оба варианта завершения.Форма * используется для всех остальных лексеров, у которых данный параметр не задан явно. |
||||||||||||||||||||||||||||||||||
autocomplete.lexer.fillups autocomplete.*.fillups |
Завершить выбор из списка автозавершения (возникающего после нажатия на Ctrl+Space ) можно с помощью клавиш Tab , Enter , а так же введя с клавиатуры любой из символов, перечисленных в параметре autocomplete.lexer.fillups.Например, если autocomplete.python.fillups=( и API-файл для Питона содержит "string.replace ", то в результате набора "string.r( " в текст будет вставлено "string.replace( ".Форма * используется для всех остальных лексеров, у которых данный параметр не задан явно. |
||||||||||||||||||||||||||||||||||
autocompleteword.automatic | Если значение данной переменной равно 1, SciTE после ввода каждого символа будет автоматически (без нажатия Ctrl+Enter ) искать в тексте текущего файла варианты дополнения введенного слова.Если при наборе какого-либо слова в файле найдется текст, начинающийся с такой же последовательности символов, то возникнет список из единственного варианта завершения, который можно будет выбрать нажатием клавиши Tab .Примечание: Две команды меню "Правка" работают следующим образом: - "Завершить символ"/Complete Symbol ( Ctrl+I , Ctrl+Space ) - берёт варианты только из API-файла [В SciTE-Ru эта команда берёт варианты дополнения и из API-файла, и из текста.];- "Завершить слово"/Complete Word ( Ctrl+Enter ) - берет варианты только из текущего текста.Установка autocompleteword.automatic=1 будет имитировать нажатие именно Ctrl+Enter , но не Ctrl+I (Ctrl+Space ). |
||||||||||||||||||||||||||||||||||
calltip.lexer.ignorecase calltip.*.ignorecase |
Если значение этой переменной равно 1, поиск функции, параметры и описание которой будет отображаться как всплывающая подсказка, ведётся без учета регистра. Форма * используется для всех остальных лексеров, у которых данный параметр не задан явно. |
||||||||||||||||||||||||||||||||||
calltip.lexer.word.characters calltip.*.word.characters |
Задает набор символов из которых строятся функции языка программирования. Несмотря на то, что может использоваться такая же настройка, как для word.characters, иногда необходимо добавлять к набору дополнительные символы. Например, в Питоне точка ('. ') обычно не рассматривается как часть слова, однако, если мы хотим увидеть всплывающую подсказку после того, как наберем "string.replace ", то нам необходимо добавить точку в набор calltip.python.word.characters=._$(chars.alpha), чтобы SciTE рассматривал "string.replace " как целую функцию (одно слово) и искал в api-файле подсказку к нему.Форма * используется для всех остальных лексеров, у которых данный параметр не задан явно. |
||||||||||||||||||||||||||||||||||
calltip.lexer.parameters.start calltip.lexer.parameters.end calltip.lexer.parameters.separators calltip.*.parameters.start calltip.*.parameters.end calltip.*.parameters.separators |
Задают символы, которые начинают, завершают и разделяют параметры. (Неверная настройка parameters.start может привести к отсутствию всплывающей подсказки, несмотря на то, что она будет верно описана в корректно подключенном api-файле. Неверная настройка calltip.lexer.parameters.separators приведет к тому, что при наборе параметров функции подсветка не будет перемещатся по подсказке.) В большинстве общеупотребительных языков в начале используется левая фигурная скобка, в конце - правая фигурная скобка, и запятая или точка с запятой используются как разделитель. Например, в CSS используется двоеточие для начала, пробел как разделитель и ничего для конца. Для каждой опции можно задать несколько различных символов. Форма * используется для всех остальных лексеров, у которых данный параметр не задан явно. |
||||||||||||||||||||||||||||||||||
calltip.lexer.end.definition calltip.*.end.definition |
В API-файлах после определения каждой функции может содержаться пояснительный текст. Чтобы отобразить пояснение во второй строке, задайте в этой настройке символ, использующийся в конце определения функции. В большинстве языков этим символом является ') '.Форма * используется для всех остальных лексеров, у которых данный параметр не задан явно. |
||||||||||||||||||||||||||||||||||
calltip.lexer.automatic calltip.*.automatic |
Установка этого параметра в 0 означает что не будет происходить автоматическое отображение окошка с calltip'ом при наборе текста, но останется возможность вызвать его вручную. (Только в SciTE-Ru) | ||||||||||||||||||||||||||||||||||
calltip.lexer.show.per.page calltip.*.show.per.page |
Возможность указать количество определений, отображаемых одновременно в calltip'е. Значение по умолчанию - 1. (Только в SciTE-Ru) | ||||||||||||||||||||||||||||||||||
calltip.lexer.word.wrap calltip.*.word.wrap |
Опция включает возможность переноса по словам длинных calltip'ов, её значение определяет максимальный размер строки calltip'а в символах, 0 означает что данная функция будет отключена. (Только в SciTE-Ru) | ||||||||||||||||||||||||||||||||||
xml.auto.close.tags | Если в XML и HTML задать этой переменной значение 1, то при наборе '> ' в качестве завершения открывающего тэга, будет автоматически вставлен соответствующий закрывающий тэг. Наберите "<td> " и в результате получите "<td></td> ", причем курсор ввода будет установлен между тэгами. |
||||||||||||||||||||||||||||||||||
asp.default.language | Скрипт в ASP-коде первоначально принимается за скрипт, написанный на JavaScript. Для того, чтобы заменить JavaScript на VBScript, задайте переменной asp.default.language значение 2. Чтобы заменить на Python - значение 3. | ||||||||||||||||||||||||||||||||||
fold.asm.comment.explicit | This option enables folding explicit fold points when using the Asm lexer. Explicit fold points allows adding extra folding by placing a ;{ comment at the start and a ;} at the end of a section that should fold. | ||||||||||||||||||||||||||||||||||
fold.asm.comment.multiline | Set this property to 1 to enable folding multi-line comments. | ||||||||||||||||||||||||||||||||||
fold.asm.explicit.anywhere | Set this property to 1 to enable explicit fold points anywhere, not just in line comments. | ||||||||||||||||||||||||||||||||||
fold.asm.explicit.end | The string to use for explicit fold end points, replacing the standard ;}. | ||||||||||||||||||||||||||||||||||
fold.asm.explicit.start | The string to use for explicit fold start points, replacing the standard ;{. | ||||||||||||||||||||||||||||||||||
fold.asm.syntax.based | Set this property to 0 to disable syntax based folding. | ||||||||||||||||||||||||||||||||||
fold.at.else | This option enables C++ folding on a "} else {" line of an if statement. | ||||||||||||||||||||||||||||||||||
fold.basic.comment.explicit | This option enables folding explicit fold points when using the Basic lexer. Explicit fold points allows adding extra folding by placing a ;{ (BB/PB) or '{ (FB) comment at the start and a ;} (BB/PB) or '} (FB) at the end of a section that should be folded. | ||||||||||||||||||||||||||||||||||
fold.basic.explicit.anywhere | Set this property to 1 to enable explicit fold points anywhere, not just in line comments. | ||||||||||||||||||||||||||||||||||
fold.basic.explicit.end | The string to use for explicit fold end points, replacing the standard ;} (BB/PB) or '} (FB). | ||||||||||||||||||||||||||||||||||
fold.basic.explicit.start | The string to use for explicit fold start points, replacing the standard ;{ (BB/PB) or '{ (FB). | ||||||||||||||||||||||||||||||||||
fold.basic.syntax.based | Set this property to 0 to disable syntax based folding. | ||||||||||||||||||||||||||||||||||
fold.comment | При использовании лексера C++ данная переменная включает свертку для многострочных комментариев и явно указаных точек свертки. Точки свертки позволяют добавлять дополнительную свертку с помощью комментариев //{ и //} , помещаемых соответственно в начале и в конце секции, которую необходимо свернуть. |
||||||||||||||||||||||||||||||||||
fold.comment.python | This option enables folding multi-line comments when using the Python lexer. | ||||||||||||||||||||||||||||||||||
fold.cpp.comment.explicit | Set this property to 0 to disable folding explicit fold points when fold.comment=1. | ||||||||||||||||||||||||||||||||||
fold.cpp.comment.multiline | Set this property to 0 to disable folding multi-line comments when fold.comment=1. | ||||||||||||||||||||||||||||||||||
fold.cpp.explicit.anywhere | Set this property to 1 to enable explicit fold points anywhere, not just in line comments. | ||||||||||||||||||||||||||||||||||
fold.cpp.explicit.end | The string to use for explicit fold end points, replacing the standard //}. | ||||||||||||||||||||||||||||||||||
fold.cpp.explicit.start | The string to use for explicit fold start points, replacing the standard //{. | ||||||||||||||||||||||||||||||||||
fold.cpp.syntax.based | Set this property to 0 to disable syntax based folding. | ||||||||||||||||||||||||||||||||||
fold.d.comment.explicit | Set this property to 0 to disable folding explicit fold points when fold.comment=1. | ||||||||||||||||||||||||||||||||||
fold.d.comment.multiline | Set this property to 0 to disable folding multi-line comments when fold.comment=1. | ||||||||||||||||||||||||||||||||||
fold.d.explicit.anywhere | Set this property to 1 to enable explicit fold points anywhere, not just in line comments. | ||||||||||||||||||||||||||||||||||
fold.d.explicit.end | The string to use for explicit fold end points, replacing the standard //}. | ||||||||||||||||||||||||||||||||||
fold.d.explicit.start | The string to use for explicit fold start points, replacing the standard //{. | ||||||||||||||||||||||||||||||||||
fold.d.syntax.based | Set this property to 0 to disable syntax based folding. | ||||||||||||||||||||||||||||||||||
fold.html | Данная переменная включает и выключает свертку кода для HTML и XML файлов. Чтобы свертка работала, необходимо также включить параметр fold. | ||||||||||||||||||||||||||||||||||
fold.html.preprocessor | Если данная переменная равна 0 (1 - значение по умолчанию), то команда "Свернуть все блоки текста" выполненная на файле содержащем только код php (не php внедренный в html) свернет файл корректно, оставляя видимыми заголовки процедур. По умолчанию этого не происходит и команда сворачивает все содержимое файла целиком. |
||||||||||||||||||||||||||||||||||
fold.hypertext.comment | Разрешает свертку в комментариях скриптов внедренных в HTML. По умолчанию отключено. | ||||||||||||||||||||||||||||||||||
fold.hypertext.heredoc | Разрешает свертку скриптов внедренных в HTML. По умолчанию отключено. | ||||||||||||||||||||||||||||||||||
fold.perl.at.else | This option enables Perl folding on a "} else {" line of an if statement. | ||||||||||||||||||||||||||||||||||
fold.perl.comment.explicit | Set to 0 to disable explicit folding. | ||||||||||||||||||||||||||||||||||
fold.perl.package | Значение 0 запрещает свертку для packages в Perl. | ||||||||||||||||||||||||||||||||||
fold.perl.pod | Значение 0 запрещает свертку для POD-блоков в Perl. | ||||||||||||||||||||||||||||||||||
fold.preprocessor | Данная переменная разрешает свертку директив препроцессора при использовании лексера C++, включая определенные в C# директивы свертки #region и #endregion . |
||||||||||||||||||||||||||||||||||
fold.quotes.python | При использовании лексера Python данная переменная разрешает использовать свертку для многострочных фрагментов текста, заключенных в кавычки. | ||||||||||||||||||||||||||||||||||
fold.sql.at.else | This option enables SQL folding on a "ELSE" and "ELSIF" line of an IF statement. | ||||||||||||||||||||||||||||||||||
html.tags.case.sensitive | Если в XML и HTML задать этой переменной значение 1, тэги становятся чувствительными к регистру, что является обычным режимом для XML и XHTML. | ||||||||||||||||||||||||||||||||||
lexer.asm.comment.delimiter | Character used for COMMENT directive's delimiter, replacing the standard "~". | ||||||||||||||||||||||||||||||||||
lexer.cpp.allow.dollars | Задайте этой переменной значение 0, чтобы запретить символ '$ ' в идентификаторах с лексером cpp. |
||||||||||||||||||||||||||||||||||
lexer.cpp.track.preprocessor | Set to 1 to interpret #if/#else/#endif to grey out code that is not active. | ||||||||||||||||||||||||||||||||||
lexer.cpp.triplequoted.strings | Set to 1 to enable highlighting of triple-quoted strings. | ||||||||||||||||||||||||||||||||||
lexer.cpp.update.preprocessor | Set to 1 to update preprocessor definitions when #define found. | ||||||||||||||||||||||||||||||||||
lexer.d.fold.at.else | This option enables D folding on a "} else {" line of an if statement. | ||||||||||||||||||||||||||||||||||
lexer.errorlist.value.separate | For lines in the output pane that are matches from Find in Files or GCC-style diagnostics, style the path and line number separately from the rest of the line with style 21 used for the rest of the line. This allows matched text to be more easily distinguished from its location. | ||||||||||||||||||||||||||||||||||
lexer.flagship.styling.within.preprocessor | For Harbour code, determines whether all preprocessor code is styled in the preprocessor style (0) or only from the initial # to the end of the command word(1, the default). It also determines how to present text, dump, and disabled code. | ||||||||||||||||||||||||||||||||||
lexer.html.django | Set to 1 to enable the django template language. | ||||||||||||||||||||||||||||||||||
lexer.html.mako | Set to 1 to enable the mako template language. | ||||||||||||||||||||||||||||||||||
lexer.props.allow.initial.spaces | For properties files, set to 0 to style all lines that start with whitespace in the default style. This is not suitable for SciTE .properties files which use indentation for flow control but can be used for RFC2822 text where indentation is used for continuation lines. | ||||||||||||||||||||||||||||||||||
lexer.python.literals.binary | Set to 0 to not recognise Python 3 binary and octal literals: 0b1011 0o712. | ||||||||||||||||||||||||||||||||||
lexer.python.strings.b | Set to 0 to not recognise Python 3 bytes literals b"x". | ||||||||||||||||||||||||||||||||||
lexer.python.strings.over.newline | Set to 1 to allow strings to span newline characters. | ||||||||||||||||||||||||||||||||||
lexer.python.strings.u | Set to 0 to not recognise Python Unicode literals u"x" as used before Python 3. | ||||||||||||||||||||||||||||||||||
lexer.sql.allow.dotted.word | Set to 1 to colourise recognized words with dots (recommended for Oracle PL/SQL objects). | ||||||||||||||||||||||||||||||||||
lexer.sql.numbersign.comment | If "lexer.sql.numbersign.comment" property is set to 0 a line beginning with '#' will not be a comment. | ||||||||||||||||||||||||||||||||||
lexer.xml.allow.scripts | Set to 0 to disable scripts in XML. | ||||||||||||||||||||||||||||||||||
sql.backslash.escapes | Разрешает использование обратного слеша в качестве escape-символа в SQL. | ||||||||||||||||||||||||||||||||||
styling.within.preprocessor | В C++ определяет, весь ли код препроцессора имеет стиль препроцессора (значение 0, установленное по умолчанию) или только начиная с начальной # и до конца управляющего слова (значение 1). | ||||||||||||||||||||||||||||||||||
tab.timmy.whinge.level | В Питоне контролирует, происходит ли деление на абзацы последовательно и непротиворечиво. По умолчанию этой переменной задано значение 0. При этом функция проверки деления на абзацы выключена. При значении 1 проверяется, согласуется ли каждая строка с предыдущей строкой, при 2 проверяется, есть ли перед символом табуляции пробелы, при 3 проверяется наличие пробелов при делении кода на абзацы, а при значении 4 проверяется наличие символов табуляции. Удобно использовать значение 1. |
||||||||||||||||||||||||||||||||||
user.shortcuts |
Задает горячие клавиши для выполнения команд. Представляет собой разделенный символом '| ' список горячих клавиш и запускаемых ими команд. Команды представляют собой либо строковый, либо числовой идентификатор.В качестве команды можно использовать: - любую команду ядра Scintilla (ее числовое обозначение) - команду встроенного меню SciTE (использовав символьный идентификатор вида IDM_* )- любую команду пользовательского меню Tools. (Для этого необходимо к номеру нужной команды из этого меню прибавить 1200 [или 9000 для SciTE-Ru] и полученную сумму вставить как числовой идентификатор. Все доступные команды и их значения перечислены в документации (Command Values). Модификаторами являются клавиши Ctrl , Shift и Alt , а в качестве именованных клавиш используются Left , Right , Up , Down , Insert , End , Home , Enter , Space , Tab , KeypadPlus , KeypadMinus , KeypadMultiply , KeypadDivide , Escape , Delete , PageUp , PageDown , Slash , Question , Equal , Win :
user.shortcuts=\ (дополнительные подробности об этом параметре можно прочесть в описании параметров command.)
Ctrl+Shift+I|IDM_OPEN|\ Ctrl+Shift+Left|IDM_CLOSE| |
||||||||||||||||||||||||||||||||||
user.context.menu |
Задает дополнительные команды для контекстного меню. Представляет собой разделенный символом '' список пунктов меню и запускаемых ими команд. При этом команды задаются так же, как и в переменной user.shortcuts. Пустой пункт меню создает разделитель.
user.context.menu=\ При наличии соответствующего перевода в файле ||\ Next File|IDM_NEXTFILE|\ Prev File|IDM_PREVFILE| locale.properties текст описания команды при показе контекстного меню может отличатся от заданного в этом параметре.В SciTE-Ru вместо одного - 3 различных контекстных меню (меню редактора, меню вкладок, меню консоли), в которых можно создавать встроенные подменю [подробности]. (Дополнительные подробности об этом параметре можно прочесть в описании параметров command.) |
||||||||||||||||||||||||||||||||||
magnification output.magnification |
Данные параметры задают начальное значение (по умолчанию - 0) на которое будет изменятся размер шрифта, заданный для каждого стиля, при его отображении в панели редактирования и вывода. Отрицательные значения уменьшают размер, а положительные - увеличивают. (Именно эти параметры меняются при нажатии на Ctrl+ и Ctrl- )
|
||||||||||||||||||||||||||||||||||
split.vertical output.horizontal.size output.vertical.size output.initial.hide |
Если задать переменной split.vertical значение 1, панель вывода будет размешена справа от панели редактирования. При значении 0 панель вывода будет расположена ниже панели редактирования. Переменная output.*.size задает первоначальный размер панели вывода. Если значение переменной output.initial.hide равно 1, при первом запуске SciTE панель вывода становится невидимой, даже если задана переменная output.*.size. В противном случае, панель вывода при запуске появляется. | ||||||||||||||||||||||||||||||||||
clear.before.execute | Если задать данной переменной значение 1, перед запуском команд меню Tools панель вывода очищается, т.е. автоматически выполняется lua-команда output:ClearAll(). | ||||||||||||||||||||||||||||||||||
horizontal.scrollbar horizontal.scroll.width horizontal.scroll.width.tracking output.horizontal.scrollbar output.horizontal.scroll.width output.horizontal.scroll.width.tracking |
Если переменной horizontal.scrollbar задать значение 0, то в панели редактирования горизонтальная прокрутка отображена не будет. Переменная horizontal.scroll.width задает ширину горизонтальной области прокрутки. Подобным образом, переменные output.horizontal.scrollbar и output.horizontal.scroll.width контролируют горизонтальную линейку прокрутки панели вывода. |
||||||||||||||||||||||||||||||||||
output.scroll | При выполнении консольных команд заполнение окна вывода данными вызывает его автоматическую прокрутку. При output.scroll=0 такой прокрутки происходить не будет. При output.scroll=1 (значение по умолчанию), текст будет прокручиваться вниз, а после того, как команда отработает, он будет прокручен вверх, к самой команде. Если вы хотите, чтобы прокрутка осуществлялась, и после выполнения команды текст вывода не был прокручен обратно вверх, задайте output.scroll значение 2 | ||||||||||||||||||||||||||||||||||
end.at.last.line | Диапазон вертикальной прокрутки обычно задается так, чтобы при максимальной позиции прокрутки последняя строка была видна в самом низу области просмотра. Задайте переменной end.at.last.line значение 0, чтобы разрешить прокрутку ниже последней строки | ||||||||||||||||||||||||||||||||||
wrap output.wrap |
Значение 1 включает перенос длинных строк в окне редактирования и/или в окне вывода соответственно. Данные опции замедляют быстродействие прямо пропорционально количеству текста, поэтому их лучше отключать при работе с крупными документами на медленных машинах. | ||||||||||||||||||||||||||||||||||
wrap.style | В зависимости от заданного значения (1 - по умолчанию, или 2) переносит на новую строку соответственно слово или символ. Перенос символов является лучшим выбором для азиатских языков, где нет пробелов между словами. | ||||||||||||||||||||||||||||||||||
wrap.visual.flags | Помечает маркерами конец и начало перенесенной строки, чтобы их можно было визуально отличить. Про значении 0 (по умолчанию) маркеры не отображаются. Задайте значение 1, чтобы маркеры отображались в конце перенесенной строки, 2 - в начале и 3 - и в начале и в конце. | ||||||||||||||||||||||||||||||||||
wrap.visual.flags.location | Указывает место отображения маркеров (если разрешено): рядом с текстом или рядом с границей. При значении 0 (по умолчанию) начальные и конечные маркеры отображаются рядом с границей. Если задано значение 1, конечные маркеры отображаются рядом с текстом, 2 - начальные маркеры отображаются рядом с текстом и 3 - все маркеры располагаются рядом с тектом. | ||||||||||||||||||||||||||||||||||
wrap.indent.mode | Wrapped sublines can be indented in various ways relative to the initial subline. Default mode 0 indents sublines to the left of window plus wrap.visual.startindent. Mode 1 aligns sublines to the first subline. Mode 2 aligns sublines to the first subline plus one more level of indentation. | ||||||||||||||||||||||||||||||||||
wrap.visual.startindent | Задает отступ для перенесенных строк, с тем, чтобы визуально лучше видеть переносы. По умолчанию задается значение 0 (отступы не ставятся). Обратите внимание, что если переменной wrap.visual.flags заданы значение 2 или 3, т.е. отображаются начальные маркеры, отступ ставится по крайней мере один раз, даже если значение переменной wrap.visual.startindent равно 0. |
||||||||||||||||||||||||||||||||||
wrap.aware.home.end.keys | Данная опция изменяет поведение клавиш Home и End в том случае, если включена опция динамического переноса строк.По умолчанию значение переменной равно 0. При этом клавиши Home и End передвигают курсор ввода в самое начало или конец "логической" строки, вне зависимости от того, перенесена ли эта строка при отображении.Если переменной задано значение 1, то при нажатии клавиши End один раз курсор ввода передвигается в конец текущей отображаемой строки, а при нажатии этой же клавиши два раза курсор передвигается в конец "логической" строки. Подобным образом однократное нажатие клавиши Home передвигает курсор в самое начало отображаемой строки, а двукратное - в начало "логической" строки.В окне, где перенос строк не разрешен, данная опция не работает. |
||||||||||||||||||||||||||||||||||
cache.layout output.cache.layout |
SciTE тратит большое количество времени на то, чтобы проанализировать текст перед тем, как отрисовать его. Эта информация обычно остается статичной между обновлениями текста, поэтому при помощи данных опций ее можно поместить в кэш. Существует четыре уровня кэширования. Если значение равно 0, кэширование не производится, 1 - кэшируется строка, на которой стоит курсор ввода, 2 - кэшируется видимая область страницы, а также курсор ввода, и 3 - кэшируется весь документ. Чем больше текста подвергается кэшированию, тем больше на это уходит памяти. Таким образом, при значении 3 используется в 7 раз больше памяти, чем занимает сам текст. Однако в этом случае значительно ускоряется динамический перенос слов и символов. В больших файлах перенос ускоряется примерно в 25 раз, поэтому данные переменные очень полезны при включенном динамическом переносе слов и символов и большом количестве свободной памяти. | ||||||||||||||||||||||||||||||||||
open.filter | Это составное выражение используется для того, чтобы задать типы файлов, которые будут доступны в диалоге "Открытие файла". Для каждого типа файлов задается пояснительный текст, символ '| ', несколько шаблонов, а затем еще один символ '| '. В файле SciTEGlobal.properties , который поставляется вместе со SciTE, для того, чтобы разбить описание пунктов меню на несколько строк, используется символ продолжения строки '\ '. Эти типы файлов появляются в выпадающем списке Типы файлов. Первый пункт меню устанавливается по умолчанию, однако его можно заменить на те типы файлов, которые используются чаще всего.Под GTK+ эта опция работает только в версиях 2.4 и выше. |
||||||||||||||||||||||||||||||||||
save.filter | Это сложное выражение используется для определения типов файлов, которые будут доступны в
диалоге сохранения файла. Структура аналогична параметру open.filter. Не работает на GTK+. |
||||||||||||||||||||||||||||||||||
max.file.size | Чтобы избежать случайной загрузки очень больших файлов на медленные носители данных или просто для уверенности в том, что SciTE используется только для редактирования удобочитаемого кода, можно задать переменную max.file.size, которая ограничивает загрузку файлов. Если значение это переменной не задано или равно 0, ограничения не устанавливаются. Если в качестве значения задано фиксированное количество байтов, а при загрузке файла это количество превышено, выводится вопрос, нужно ли продолжать загрузку. Если ответ утвердительный, файл считывается в обычном режиме. В противном случае, никаких действий более не предпринимается (файл не загружается, вкладка не создается). | ||||||||||||||||||||||||||||||||||
save.deletes.first | Удаляет ранее сохраненную версию файла перед тем, как SciTE будет записывать новый вариант на место существующего. Может использоваться под Windows для уверенности в том, что сохранение в другом регистре действительно изменяет регистр имен файлов, а не молча использует старый регистр. | ||||||||||||||||||||||||||||||||||
save.check.modified.time | При установке save.check.modified.time=1 сохраняемый файл будет проверятся не был ли он изменен другим процессом. Если это так, то возникнет диалоговое окно с предложением переписать содержимое этого файла текущим содержанием. | ||||||||||||||||||||||||||||||||||
save.session save.recent save.position |
Установка этих переменных в 1 заставляет SciTE сохранять в файле сеанса список последних использованных файлов, список открытых в настоящее время буферов и положение окна SciTE на экране соответственно. В Windows файл называется SciTE.session и расположен в каталоге, заданном переменной окружения SciTE_HOME . Если эта переменная не задана, тогда он расположен в каталоге, заданном значением переменной окружения USERPROFILE , а если и эта переменная не задана, тогда файл расположен в каталоге, в котором находится исполняемый файл scite.exe Под GTK+ этот файл называется " .SciTE.session ". Он расположен в каталоге, заданном переменной окружения SciTE_HOME . Если эта переменная не задана, тогда он расположен в каталоге, заданном значением переменной окружения HOME, а если и эта переменная не задана, тогда файл расположен в каталоге верхнего уровня. |
||||||||||||||||||||||||||||||||||
session.bookmarks session.folds |
Задайте переменную session.bookmarks, чтобы положение меток сохранялось в файлах сессий. Если задать переменную session.folds, в файлах сессий будет сохранено положение свертки кода. При загрузке файла сессии, метки и/или положение свертки кода восстанавливаются. Если задана переменная fold.on.open, положение свертки кода не восстанавливается. | ||||||||||||||||||||||||||||||||||
open.dialog.in.file.directory | Задайте переменную open.dialog.in.file.directory, чтобы диалог открытия файла первоначально отображал тот же каталог, где находится текущий файл. Если переменная не задана, тогда используются значения системы по умолчанию. В Windows XP это последний каталог, который был открыт в диалоге открытия файла в любом экземпляре SciTE. В некоторых версиях GTK+ может быть открыт неожиданный каталог. |
||||||||||||||||||||||||||||||||||
find.close.on.find | Задайте данной переменной значение 0, чтобы при нажатии кнопки "Найти" диалог поиска оставался открытым. | ||||||||||||||||||||||||||||||||||
find.replace.matchcase find.replace.regexp find.replace.wrap find.replace.escapes find.replacewith.focus |
Данные переменные задают первоначальные состояния для окон Найти и Заменить. Переменная find.replace.matchcase включает опцию "Учитывать регистр", переменная find.replace.regexp включает опцию "Регулярные выражения", переменная find.replace.wrap включает опцию "Возвращаться к началу" и переменная find.replace.escapes включает опцию "Преобразовывать backslash-выражения". Если задана переменная find.replacewith.focus, и в поле "Что" окна "Заменить" содержатся данные, то фокус находится на поле "Чем". |
||||||||||||||||||||||||||||||||||
find.replace.regexp.posix | Изменяет поведение поиска с использованием регулярных выражений. Если данной переменной задано значение 0 (по умолчанию), символы '( ' и ')' должны экранироваться символом '\ ', с тем чтобы они вели себя как метасимволы. Если значение равно 1, эти символы являются метасимволами сами по себе. |
||||||||||||||||||||||||||||||||||
find.use.strip replace.use.strip |
Use in-window strips rather than dialogs for performing Find or Replace commands. | ||||||||||||||||||||||||||||||||||
strip.button.height | Buttons on GTK+ often contain extra spacing that makes strips take too much room. This setting tries to limit the height of buttons. A value of 23 or 24 may work well. | ||||||||||||||||||||||||||||||||||
find.replace.advanced | В диалоге "Заменить" разрешает кнопку "Заменить во всех файлах" и флажок "Только в этом стиле". Если флажок "Только в этом стиле" установлен, поиск ограничивается только этим стилем. | ||||||||||||||||||||||||||||||||||
find.command find.input |
Команда меню "Поиск" - "Найти в файлах" отрабатывает так же, как обычная команда из меню "Tools", производящая запуск утилиты командной строки, вывод которой перенаправляется в панель консоли. Поскольку результатом выполнения команды являются данные, содержащие имена файлов и номера строк, содержащих искомый текст (т.е. этот текст по формату аналогичен сообщениям об ошибках, которые выводят в процессе работы компиляторы, и т.п.), то для перехода между найденными вхождениями могут использоваться клавиши F4 и Shift+F4 (или двойной клик по строке с найденным текстом).Существует 2 способа запуска этой команды: - Первый способ используется по умолчанию при отсутствии переменной find.command. В этом случае используется встроенное средство для поиска, которое работает на порядок быстрее и эффективнее любых внешних средств. Единственный его недостаток - невозможность использования регулярных выражений. - Второй способ заключается в использовании внешних консольных утилит для поиска в файлах. В этом случае параметром find.command задается командная строка для запуска этой утилиты. В качестве параметров командной строки разрешается использовать переменные $(find.directory) (каталог для поиска, будет взят из поля "Каталог:"), $(find.files) (маска файловых расширений, будет взята из поля "В файлах:") и $(find.what) (искомый текст, будет взят из поля "Что:"). Задание параметров "Только слово целиком" и "Учитывать регистр" через диалоговое окно недоступно.Если утилита может принимать входные параметры через стандартный поток ввода, то SciTE может сформировать выходной поток с помощью параметра find.input (доступен только для Windows), например так: find.input=$(find.what) - для того, чтобы избежать проблем, связанных с интерпретацией кавычек. В качестве внешних утилит для поиска текста в файлах можно использовать FINDSTR (имеется в стандартной поставке Windows). Пример командной строки для ее запуска:
find.command=FINDSTR /n /s /c:"$(find.what)" $(find.files)
Кроме того, можно воспользоватся пакетом Cygwin (~60Mб, множество утилит):
find.command=cmd /c c:\cygwin\bin\find "$(find.directory)" -name "$(find.files)" -print0 | c:\cygwin\bin\xargs -0 fgrep -G -n "$(find.what)"
В примере необходимо исправить путь к каталогу установки Cygwin , если он у вас отличается от указанного.Кроме этого, в качестве внешних утилит можно использовать и утилиту grep , и различные скриптовые решения, которые могут быть весьма эффективны. Например, cуществует несколько скриптов, которые реализуют данную возможность на языке Perl лучше, чем утилита grep - здесь и здесь.
|
||||||||||||||||||||||||||||||||||
find.files | Определяет содержимое раскрывающегося списка "В файлах:" в диалоге "Найти в файлах". Переменная find.files содержит список расширений файлов, разделенных символом '| ', как, например *.cxx *.h*.py *.pyw|*.html. В этом примере в список добавляется три строчки, среди которых первая будет использоваться по умолчанию.Обработка данного параметра немного необычна, т.к. содержимое аналогичного параметра в файле локальных настроек не заменяет значение, заданное в SciTEGlobal.properties , а добавляется в конец списка, в том случае, если строка с расширениями не совпадает ни с одной из строк, заданных в SciTEGlobal.properties .Максимальное количество строк в этом списке - 10. |
||||||||||||||||||||||||||||||||||
find.in.dot | Если значение переменной find.in.dot равно 1, команда "Найти в файлах" производит поиск в каталогах, название которых начинается с символа '. '. По умолчанию SciTE не производит поиск в служебных каталогах Subversion, которые называются .svn . |
||||||||||||||||||||||||||||||||||
find.in.binary | Если значение переменной find.in.binary равно 1, команда "Найти в файлах" отображает совпадения в двоичных файлах. Двоичным для команды "Найти в файлах" является файл, который в первых 64 Кб содержит байт NUL. | ||||||||||||||||||||||||||||||||||
find.in.files.close.on.find | Задайте данной переменной значение 0, чтобы при нажатии кнопки "Найти" диалог "Найти в файлах" оставался открытым. | ||||||||||||||||||||||||||||||||||
code.page output.code.page |
Чтобы SciTE мог поддерживать язык с набором двухбайтовых символов (например, японский), здесь необходимо задать кодовую страницу. Это нужно для того, чтобы двухбайтовые символы рассматривались как единое целое, и курсор ввода никогда не оказывался между двумя байтами двухбайтового символа.
Tahoma .Данной переменной нельзя задать набор однобайтовых символов. Любые другие значения данного параметра, кроме вышеперечисленных, недопустимы и будут игнорироваться SciTE. Более того, установка code.page=1251, рекомендуемая в некоторых пособиях, приводит к проблемам с переключением кодировок. Переменная output.code.page используется в том случае, если настройки панели вывода отличаются от настроек панели редактора. |
||||||||||||||||||||||||||||||||||
character.set | Данная настройка позволяет изменять набор символов, который запрашивается при настройке шрифтов. Не все из этих значений будут работать на всех платформах.
Если вы используете одно из данных значений, пожалуйста, сообщите разработчикам по электронной почте, работают они или нет. Напишите также (если обладаете информацией об этом), как обеспечить поддержку других языков. Для того чтобы использовать кириллицу на платформе Windows, задайте character.set=204 (кодировка CP1251) или character.set=255 (кодировка DOS-866). Для использования символов кириллицы под GTK+ нужно задать character.set=204 (кодировка KOI8-R) или character.set=1251 (кодировка CP1251). Естественно, что используемый шрифт должен содержать заданную кодовую страницу. |
||||||||||||||||||||||||||||||||||
comment.block.lexer comment.block.at.line.start.lexer comment.stream.start.lexer comment.stream.end.lexer comment.box.start.lexer comment.box.middle.lexer comment.box.end.lexer |
Данные переменные используются для комментирования команд через меню "Правка" и задаются раздельно для каждого лексера. Однако не все языки поддерживают и потоковые, и строковые комментарии. Строковые комментарии начинаются с определенной строки и продолжаются до ее конца. В переменной comment.block задается строка, которая при выполнении команды "Закомментировать или раскомментироватть текст" (Block Comment or Uncomment) вставляется или удаляется в начале выделенных строк. Для того, чтобы одна и та же команда ( Ctrl+Q ) могла и устанавливать и снимать комментарии, заданная в переменной строка должна содержать символ (например '~ '), который не используется в реальных комментариях.Задайте переменной comment.block.at.line.start значение 1, чтобы символы строкового комментария помещались в начале строк, а не перед первым непустым символом. Потоковые комментарии начинаются с произвольного места и заканчиваются в другом произвольном месте строки. При помощи переменных comment.stream.start и comment.stream.end задаются символы, используемые соответственно для обозначения начала и конца потокового комментария. Ещё одна форма потокового комментария (в меню он называется "блочным") использует три обязательных параметра, задающих: - символы, с которых начинается комментарий (comment.box.start); - символы, с помощью которых комментируются все промежуточные строки (comment.box.middle); - символы, которыми заканчивается комментарий (comment.box.end), после которых автоматически добавляется перевод строки. |
||||||||||||||||||||||||||||||||||
preprocessor.symbol.filepattern preprocessor.start.filepattern preprocessor.middle.filepattern preprocessor.end.filepattern |
Данные переменные задают символ начала директив и команды условного перехода препроцессора, используемые в файлах, попадающих под заданный в filepattern перечень расширений. Символ, который определяет строки препроцессора, указывается в переменной preprocessor.symbol. Ключевые слова препроцессора, которые задают начало ( if ), середину (else ) и конец (end ) условных директив препроцессора, задаются остальными тремя переменными. Каждая из них может иметь множество значений. Например, в Cи для определения условных директив препроцессора используются значения "if ", "ifdef " и "ifndef ". |
||||||||||||||||||||||||||||||||||
lexer.filepattern | Лексер разбивает текст на синтаксические части. После этого SciTE может отображать эти части в различных визуальных стилях. Лексеры, входящие в SciTE, предназначены для таких популярных языков программирования, как Python, Java, C/C++, JavaScript и VB. Часто несколько типов файлов относятся к одному языку (например, файлы с расширением .cpp, .cc, .h относятся к C++) и, следовательно, к одному лексеру. Данные опции ассоциируют имя файла с лексером. Лексеры, входящие в SciTE, написаны на C++ и скомпилированы в исполняемое ядро программы. Также лексеры могут быть написаны в виде Lua скриптов. Кроме этого возможно применение скриптовых лексеров из пакета scintillua, которые используют Lua LPeg парсер. |
||||||||||||||||||||||||||||||||||
shbang.command | В Unix командные файлы часто не имеют расширения. Вместо этого, в начальной строке, начинающейся с символов "#! ", указывается подходящий интерпретатор. Если лексер другим путем указать нельзя, а файл начинается с символа "#! ", SciTE разбивает начальную строку на слова и перед каждым словом добавляет "shbang. ". Если задана переменная с каким-нибудь из этих имён, SciTe использует её для определения расширения файла. К примеру, для начальной строки #!/usr/bin/env/python подойдёт переменная shbang.python=py, и SciTe распознает этот файл как питоновский. |
||||||||||||||||||||||||||||||||||
lexerpath.filepattern | Данная переменная определяет путь к внешнему модулю лексера, загружаемому в Scintilla. | ||||||||||||||||||||||||||||||||||
keywords.filepattern keywords2.filepattern keywords3.filepattern keywords4.filepattern keywords5.filepattern keywords6.filepattern keywords7.filepattern keywords8.filepattern keywords9.filepattern keywordclass.lexer |
Большинство лексеров различают имена и ключевые слова, используя для этого переменные keywords. Каждый keywords соответствует строго определенному типу (например комментарию, строковой константе, оператору и т.п.), в качестве значения которого указывается список слов, разделенных пробелами, которые в данном языке попадают под заданное определение. Зачастую списки ключевых слов не приравнивают к keywords непосредственно, а создают несколько условных пользовательских переменных keywordclass.lexer, и все ключевые слова задают в них. После этого keywords присваивают значение одного или нескольких keywordclass.lexer. Поэтому keywordclass.lexer не являются самостоятельными параметрами SciTE и присутствуют в настройках только для удобства. Некоторые лексеры могут анализировать несколько языков программирования одновременно. Для них необходимо задание нескольких наборов ключевых слов, которые будут отображаться в стиле, отличающемся от стиля первого набора. Эта особенность используется в лексере HTML для отображения ключевых слов JavaScript в стиле, отличном от стиля тегов и аттрибутов HTML. Ключевые слова могут основываться на префиксе. К примеру, ^GTK_ будет считать ключевыми словами все слова, которые начинаются с "GTK_ ". |
||||||||||||||||||||||||||||||||||
default.file.ext | Данная переменная задает язык, который используется по умолчанию до того, как файл получит имя. Например: если задано default.file.ext=.py, то при создании нового файла с помощью команды "New", используется синтаксическая подсветка для языка Python. |
||||||||||||||||||||||||||||||||||
word.characters.filepattern | Указывает, какие символы могут быть частью слов. Значением этой переменной по умолчанию являются все буквенно-цифровые символы и символ подчеркивания "_ ", которые приемлемы для таких языков, как C++.Функции SciTE, основанные на обработке слов, различают начало и конец слова по этой установке. Например, если добавить точку в значение этого параметра, SciTE будет считать составные конструкции вида WScript.Echo одним словом. |
||||||||||||||||||||||||||||||||||
whitespace.characters.filepattern | Указывает, какие символы будут считаться пробелами. Значение по умолчанию задано Scintilla и содержит пробел и все символы с кодами меньше 0x20. При таких операциях, как перемещение курсора (Ctrl+влево/вправо), данная переменная позволяет использовать в Scintilla в качестве пробелов другие символы (например, пунктуацию). | ||||||||||||||||||||||||||||||||||
style.*.stylenumber style.lexer.stylenumber |
SciTE каждому участку поля редактирования присваивает определенный номер стиля - stylenumber (от 0 до 128). С помощью лексеров номера стилей присваиваются отдельным словам и конструкциям кода. С помощью параметров style. в соответствие этому номеру ставится строка, определяющая, как будет отображаться этот стиль в SciTE. Строка для задания параметров стиля представляет собой набор полей, разделенных запятой. Некоторые поля имеют подзначения, которое следует после символа " : ". Полный синтаксис данной строки представлен ниже:font:<name>, size:<number>, fore:<colour>, back:<colour>, italics|notitalics, bold|notbold, eolfilled|noteolfilled, underlined|notunderlined, case:m|u|l, visible|notvisible, changeable|notchangeable, hotspot|nothotspot Где: font:<name> - имя шрифта, например font:Courier size:<number> - размер шрифта, например size:14 fore:<colour> - цвет шрифта, например fore:#FF0000 back:<colour> - цвет фона, например back:#00FF00 italics|notitalics - один из вариантов: курсив|обычный шрифт bold|notbold - один из вариантов: жирный|обычный шрифт eolfilled|noteolfilled - один из вариантов: этот стиль будет применен до конца строки | обычное применение underlined|notunderlined - один из вариантов: подчеркнутый|обычный шрифт case:m|u|l - - один из вариантов: смешанный|верхний|нижний регистр шрифта (реально регистр не меняется, меняется лишь его отображение в редакторе) visible|notvisible - один из вариантов: видимый | невидимый текст changeable|notchangeable - один из вариантов: редактируемый | недоступный для редактирования текст hotspot|nothotspot - один из вариантов: "hotspot" (при наведении мыши, такой текст подчеркивается и вид курсора принимает форму руки) | обычный текст Ни один из параметров не является обязательным. Очередность также не имеет значения. Но если в строке стиля параметр упоминается дважды (чего следует избегать!), то действует крайнее правое значение. Часто длинные строки описания стиля присваивают пользовательским переменным, а затем используют эти переменные при задании стиля. Если при использовании таких подстановок в строку стиля помимо этой переменной будут добавлены и другие параметры, то возможна ситуация, когда их значения полностью перекроют одноименные параметры пользовательской переменной, и ее существование в строке описания стиля станет просто бессмысленным. Пример:
colour.number=fore:#AC00A9, back:#FEFEFE Глобальные стили задаются при помощи переменных style.*.stylenumber. Опции, заданные в этих стилях, будут использоваться при отображении файлов всех типов. Но если в строке этого стиля, заданной для конкретного лексера, имеются такие же параметры, то будут использованы их значения.style.vb.2=$(colour.number), bold, fore:#7F7F00, back:#808080 В GTK+ сглаженный шрифт Pango можно выбрать, указав перед именем шрифта символ " ! ", например: "font:!Sans ".
|
||||||||||||||||||||||||||||||||||
style.lexer.32 style.lexer.33 style.lexer.34 style.lexer.35 style.lexer.36 style.lexer.37 style.lexer.38 |
Помимо стилей, генерируемых различными лексерами, в SciTe используется ряд встроенных стилей. Стиль 32 используется по умолчанию. Его свойства наследуется всеми другими стилями до тех пор, пока не будут перекрыты. Стиль 33 используется для отображения номеров строк на соответствующем поле. Стили 34 и 35 используются для отображения соответственно согласованых (закрытых) и несогласованых (незакрытых) скобок. Стиль 36 используется для отображения управляющих символов и не является полноценным стилем, так как цвета текста и фона для управляющих символов задаются чаще конкретным лексером, чем эти параметром. Стиль 37 используется для отображения направляющих отступа. При этом используются только цвета текста и фона. Стиль 38 используется для отображения всплывающей подсказки. При этом используются только параметры font, size, fore и back. Символ " * " может использоваться вместо имени конкретного лексера для задания глобальных настроек. |
||||||||||||||||||||||||||||||||||
braces.check braces.sloppy style.lexer.34 style.lexer.35 braces.lexer.style |
Подсветка скобок используется для того, чтобы выделить заключенное внутри них выражение и появляется, когда курсор ввода стоит непосредственно за одной из скобок. Данное свойство особенно полезно при использовании текста со множеством вложеных скобок. Скобками являются символы "( ", ") ", "[ ", "] ", "{ " и "} ". По умолчанию, эта опция отключена, поскольку замедляет перемещение каретки. Для того чтобы ее включить, необходимо переменной braces.check задать значение 1. Если значение переменной braces.sloppy равно 1, то при отсутствии скобки непосредственно перед курсором ввода, проверяется символ после него. Подсветка осуществляется стилем 34 или, если нет согласованной (парной) скобки, стилем 35. Несмотря на то, что данный стиль является полноценным, для избежания частичного отображения скобок лучше сделать его отличным от стандартного стиля скобок только в том, что касается цвета текста и цвета фона. |
||||||||||||||||||||||||||||||||||
font.monospace | Задает название шрифта и размер, которые будут использоваться при исполнении команды "Использовать моноширинные шрифты". При этом используется такой же синтаксис, как и для параметров стиля. Правда, в отличии от переменных определяющих стиль, font.monospace поддерживает только два параметра font:<name> и size:<number>. При нажатии Ctrl+F11 эти параметры применяются ко всем стилям, кроме 33 - 37. |
||||||||||||||||||||||||||||||||||
command.compile.filepattern command.compile.subsystem.filepattern command.build.filepattern command.build.subsystem.filepattern command.build.directory.filepattern command.go.filepattern command.go.subsystem.filepattern |
При помощи данных переменных указывается, какие команды будут выполняться при выборе пунктов меню "Компилировать", "Собрать" и "Выполнить". Опции subsystem указывают, как в Windows запускать инструменты: как командную строку (0), в оконном режиме (1), через ShellExecute (2) или как команду Lua (3). (см. тут для подробностей). Если исходные файлы в находятся не в том каталоге, где будет производиться сборка, то перед выполнением сборки необходимо указать в переменной command.build.directory путь к каталогу для сборки. |
||||||||||||||||||||||||||||||||||
command.go.needs.filepattern command.go.needs.subsystem.filepattern |
Иногда перед запуском файла его необходимо собрать или скомпилировать. В этом случае в данной переменной указывается команда, которая используется для сборки или компиляции. После завершения компиляции, состояние файла запоминается, с тем чтобы при последующих запусках компиляция или сборка не производились. Чтобы создать команду "Компилировать и выполнить" для .c файлов, необходимо сделать следующее:
command.go.*.c=$(FileName)
command.go.needs.*.c=g++ $(FileNameExt) -o $(FileName) |
||||||||||||||||||||||||||||||||||
command.name.number.filepattern command.number.filepattern command.is.filter.number.filepattern command.subsystem.number.filepattern command.save.before.number.filepattern command.input.number.filepattern command.replace.selection.number.filepattern command.quiet.number.filepattern command.mode.number.filepattern command.shortcut.number.filepattern |
В меню "Tools" можно добавить дополнительные команды. Например, для того чтобы добавить в меню вызов внешней консольной утилиты для оптимизации кода "astyle ", файл настроек должен содержать следующее:
command.name.3.*.cc=Indent В первой строке задается наименование команды, которая будет отображаться в меню "Tools" ниже комманды "Выполнить". Вторая строка представляет собой собственно команду, подобную командам "Компилировать", "Собрать" и "Выполнить". Необязательная переменная command.is.filter указывает на то, что команда модифицирует файл, поэтому после выполнения команды, в случае, если включена опция load.on.activate, может возникнуть необходимость его прочитать. С помощью опции load.on.activate SciTE следит за тем, был ли изменен редактируемый файл внешней программой, и перезагружает его при необходимости.
command.3.*.cc=astyle -taO $(FileNameExt) command.is.filter.3.*.cc=1 Опция subsystem указывает, как будет выполнятся заданная коммандная строка: Опция command.save.before определяет, будет ли текущий файл сохранен перед выпонением команды автоматически (при 1), или же SciTE сделает запрос на сохранение (при 2). Опция command.input задает текст, который будет передан команде через стандартный поток вывода. (Естественно, приложение, запускаемое из коммандной строки, должно поддерживать чтение со стандартного входного потока.) Опция command.replace.selection задает режим для замены выделенного текста на выходные данные (или, если текст не выделен, то выходные данные вставляются в место расположения курсора). Данная переменная может иметь три значения: При значении command.quiet, равном 1, ввод-вывод команды не отображается на панели вывода. Это свойство может быть полезно в комбинации с переменными command.input и command.replace.selection. Вместо того, чтобы задавать все вышеперечисленные параметры отдельно, имеется возможность задать их в одной строке с помощью параметра command.mode. Переменная command.shortcut позволяет задавать клавиатурные комбинации для быстрого запуска команды. По умолчанию команды от 0 до 9 имеют быстрые клавиши от В строке значения параметра command. можно использовать переменные $(1) .. $(4). Например, так:
command.11.*=*CMD /K COPY $(1) $(2)
Эти переменные можно задать предварительно (как и все остальные пользовательские переменные), а можно и через немодальное диалоговое окно "Параметры" Если переменная command.name не имеет значения, то соответсвующие пункты в меню Tools не отображаются. Независимо от того, отображается команда в меню Tools или нет, ее можно вызвать с помощью быстрых клавиш или использовать для задания собственных пунктов в контекстном меню.
user.context.menu=Indent|1103|
user.shortcuts=Ctrl+Alt+I|1103| |
||||||||||||||||||||||||||||||||||
command.help.filepattern command.help.subsystem.filepattern |
Задает команду, которая выполняется при вызове команды "Справка" или нажатии клавиши F1 . Без данных команд вполне можно было бы обойтись, т.к. они, по сути, являются частным случаем описанных выше параметров command.*.Под Windows типичным значением command.help.filepattern является строка вида $(CurrentSelection)!help.hlp (или help.chm ), а значение subsystem равно 4 или 5.Под Linux наиболее распространенными способами отображения справки является запуск мануала или браузера. |
||||||||||||||||||||||||||||||||||
command.scite.help command.scite.help.subsystem |
Задает команду для вызова справки SciTE, что также является частным случаем описанных выше параметров command.*. Поскольку оринальная справка написана в html формате, то в качестве команды обычно задается строка для отображения этого файла в браузере. |
||||||||||||||||||||||||||||||||||
command.print.filepattern command.print.subsystem.filepattern |
Задает команду, выполняемую при печати под GTK+. | ||||||||||||||||||||||||||||||||||
time.commands | При значении данного параметра 1, команды, вывод которых перенаправляется в окно консоли, будут дополнительно выводить время выполнения в секундах. | ||||||||||||||||||||||||||||||||||
print.magnification | Размер шрифта, используемый для печати, соответствует заданному в параметрах каждого стиля. (При этом Ctrl+ и Ctrl- , меняя размер шрифта на экране, не изменяют размера для печати).Чтобы увеличить или уменьшить размер печатного шрифта, задайте переменной print.magnification значение, которое будет суммироваться с размером шрифта заданного для каждого стиля. Отрицательные значения будут уменьшать текст на указанное количество пунктов. В SciTE-Ru использовано скриптовое решение, позволяющее изменять размер шрифта для печати одновременно с изменением экранного представления |
||||||||||||||||||||||||||||||||||
print.colour.mode | Некоторые программисты предпочитают, чтобы на экране отображался светлый текст на темном фоне, а на печать выводился темный текст на светлом фоне. Если переменной print.colour.mode задать значение 1, то во время печати каждый цвет будет инвертироваться. При значении 2 на печать будет выводиться черный текст на белом фоне. Если значение будет равно 3, фон станет белым, а при значении 4 фон будет белым по умолчанию. |
||||||||||||||||||||||||||||||||||
print.margins | Под Windows данная переменная задает поля по умолчанию для вывода на печать. Поля задаются в следующем порядке: левое поле, затем правое, верхнее и нижнее. Единицы измерения, в которых задаются значения переменной, зависят от национальных настроек и могут быть или сотыми миллиметра или тысячными дюйма. Какие единицы измерения используются на вашем компьютере, можно увидеть в диалоге "Параметры страницы". Данная настройка считывается только при запуске SciTE. | ||||||||||||||||||||||||||||||||||
print.header.format print.footer.format |
Данные переменные задают текст, который будет печататься в верхнем и нижнем колонтитуле. При помощи синтаксиса $(параметр) в качестве значений можно подставить другие параметры. Есть несколько дополнительных переменных: CurrentPage , FileTime , FileDate , CurrentDate , и CurrentTime (на начало печати). Чаще всего в верхнем и нижнем колонтитулах используются переменные FileNameExt и FilePath .Верхний колонтитул может выглядеть следующим образом:
print.header.format=$(FileNameExt) - Распечатано $(CurrentDate),$(CurrentTime) - Страница $(CurrentPage)
|
||||||||||||||||||||||||||||||||||
print.header.style print.footer.style |
При помощи данных переменных задается стиль для колонтитулов. При этом используется тот же формат, что и для других стилей SciTE. Поддерживаются только следующие аттрибуты: fore, back, font, size, bold, italics и underlined . |
||||||||||||||||||||||||||||||||||
export.keep.ext | Данная переменная указывает, как трансформируется имя файла (например, LineMarker.cxx ) при экспорте, когда к нему добавляется соответствующее экспортируемому формату расширение - .html для HTML и .rtf для RTF.Если значение переменной export.keep.ext равно 0 (по умолчанию), текущее расширение изменяется ( LineMarker.html ).Если значение равно 1 - расширение, соответствующее экспортируемому формату, присоединяется в конец ( LineMarker.cxx.html ).Если 2 - тогда конечный символ " . " заменяется на "_ " и в конец добавляется расширение, соответствующее экспортируемому формату (LineMarker_cxx.html ). |
||||||||||||||||||||||||||||||||||
export.html.wysiwyg export.html.tabs export.html.folding export.html.styleused export.html.title.fullpath |
Если значение переменной export.html.wysiwyg равно 0, то при экспорте в HTML получается файл меньшего размера, но менее детально описанный, поэтому при выводе на экран этот файл может выглядеть по-другому. Если значение переменной export.html.tabs равно 1, а значение переменной export.html.wysiwyg равно 0, символы табуляции будут экспортированы как символы табуляции, а не как последовательность символов пробела. В браузерах, хорошо поддерживающих CSS (Mozilla и Internet Explorer), экспортируемый файл может иметь свертку. Для этого переменной export.html.folding необходимо задать значение 1. Если значение переменной export.html.styleused равно 1, используются только экспортируемые стили. Если переменной export.html.title.fullpath задать значение 1, то в заголовок будет вставлен полный путь к файлу, а не просто имя файла. |
||||||||||||||||||||||||||||||||||
export.rtf.wysiwyg export.rtf.tabs export.rtf.font.face export.rtf.font.size export.rtf.tabsize |
Когда значение переменной export.rtf.wysiwyg равно 0, при экспорте в RTF получается файл меньшего размера, но менее детально описанный, поэтому при выводе на экран этот файл может выглядеть по-другому. Если значение переменной export.rtf.tabs равно 1, то символы табуляции будут экспортироваться как символы табуляции, а не как последовательность символов пробела. (Это верно при export.rtf.wysiwyg=0 )Переменная export.rtf.font.face используется для задания шрифта для экспортируемого RTF-файла. С помощью переменной export.rtf.tabsize можно задать размер табулятора, отличный от заданного настройкой tabsize. |
||||||||||||||||||||||||||||||||||
export.pdf.magnification export.pdf.font export.pdf.pagesize export.pdf.margins |
Значение переменной export.pdf.magnification добавляется к размеру шрифта, используемому по умолчанию при выводе на экран. Положительное значение увеличивает размер шрифта в документе PDF, и наоборот. Переменная export.pdf.font принимает однословное значение, задающее шрифт по умолчанию в документе PDF: Courier, Helvetica или Times. Helvetica используется по умолчанию. При использовании Helvetica и Times нельзя переносить строки, при использовании Courier можно. Переменная export.pdf.pagesize используется для того, чтобы задать размер страницы PDF. Единицей измерения здесь является точка (1/72 дюйма). Напрмер, формат Letter (8.5 дюймов x 11 дюймов) будет указан как 612,792 .Переменная export.pdf.margins задает ширину полей страницы. По умолчанию значение переменной равно 72 pt или 1 дюйм. Экспорт в PDF ограничен в возможностях, что неизбежно, поскольку PDF является архивным форматом документа. Поддержка полного набора возможностей сильно увеличит размер SciTE. Перенос Helvetica или Times невозможен без сложностей управления метриками и кернингом шрифтов. Документ PDF создается с использованием WinAnsiEncoding, поэтому, если вы хотите использовать расширеный набор символов, перед экспортом в PDF необходимо сделать предварительную перекодировку. |
||||||||||||||||||||||||||||||||||
export.tex.title.fullpath | The full path name of the file is put in the title, instead of just the file name when export.tex.title.fullpath set to 1. | ||||||||||||||||||||||||||||||||||
export.xml.collapse.spaces export.xml.collapse.lines |
Данные переменные являются флагами, контролирующими то, как пустые строки и последовательности из нескольких символов пробела конвертируются в XML. Если при экспорте в XML значение параметра export.xml.collapse.spaces равно 1, то последовательности из нескольких символов пробела будут отконвертированы как единственный знак пробела с указанием количества повторений ( <s n='5'/> ).Если при экспорте в XML значение параметра export.xml.collapse.lines равно 1, то последовательности из нескольких пустых строк будут отконвертированны в единственный знак перевода строки ( <line/> ).Символы табуляции всегда конверитруются в соответствии с настройкой tabsize в символы пробела. |
||||||||||||||||||||||||||||||||||
fold | Свертка включается, если переменной fold задано значение 1 | ||||||||||||||||||||||||||||||||||
fold.symbols | Переменная fold.symbols задает один из четырех способов отображения свертки. Если значение этой переменной равно 0 (по умолчанию), используется стиль MacOS (стрелка вправо для свернутого текста, стрелка вниз для развернутого); 1 - свернутый текст отмечается символом "+", а развернутый - символом "-". При значении 2 отображается плоская древовидная структура с круглыми значками и закругленными соединениями, значение 3 выводит плоскую древовидную структуру с квадратными значками. |
||||||||||||||||||||||||||||||||||
fold.margin.width | Задаёт ширину колонки свёртки кода. | ||||||||||||||||||||||||||||||||||
fold.margin.colour fold.margin.highlight.colour |
Данные переменные определяют цвет колонки свёртки кода. Если переменные не заданы (закомментированы), цвет поля будет установлен по умолчанию. В Windows поле свёртки кода по умолчанию отображается как у полосы прокрутки. Например, если задать fold.margin.colour=#FF0000 и fold.margin.highlight.colour=#0000FF, цвет колонки свёртки кода будет представлять собой смесь красного и синего, т.е. цвет колонки для свёртки кода - составной (из этих двух цветов). | ||||||||||||||||||||||||||||||||||
fold.on.open | Для автоматической свертки загружаемых файлов задайте переменной fold.on.open значение 1. | ||||||||||||||||||||||||||||||||||
fold.flags | Не в полной мере задокументированные ;) битовые флаги, которые могут исчезнуть в будущих версиях. Значения 2, 4, 8 и 16 управляют отрисовкой строк выше и ниже свертываемых строк, как в свернутом, так и в развернутом состоянии. Значение 64 поможет отладить свертку, отобразив в поле уровни свертки в шестнадцатеричном виде. |
||||||||||||||||||||||||||||||||||
fold.compact | Для файлов HTML, XML, Lua, C++ и подобных включение данной опции ведет к тому, что пустые строки после элемента свертки свертываются вместе с ней. По умолчанию включено. | ||||||||||||||||||||||||||||||||||
fold.highlight | При 1 включается подсветка вертикальной линии фолдинга. Подсвечивается наименьший блок в котором находится в текущий момент курсор. По умолчанию выключено. Примечание: Подсветка работает только если fold.symbols равен 2 (круглые узлы) или 3 (квадратные узлы) |
||||||||||||||||||||||||||||||||||
fold.highlight.colour | Задает цвет подсветки линии, обрамляющей текущий блок свертки. По умолчанию используется красный цвет (#FF0000) | ||||||||||||||||||||||||||||||||||
title.full.path | Указывает способ отображения имени файла в строке заголовка. Если значение переменной равно 0 (по умолчанию), отображается имя файла, 1 - отображается полный путь, 2 - заголовок окна отображается в виде "имя файла в папке". | ||||||||||||||||||||||||||||||||||
title.show.buffers | Если значение данной переменной равно 1, в заголовке окна отображается номер текущей вкладки. | ||||||||||||||||||||||||||||||||||
tabsize tab.size.filepattern indent.size indent.size.filepattern use.tabs use.tabs.filepattern indent.auto tab.indents backspace.unindents |
Переменная tabsize задает размер символа табуляции. Если данный параметр не задан, то размер табуляции равен 8 символам. Переменная indent.size определяет размер отступов при автоматическом структурировании текста. По умолчанию этот размер равен размеру табуляции. Многие программисты задают размер табуляции равным 8, а размер отступа - равным 4. При структурировании текста переменная use.tabs определяет, каким должен быть отступ: состоять из последовательности символов пробела или из сочетания символов табуляции и пробела с использованием как можно больше символов табуляции. Глобальные переменные tabsize, indent.size и use.tabs могут перекрываться для файлов, соответствующих определенному шаблону:
indent.size.*.pas=3
Если задана переменная indent.auto, то значения переменных tabsize и indent.size определяются согласно содержимому открытого документа.Если задана переменная tab.indents, то при нажатии клавиши TAB для отступа строки будет применен размер, заданный переменной indent.size, а не tabsize. Если задана переменная backspace.unindents, тогда нажатие клавиши Backspace внутри отступа приведет к тому, что вместо удаления символа перед курсором, будет произведено уменьшение отступа на значение, заданное в переменной indent.size. |
||||||||||||||||||||||||||||||||||
indent.automatic indent.opening indent.closing indent.maintain.filepattern |
Определяют вид автоматического структурирования текста. Автоматическое структутрирование включено, если значение переменной indent.automatic равно 1. Чтобы сделать отступ в строке, содержащей открывающую скобку в начале блочного оператора, задайте переменной indent.opening значение 1. То же верно и для закрывающей скобки. Например, если оба параметра равны 0, то:
if (c) Если оба равны 1:
{ s; }
if (c) Автоматическое структурирование можно заменить простым повторением отступа предыдущей строки для определенных файлов, если значение переменной indent.maintain.filepattern равно 1. В этом случае отменяются другие специфичные для языка настройки.
{ s; } |
||||||||||||||||||||||||||||||||||
statement.indent.filepattern statement.end.filepattern statement.lookback.filepattern block.start.filepattern block.end.filepattern |
Данные настройки влияют на распознавание блочных операторов, таких как begin...end , if..else, while...wend . Данные переменные начинаются с номера стиля, затем идет набор слов или символов, который указывает, как распознавать это свойство. Если в значении переменной более 1 пробела, это трактуется как набор слов, иначе это набор символов. Набор ключевых слов, используемый для обозначения начала блочного оператора, объявляется в statement.indent. Например:
statement.indent.$(file.patterns.cpp)=5 if else while
означает, что для C++ слова "if ", "else ", и "while " используют стиль номер 5 для ключевых слов и начинают блочный оператор, поэтому, если не повлияют другие факторы, следующая строка будет иметь отступ.Количество строк, просматриваемых для применения отступа, может быть задано в переменной statement.lookback. Эта возможность используется либо для увеличения производительности, либо для указания на то, что просматриваться должна только последняя строка. Переменные block.start и block.end объявляют элементы языка, используемые для группировки операторов. В C++ для этого используются символы " { " и "} ".
|
||||||||||||||||||||||||||||||||||
indent.python.colon | For Python, automatically indent by one level if the previous line ended in a ':' ignoring comments and whitespace. Otherwise use the same indentation as the previous line. This property overrides other indentation settings. | ||||||||||||||||||||||||||||||||||
vc.home.key | Данная переменная задает поведение клавиш Home и Shift+Home . Если значение переменной равно 1 (по умолчанию), курсор, как в Visual C++, переносится в конец отступа. Если курсор уже находится там, курсор помещается в начало строки. Если переменная равна 0, курсор перемещается в начало строки. |
||||||||||||||||||||||||||||||||||
warning.findwrapped warning.notfound warning.wrongfile warning.executeok warning.executeko warning.nootherbookmark |
Если заданы данные переменные, то при возникновении определенных событий под Windows проигрываются звуки и мигают окна. Значение переменной состоит из 3 частей, разделенных символом ", " : продолжительность мигания окна, звук и продолжительность звука. Если звук задан числом, это значение рассматривается как высота звука, и звук проигрывается с заданой продолжительностью в миллисекундах. В противном случае, оно считается путем к предназначенному для воспроизведения звуковому файлу. Если мигание окна нежелательно, укажите в качестве продолжительности мигания 0. Например,
warning.wrongfile=0,C:\Windows\Media\SFX\Glass.wav
при попытке открыть файл с неправильным именем воспроизведет звук вибрирующего стекла.Предупреждение: findwrapped будет иметь место, если операция поиска дойдет до любого конца файла, notfound - когда поиск или команды условного перехода препроцессора не дадут результатов, executeok - после успешного выполнения такой команды, как "Собрать", executeko - когда команда выполнится с ошибкой, и nootherbookmark - когда больше нет меток для поиска. SciTE-Ru дополнительно предоставляет пользователю возможность использовать текстовые сообщения об ошибках. |
||||||||||||||||||||||||||||||||||
fileselector.width fileselector.height |
В версии SciTe для GTK+ данные переменные определяют начальные размеры окна диалога выбора файлов, вызываемого командами Открыть и Сохранить. В Windows данные переменные не работают. | ||||||||||||||||||||||||||||||||||
fileselector.show.hidden | В GTK+, если значение данной переменной равно 1, в диалоге выбора файлов, вызываемом командой "Открыть", автоматически отображаются скрытые файлы. | ||||||||||||||||||||||||||||||||||
locale.properties | Задает имя файла локализации. Для многопользовательской установки это позволяет каждому пользователю устанавливать предпочтительный язык интерфейса. | ||||||||||||||||||||||||||||||||||
translation.missing | При использовании локализованной версии SciTe и отсутствии термина в файле перевода locale.properties, используется значение переменной translation.missing. Задав этой переменной маркер ***, можно легко проверить, какие термины не поддерживаются переводом. | ||||||||||||||||||||||||||||||||||
menu.language |
Задает пункты в меню Подсветка (Language) и определяет расширения файлов, которые они отображают. Каждый пункт меню объявляется 3 элементами: название языка, расширение и опциональный клавиатурный эквивалент. Каждый элемент заканчивается символом '| '. Например:
H&ypertext|html|F12|
Пункты меню могут быть закомментированы с помощью указания перед именем символа '# '.
|
||||||||||||||||||||||||||||||||||
menukey.* |
Переменная menukey.* позволяет пользователю задавать другие клавиши быстрого доступа для меню без изменения исходного кода SciTE. Синтаксис для этой переменной выглядит следующим образом:
menukey.menu_title.menu_name=<modifier>key
Например, быстрый доступ к File | Exit будет объявлен так:
menukey.file.exit=<control>Q
Пробелы в заголовках меню и именах должны быть заменены символом подчеркивания, а многоточия в конце - удалены. Например, "File | Save As.... " будет представлено как "menukey.file.save_as ".Можно задать несколько модификаторов, однако каждый из них должен быть заключен в одиночные скобки. Распознаваемые модификаторы аналогичны тем, которые используются для переменной user.shortcuts, описанной выше. Распознаваемые именованые клавиши также аналогичны тем, которые используются для user.shortcuts, однако в этом случае добавляется слово " none " указывающее, что для определенных пунктов меню не нужно задавать какие-либо клавиши быстрого доступа.
|
||||||||||||||||||||||||||||||||||
source.default.extensions |
Если имя, указанное в командной строке, не может быть найдено как директория или файл (включая поиск по групповому символу), содержимое свойства трактуется как расширение по умолчанию, которое и будет использоваться для определения местонахождения имени файла. Например:
.cxx|.cpp|.c|.hxx|.hpp|.h|.bat|.txt|.lua
При попытке открыть win32\SciTEWin будет открыт win32\SciTEWin.cxx , так как в этом случае совпадение будет найдено раньше, чем совпадение с win32\SciTEWin.h . Если значение переменной содержит Bar.cxx|.cxx и вы пытаетесь открыть win32\SciTEWin , то будет открыт ScTEWinBar.cxx , так как это совпадение будет найдено раньше.
|
||||||||||||||||||||||||||||||||||
ext.lua.startup.script ext.lua.auto.reload ext.lua.reset extension.filepattern |
Переменные ext.lua используются исключительно для SciTE Lua Scripting Extension. Переменная extension.filepattern является частью общего интерфейса расширений SciTE (SciTE Extension Interface), но в настоящее время используется только в Lua Scripting Extension Переменная ext.lua.startup.script задает имя файла скрипта Lua, который будет загружаться вместе со SciTE и настраивать глобальное окружение для Lua. Значение по-умолчанию равно $(SciteUserHome)/SciTEStartup.lua . В этой переменной необходимо использовать абсолютный путь, однако можно ссылаться на $(SciteDefaultHome) или $(SciteUserHome) . Здесь могут быть объявлены обработчики глобальных событий, командные функции, а также другие функции и объекты.Переменная ext.lua.auto.reload определяет, что случится, если вы сохраните загрузочный скрипт или скрипт для активного расширения из SciTE. Если значение переменной равно 0, то загрузочный скрипт будет запускаться только во время загрузки или при переключении вкладок (в зависимости от ext.lua.reset), а изменения в скрипте для расширения будут применяться только при переключении вкладок. Если значение переменной ext.lua.auto.reload равно 1 (по умолчанию), SciTE заново инициализирует глобальное окружение непосредственно после того, как какой-либо скрипт будет сохранен в пределах SciTE. Однако даже если опция ext.lua.auto.reload включена, SciTE не посылает уведомления, если файлы были изменены другой программой (см. ниже ext.lua.reset.) Опция ext.lua.reset используется в основном для отладки. Если значение переменной ext.lua.reset равно 0 (по умолчанию), переменная ext.lua.startup.script будет проверяться только один раз, при запуске SciTE. Если значение переменной ext.lua.reset изменить на 1, SciTE будет проверять переменную ext.lua.startup.script и перезагружать загрузочный скрипт при каждом переключении вкладок. Опция ext.lua.reset обладает большим набором побочных эффектов, чем опция ext.lua.auto.reload. В некоторых ситуациях имеет смысл включить обе опции (auto.reload и reset), однако обычно одной ext.lua.auto.reload вполне достаточно. Помимо переменной ext.lua.startup.script, возможность для загрузки дополнительных функций и обработчиков событий, специфичных для конкретных типов файлов, предоставляет переменная extension.filepattern. Если значение переменной extension заканчивается на .lua и ссылается на существующий файл, расширение Lua определяет скрипт, так что обработчики событий и команды, объявленые в скрипте, будут доступны до тех пор, пока вкладка активна. Функции и объекты, объявленные через ext.lua.startup.script также доступны, если не перекрыты. Опция extension может также определять поведение, специфичное для конкретной директории. Если в опции extension указано имя файла (не путь), Scite ищет файл в местах стандартного расположения файлов свойств, начиная с текущей папки. Эта возможность может быть очень полезна в комбинации с локальным файлом SciTE.properties . |
||||||||||||||||||||||||||||||||||
caret.sticky | Контролирует момент изменения последней позиции курсора. Если значение переменной равно 1, при наборе символа, табуляции, вставке содержимого буфера или нажатии клавиши возврата (backspace), позиция не изменяется. По умолчанию значение равно 0, что означает отключение данной опции. | ||||||||||||||||||||||||||||||||||
properties.directory.enable | Разрешает или запрещает использование файлов настроек папки. Если значение данной переменной равно 0 (по умолчанию), опция отключена. Любое другое значение разрешает использование файлов настроек. |
caret.policy.{x|y}<param> взаимодействие:
slop | strict | jumps | even | Курсор может достигнуть поля | Если курсор выходит за пределы видимости или входит в нежелательную зону (НЗ) то экран... |
---|---|---|---|---|---|
0 | 0 | 0 | 0 | Да | передвигается и курсор помещается сверху/справа |
0 | 0 | 0 | 1 | Да | передвигается на 1 позицию |
0 | 0 | 1 | 0 | Да | передвигается и курсор помещается сверху/справа |
0 | 0 | 1 | 1 | Да | передвигается так, что курсор оказывается в центре |
0 | 1 | - | 0 | Курсор всегда вверху/с правой стороны экрана | - |
0 | 1 | - | 1 | Нет, курсор всегда в центре | - |
1 | 0 | 0 | 0 | Да | передвигается так, что курсор помещается вне несимметричной НЗ |
1 | 0 | 0 | 1 | Да | передвигается и курсор помещается вне НЗ |
1 | 0 | 1 | 0 | Да | передвигается и курсор помещается на 3 НЗ от верхнего/правого поля |
1 | 0 | 1 | 1 | Да | передвигается и курсор помещается на 3 НЗ от поля |
1 | 1 | - | 0 | Курсор всегда на НЗ от верхнего/правого поля | - |
1 | 1 | 0 | 1 | Нет, избегает НЗ | передвигается на 1 позицию |
1 | 1 | 1 | 0 | Нет, избегает НЗ | передвигается и курсор помещается на 3 НЗ от поля |
В языках, которые лишь незначительно отличаются от поддерживаемых языков программирования (например, ключевыми словами), зачастую могут использоваться уже существующие лексеры. В этом случае под новый язык можно изменить набор ключевых слов. В языках Java и JavaScript могут использоваться настройки лексера от С++. Лексер Java был добавлен только для поддержки комментариев.
В языках, где нельзя использовать существующие лексеры, можно написать новый лексер на C++. Новый лексер можно встроить в Scintilla или поместить во внешний модуль, откуда он будет загружаться при каждом запуске SciTE (см. lexerpath).
Встраивание лексера в SciTEВ параметр open.filter необходимо добавить расширения файлов, которые будут использоваться в новом языке, а в команды command.compile, command.build, command.go и command.go.needs - необходимые для этого языка входные данные.
*.api
-файл представляет собой текстовый документ, формат которого изложен в описании параметров api.filepattern и autocomplete.lexer.
Такие файлы можно создать вручную или с помощью программы. Существуют также уже готовые .api файлы.
Для C/C++ файлов API-файлы можно создавать с помощью ctags, а затем скрипта на Python tags2api (что предполагает исходный код на C/C++) на основе файла тегов для выполения захвата прототипов функций, расположенных на нескольких строках. Некоторые часто используемые файлы заголовков окружают списки параметров макросом "__P
" и могут иметь комментарии. Для таких файлов может быть использована утилита cleanapi.
API файл для модулей Python создается с помощью скрипта gen_python_api.
API файл для классов Java создается с помощью программы ApiBuilder.java.
Данная команда открывает файл по имени файла, выделенному в панели редактирования или в панели вывода. Команда использует текущее выделение или поиск вблизи курсора, пытаясь найти имя файла по символам, которые обычно используются при задании пути. При отсутствии расширения, оно определяется из текущего файла при помощи переменной open.suffix, которая в файле .properties
по умолчанию принимает значение ".properties
". Если за именем файла следует число (в формате, подобном ctags
, grep output
или Visual Studio messages
), в открываемом файле отображается строка с этим номером. Если имя файла представляет собой абсолютный путь, файл открывается напрямую. В противном случае, команда производит поиск вначале в текущем каталоге, а затем в каталоге, заданном в переменной openpath. В Windows URL-адреса web-
, ftp-
, mail-
и news-
открываются ассоциированными с ними приложениями.
В SciTE-Ru для этих целей используются скриптовые решения, работающие более корректно и обладающие расширенными возможностями.
Если в каталоге, определяемом переменной SciteDefaultHome
присутствует файл locale.properties
, с записями в формате:
Процедура сборки и установки SciTE описана в файле README
в папке исходных кодов scite.
Чаще всего для компиляции SciTE используется пакет Microsoft Visual Studio .NET 2003
(именно его используют разработчики).
Возможна компиляция с помощью VC6
или MinGW
.
С версии SciTE 1.75 компиляция Scintilla
в Borland C++
больше не поддерживается.
Можно использовать для компиляции пакетные файлы (удобно их запускать непосредственно из SciTE). Помещать пакетный файл необходимо в одной папке с подкаталогами scintilla
и scite
.
Существует 2 пути расширения SciTE:
SciTE Extension Interface - расширяет возможности SciTE с помощью дополнительного в исполняемом файле SciTE (SciTE Lua Scripting Extension, позволяющее исполнять сценарии на языке LUA внутри SciTE, использует именно его) и
SciTE Director Interface для управления SciTE из других программ Windows.