Skip to main content

A formatter for SPARQL queries

Project description

[!CAUTION] This Project is still in an early stage.
Only the format capability is production ready.
The rest is experimental.

Fichu 🦀

⚡A blazingly fast language server for SPARQL, written in Rust 🦀.

Getting Started

Installation

Fichu is available on crate.io:

cargo install fichu

And on PyPi:

pipx install fichu

You can also build it from source:

git clone https://github.com/IoannisNezis/sparql-language-server.git
cd sparql-language-server
cargo build --release --bin fichu

Usage

To run Fichu as formatter run:

fichu format <PATH>

To run Fichu as lanugage server run:

fichu server

This will create a language server listening on stdio.

Connect to Neovim

After you installed the language server, add this to your init.lua:

vim.api.nvim_create_autocmd({ 'FileType' }, {
  desc = 'Connect to sparql-language-server',
  pattern = { 'sparql' },
  callback = function()
    vim.lsp.start {
      name = 'fichu',
      cmd = { 'fichu', 'server' },
      root_dir = vim.fn.getcwd(),
      on_attach = function(client, bufnr)
        vim.keymap.set('n', '<leader>f', vim.lsp.buf.format, { buffer = bufnr, desc = 'LSP: ' .. '[F]ormat' })
      end,
    }
  end,
})

Open a .rq file and check that the buffer is attached to th server:

:checkhealth lsp

Configure keymaps in on_attach function.

Capabilities

Formatting

Status: Full support

Formats SPARQL queries to ensure consistent and readable syntax. Customizable options to align with preferred query styles are also implemented.

Diagnostics

Status: Partial support

Currently provides a few basic diagnostics for syntax errors and simple issues in SPARQL queries. Further enhancements are planned to cover a broader range of semantic and logic-related diagnostics.

Currently provided diagnostics:

  • unused namespace (warning): A declared namespace is not used
  • undefined namespace (error): A used namespace is not declared

Planed diagnostics:

  • path compresion possible (info): A declared namespace is not used

Completion

Status: Rudimentary

Basic auto-completion for SPARQL keywords and variables. Currently not context aware.
Future improvements will expand suggestions to include functions, predicates, and custom completions based on query context.

Code Actions

Status: Planed

Future support for code actions, such as quick fixes and refactoring suggestions, to improve productivity and code quality in SPARQL development.

Planed code actions:

  • Consolidate property paths
  • Refactor iris into namespaces
  • Sort Prefixes

Configuration

Fichu can be configured through a fichu.toml or fichu.yml file.

Here is the full default configuration

[format]
align_predicates = false
align_prefixes = false
separate_prolouge = true
capitalize_keywords = true
insert_spaces = true
tab_size = 2
where_new_line = true

use in web

If you want to connect from a web-based-editor, you can use this package as well.
For this purpouse this can be compiled to wasm and is availible on npm:

npm i @ioannisnezis/sparql-language-server

You will have to wrap this in a Web Worker and provide a language server client. There will be more documentation on this in the future...

Demo

In the mean time, check out the demo.

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

fichu-0.1.16.tar.gz (54.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fichu-0.1.16-py3-none-manylinux_2_34_x86_64.whl (2.1 MB view details)

Uploaded Python 3manylinux: glibc 2.34+ x86-64

File details

Details for the file fichu-0.1.16.tar.gz.

File metadata

  • Download URL: fichu-0.1.16.tar.gz
  • Upload date:
  • Size: 54.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: maturin/1.7.1

File hashes

Hashes for fichu-0.1.16.tar.gz
Algorithm Hash digest
SHA256 f4e2047dc0d2d068def391e1e286554dbd9fb460f80f1bb4173fd1c0e96de8b0
MD5 8adfd11ee989be4782eb625cf8c518e5
BLAKE2b-256 e54794a509a59b3134a03f192935147e7ea00c1f79c324a57392c9f7f990e4d1

See more details on using hashes here.

File details

Details for the file fichu-0.1.16-py3-none-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for fichu-0.1.16-py3-none-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 ae433520f55f0fc419c76270c6319723031bad254adbf2e7d65c16d1aeb6bef2
MD5 249951f77f6e079faac325bcf642a701
BLAKE2b-256 e0c345a7979407c53f36dadc68c60aaec340f5c29ebcaa5d24c99c296e39a71b

See more details on using hashes here.

Supported by

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