2020-06-15 09:08:35 -07:00
|
|
|
## Set up your environment
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
To productively get going with Deno you should set up your environment. This
|
|
|
|
means setting up shell autocomplete, environmental variables and your editor or
|
|
|
|
IDE of choice.
|
|
|
|
|
|
|
|
### Environmental variables
|
|
|
|
|
|
|
|
There are several env vars that control how Deno behaves:
|
|
|
|
|
2020-05-26 12:12:07 +01:00
|
|
|
`DENO_DIR` defaults to `$HOME/.cache/deno` but can be set to any path to control
|
|
|
|
where generated and cached source code is written and read to.
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
`NO_COLOR` will turn off color output if set. See https://no-color.org/. User
|
|
|
|
code can test if `NO_COLOR` was set without having `--allow-env` by using the
|
|
|
|
boolean constant `Deno.noColor`.
|
|
|
|
|
|
|
|
### Shell autocomplete
|
|
|
|
|
|
|
|
You can generate completion script for your shell using the
|
|
|
|
`deno completions <shell>` command. The command outputs to stdout so you should
|
|
|
|
redirect it to an appropriate file.
|
|
|
|
|
|
|
|
The supported shells are:
|
|
|
|
|
|
|
|
- zsh
|
|
|
|
- bash
|
|
|
|
- fish
|
|
|
|
- powershell
|
|
|
|
- elvish
|
|
|
|
|
2020-06-15 21:39:17 +05:30
|
|
|
Example (bash):
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
```shell
|
2020-11-22 20:59:22 +05:30
|
|
|
deno completions bash | sudo tee /etc/bash_completion.d/deno.bash > /dev/null
|
|
|
|
source /etc/bash_completion.d/deno.bash
|
2020-05-07 00:21:13 +02:00
|
|
|
```
|
|
|
|
|
2020-11-22 20:59:22 +05:30
|
|
|
Example (zsh):
|
2020-08-10 09:20:29 +05:30
|
|
|
|
|
|
|
```shell
|
2020-11-22 20:59:22 +05:30
|
|
|
deno completions zsh | sudo tee /usr/local/share/zsh/site-functions/_deno
|
2020-08-10 09:20:29 +05:30
|
|
|
```
|
|
|
|
|
2020-11-22 20:59:22 +05:30
|
|
|
Example (fish):
|
2020-08-10 09:20:29 +05:30
|
|
|
|
|
|
|
```shell
|
2020-11-22 20:59:22 +05:30
|
|
|
deno completions fish > ~/.config/fish/completions/deno.fish
|
2020-08-10 09:20:29 +05:30
|
|
|
```
|
|
|
|
|
2020-09-10 05:13:30 -03:00
|
|
|
Example (Powershell):
|
|
|
|
|
2020-11-22 20:59:22 +05:30
|
|
|
```shell
|
2020-09-10 05:13:30 -03:00
|
|
|
deno completions powershell > $profile
|
|
|
|
.$profile
|
|
|
|
```
|
|
|
|
|
|
|
|
This will be create a Powershell profile at
|
|
|
|
`$HOME\Documents\WindowsPowerShell\Microsoft.PowerShell_profile.ps1` by default,
|
|
|
|
and it will be run whenever you launch the PowerShell.
|
|
|
|
|
2020-05-07 00:21:13 +02:00
|
|
|
### Editors and IDEs
|
|
|
|
|
|
|
|
Because Deno requires the use of file extensions for module imports and allows
|
2020-05-14 13:10:25 -05:00
|
|
|
http imports, and most editors and language servers do not natively support this
|
|
|
|
at the moment, many editors will throw errors about being unable to find files
|
|
|
|
or imports having unnecessary file extensions.
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
The community has developed extensions for some editors to solve these issues:
|
|
|
|
|
2020-05-17 19:24:39 +02:00
|
|
|
#### VS Code
|
|
|
|
|
|
|
|
The beta version of [vscode_deno](https://github.com/denoland/vscode_deno) is
|
|
|
|
published on the
|
2020-05-27 13:06:08 +08:00
|
|
|
[Visual Studio Marketplace](https://marketplace.visualstudio.com/items?itemName=denoland.vscode-deno).
|
2020-05-17 19:24:39 +02:00
|
|
|
Please report any issues.
|
|
|
|
|
|
|
|
#### JetBrains IDEs
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-05-26 19:11:08 +02:00
|
|
|
Support for JetBrains IDEs is available through
|
|
|
|
[the Deno plugin](https://plugins.jetbrains.com/plugin/14382-deno).
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-05-26 19:11:08 +02:00
|
|
|
For more information on how to set-up your JetBrains IDE for Deno, read
|
|
|
|
[this comment](https://youtrack.jetbrains.com/issue/WEB-41607#focus=streamItem-27-4160152.0-0)
|
|
|
|
on YouTrack.
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-05-17 19:24:39 +02:00
|
|
|
#### Vim and NeoVim
|
|
|
|
|
|
|
|
Vim works fairly well for Deno/TypeScript if you install
|
|
|
|
[CoC](https://github.com/neoclide/coc.nvim) (intellisense engine and language
|
2020-06-07 13:52:53 +02:00
|
|
|
server protocol).
|
|
|
|
|
|
|
|
After CoC is installed, from inside Vim, run`:CocInstall coc-tsserver` and
|
|
|
|
`:CocInstall coc-deno`. To get autocompletion working for Deno type definitions
|
|
|
|
run `:CocCommand deno.types`. Optionally restart the CoC server `:CocRestart`.
|
|
|
|
From now on, things like `gd` (go to definition) and `gr` (goto/find references)
|
|
|
|
should work.
|
2020-05-17 19:24:39 +02:00
|
|
|
|
2020-05-28 22:27:27 +02:00
|
|
|
#### Emacs
|
|
|
|
|
|
|
|
Emacs works pretty well for a TypeScript project targeted to Deno by using a
|
|
|
|
combination of [tide](https://github.com/ananthakumaran/tide) which is the
|
|
|
|
canonical way of using TypeScript within Emacs and
|
|
|
|
[typescript-deno-plugin](https://github.com/justjavac/typescript-deno-plugin)
|
|
|
|
which is what is used by the
|
|
|
|
[official VSCode extension for Deno](https://github.com/denoland/vscode_deno).
|
|
|
|
|
|
|
|
To use it, first make sure that `tide` is setup for your instance of Emacs.
|
|
|
|
Next, as instructed on the
|
|
|
|
[typescript-deno-plugin](https://github.com/justjavac/typescript-deno-plugin)
|
|
|
|
page, first `npm install --save-dev typescript-deno-plugin typescript` in your
|
|
|
|
project (`npm init -y` as necessary), then add the following block to your
|
|
|
|
`tsconfig.json` and you are off to the races!
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
"compilerOptions": {
|
|
|
|
"plugins": [
|
|
|
|
{
|
|
|
|
"name": "typescript-deno-plugin",
|
|
|
|
"enable": true, // default is `true`
|
|
|
|
"importmap": "import_map.json"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-05-07 00:21:13 +02:00
|
|
|
If you don't see your favorite IDE on this list, maybe you can develop an
|
2020-07-02 16:15:36 +03:00
|
|
|
extension. Our [community Discord group](https://discord.gg/deno) can give you
|
|
|
|
some pointers on where to get started.
|