Skip to content

Commit

Permalink
Release 0.3
Browse files Browse the repository at this point in the history
  • Loading branch information
swsnr committed Mar 13, 2014
1 parent b8178c1 commit d943149
Show file tree
Hide file tree
Showing 3 changed files with 48 additions and 3 deletions.
4 changes: 2 additions & 2 deletions CHANGES.rst
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@

.. role:: kbd(literal)

0.3 (in development)
--------------------
0.3 (Mar 13, 2014)
------------------

This version is the first release under new maintenance.

Expand Down
2 changes: 1 addition & 1 deletion puppet-mode.el
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
;; Sebastian Wiesner <[email protected]>
;; URL: https://github.com/lunaryorn/puppet-mode
;; Keywords: languages
;; Version: 0.3-cvs
;; Version: 0.3
;; Package-Requires: ((emacs "24.1") (cl-lib "0.5") (pkg-info "0.4"))

;; This file is not part of GNU Emacs.
Expand Down
45 changes: 45 additions & 0 deletions relnotes/0.3.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
This is the first release from the new Puppet Mode maintainers @bbatsov and @lunaryorn.

We forked Puppet Mode about half a year ago, to fix many outstanding issues, and improve the mode to work better with modern Emacsen. It took us longer than expected to bring the mode into shape, but now we are finally there.

Changes
=======

New commands
------------

This release adds a bunch of brand-new commands to work on Puppet manifests:

- <kbd>C-c C-j</kbd>: Jump to definition of classes, resources and variables (powered by the **new Imenu support**)
- <kbd>C-M-a</kbd> and <kbd>C-M-e</kbd>: Move to the beginning and end of the current block
- <kbd>C-c C-a</kbd>: Align parameters in the current block (powered by the new **builtin alignment rules**)
- <kbd>C-c C-v</kbd>, <kbd>C-c C-l</kbd>, <kbd>C-c C-c</kbd>: Validate (with `puppet parser validate`), lint (with `puppet-lint`) and apply (with `puppet apply`) the current manifest

Font lock
---------

We completely rewrote the fontification code. Puppet Mode now fontifies more expressions than before:

- All keywords and built-in functions from Puppet 3.4
- Variable declarations and references
- Variable expansions in double-quoted and single-quoted strings (the latter with `font-lock-warning-face`, to make aware of a possible mistake)
- Variable references in comments, if you set the new option `puppet-fontify-variables-in-comments` to a non-nil value.
- Special escape sequences in double quoted strings
- Regular expression literals
- Built-in metaparameters
- The negation operator
- Class, node and type definitions
- Resource declarations, references and collectors

We also fixed a number of outstanding issues. Notably, Puppet Mode understands C-style comments, and will no longer highlight the names of built-in types or functions in parameters.

Roadmap
=======

This release is the first major step to bring Puppet Mode into a decent shape, but we are far from complete. We currently lack any unit tests, so your immediate focus is now on improving the test coverage to make sure that we never break Puppet Mode for you.

The indentation code also needs a lot of work. Currently Puppet Mode still uses the imperative ad-hoc indentation code we inherited from Puppetlabs Inc. We plain to rewrite indentation based on SMIE, the powerful indentation and navigation engine in Emacs 24. Hopefully this fixes many broken corner-cases and hiccups of the current imperative indentation code we inherited from Puppetlabs Inc.

Beyond these immediate steps we are open for suggestions and contributions to improve the mode and add new features. If you have any idea, please share your thoughts!

Enjoy this release!

0 comments on commit d943149

Please sign in to comment.