Skip to content

Latest commit

 

History

History
317 lines (209 loc) · 9.54 KB

README.md

File metadata and controls

317 lines (209 loc) · 9.54 KB

VSCode Extension for Crystal Language

This extension provides support for The Crystal programming language.

crystal icon

1. Features

  • Snippets
  • Formatting
  • Problems finder
  • Document Symbols
  • Syntax highlighting
  • Show variable type on Hover
  • Show and Peek Implementations
  • Increment and decrements indentation
  • Method completion for Literals and Symbols

2. Requirements

You need Crystal installed in your system to get compiler features like goTo implementation and diagnostics.

Other features like syntax highlighting, snippets, symbols and basic completion work without Crystal compiler.

3. Configuration

crystal-lang provides some useful configuration inside settings.json:

{
  "crystal-lang.problems": "syntax",
  "crystal-lang.maxNumberOfProblems": 10,
  "crystal-lang.mainFile": "",
  "crystal-lang.processesLimit": 3,
  "crystal-lang.implementations": true,
  "crystal-lang.completion": true,
  "crystal-lang.types": true,
  "crystal-lang.server": "",
  "crystal-lang.logLevel": "error"
}

On Windows the document must use LF instead of CRLF to allow symbols completion.

3.1. Problems

crystal-lang.problems allow setting different error levels. By default, the problem finder just check syntax errors. The options are:

problem finder

  • syntax: check syntax and tokens (default).
  • build: check requires, objects and methods without code gen (resource heavy).
  • none: disable problem finder.
{
  "crystal-lang.problems": "syntax | build | none",
}

Problems are checked when a crystal document is opened or saved.

Syntax checking is activated on type allowing live diagnostics.

Features like implementations and show type on hover can find errors.

3.2. PoblemsLimit

crystal-lang.maxNumberOfProblems allow to limit the amount of problems that appears in problems view.

The default value is 20.

3.3. MainFile

crystal-lang.mainFile says to the compiler which file should analyze.

It is useful when "crystal-lang.problems" = "build" in projects where a main file do require "/**"

Also is used by features like implementations and show type on hover to specify the tool scope.

Be sure that mainFile is a valid absolute filepath.

{
  "crystal-lang.mainFile": "/absolute/path/src/main.cr",
}

3.4. ProcessesLimit

This extension block the amout of crystal processes executing in parallel to reduce resources usage.

Commonly crystal takes milliseconds to do something like formatting, but in some projects other features like implementations or completion can take a moment. To prevent using too many resources you can set the amount of processes with:

{
  "crystal-lang.processesLimit": 3,
}

By default, is 3. In my computer each crystal process uses almost 50 MB and less than 1 second.

3.5. Implementations

You can use this feature to peek or go to implementation of a method.

implementations

3.6. Completion

This setting ensure to enable instance method completion using crystal tool context.

Suggestion of methods and subtypes while typing is not supported. You need to type . (dot) or :: (colons) and then press CTRL + SPACE or CMD + SPACE to call method suggestion.

instance method completion

String methods

Basic code completion is always enabled. (Top Level, Symbols and Snippets)

subtypes completion

File methods

However, you can totally disable completions in settings.json:

{
  "editor.quickSuggestions": {
    "other": true,
    "comments": false,
    "strings": false
  }
}

3.7. Types

Show type information for variables only. This feature uses crystal tool context to get types. Information is recalculated when the cursor changes line position.

types on hover

3.8. Server (NEW)

It's Experimental feature using Scry and Language Server Protocol.

Reload your editor after enable this feature.

Scry

The following features are implemented:

  • Formatting
  • Live Diagnostics
  • GoTo Definition
  • Peek Definition

Scry server isn't distributed with this extension. You need to compile it from scry-vscode-crystal-lang and configure on settings.json

{
  "crystal-lang.server": "/absolute/path/bin/scry",
}

3.9. LogLevel

Controls the amount of data logged by Scry server.

You can see logs in .scry.out located in your home directory or your workspace.

Levels avaliables:

{
  "type": "string",
  "default": "error",
  "enum": [
    "debug",
    "info",
    "warn",
    "error",
    "fatal"
  ]
}

4. Messages

Sometimes in some projects, crystal tool turns heavy, in this case you can check error and info messages.

Errors and info messages are shown in developer tools:

  • ERROR: spawn: when crystal program not exist in path or mainFile is wrong.
  • ERROR: JSON parse: when crystal output is different of JSON.
  • INFO: processesLimit has been reached: your project is taking too much time to analyze.

The following images show crystal status bar messages:

crystal build

crystal tool context

crystal tool implementations

5. Know issues

  • Linter and formatter are implemented using Node.js child_process, so perfomance could be affected. You can use a different problem level.

  • macros can produce some unwanted behaviors, disable peek implementations, instance method completions and types on hover to hide errors.

  • ECR syntax is very basic. You can use vscode text.html instead or enable emmet for text.ecr in your settings.json:

{
  "emmet.syntaxProfiles": {
    "ecr": "html"
  }
}
  • In some big projects like crystal compiler itself, the setting "crystal-lang.problems" = "build" could be very unresponsible, use "syntax" instead.

  • Scry server is experimental, some bug can appear. Scry is a bit heavy, it uses from 5 Mb until 500Mb of RAM in my computer.

6. More Screenshots

6.1. Increment and decrement identation

identation

Decrement end keyword on type is now avaliable in vscode 1.14.

6.2. Formatting code support

formatting

6.3. Syntax highlighting

ecr

6.4. Snippets

snippets

6.5. Symbols

symbols

6.6. Code Outline (NEW)

Recent version of VSCode (1.13.1) allow to extensions creators show symbols in tree view. You can use the awesome Code Outline extension to see code tree of crystal document.

code outline

6.7. Debugging

Native Debug is an excelent extension that allow you to debug crystal and other languages that compile to binary.

Be sure of compile your crystal code with --debug flag

Native Debug extension

6.8. Icon theme

You can use the wonderful Nomo Dark icon theme to see crystal icon.

Nomo Dark icon theme

7. Roadmap

  • Translate Crystal syntax from .tmLanguage to .json.
  • Full Support for Language Server Protocol, see Scry

8. Release Notes

See Changelog

9. Contributing

  1. Fork it https://github.com/faustinoaq/vscode-crystal-lang/fork
  2. Create your feature branch git checkout -b my-new-feature
  3. Commit your changes git commit -am 'Add some feature'
  4. Push to the branch git push origin my-new-feature
  5. Create a new Pull Request

10. Contributors