Abstract
Effectively using software languages, be it programming or domain-specific languages, requires effective editing support. Modern IDEs, modeling tools, and code editors typically provide sophisticated support to create, comprehend, or modify instances---programs or models---of particular languages. Unfortunately, building such editing support is challenging. While the engineering of languages is well understood and supported by modern model-driven techniques, there is a lack of engineering principles and best practices for realizing their editing support. Especially domain-specific languages---often created by smaller organizations or individual developers, sometimes even for single projects---would benefit from better methods and tools to create proper editing support.
We study practices for implementing editing support in 30 so-called language servers---implementations of the language server protocol (LSP). The latter is a recent de facto standard to realize editing support for languages, separated from the editing tools (e.g., IDEs or modeling tools), enhancing the reusability and quality of the editing support. Witnessing the LSP's popularity---a whopping 121 language servers are in existence today---we take this opportunity to analyze the implementations of 30 language servers, some of which support multiple languages. We identify concerns that developers need to take into account when developing editing support, and we synthesize implementation practices to address them, based on a systematic analysis of the servers' source code. We hope that our results shed light on an important technology for software language engineering, that facilitates language-oriented programming and systems development, including model-driven engineering.
We study practices for implementing editing support in 30 so-called language servers---implementations of the language server protocol (LSP). The latter is a recent de facto standard to realize editing support for languages, separated from the editing tools (e.g., IDEs or modeling tools), enhancing the reusability and quality of the editing support. Witnessing the LSP's popularity---a whopping 121 language servers are in existence today---we take this opportunity to analyze the implementations of 30 language servers, some of which support multiple languages. We identify concerns that developers need to take into account when developing editing support, and we synthesize implementation practices to address them, based on a systematic analysis of the servers' source code. We hope that our results shed light on an important technology for software language engineering, that facilitates language-oriented programming and systems development, including model-driven engineering.
| Original language | English |
|---|---|
| Title of host publication | Proceedings of the 25th International Conference on Model Driven Engineering Languages and Systems |
| Publisher | Association for Computing Machinery |
| Publication date | 23 Oct 2022 |
| Pages | 232 - 243 |
| ISBN (Electronic) | 9781450394666 |
| DOIs | |
| Publication status | Published - 23 Oct 2022 |
| Externally published | Yes |
| Event | International Conference on Model Driven Engineering Languages and Systems - Montreal, Canada Duration: 23 Oct 2022 → 28 Oct 2022 Conference number: 25 https://conf.researchr.org/home/models-2022 |
Conference
| Conference | International Conference on Model Driven Engineering Languages and Systems |
|---|---|
| Number | 25 |
| Country/Territory | Canada |
| City | Montreal |
| Period | 23/10/2022 → 28/10/2022 |
| Internet address |
Keywords
- Language engineering
- code assistance
- source code editor
- implementation practices
Fingerprint
Dive into the research topics of 'Editing support for software languages: implementation practices in language server protocols'. Together they form a unique fingerprint.Cite this
- APA
- Author
- BIBTEX
- Harvard
- Standard
- RIS
- Vancouver