Skip to content

Commit

Permalink
Updates to readmes (#419)
Browse files Browse the repository at this point in the history
* Updates to readmes

* Update Getting-Started.md

* Update Getting-Started.md

* Inlined Getting Started
  • Loading branch information
LPeter1997 authored Jul 29, 2024
1 parent c4c3846 commit 5aae0bd
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 29 deletions.
7 changes: 0 additions & 7 deletions Getting-Started.md

This file was deleted.

46 changes: 24 additions & 22 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,25 +15,27 @@
This is the repository for the work-in-progress compiler for the Draco programming language, a new .NET programming language under development. If you want further details on the language itself or want to contribute ideas, head over to the [language suggestions repository](https://github.com/Draco-lang/Language-suggestions).

### Try it out
You can either use the online [playground](https://playground.draco-lang.org/), or you can play with it locally, for that look at the [Getting started guide](Getting-Started.md).

### Roadmap

* Syntax analysis
* [x] Lexing
* [x] Parsing
* [x] Red-green trees
* Semantic analysis
* [x] Symbol resolution
* [x] Type checking
* [x] Type inference
* [x] Dataflow analysis
* Codegen
* [x] AST
* [x] Lowering
* [x] Custom IR
* [x] Writing IL
* [x] Writing PE
* Optimization
* [x] TCO
* [ ] Vectorization
You can either use the online [playground](https://playground.draco-lang.org/), or you can play with it locally. To install it from NuGet or right from source, look at the instructions below.

#### Installing the latest release from NuGet

Note, that this might not reflect the latest developments, as we don't release too frequently until we hit a stable point, which hopefully will be the 1.0 milestone.

0. First, you need to have the [.NET SDK](https://dotnet.microsoft.com/en-us/download) installed. The minimum required SDK version is the one the compiler targets, which is currently .NET 8.
1. Run `dotnet new install Draco.ProjectTemplates` in a terminal. This installs dotnet project templates for the Draco language.
2. Now, that you have project templates installed, you can run `dotnet new console --language draco` to create a new Draco project. This is a regular .NET project, you will find `yourprojectname.dracoproj` file and `main.draco` file there. The projectfile references the SDK and MSBuild will automatically pull this for you on the first run. If you really want, you can even skip installing the project templates by making a new projectfile and referencing `Sdk="Draco.Sdk/<version>"` there.
3. All of the usual `dotnet` commands should work as expected. You can build with `dotnet build`, or directly run with `dotnet run`.
4. If you want editor support for Draco, you can use our [VS Code](https://code.visualstudio.com/download) extension [Draco language support](https://marketplace.visualstudio.com/items?itemName=Draco-lang.draco-language-support). This extension adds syntax highlighting, error detection, go to definition, and other features to VS Code. Once you open any file with the `.draco` extension in VS Code, you will be prompted with a message to install the Draco language server. Click yes. This will install the language server as a global .NET tool. If you run, you will also be prompted if you want to install the debug adapter, allowing you to debug Draco programs from VS Code.

We also have an extension for [NeoVim](https://neovim.io/), you can find a tutorial on how to install it [here](https://github.com/Draco-lang/draco-nvim).

#### Installing from source

Installing everything from source should also be relatively easy, as we made PowerShell scripts that you can find in the `scripts` folder. If you are not on Windows, most of the script should be trivially executable by hand. We are still looking into how to make these scripts completely cross-platform without needing to duplicate them.

0. First, you need to have the [.NET SDK](https://dotnet.microsoft.com/en-us/download) installed. The minimum required SDK version is the one the compiler targets, which is currently .NET 8.
1. Run `install_toolchain.ps1` and specify a folder where you want to install the SDK. This will build and install the SDK into that location. For example, you can install it into the `examples` folder to run them on your source-built SDK.
2. If you want editor support, you can install the components with their respective scripts:
* Language Server: `install_langserver.ps1`
* Debug Adapter: `install_debugadapter.ps1`
* VS Code extension: `install_vscext.ps1`

0 comments on commit 5aae0bd

Please sign in to comment.