gifts2017

Подсветка синтаксиса 1С в текстовых редакторах Atom, Sublime Text, VS Code

Опубликовал Никита Грызлов (nixel) в раздел Программирование - Инструментарий

Пакеты, добавляющие поддержку синтаксиса языка 1С:Предприятие 8 в текстовые редакторы Atom, Sublime Text и VS Code.
И не только.

В последнее время на Инфостарте набирает популярность тема различных "разукрашек" 1С-текста. Внесу и свою лепту.

Мной, совместно с коллегами из сообщества xDrivenDevelopment, были разработаны синтаксис-пакеты для текстовых редакторов Atom, Sublime Text и VS Code.

Что такое синтаксис-пакет?

Синтаксис-пакеты - это специальные расширения-плагины для редакторов, описывающие правила разбора текстового модуля. Обращаю Ваше внимание на словосочетание "правила разбора". С таким пакетом Вы можете установить любую тему редактора каких угодно цветов. Самое главное, что редактор будет понимать, что "ЗначениеЗаполнено" - это встроенная функция, а "Экспорт" - ключевое слово.

Пара примеров работы:

Monokai:

Monokai

Не менее популярный Solarized Light:

Solarized Light

 

Как видите, вне зависимости от расцветки редактора, все ключевые слова, операторы, etc..., подсвечиваются корректно.

Так же в пакете присутствует подсветка языка запросов. Текст запроса подсвечивается даже внутри текста модуля.

Query-monokai

Что еще?

Однако, не расцветкой единой жив 1С-программист. Пакеты добавляют несколько приятных и нужных функций для редактирования кода.

Пройдемся по некоторым пунктам из списка полезностей:

1) Автоматическая вставка | при редактировании многострочной строки:

Автоперенос строки

2) Список процедур и функций текущего файла и/или рабочего каталога:

Список процедур и функций

3) Дополнение процедур и функций глобального контекста:

Контекстная подсказка

4) Автоматические отступы (вперед и назад) при наборе блочных конструкций (например, Если ... Тогда ... КонецЕсли):

Автоотступы

5) Используя данные пакеты, Вы можете запускать файлы *.bsl или *.os через интерпретатор OneScript, разработанный EvilBeaver (http://infostart.ru/profile/267027/). Подробную инструкцию по настройке запуска скриптов смотрите в "README" интересующего Вас пакета.

Запуск oscript

 

С полным списком возможностей и доступностью каждой из них в редакторах Вы можете ознакомиться здесь, в разделе "Дополнительные возможности". Ссылка ведет на "головной" репозиторий, где консолидируются работы по развитию пакетов.

Что дальше?

Наша команда старается постепенно расширять функциональность пакетов, добавляя новые возможности. В следующем релизе, например, планируется добавить поддержку стандартных шаблонов текста или, как их еще называют, сниппетов.

Так же идут работы по добавлению подсветки синтаксиса 1С на сам github. Основная сложность сейчас - недостаточная популярность расширения *.bsl на github. Публикуйте свои конфигурации и обработки, приобщайтесь к git и OpenSource. Количество репозиториев на данном шаге очень важно.

Ну и конечно же оставляйте свои замечания и пожелания здесь, разделе Issues репозитория или чате gitter.

Ссылки

А вот и список ссылок на пакеты:

Пакеты можно установить через штатные пакетные менеджеры каждого из редакторов (поиск по "1c bsl" должен выдать наиболее релевантный результат). Если не знаете как это сделать, на странице пакетов есть ссылки на инструкции по установке. README так же содержит ссылки на дополнительные инструкции по настройке функциональности.

Благодарности

Огромное спасибо bambr1975 (http://infostart.ru/profile/128365/) за помощь в укрощении VS Code и реализацию множества полезных фич в пакетах!

Спасибо Андрею Овсянкину (EvilBeaver) за OneScript. Именно наличие внешних скриптов на 1С-языке и побудило меня начать работать над грамматикой.

Спасибо всей команде xDrivenDevelopment за тестирование, обсуждение, и всяческую помощь при разработке :)

 

И спасибо Вам за внимание!

 

Обновления (значимые)

Полный список изменений всегда доступен здесь (CHANGELOG в основном репозитории проекта).

1.3.0

Добавлен линтер файлов *.os. Используется интерпретатор OneScript в режиме "check". Позволяет при сохранении сразу увидеть допущенные ошибки.

1.4.0

Добавлены шаблоны текста (сниппеты). За основу взяты стандартные шаблоны из конфигуратора.

Сниппеты

См. также

Подписаться Добавить вознаграждение

Комментарии

1. Алексей Лустин (lustin) 02.02.16 11:03
5-ый пункт желательно расшифровать - как запуск настроить прям из редактора.
sorb; JohnyDeath; +2 Ответить 1
2. Евгений Мартыненков (JohnyDeath) 02.02.16 11:15
Автору огромное спасибо за проделанную работу. Реально удобно и приятно стало работать со скриптами OneScript, за который отдельное спасибо Андрею Овсянкину ;)
Созинов; sorb; kuntashov; artbear; +4 Ответить
3. Никита Грызлов (nixel) 02.02.16 11:17
(1) lustin, ссылки на подробные инструкции по запуску указаны в README каждого пакета. Сейчас так же добавлю в статью сноску
4. Артур Аюханов (artbear) 02.02.16 11:48
поиск по "1c bsl" должен выдать наиболее релеватный результат

