clarity-lsp 0.4.0

Clarity Language Server
clarity-lsp-0.4.0 is not a library.

clarity-lsp

Clarity is a decidable smart contract language that optimizes for predictability and security, designed by Blockstack. Smart contracts allow developers to encode essential business logic on a blockchain.

A programming language is decidable if you can know, with certainty, from the code itself what the program will do. Clarity is intentionally Turing incomplete as it avoids Turing complexity. This allows for complete static analysis of the entire call graph of a given smart contract. Further, our support for types and type checker can eliminate whole classes of bugs like unintended casts, reentrancy bugs, and reads of uninitialized values.

The Language Server Protocol (LSP) defines the protocol used between an editor or IDE and a language server that provides language features like auto complete, go to definition, find all references etc.

This project aims at leveraging the decidability quality of Clarity and the LSP for providing some great insights about your code, without publishing your smart contracts to a blockchain.

screenshot

Quick Start

VSCode

This is the best supported editor at the moment. clarity-lsp plugin for VS Code is maintained in tree. You can install the latest release of the plugin from the marketplace.

Building From Source

Alternatively, both the server and the plugin can be installed from source.

The first step is to ensure that you have Rust and the support software installed.

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

From there, you can clone this repository:

git clone https://github.com/lgalabru/clarity-lsp.git

cd clarity-lsp

Then build and install:

cargo xtask install

Initial feature set

  • Auto-complete native functions
  • Check contract on save, and display errors inline.
  • VS-Code support

Additional desired features (not exhaustive, not prioritized)

  • Inline documentation
  • Auto-complete user defined functions
  • Return and display cost analysis
  • Resolve contract-call targeting local contracts
  • Resolve contract-call targeting deployed contracts
  • Support for traits
  • Support for multiple errors
  • Supporting more editors (vim, emacs, atom, etc)