И не только.
В последнее время на Инфостарте набирает популярность тема различных «разукрашек» 1С-текста. Внесу и свою лепту.
Мной, совместно с коллегами из сообщества xDrivenDevelopment, были разработаны синтаксис-пакеты для текстовых редакторов Atom, Sublime Text и VS Code.
Что такое синтаксис-пакет?
Синтаксис-пакеты — это специальные расширения-плагины для редакторов, описывающие правила разбора текстового модуля. Обращаю Ваше внимание на словосочетание «правила разбора». С таким пакетом Вы можете установить любую тему редактора каких угодно цветов. Самое главное, что редактор будет понимать, что «ЗначениеЗаполнено» — это встроенная функция, а «Экспорт» — ключевое слово.
Пара примеров работы:
Monokai:
Не менее популярный Solarized Light:
Как видите, вне зависимости от расцветки редактора, все ключевые слова, операторы, etc…, подсвечиваются корректно.
Так же в пакете присутствует подсветка языка запросов. Текст запроса подсвечивается даже внутри текста модуля.
Что еще?
Однако, не расцветкой единой жив 1С-программист. Пакеты добавляют несколько приятных и нужных функций для редактирования кода.
Пройдемся по некоторым пунктам из списка полезностей:
1) Автоматическая вставка | при редактировании многострочной строки:
2) Список процедур и функций текущего файла и/или рабочего каталога:
3) Дополнение процедур и функций глобального контекста:
4) Автоматические отступы (вперед и назад) при наборе блочных конструкций (например, Если … Тогда … КонецЕсли):
5) Используя данные пакеты, Вы можете запускать файлы *.bsl или *.os через интерпретатор OneScript, разработанный EvilBeaver (//infostart.ru/profile/267027/). Подробную инструкцию по настройке запуска скриптов смотрите в «README» интересующего Вас пакета.
С полным списком возможностей и доступностью каждой из них в редакторах Вы можете ознакомиться здесь, в разделе «Дополнительные возможности». Ссылка ведет на «головной» репозиторий, где консолидируются работы по развитию пакетов.
Что дальше?
Наша команда старается постепенно расширять функциональность пакетов, добавляя новые возможности. В следующем релизе, например, планируется добавить поддержку стандартных шаблонов текста или, как их еще называют, сниппетов.
Так же идут работы по добавлению подсветки синтаксиса 1С на сам github. Основная сложность сейчас — недостаточная популярность расширения *.bsl на github. Публикуйте свои конфигурации и обработки, приобщайтесь к git и OpenSource. Количество репозиториев на данном шаге очень важно.
Ну и конечно же оставляйте свои замечания и пожелания здесь, разделе Issues репозитория или чате gitter.
Ссылки
А вот и список ссылок на пакеты:
- для Atom: atom.io/packages
- для Sublime Text: Package control
- для VS Code: Marketplace
Пакеты можно установить через штатные пакетные менеджеры каждого из редакторов (поиск по «1c bsl» должен выдать наиболее релевантный результат). Если не знаете как это сделать, на странице пакетов есть ссылки на инструкции по установке. README так же содержит ссылки на дополнительные инструкции по настройке функциональности.
Благодарности
Огромное спасибо bambr1975 (//infostart.ru/profile/128365/) за помощь в укрощении VS Code и реализацию множества полезных фич в пакетах!
Спасибо Андрею Овсянкину (EvilBeaver) за OneScript. Именно наличие внешних скриптов на 1С-языке и побудило меня начать работать над грамматикой.
Спасибо всей команде xDrivenDevelopment за тестирование, обсуждение, и всяческую помощь при разработке 🙂
И спасибо Вам за внимание!
Обновления (значимые)
Полный список изменений всегда доступен здесь (CHANGELOG в основном репозитории проекта).
1.3.0
Добавлен линтер файлов *.os. Используется интерпретатор OneScript в режиме «check». Позволяет при сохранении сразу увидеть допущенные ошибки.
1.4.0
Добавлены шаблоны текста (сниппеты). За основу взяты стандартные шаблоны из конфигуратора.
5-ый пункт желательно расшифровать — как запуск настроить прям из редактора.
Автору огромное спасибо за проделанную работу. Реально удобно и приятно стало работать со скриптами OneScript, за который отдельное спасибо Андрею Овсянкину 😉
(1) lustin, ссылки на подробные инструкции по запуску указаны в README каждого пакета. Сейчас так же добавлю в статью сноску
Исправь на релевантный
ИМХО лучше добавить прямую ссылку.
(5) artbear, добавил ссылку.
очепятки лучше в личку 😉
Ого вот это реально круто 🙂 Большое спасибо!
Кусок типо
Не подсвечивается 🙁
(8) nSpirit2, поправим, спасибо 🙂
Отличная вещь!
в конфигуратор бы засунуть все эти возможности
(11) fishca, есть snegopat :). плюс, я надеюсь на EDT и его плагины.
И не забудем похвалить bambr1975, которая невероятно быстро и качественно разобралась, как командовать всеми этими редакторами!
+ (13) Добавь ссылку на профильhttp://infostart.ru/profile/128365/ чтобы страна более точно знала своих героев
Установил атом, установил пакеты language-1c-bsl и scripts.
Открыл скрипт, который успешно работает в notepad++. Грамматика указана правильная. Нажимаю на Ctrl-Shift-B.
Атом ругается — Unable to run.
ЧЯДНТ?
Удобная вещь. Спасибо автору.
(15) ardn, возможно вы нарвались вот на этот баг —https://github.com/xDrivenDevelopment/1c-syntax/issues/74
Попробуйте открыть каталог или запустить атом с консоли.
(17)
Спасибо. При открытии из каталога скрипты запускаются
(8) nSpirit2, исправлено в версии 1.1.6.
Супер! Все-же сделали! Самому нет нужды теперь делать под sublime, а так хотелось.
Баг с подсветкой в VS Code исправлен в редакторе версии 0.10.8. Обновляйтесь и будет вам щастье.
Вышла версия 1.2.0 с подсветкой языка запросов. Для работы подсветки выберите синтаксис 1C (Query). Текст запроса должен быть не внутри кавычек, иначе он будет отображаться как строка.
Добавил пример подсветки в статью.
Вышел релиз 1.2.1 с подсветкой текста запроса прямо в тексте модуля. Выглядит примерно вот так:
Спасибо, реально очень удобно пользоваться редакторами!
Как пользоваться то?
Редактором ведь базу не откроешь?
(25) baracuda, базу — не откроешь.
Исходники конфигураций или обработок, выгруженные в файлы — без проблем. А еще есть скрипты на OneScript. Да и копипаст в окно никто не отменял.
Пользоваться не планирую, где мог бы применить пока не понятно, но выглядит офигенно 🙂
Добавлена информация о вышедших релизах 1.3.0 (линтер) и 1.4.0 (шаблоны текста).
Так же хорошая новость для пользователей Atom — в релизе 1.7 в редактор включат наши изменения по поддержке кириллических (и не только) символов при работе автодополнения. Надеемся на скорый выпуск (1.6 должен выйти уже на днях).
https://github.com/xDrivenDevelopment/1c-syntax/issues/50#issuecomment-181997844
Временное решение можно посмотреть по этой ссылке —
Вышел стабильный релиз Atom 1.7, в который включены наши правки по поддержке Юникода при работе автодополнения. Теперь не требуются танцы с бубном, чтобы заставить работать сниппеты и автодополнение в Атоме.
Если вы по инструкции ставили пакет autocomplete-plus вручную, то крайне (очень-очень) рекомендуется его удалить. Напомню, что установлен он был сюда: %userprofiles%.atompackagesautocomplete-plus
Выпущен релиз language-1c-bsl 1.5.0 для VS Code.
Новая система автодополнения для конфигураций, разложенных на исходные файлы, и скриптов `.os`
https://goo.gl/ZrLBjk
Изменений настолько много, что полное описание новых возможностей заняло отдельную страницу в wiki проекта —
* Переход к определению
* Поиск мест использования процедур
* Информация о процедуре
* Предварительный просмотр определения процедуры
* Автодополнение через точку
* Подсказка по параметрам процедур
* Поиск определения
* Поддержка английского языка конфигурации
* Создание описания метода
* Синтаксис-помощник по функциям глобального контекста
* Добавлены настройки для работы с OneScriptLint и системой автодополнения
* Автоматическая вставка скобок
(30) я независимо начал свое, но дляVisual Studio Integrated Shell . Предлагаю свои корявые исходники влить в общее дело
(31) MadDAD, да, я видел 🙂 все бы хорошо, но я не нашел исходников 🙂
Плюс — мое для восьмерки. Слабо представляю, что можно слить. Грамматику разве что.
Но если есть что сливать, то буду рад 🙂
Можно подробнее о практике применения.
С OneScript понятно: пишем код на языке 1С — получаем скрипт. Тут польза очевидна.
Касаемо разработки конфигураций — какие есть альтернативы ручному копипасту?
(34) HDRX, простейший watch за файловой системой и при изменении модуля частичная загрузка в cf (как сейчас и edt делает).
(22) В запросах не подсвечиваются параметры, те что начинаются с &.
(36) WildVirus, уточните, пожалуйста, ваш редактор, версию редактора, используемую цветовую тему и версию плагина.
https://github.com/xDrivenDevelopment/atom-language-1c-bsl/blob/master/spec/fixtures/grammar/syntax_test_bsl.bsl
Грамматика перед каждым релизом проверяется автоматически по заранее описанным правилам, например, вот:
Последние 3 месяца изменений в работе грамматики (встроенного языка и языка запросов) не было.