Skip to main content

Language Server Protocol para Synesis v1.1

Project description

synesis-lsp

Real-time validation and language intelligence for Synesis projects.

A Language Server Protocol (LSP) implementation that brings the full power of the Synesis compiler into VS Code and any LSP-compatible editor — diagnostics, hover, completion, semantic tokens, relation graphs, and more.

PyPI version Python 3.10+ License: MIT

Copyright (c) 2011–2026 Christian Maciel de Britto https://github.com/synesis-lang · ORCID


What is synesis-lsp?

synesis-lsp is a protocol adapter, not a second parser. All validation is delegated entirely to the Synesis compiler — the server translates compiler output into LSP diagnostics and editor features. This means the language server and the CLI always agree: if synesis check passes, the editor shows no errors.

The result is a live editorial environment where ontological constraints, required fields, and relational rules are enforced as you type — with pedagogical error messages that explain why a construct is invalid, not just that it is.


Features

  • Real-time validation — syntax and semantic errors as you type, delegated to the Synesis compiler
  • Pedagogical diagnostics — clear explanations of template rules, REQUIRED/OPTIONAL, BUNDLE, ARITY
  • Semantic tokens — AST-driven syntax highlighting (not regex)
  • Document symbols — structured outline of SOURCE, ITEM, ONTOLOGY blocks
  • Hover documentation — field definitions, ontology entries, and template rules on hover
  • Completion — context-aware suggestions for codes, bibrefs, relation types, and field names
  • Inlay hints — inline field type annotations
  • Go-to-definition & Rename — for bibrefs and ontology codes, across files
  • Relation graph — Mermaid diagram of the current project's relational structure
  • Fuzzy matching — suggestions for mistyped bibrefs and codes
  • Full file type support.syn, .synp, .synt, .syno

Requirements

  • Python 3.10+
  • synesis compiler ≥ 0.5.5

Installation

pip install synesis
pip install synesis-lsp

From source:

git clone https://github.com/synesis-lang/synesis.git
git clone https://github.com/synesis-lang/synesis-lsp.git

pip install -e synesis
pip install -e synesis-lsp

Usage

Standalone server (STDIO)

python -m synesis_lsp

The server communicates via JSON-RPC over STDIO and is compatible with any LSP client.

VS Code

The Synesis Explorer extension manages the LSP server automatically. No manual configuration required — install the extension, open a Synesis project, and the server starts.

Workspace requirements

For full semantic validation, the workspace should contain:

File Role
*.synp Project file — required for full validation
*.synt Template referenced by .synp
*.bib BibTeX bibliography
*.syn Annotation files
*.syno Ontology files

Without a .synp, the LSP provides syntax validation and grammar keywords only — no template or ontology enforcement.


Architecture

┌─────────────┐
│   VS Code   │  (or any LSP client)
└──────┬──────┘
       │ JSON-RPC / STDIO
       ▼
┌──────────────────────────────────┐
│   synesis_lsp.server             │
│                                  │
│  Handlers: did_open, did_change  │
│  Providers: tokens · symbols     │
│             hover · completion   │
│             definition · inlay   │
│             signature · rename   │
│  Commands:  loadProject · stats  │
│             explorer · graph     │
└──────┬───────────────────────────┘
       │ delegates all validation to
       ▼
┌──────────────────────────────────┐
│   synesis.lsp_adapter            │
│   validate_single_file()         │
│   Context discovery              │
└──────┬───────────────────────────┘
       │
       ▼
┌──────────────────────────────────┐
│   synesis.compiler               │
│   Lark LALR(1) parser            │
│   Semantic validator             │
│   ValidationResult               │
└──────────────────────────────────┘

Design principle: this layer never re-implements parsing or semantics. If a diagnostic is incorrect, the issue is in the compiler — reproduce it with synesis check file.syn and report in the compiler issue tracker.


Custom LSP Commands

Cross-file features (hover, definition, completion, rename, graph) depend on the workspace cache loaded via synesis/loadProject.

Command Description
synesis/loadProject Load and cache the full project
synesis/getProjectStats Compilation statistics
synesis/getReferences All source references in scope
synesis/getCodes All ontology codes in scope
synesis/getRelations All declared relation types
synesis/getRelationGraph Mermaid diagram of project relations

Compatibility

