Skip to main content

A language server for zc.buildout

Project description

A Language Server for zc.buildout.

This language server is implemented using pygls.

Installation

Standalone

Needs a python >= 3.7.

python -m pip install zc.buildout.languageserver

Then configure your editor to run buildoutls ( or python3 -m buildoutls ).

From vscode extension

On activation, the extension automatically installs the extension on the python configured in the extension preferences.

The automatic installation does not seem to work with theia and the python egg has to be installed beforehand.

Features

Completions

  • ${ complete sections.
  • ${section: complete section's options. If section uses a known recipe, dynamic options from the recipe are also completed.
  • ${buildout:extends} completes filenames.
  • ${buildout:parts} and <= option completes parts.

Diagnostics

  • non existant section and options in ${section:option} references.
  • required options not defined for a a few "known recipes".
  • python package listed in [versions] with known vulnerabilities

Symbols

  • Sections and options are shown are displayed in outline as symbols.

Links

  • ${buildout:extends} are links.

Go to definitions

  • from ${section:options} we can go to the location where option is defined in section, or to section header if it's not defined.
  • from <= section we can go to section.
  • from ${buildout:extends} we can go to the extended profile.

Hover

  • Hover on an option show the option value.

Find references

  • Find references of the current symbol. A bit simple, it only look for references and does not check if profiles really extends each other. It does not look in templates either.

Code actions

  • update a python package from [versions] to its latest version on pypi
  • compute the md5sum of an url

Template support

  • "current" buildout profile is guessed, then completions and diagnostics should work on any files.

Jinja2 support

  • Jinja syntax is syntax highlighted and jinja syntax markers are ignored when parsing buildout.

SlapOS support

  • SlapOS instance buildout (ie. buildout generated by buildout) is understood, ${ and $${ are treated separatly for completions and diagnostics.

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

Unreleased

0.7.0 - 2022-01-06

Added:

  • code actions: report progress when updating md5sum
  • expose commands to start & stop profiling.

Fixed:

  • significantly improve performance by implementing .copy() method and using an intermediate cache.
  • fix crash when completing option made only of space
  • fix crash when completing after ${}

0.6.2 - 2022-01-06

Fixed:

  • fix a packaging mistake with the vscode extension

0.6.1 - 2022-01-04

Fixed:

  • fix problems with automatic publishing of packages

0.6.0 - 2022-01-04

Added:

  • diagnostic: report versions with known vulnerabilities
  • code action: update a python package listed in versions to latest version
  • code action: view a python package page on pypi
  • code action: compute md5sum of an url

Removed

  • support for python 3.6, minimal supported version is now 3.7

Fixed:

  • completions: don't offer completions in comments
  • fix performance issues by cancelling pending tasks actually the fix was wrong

0.5.0 - 2021-03-28

Added:

  • diagnostic: warn when options are redefining the current value
  • completions: complete existing options of current sections
  • diagnostic: support recipes with arbitrary options (like slapos.recipe.build)
  • diagnostic: report error when existing non existant profiles

Fixed:

  • stop emitting false positives diagnostics with multi line jinja
  • stop emitting false positives diagnostics for missing sections/options when extending dynamic profile
  • fixed "add line comment" action

0.4.0 - 2020-10-08

Fixed:

  • don't skip lines containing jinja expressions. This was causing some missing options when jinja was used in option
  • diagnostic: tolerate unknown part when extends jinja

0.3.0 - 2020-02-23

Added:

  • support http URLs in ${buildout:extends}

0.2.1 - 2020-04-25

Fixed

  • references: consider listing a section in ${buildout:parts} as a reference.
  • completions: use textEdit to properly overwrite exiting text.
  • all: debounce protocol functions to accept cancellations.
  • all: fix errors when opening profiles outside of workspace.

0.2.0 - 2020-02-12

Added:

  • support running with buildout < 2.9.3
  • initial support of instance.cfg defined using slapos.recipe.template:jinja2

Fixed

  • fixed broken v0.1.1 release, it could not be installed from pypi.
  • diagnostics: prevent "missing required options" false positive on sections used only as macros.
  • diagnostic: Correctly analyze sections with . or - in their names
  • diagnostic: Fix false positives on ${buildout:parts} with extended sections
  • diagnostic: Fix false positives on ${buildout:parts} when dynamically adding parts with jinja.

0.1.1 - 2020-01-30

Added

  • definitions: paths from ${buildout:extends} can also be opened with jump to definition.
  • completions: fix insertText with -.
  • diagnostics: detect missing non existant sections listed in ${buildout:parts}.
  • diagnostics: detect sections without recipe listed in ${buildout:parts}.

0.1.0 - 2020-01-04

  • Initial Version

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

zc.buildout.languageserver-0.7.0.tar.gz (39.9 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file zc.buildout.languageserver-0.7.0.tar.gz.

File metadata

File hashes

Hashes for zc.buildout.languageserver-0.7.0.tar.gz
Algorithm Hash digest
SHA256 5b11520aaa7e0e23c94d37d570ca36a7b4721b6b7472f4ca616af73b55d58d97
MD5 ce83525e876952be0933ec76220ac03f
BLAKE2b-256 9b8fcbea4390200b06fb92c143fbe182288a9aa0139769158f785c3801003b69

See more details on using hashes here.

File details

Details for the file zc.buildout.languageserver-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for zc.buildout.languageserver-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1e5ed2d0baea84ae6fb14dc94fe6e8841dd47221a64f929bee083786242942af
MD5 2e421e4407813e712755bdcdd7b888bf
BLAKE2b-256 d23db1da5774c0869777d69b0c9c1b28fca013b13b90d312a67fb6080b9e49c0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page