FStarLang/fstar-mode.el@6e5d3ea858 -> FStarLang/fstar-mode.el@36ffb46259 ProofGeneral/PG@d668946929 -> ProofGeneral/PG@e0ec3db200 Wilfred/helpful@4ba24cac9f -> Wilfred/helpful@5ad8a9ce57 agda/agda@3344ca8058 -> agda/agda@10a0ca0516 bastibe/org-journal@17b34ce8df -> bastibe/org-journal@115b9c0354 beancount/beancount-mode@452621fa1f -> beancount/beancount-mode@ddd4b87257 clojure-emacs/cider@f00e83d338 -> clojure-emacs/cider@a0d6169026 crystal-lang-tools/emacs-crystal-mode@ea89b108fa -> crystal-lang-tools/emacs-crystal-mode@d913fea6f0 emacs-ess/ESS@c72b911d70 -> emacs-ess/ESS@0eb240bcb6 emacs-geiser/geiser@74eed1669a -> emacs-geiser/geiser@c1c27072a4 emacs-lsp/lsp-haskell@6981f8d122 -> emacs-lsp/lsp-haskell@b2edf1a9f8 emacs-lsp/lsp-metals@6a6a345a8a -> emacs-lsp/lsp-metals@567089f7f4 emacs-rustic/rustic@e5c0271f1e -> emacs-rustic/rustic@fbbf0a7192 emacs-straight/auctex@f00256cbfd -> emacs-straight/auctex@53f80ba36c emacs-straight/org-mode@5a4686915e -> emacs-straight/org-mode@ff33d9ec2e emacs-typescript/typescript.el@dd10f702d4 -> emacs-typescript/typescript.el@481df3ad2c emacsorphanage/dart-mode@02e919c1cf -> emacsorphanage/dart-mode@88b6683f43 emacsorphanage/macrostep@44faf4f7bf -> emacsorphanage/macrostep@d0928626b4 erlang/otp@3e7f126fe4 -> erlang/otp@64185e73b0 fuxialexander/org-pdftools@4e420233a1 -> fuxialexander/org-pdftools@5613b7ae56 greghendershott/racket-mode@f2645aadd2 -> greghendershott/racket-mode@eef5e9ab2c hakimel/reveal.js@e15cf92ccd -> hakimel/reveal.js@2059d388f7 haskell/haskell-mode@1a285fc4c5 -> haskell/haskell-mode@7f452cc9e6 joaotavora/sly@742355f755 -> joaotavora/sly@c48defcf58 jorgenschaefer/emacs-buttercup@bf01a33f8b -> jorgenschaefer/emacs-buttercup@c467c659b2 jrblevin/markdown-mode@e100778594 -> jrblevin/markdown-mode@ee9d6de1d2 js-emacs/js2-refactor.el@a0977c4ce1 -> js-emacs/js2-refactor.el@e1177c728a kaushalmodi/ox-hugo@98421a1298 -> kaushalmodi/ox-hugo@e3365cb4e6 ljos/jq-mode@a0f79eba78 -> ljos/jq-mode@eeb86b4d5a magit/orgit@59d21fdb21 -> magit/orgit@3b6b34bd11 nonsequitur/inf-ruby@dad78a13f1 -> nonsequitur/inf-ruby@b8076aad10 ocaml/dune@098117d229 -> ocaml/dune@b74586e909 ocaml/merlin@3a806ef87f -> ocaml/merlin@92c3ba9473 oer/org-re-reveal@ab1422c163 -> oer/org-re-reveal@88e9d9e679 org-roam/org-roam@cad3518788 -> org-roam/org-roam@0037daaf3e purescript-emacs/purescript-mode@07e4d6ecfe -> purescript-emacs/purescript-mode@b076bafe94 pythonic-emacs/anaconda-mode@f900bd7656 -> pythonic-emacs/anaconda-mode@5c6eff4645 pythonic-emacs/company-anaconda@169252fca7 -> pythonic-emacs/company-anaconda@0f7984b3be pythonic-emacs/pyenv-mode@76787ea44f -> pythonic-emacs/pyenv-mode@f7d53796d6 seagle0128/grip-mode@df0ba7589d -> seagle0128/grip-mode@ffce7f78eb swift-emacs/swift-mode@ab189d6e89 -> swift-emacs/swift-mode@2c0b2b72dc technomancy/fennel-mode@3632cc77de -> technomancy/fennel-mode@4ccb6d5944 weijiangan/flycheck-golangci-lint@91c59b128a -> weijiangan/flycheck-golangci-lint@424ba1b3a1
:lang dart
Description unfold
Dart is a client-optimized language by Google for fast apps on any platform. It is fast and optimized for UI, famous for the Flutter framework, also made by Google. Both Flutter and Dart are free and open-source.
This module wraps dart-mode
, with LSP features like code completion for
.dart
files, syntax highlighting, debugging, closing labels, etc.
Maintainers
Module flags
- +flutter
-
Enable
flutter
integration and some sane defaults for Flutter development along withhover
for desktop development. - +lsp
-
Enable LSP support for
dart-mode
. Requires doom-module::tools lsp and a langserver (supports flutter).
Hacks
No hacks documented for this module.
TODO Changelog
This module does not have a changelog yet.
Installation
Enable this module in your doom!
block.
Make sure that the Dart SDK is on your $PATH
, and if using Flutter, make sure
the Flutter binary is on your $PATH
as well.
Installing Dart SDK
Before starting note that Flutter SDK will have a version of Dart. Therefore, there is no need to install Dart. If you want to use Flutter just see the next part.
The stable version of the SDK is in most major distributions repositories. If you find it necessary to install any other version or build from source, please refer to the official website at: https://dart.dev/get-dart
-
On Debian (also Ubuntu and its derivations):
apt-get install dart
-
On Arch Linux (and derivations like Manjaro):
pacman -S dart
-
On macOS:
brew tap dart-lang/dart brew install dart
-
On NixOS:
nix-env -iA nixpkgs.dart
Installing Flutter SDK
Due to complications with permissions, it is suggested not to use AUR or any automatic installation tools for Flutter SDK.
On any system just run the following commands to install Flutter, once you have met dependencies named on the site:
git clone https://github.com/flutter/flutter --branch stable # to download Flutter
export PATH="$PATH:$(pwd)/flutter/bin" # to add it to PATH
flutter doctor # for Dependency check and further instructions
TODO Usage
This module's usage documentation is incomplete. Complete it?
- Syntax highlighting and formatting for
.dart
files provided by LSP or doom-module::editor format. - Auto import.
- Widget guide lines for Flutter.
- Closing labels for constructors.
- Run tests interactively.
- Outline support via doom-package:lsp-treemacs.
- Emacs functions for running and debugging Flutter projects.
TODO Configuration
This module's configuration documentation is incomplete. Complete it?
Dart & Flutter
On Linux, the installers for Dart and Flutter use the /opt
directory, and this
module assumes that. However, you may set lsp-dart-sdk-dir
to your Dart
install directory and flutter-sdk-path
to you flutter SDK folder, to make sure
LSP can find the language server included with the Dart SDK.
Alternatively, these variables shouldn't be necessary if you just include Dart
and Flutter on your PATH
variable.
Android
You will also need to setup your system for Android development if you intend to
use Flutter to develop mobile applications. Refer to your distributions package
manager for details. In most distributions the /opt/android-sdk
directory is
used, and you might have to change some permissions in this directory since it's
owned by root. The Arch Linux wiki has a great guide on this here.
Flutter mobile development on desktop
Hover is an application that can run Flutter mobile apps on your desktop, this makes the mobile development a lot easier without the need to setup an Android emulator.
Troubleshooting
See the configuration section for information on the binaries for Dart and
Flutter. On new installs to the /opt
directory, you will likely need to edit
the permissions of the /opt/dart-sdk
and /opt/flutter
directories (not to
mention the Android SDK, as discussed above).
Frequently asked questions
This module has no FAQs yet. Ask one?
TODO Appendix
This module has no appendix yet. Write one?