Skip to content

Language Server for protocol buffers

License

Notifications You must be signed in to change notification settings

coder3101/protols

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Protols - Protobuf Language Server

Crates.io
Build and Test

WARNING : Master branch is undergoing a massive refactoring, please use last relesed tag instead.

Protols is an open-source, feature-rich Language Server Protocol (LSP) for Protocol Buffers (proto) files. Powered by the efficient tree-sitter parser, Protols offers intelligent code assistance for protobuf development, including features like auto-completion, diagnostics, formatting, and more.

Protols Demo

✨ Features

  • Code Completion: Auto-complete messages, enums, and keywords in your .proto files.
  • Diagnostics: Syntax errors detected with the tree-sitter parser.
  • Document Symbols: Navigate and view all symbols, including messages and enums.
  • Code Formatting: Format .proto files using clang-format for a consistent style.
  • Go to Definition: Jump to the definition of symbols like messages or enums.
  • Hover Information: Get detailed information and documentation on hover.
  • Rename Symbols: Rename protobuf symbols and propagate changes across the codebase.
  • Find References: Find where messages, enums, and fields are used throughout the codebase.

Table of Contents


🚀 Installation

For Neovim

You can install Protols via mason.nvim, or install it directly from crates.io:

cargo install protols

Then, configure it in your init.lua using nvim-lspconfig:

require'lspconfig'.protols.setup{}

For Visual Studio Code

If you're using Visual Studio Code, you can install the Protobuf Language Support extension, which uses this LSP under the hood.

Note: This extension is open source, but is not officially maintained by us.


⚙️ Configuration

Protols is configured using a protols.toml file, which you can place in any directory.

Sample protols.toml

[config] # Base configuration; these are considered stable and should not change
include_paths = ["foobar", "bazbaaz"] # Include paths to look for protofiles during parsing
disable_parse_diagnostics = true # Disable diagnostics for parsing

[config.experimental] # Experimental configuration; this should be considered unsafe and not fully tested
use_protoc_diagnostics = true # Use diagnostics from protoc

[formatter] # Formatter specific configuration
clang_format_path = "/usr/bin/clang-format" # clang-format binary to execute in formatting

Configuration Sections

Basic Configuration

The [config] section contains stable settings that should generally remain unchanged.

  • include_paths: Directories to search for .proto files.
  • disable_parse_diagnostics: Set to true to disable diagnostics during parsing.

Experimental Configuration

The [config.experimental] section contains settings that are in development or not fully tested.

  • use_protoc_diagnostics: Enable diagnostics from the protoc compiler when set to true.

Formatter Configuration

The [formatter] section allows configuration for code formatting.

  • clang_format_path: Specify the path to the clang-format binary.

🛠️ Usage

Protols offers a rich set of features to enhance your .proto file editing experience.

Code Completion

Protols offers intelligent autocompletion for messages, enums, and proto3 keywords within the current package. Simply start typing, and Protols will suggest valid completions.

Diagnostics

Syntax errors are caught by the tree-sitter parser, which highlights issues directly in your editor. For more advanced error reporting, the LSP can be configured to use protoc diagnostics.

Code Formatting

Format your .proto files using clang-format. To customize the formatting style, add a .clang-format file to the root of your project. Both document and range formatting are supported.

Document Symbols

Protols provides a list of symbols in the current document, including nested symbols such as messages and enums. This allows for easy navigation and reference.

Go to Definition

Jump directly to the definition of any custom symbol, including those in other files or packages. This feature works across package boundaries.

Hover Information

Hover over any symbol to get detailed documentation and comments associated with it. This works seamlessly across different packages and namespaces.

Rename Symbols

Rename symbols like messages or enums, and Propagate the changes throughout the codebase. Currently, field renaming within symbols is not supported.

Find References

Find all references to user-defined types like messages or enums. Nested fields are fully supported, making it easier to track symbol usage across your project.


🤝 Contributing

We welcome contributions from developers of all experience levels! To get started:

  1. Fork the repository and clone it to your local machine.
  2. Create a new branch for your feature or fix.
  3. Run the tests to ensure everything works as expected.
  4. Open a pull request with a detailed description of your changes.

Setting Up Locally

  1. Clone the repository:

    git clone https://github.com/coder3101/protols.git
    cd protols
  2. Build and test the project:

    cargo build
    cargo test

📄 License

This project is licensed under the MIT License. See the LICENSE file for more details.