Исправь на релевантный
5. Артур Аюханов (artbear) 02.02.16 11:49
чате gitter

ИМХО лучше добавить прямую ссылку.
6. Никита Грызлов (nixel) 02.02.16 11:52
(5) artbear, добавил ссылку.
очепятки лучше в личку ;)
7. Иван Устьянцев (nSpirit2) 02.02.16 12:09
Ого вот это реально круто :) Большое спасибо!
8. Иван Устьянцев (nSpirit2) 02.02.16 12:34
Кусок типо
#Область ПрограммныйИнтерфейс

#КонецОбласти
...Показать Скрыть


Не подсвечивается :(
9. Никита Грызлов (nixel) 02.02.16 12:42
(8) nSpirit2, поправим, спасибо :)
10. Леонид Паутов (Pr-Mex) 02.02.16 12:59
11. Сергей Рудаков (fishca) 02.02.16 13:37
в конфигуратор бы засунуть все эти возможности
12. Никита Грызлов (nixel) 02.02.16 13:39
(11) fishca, есть snegopat :). плюс, я надеюсь на EDT и его плагины.
13. Андрей Овсянкин (Evil Beaver) 02.02.16 14:02
И не забудем похвалить bambr1975, которая невероятно быстро и качественно разобралась, как командовать всеми этими редакторами!
sikuda; awa; nSpirit2; JohnyDeath; nixel; lustin; sorb; artbear; kuntashov; +9 Ответить 1
14. Артур Аюханов (artbear) 02.02.16 14:46
+ (13) Добавь ссылку на профиль http://infostart.ru/profile/128365/ чтобы страна более точно знала своих героев
15. Юрий Былинкин (ardn) 02.02.16 14:56
Установил атом, установил пакеты language-1c-bsl и scripts.
Открыл скрипт, который успешно работает в notepad++. Грамматика указана правильная. Нажимаю на Ctrl-Shift-B.
Атом ругается - Unable to run.
ЧЯДНТ?
16. Дмитрий Майоров (damayorov) 02.02.16 15:02
Удобная вещь. Спасибо автору.
17. Никита Грызлов (nixel) 02.02.16 15:07
(15) ardn, возможно вы нарвались вот на этот баг - https://github.com/xDrivenDevelopment/1c-syntax/issues/74
Попробуйте открыть каталог или запустить атом с консоли.
18. Юрий Былинкин (ardn) 02.02.16 15:39
(17) nixel,
Спасибо. При открытии из каталога скрипты запускаются
19. Никита Грызлов (nixel) 03.02.16 23:15
(8) nSpirit2, исправлено в версии 1.1.6.
20. Andrey Star (st00) 04.02.16 12:14
Супер! Все-же сделали! Самому нет нужды теперь делать под sublime, а так хотелось.
21. Никита Грызлов (nixel) 09.02.16 11:44
Баг с подсветкой в VS Code исправлен в редакторе версии 0.10.8. Обновляйтесь и будет вам щастье.
JohnyDeath; +1 Ответить
22. Никита Грызлов (nixel) 12.02.16 17:03
Вышла версия 1.2.0 с подсветкой языка запросов. Для работы подсветки выберите синтаксис 1C (Query). Текст запроса должен быть не внутри кавычек, иначе он будет отображаться как строка.
Добавил пример подсветки в статью.
23. Никита Грызлов (nixel) 15.02.16 12:29
Вышел релиз 1.2.1 с подсветкой текста запроса прямо в тексте модуля. Выглядит примерно вот так:
lustin; JohnyDeath; +2 Ответить
24. Ben Mcgewen (bruho) 19.02.16 11:11
Спасибо, реально очень удобно пользоваться редакторами!
25. Олег Дмитров (baracuda) 19.02.16 11:17
Как пользоваться то?
Редактором ведь базу не откроешь?
26. Никита Грызлов (nixel) 19.02.16 14:54
(25) baracuda, базу - не откроешь.
Исходники конфигураций или обработок, выгруженные в файлы - без проблем. А еще есть скрипты на OneScript. Да и копипаст в окно никто не отменял.
27. Роман Ложкин (webester) 06.03.16 16:24
Пользоваться не планирую, где мог бы применить пока не понятно, но выглядит офигенно :)
baracuda; +1 Ответить
28. Никита Грызлов (nixel) 10.03.16 16:02
Добавлена информация о вышедших релизах 1.3.0 (линтер) и 1.4.0 (шаблоны текста).

