spacemacs/layers/+os/nixos/README.org
Aaron Zeng fdeb770103
[nixos] Add nixos-format-on-save (#14982)
* [nixos] Add nixos-format-on-save
2021-08-20 03:09:00 +00:00

51 lines
1.8 KiB
Org Mode

#+TITLE: NixOS layer
#+TAGS: layer|os
[[file:img/nixos.png]]
* Table of Contents :TOC_5_gh:noexport:
- [[#description][Description]]
- [[#features][Features:]]
- [[#install][Install]]
- [[#layer][Layer]]
- [[#format-on-save][Format on save]]
- [[#configuration][Configuration]]
- [[#key-bindings][Key bindings]]
- [[#nixos-options][NixOS Options]]
* Description
This layer adds tools for better integration of Emacs in NixOS.
** Features:
- Nix-mode using [[https://github.com/NixOS/nix-mode][nix-mode]]
- Automatic formatting via [[https://github.com/serokell/nixfmt][nixfmt]]
- Auto-completion of NixOS Options using [[https://github.com/travisbhartwell/nix-emacs/blob/master/company-nixos-options.el][company-nixos-options]]
- Helm Lookup for NixOS Options [[https://github.com/travisbhartwell/nix-emacs/blob/master/helm-nixos-options.el][helm-nixos-options]]
* Install
** Layer
To use this configuration layer, add it to your =~/.spacemacs=. You will need to
add =nixos= to the existing =dotspacemacs-configuration-layers= list in this
file.
** Format on save
To enable automatic formatting on save, set the layer variable
~nixos-format-on-save~ to ~t~:
#+begin_src elisp
(nixos :variables nixos-format-on-save t)
#+end_src
* Configuration
On some systems, =company-nixos-options= may be very slow. If this is the case,
see the section on disabling the [[https://github.com/syl20bnr/spacemacs/blob/develop/doc/DOCUMENTATION.org#disabling-layer-services-in-other-layers][disabling auto-complete]] for the =nixos= layer.
* Key bindings
** NixOS Options
| Key binding | Description |
|-------------+----------------------------|
| ~SPC h >~ | Call helm-nixos-options |
| ~SPC m = =~ | Format buffer using nixfmt |