Skip to content

Latest commit

 

History

History
119 lines (80 loc) · 5.4 KB

README.md

File metadata and controls

119 lines (80 loc) · 5.4 KB

Eohippus

CI Status

The Eohippus (a genus of small prehistoric horses) project contains some functionality for analysis of Pony programming language source code. It is written primarily in Pony itself.

The goals of this project are to eventually:

  • Provide tools for analysis of Pony programs, suitable for use in formatters, as well as editors that can use the Language Server Protocol.
  • Provide a front-end for incremental and parallelized Pony compilation.

The project is at a very early stage. Hardly any functionality is complete, but there exists enough to demonstrate some potential.

Various parts of the code may be vastly over- or under-engineered.

Documentation is quite minimal.

There is a basic test suite for the parser itself, but hardly anything else for other parts of the project.

The project contains the following parts:

Contains data structures for representing Pony code as an abstract syntax tree. Start with NodeWith.

This implements a Kiuatan parser for parsing Pony source files. It is a PEG parser (with left-recursion handling) and can recover from errors in functions or classes.

Start with Builder

Provides an actor that coordinates the analysis (currently parsing, rudimentary scope analysis, and linting) of a workspace containing Pony source files.

Provides an actor for detcting formatting problems in Pony ASTs, and fixing them.

Currently the linter only knows about the .editorconfig standard rule trim_trailing_whitespace.

A standalone executable that uses the linter to format Pony source files.

An implementation of the Language Server Protocol that uses Eohippus for analysis.

The language server is currently very minimal; it provides:

  • Document synchronization: tracks changes to open files
  • Diagnostics: provides information about parsing and linting errors.
  • Go to definition: can find definitions for identifiers, but only in a single file, nor can it correctly handle qualified identifiers. See #19, #20

There exists the beginnings of a Visual Studio Code extension that uses the language server. It is not published yet, but it can be used for debugging the parser, analyzer, and linter.

API Documentation

Some source code documentation is here.

Development

Working on Eohippus requires that you have ponyc and corral in your PATH. You can use the ponyup tool to manage these.

Building

On Unix:

  • make builds the unit tests on Unix; make config=debug for debug mode.
  • make test runs the unit tests.
  • make fmt to build the formatter (build/{release,debug}/eohippus-fmt).
  • make lsp to build the language server (build/{release,debug}/eohippus-lsp).

On Windows:

  • .\make.ps1 build -Target test builds the unit tests; .\make.ps1 build -Config debug -Target test for debug mode.
  • .\make.ps1 test runs the unit tests.
  • .\make.ps1 build -Target fmt builds the formatter (build\{release,debug}\eohippus-fmt.exe).
  • .\make.ps1 build -Target lsp builds the language server (build\{release,debug}\eohippus-lsp).

Formatter

Usage: build/release/eohippus-fmt [--verbose=false] [--fix=true] package_or_file

  • --verbose=true will print some information about what the formatter is doing.
  • --fix=true (the default) will modify source files to fix formatting problems.

Visual Studio Code Extension

In order to test the VSCode extension, you will need to build eohippus-lsp. You will also need to run npm install in the eohippus-vscode directory before your first use.

Then go to the "Run and Debug" pane in VSCode and run the Debug VSCode Extension configuration. This will open a new instance of VSCode that has the extension loaded, in a test folder that contains some example Pony files.

If the extension is working and can connect to the language server, you should see a folder called .eohippus appear in the test folder. This contains cached representations of the various stages of analysis.