Так же хорошая новость для пользователей Atom - в релизе 1.7 в редактор включат наши изменения по поддержке кириллических (и не только) символов при работе автодополнения. Надеемся на скорый выпуск (1.6 должен выйти уже на днях).
Временное решение можно посмотреть по этой ссылке - https://github.com/xDrivenDevelopment/1c-syntax/issues/50#issuecomment-181997844
29. Никита Грызлов (nixel) 14.04.16 18:58
Вышел стабильный релиз Atom 1.7, в который включены наши правки по поддержке Юникода при работе автодополнения. Теперь не требуются танцы с бубном, чтобы заставить работать сниппеты и автодополнение в Атоме.

Если вы по инструкции ставили пакет autocomplete-plus вручную, то крайне (очень-очень) рекомендуется его удалить. Напомню, что установлен он был сюда: %userprofiles%\.atom\packages\autocomplete-plus
30. Никита Грызлов (nixel) 11.05.16 21:34
Выпущен релиз language-1c-bsl 1.5.0 для VS Code.

Новая система автодополнения для конфигураций, разложенных на исходные файлы, и скриптов `.os`
Изменений настолько много, что полное описание новых возможностей заняло отдельную страницу в wiki проекта - https://goo.gl/ZrLBjk

* Переход к определению
* Поиск мест использования процедур
* Информация о процедуре
* Предварительный просмотр определения процедуры
* Автодополнение через точку
* Подсказка по параметрам процедур
* Поиск определения
* Поддержка английского языка конфигурации
* Создание описания метода
* Синтаксис-помощник по функциям глобального контекста
* Добавлены настройки для работы с OneScriptLint и системой автодополнения
* Автоматическая вставка скобок
31. Дмитрий Дрейцер (MadDAD) 10.06.16 10:41
(30) nixel, я независимо начал свое, но для Visual Studio Integrated Shell. Предлагаю свои корявые исходники влить в общее дело
32. Никита Грызлов (nixel) 10.06.16 18:04
(31) MadDAD, да, я видел :) все бы хорошо, но я не нашел исходников :)
Плюс - мое для восьмерки. Слабо представляю, что можно слить. Грамматику разве что.
33. Никита Грызлов (nixel) 10.06.16 18:40
Но если есть что сливать, то буду рад :)
34. Николай Князев (HDRX) 30.09.16 09:42
Можно подробнее о практике применения.
С OneScript понятно: пишем код на языке 1С - получаем скрипт. Тут польза очевидна.
Касаемо разработки конфигураций - какие есть альтернативы ручному копипасту?
35. Евгений Сосна (pumbaE) 30.09.16 10:19
(34) HDRX, простейший watch за файловой системой и при изменении модуля частичная загрузка в cf (как сейчас и edt делает).
36. Roman None (WildVirus) 05.10.16 12:01
(22) nixel, В запросах не подсвечиваются параметры, те что начинаются с &.
37. Никита Грызлов (nixel) 05.10.16 21:14
(36) WildVirus, уточните, пожалуйста, ваш редактор, версию редактора, используемую цветовую тему и версию плагина.
Грамматика перед каждым релизом проверяется автоматически по заранее описанным правилам, например, вот: https://github.com/xDrivenDevelopment/atom-language-1c-bsl/blob/master/spec/fixtures/grammar/syntax_test_bsl.bsl
Последние 3 месяца изменений в работе грамматики (встроенного языка и языка запросов) не было.
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа