Протокол языкового сервера - Language Server Protocol

В Протокол языкового сервера (LSP) является открытым, JSON-RPC -основан протокол для использования между редакторы исходного кода или же интегрированные среды разработки (IDE) и серверы которые обеспечивают язык программирования -специфические особенности. Цель протокола - обеспечить реализацию и распространение поддержки языков программирования независимо от какого-либо редактора или IDE.[1]

История

LSP изначально разрабатывался для Код Microsoft Visual Studio и теперь это открытый стандарт. 27 июня 2016 г. Microsoft объявила о сотрудничестве с Красная шляпа и Codenvy для стандартизации спецификации протокола. Протокол поддерживается и принят тремя компаниями.[2][3] Его спецификация размещена и разработана на GitHub.

Фон

Современные IDE предоставляют разработчикам такие сложные функции, как завершение кода, рефакторинг, переход к определению символа, подсветка синтаксиса, а также маркеры ошибок и предупреждений.

Например, в текстовом языке программирования программист может захотеть переименовать метод читать. Программист мог либо вручную отредактировать соответствующие файлы исходного кода и заменить соответствующие вхождения старого имени метода на новое имя, либо вместо этого использовать возможности рефакторинга IDE для автоматического внесения всех необходимых изменений. Чтобы иметь возможность поддерживать этот стиль рефакторинга, IDE необходимо глубокое понимание язык программирования что программа источник написан на. Инструмент программирования без такого понимания - например, тот, который выполняет наивную поиск и замена вместо этого - может привести к ошибкам. При переименовании читать метод, например, инструмент не должен заменять частичное совпадение в переменной, которая может быть вызвана readyState, и он не должен заменять часть комментарий кода содержащий слово «уже». Также не следует переименовывать локальная переменная читать, например, в конечном итоге изменить одноименные переменные в других объемы.

Обычный компиляторы или же переводчики для конкретного языка программирования, как правило, не могут предоставить эти языковые услуги, потому что они написаны с целью преобразования исходного кода в объектный код или сразу выполнить код. Кроме того, языковые службы должны иметь возможность обрабатывать исходный код, который не правильно сформированный, например потому что программист находится в процессе редактирования и еще не закончил ввод оператора, процедуры или другой конструкции. Кроме того, небольшие изменения в файле исходного кода, которые вносятся во время набора текста, обычно изменяют семантику программы. Чтобы обеспечить мгновенную обратную связь с пользователем, инструмент редактирования должен уметь очень быстро оценивать синтаксические и семантические последствия конкретной модификации. Таким образом, компиляторы и интерпретаторы - плохой кандидат для производства информации, необходимой для использования инструментом редактирования.[4]

До разработки и реализации протокола языкового сервера для разработки кода Visual Studio большинство языковых служб обычно были привязаны к данной среде IDE или другому редактору. В отсутствие протокола языкового сервера языковые службы обычно реализуются с использованием API расширения для конкретного инструмента. Предоставление того же языкового сервиса другому инструменту редактирования требует усилий по адаптации существующего кода, чтобы сервис мог быть нацелен на интерфейсы расширения второго редактора.[5]

Протокол языкового сервера позволяет отделить языковые службы от редактора, чтобы эти службы могли быть включены в общую цель. языковой сервер. Любой редактор может унаследовать развитую поддержку множества разных языков, используя существующие языковые серверы. Точно так же программист, участвующий в разработке нового языка программирования, может сделать службы для этого языка доступными для существующих инструментов редактирования.[4] Таким образом, использование языковых серверов через протокол языкового сервера также снижает нагрузку на поставщиков средств редактирования, поскольку поставщикам не нужно разрабатывать собственные языковые службы для языков, которые поставщик намеревается поддерживать, если языковые серверы уже имеют реализовано. Протокол языкового сервера также позволяет распространять и разрабатывать серверы, предоставленные заинтересованной третьей стороной, такой как конечные пользователи, без дополнительного участия ни поставщика компилятора для используемого языка программирования, ни поставщика редактора, которому добавляется языковая поддержка.[нужна цитата ]

LSP не ограничивается языками программирования. Его можно использовать для любого текстового языка, например для спецификаций.[6] или же предметно-ориентированные языки (DSL).[7]

Технический обзор

Когда пользователь редактирует один или несколько файлов исходного кода с помощью инструмента с поддержкой протокола языкового сервера, инструмент действует как клиент который потребляет языковые услуги предоставленный языковой сервер. Инструмент может быть Текстовый редактор или же IDE и языковые услуги могут быть рефакторинг, завершение кода, так далее.

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

Протокол языкового сервера определяет сообщения, которыми должен обмениваться клиент и языковой сервер. Они есть JSON-RPC предшествуют заголовки, аналогичные HTTP. Сообщения могут исходить от сервера или клиента.

Протокол не содержит никаких положений о том, как запросы, ответы и уведомления передаются между клиентом и сервером. Например, клиент и сервер могут быть компонентами в одном процессе, обмениваясь JSON строки через вызовы методов. Они также могут быть разными процессами на одном или на разных машинах, обменивающихся данными через сетевые розетки.

Реестр

Глобальный реестр языковых служб, размещенный на Eclipse Foundation, должен сделать языковые серверы общедоступными.[8] Кроме того, существуют списки LSP-совместимых реализаций, поддерживаемые сообществом Langserver.org.[9] или Microsoft.[10]

Рекомендации

  1. ^ Эффтинге, Свен; Спёнеманн, Миро (11 декабря 2016 г.). «Объяснение протокола языкового сервера». Фонд Затмения. Получено 25 апреля 2017.
  2. ^ Криль, Пол (27 июня 2016 г.). «Поддерживаемый Microsoft протокол языкового сервера стремится к языковой и инструментальной совместимости». InfoWorld. Получено 26 апреля 2017.
  3. ^ Хэнди, Алекс (27 июня 2016 г.). «Codenvy, Microsoft и Red Hat совместно работают над протоколом языкового сервера». SD Times. Получено 26 апреля 2017.
  4. ^ а б Хуарес, Сет (12 мая 2016 г.). «Андерс Хейлсберг о современной конструкции компиляторов». Microsoft. Получено 22 февраля 2017.
  5. ^ Эффтинге, Свен (декабрь 2016 г.). «Eclipse изучает новые протоколы». Получено 26 апреля 2017.
  6. ^ Томассетти, Габриэле (16 февраля 2017 г.). "Почему вы должны знать протокол языкового сервера". Федерико Томассетти. Получено 8 мая 2017.
  7. ^ Нойман, Александр (1 июня 2016 г.). "Протокол языкового сервера Xtext 2.11 unterstützt" [Xtext 2.11 поддерживает протокол языкового сервера]. Heise Developer (на немецком языке). Heise Medien. Получено 8 мая 2017.
  8. ^ Мохило, Доминик (28 июня 2016 г.). "Протокол языкового сервера Polyglott dank: Microsoft, Red Hat и Codenvy streben nach der universellen IDE" [Polyglot благодаря протоколу языкового сервера: Microsoft, Red Hat и Codenvy стремятся к универсальной среде IDE]. Jaxenter (на немецком языке). Программное обеспечение и средства поддержки. Получено 8 мая 2017.
  9. ^ "Langserver.org". Langserver.org. Получено 8 мая 2017 - через Sourcegraph.
  10. ^ Гамма, Эрих (21 января 2019 г.). «Языковые серверы». Microsoft. Получено 25 января 2019 - через GitHub.

внешняя ссылка