Найти в Дзене
Infostart.ru - Инфостарт

Фирма «1С» выложила на GitHub исходный код фреймворка для Eclipse, используемого в IDE «1С:Исполнителя»

Оглавление

K предоставляет гибкие интерфейсы для интеграции в Eclipse IDE языковых серверов, соответствующих спецификации Language Server Protocol (LSP). Предназначен для реализации плагинов по поддержке различных языков в Eclipse.

Проект построен на базе Eclipse LSP4J без использования Eclipse LSP4E, обеспечивая большее количество возможностей по взаимодействию с LSP-серверами.

В состав репозитория входят примеры исходного кода плагинов Eclipse по поддержке основных функций стандартных языковых серверов TypeScript и JSON, а также простейшего языкового сервера для работы с файлами, имеющими расширение .proto.

Что это значит?

С помощью фреймворка LXTK можно подключить к Eclipse свой языковой сервер, соответствующий спецификации Language Server Protocol – например, Gherkin – и реализовать функциональность для синтаксической подсветки, автодополнения, проверки правильности написания и т.д. Причем, эту функциональность можно будет использовать в различных средах разработки, поддерживающих технологию LSP.

Языковой сервер взаимодействует со средой разработки через JSON-RPC.
Источник: microsoft.github.io
Языковой сервер взаимодействует со средой разработки через JSON-RPC. Источник: microsoft.github.io

Особенности

Текущая версия LXTK обеспечивает на стороне клиента поддержку следующих функций LSP:

  • Document Highlight – подсветка мест использования в документе;
  • Completion – автодополнение при написании текста по Ctrl+пробел;
  • Code Action – быстрые исправления и рефакторинг;
  • Code Lens – информационные гиперссылки между строками документа, запускающие определенные действия в заданном контексте;
  • Hover – подсказка при наведении курсора;
  • Signature Help – подсказка по параметрам методов;
  • Диагностики;
  • Форматирование документа и выделенного диапазона;
  • Document Symbol – структура типов, свойств и методов документа;
  • Find Reference – поиск мест использования;
  • Folding Range – настройка сворачивания языковых конструкций;
  • Go to Declaration – переход к объявлению;
  • Go to Definition – переход к определению;
  • Go to Implementation – переход к реализации;
  • Go to Type Definition – переход к определению типа;
  • Rename – переименование методов и свойств;
  • Workspace Edit – рефакторинг в пределах рабочей области;
  • Workspace Folders – получение данных о папках рабочей области;
  • Workspace Symbols – список типов, свойств и методов, соответствующих запросу, в целом по рабочей области.

На данный момент фреймворк поддерживает только те функции, которые представлены в спецификациях LSP версии ниже 3.15.

Архитектура LXTK

Архитектурно, фреймворк состоит из двух основных слоев: LXTK Core Framework и LXTK Integration for Eclipse (LX4E).

  • LXTK Core Framework (org.lxtk) реализован на основе LSP4J и предоставляет базовую инфраструктуру для создания LSP-клиентов на Java (например, LSP-клиентов для Eclipse, IntelliJ и т.д.).
  • LXTK Integration for Eclipse (LX4E) содержит базовую часть (org.lxtk.lx4e) и клиентскую часть с пользовательским интерфейсом (org.lxtk.lx4e.ui) для Eclipse, использующие сервисы Core Framework. Облегчает интеграцию языковых серверов в IDE Eclipse.

Примеры применения

В состав проекта LXTK входят три примера плагинов для Eclipse, демонстрирующих основные возможности использования фреймворка для поддержки языков:

Подсветка кода и структура документа на базе LSP для JSON-файлов
Подсветка кода и структура документа на базе LSP для JSON-файлов
Провайдер диагностик и автодополнения для proto-файлов
Провайдер диагностик и автодополнения для proto-файлов

В отдельном репозитории организации LXTK приведен пример исходного кода простейшего языкового сервера на Node.js, который реализует основные возможности по работе с протоколом LSP и может быть использован в качества шаблона при тестировании.

У проекта есть документация Javadocs с описанием API, предоставляемого LXTK Core Framework и LX4E.

Подробнее о проекте LXTK в репозитории на GitHub

Комментарии на Infostart.ru