Package Latest Requires synesis Python
synesis 0.6.0 ≥ 3.10
synesis-lsp 0.16.0 ≥ 0.5.5 ≥ 3.10
synesis-coder 0.4.1 ≥ 0.5.5 ≥ 3.10
synesis-graph 0.2.0 ≥ 0.5.5 ≥ 3.10

Troubleshooting

Error: Package 'synesis' not found

pip install synesis

LSP does not validate after editing

  1. Check logs: Output → Synesis LSP in VS Code
  2. Reload window: Ctrl+Shift+P → Reload Window
  3. Ensure .synp references the correct template and bibliography
  4. Look for log messages: Projeto Synesis carregado, Template carregado, Bibliografia carregada

Incorrect diagnostics

The LSP delegates all validation to the compiler. To isolate the issue:

synesis check your_file.syn

If the CLI also reports it, the issue is in the compiler — report it in the compiler repository. If the CLI passes but the LSP flags it, report in the LSP repository.


Development

pip install -e ".[dev]"
pytest tests/
pytest --cov=synesis_lsp tests/

Contributing guidelines:

  • This server is a protocol adapter — do not implement parsing or semantics here
  • All validation must use synesis.lsp_adapter.validate_single_file
  • Always convert SourceLocation (1-based) to LSP Range (0-based)
  • If you change error/result contracts, update INTERFACES.md and converters.py
  • Keep the server resilient: exceptions must become diagnostics, never crashes

Project Structure

synesis-lsp/
├── synesis_lsp/
│   ├── server.py            # LSP server (pygls)
│   ├── converters.py        # ValidationError → LSP Diagnostic
│   ├── cache.py             # Workspace cache
│   ├── semantic_tokens.py   # Semantic tokens
│   ├── symbols.py           # Document symbols
│   ├── hover.py             # Hover provider
│   ├── definition.py        # Go-to-definition
│   ├── completion.py        # Autocomplete
│   ├── inlay_hints.py       # Inlay hints
│   ├── graph.py             # Relation graph (Mermaid)
│   ├── rename.py            # Rename provider
│   └── explorer_requests.py # Custom explorer commands
├── tests/
├── INTERFACES.md            # Compiler ↔ LSP contracts
├── CHANGELOG.md
├── LICENSE
└── README.md

Intellectual Genealogy

synesis-lsp is part of the Synesis ecosystem. The compiler and language it serves are the formal culmination of a research and development trajectory spanning more than a decade. See the compiler README and the project's NOTICE file for the full intellectual genealogy and copyright notices for predecessor works.


License

MIT — see LICENSE.

A license change to AGPL-3.0-only (with Synesis Data Output Exception) is planned for an upcoming release, aligned with the compiler.


References


Author

Dr. Christian Maciel de Britto

GitHub · ORCID · Lattes

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

synesis_lsp-0.16.0.tar.gz (101.3 kB view details)

Uploaded Source

Built Distribution

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

synesis_lsp-0.16.0-py3-none-any.whl (89.3 kB view details)

Uploaded Python 3

File details

Details for the file synesis_lsp-0.16.0.tar.gz.

File metadata

  • Download URL: synesis_lsp-0.16.0.tar.gz
  • Upload date:
  • Size: 101.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.9

File hashes

Hashes for synesis_lsp-0.16.0.tar.gz
Algorithm Hash digest
SHA256 9aa2a367ff247b8980102fa0df16a9eab7de500df9d7166db1b5033f37923339
MD5 2a7f13a858030fdd65be6fd636b40b35
BLAKE2b-256 774f299133c0d0cf2e26ae4ea9c0e18af2125973c8a82ec8b39bceee5e7353ea

See more details on using hashes here.

File details

Details for the file synesis_lsp-0.16.0-py3-none-any.whl.

File metadata

  • Download URL: synesis_lsp-0.16.0-py3-none-any.whl
  • Upload date:
  • Size: 89.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.9

File hashes

Hashes for synesis_lsp-0.16.0-py3-none-any.whl
Algorithm Hash digest
SHA256 573073fb4675567c151bd5d8c940795f634b37934ae5f495f8b73a55e487890a
MD5 677732dbcc2e2f9f0ac85c37d73cd047
BLAKE2b-256 c6dc2d892feecd238524e5347f5c007f510264c1dd2261b33bb4b0522e115247

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