Puppet Mode lets you edit Puppet 3 manifests with GNU Emacs 24.
Puppet Mode is a major mode for GNU Emacs 24 which adds support for the Puppet language. Puppet is a system provisioning and configuration tool by Puppetlabs Inc. This mode supports Puppet 3 and later. Puppet 2 is not explicitly supported anymore, but should mostly work.
This mode needs GNU Emacs 24. It will not work with GNU Emacs 23 and below, or with other flavors of Emacs (e.g. XEmacs).
- Syntax highlighting
- Indentation and alignment of expressions and statements
- Tag navigation (aka
imenu
) - Manual validation and linting of manifests (see Flycheck for on-the-fly validation and linting)
- Integration with Puppet Debugger
- Skeletons for many standard Puppet statements and resource declarations
From MELPA or MELPA Stable with M-x package-install RET
puppet-mode. Users of Debian ≥11 and derivatives can sudo apt install elpa-puppet-mode
. Manifest validation and linting support is
enabled by installing the elpa-flycheck
package.
In your Cask
file:
(source melpa)
(depends-on "puppet-mode")
Just visit Puppet manifests. The major mode is enabled automatically for Puppet
manifests with the extension .pp
.
The following key bindings are available in Puppet Mode:
Key | Command |
---|---|
C-M-a | Move to the beginning of the current block |
C-M-e | Move to the end of the current block |
C-c C-a | Align parameters in the current block |
C-c C-' | Toggle string quoting between single and double |
C-c C-; | Blank the string at point |
C-c C-j | Jump to a class , define , variable or resource |
C-c C-c | Apply the current manifest in dry-run mode |
C-c C-v | Validate the syntax of the current manifest |
C-c C-l | Check the current manifest for semantic issues |
C-c C-z | Launch a puppet-debugger REPL |
C-c C-r | Send the currently marked region to the REPL |
C-c C-b | Send the current buffer to the REPL |
C-c C-k c | Insert class definition skeleton |
C-c C-k d | Insert define definition skeleton |
C-c C-k n | Insert node definition skeleton |
C-c C-k i | Insert if statement skeleton |
C-c C-k e | Insert elsif statement skeleton |
C-c C-k o | Insert else statement skeleton |
C-c C-k u | Insert unless statement skeleton |
C-c C-k s | Insert case statement skeleton |
C-c C-k ? | Insert selector statement skeleton |
C-c C-t a | Insert anchor resource skeleton |
C-c C-t c | Insert class resource skeleton |
C-c C-t e | Insert exec resource skeleton |
C-c C-t f | Insert file resource skeleton |
C-c C-t g | Insert group resource skeleton |
C-c C-t h | Insert host resource skeleton |
C-c C-t n | Insert notify resource skeleton |
C-c C-t p | Insert package resource skeleton |
C-c C-t s | Insert service resource skeleton |
C-c C-t u | Insert user resource skeleton |
For the integration with puppet-debugger to work, the puppet-debugger gem needs
to be installed and available in your $PATH
.
See the instructions on
puppet-debugger's repository on how to install it.
Use M-x customize-group RET puppet
to customize Puppet Mode.
Feel free to ask question or make suggestions in our issue tracker.
Puppet Mode is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
Puppet Mode is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
See COPYING
for the complete license.