This project implements a language server for Zeek script.
This is alpha-quality software, especially regarding type resolution. While it already now provides useful results, not all of Zeek script is resolved; we do however strive to either correctly resolve symbols or not at all, i.e., if a result is presented it should be correct.
In order to see symbols from Zeek system scripts, Zeek needs to be installed
and zeek-config
should be in PATH
.
For optional formatting support
zeek-format
should be in PATH
.
The server interprets the following initializationOptions
:
-
check_for_updates
(default:true
): Whether to check for newer releases during startup -
enable_filewatcher
(default:false
): Whether to watch the filesystem for out-of-band changes to known files -
inlay_hints_parameters
(default:true
): Whether to show inlay hints for function call parameters -
inlay_hints_variables
(default:true
): Whether to show inlay hints for variable declarations -
references
(default:false
): Whether to enable Go To References. -
rename
(default:false
): Whether to enable Rename. -
semantic_highlighting
(default:true
) Enable semantic highlighting. -
debug_ast_nodes
(default:false
) Enable debug output of AST nodes on hoverWARNING: Since typically Zeek scripts have incomplete
@load
statements the provided list is very likely incomplete. Use a tool likegrep
to search for all references of an identifier.
We provide a minimal extension for vscode which is published to the vscode marketplace. Additionally, an extension VSIX file is created for each release. On startup the extension will automatically download the server binary for the release.
For installation instructions on Emacs, see here.
For installation instructions on JetBrains IDEs, see here.
We provide binaries for releases for x86_64 Darwin or Linux systems. You should then set up your client to use this binary. A list of editor plugins can be found e.g., here.
This project requires Rust to build which can be set up e.g., with rustup.
The project can then be installed with
# Also available in many distribution repositories.
cargo install tree-sitter-cli
# Install actual server.
cargo install --git https://github.com/bbannier/zeek-language-server.git
This installs a binary zeek-language-server
which provides the full server.
See these instructions for VS Code setup and the list of features (some of which are VS Code specific).
This server provides support for highlighting via tree-sitter highlighting
queries. To
tweak existing or for adding new queries one needs to edit the files in
crates/tree-sitter-zeek/vendor
,
and perform a bump of the submodule.