============================= Yet Another Snippet extension ============================= .. _Organizing Snippets: snippet-organization.html .. _Expanding Snippets: snippet-expansion.html .. _Writing Snippets: snippet-development.html .. _The YASnippet Menu: snippet-menu.html .. contents:: YASnippet is a template system for Emacs. It allows you to type a abbreviation and automatically expand the abbreviation into function templates. Bundled language templates includes: C, C++, C#, Perl, Python, Ruby, SQL, LaTeX, HTML, CSS and more. YASnippet system is inspired from TextMate's template system. You can use `a tool to import most TextMate templates to YASnippet. YASnippet is a re-write of the extension `smart-snippet`_. Both are original creations of `pluskid `_. .. _smart-snippet: http://code.google.com/p/smart-snippet/ Video Demo ========== .. youtube:: vOj7btx3ATg :align: right Watch the `demo at YouTube `_ (download a higher resolution version: `yasnippet.avi `_). Installation ============ There are two archives of YASnippet. One is a single file compiled “bundle”, and the other is normal. If all you need is to use the built-in templates, download the bundle one. If you want to add your own templates, download the normal one. Bundle Install -------------- 1. Download the latest ``yasnippet-bundle-x.y.z.el.tgz`` and unpack it. 2. You'll get a file named ``yasnippet-bundle.el``, put it under ``~/.emacs.d/plugins/`` (create the directory if not exists). 3. Open the file in Emacs, and type ``Alt+x eval-buffer``. That's it. Now open any one of your language file, you'll see a menu YASnippet. you can pull the menu to insert a template. Or, you can type the pre-defined abbrev and press ``TAB`` to expand it. To have Emacs load YASnippet automatically when it starts, put the following in your ``~/.emacs`` file: .. sourcecode:: common-lisp (add-to-list 'load-path "~/.emacs.d/plugins") (require 'yasnippet-bundle) Normal Install -------------- For full install of the normal archive, just download and unpack the latest ``yasnippet-x.y.z.tar.bz2``. You'll get a directory named ``yasnippet``, put it in your ``~/.emacs.d/plugins`` and add the following in your ``.emacs`` file: .. sourcecode:: common-lisp (add-to-list 'load-path "~/.emacs.d/plugins") (require 'yasnippet) ;; not yasnippet-bundle (yas/initialize) (yas/load-directory "~/.emacs.d/plugins/yasnippet/snippets") Please refer to the documentation for full customization, or use the customization group. How to use YASnippet ==================== Since version 0.6, YASnippet contains more functionality. You don't need to know all of it to use it successfully, but you it can improve your snippeting experience. Hence this section has been split into separate documents: 1. `Organizing Snippets`_ Describes ways to organize your snippets in the hard disk (or not organize them at all and just use ``yasnippet-bundle.el``. 2. `Expanding Snippets`_ Describes how YASnippet chooses snippets for expansion at point. Maybe, you'll want some snippets to be expanded in a particular mode, or only under certain conditions, or be prompted using ``ido``, etc... 3. `Writing Snippets`_ Describes the YASnippet definition syntax, which is very close (but not equivalent) to Textmate's. Includes a section about converting TextMate snippets. 4. `The YASnippet menu`_ Explains how to use the YASnippet menu to explore and learn new snippets. Bugs, Contribution and Support ============================== * If you find a bug, please report it at `Issue List `_. * If you have problem using YASnippet, or have some new ideas, including snippets, please post to the `discussion group`_. .. _discussion group: http://groups.google.com/group/smart-snippet .. _wish list: http://code.google.com/p/yasnippet/wiki/WishList Thank you very much for using YASnippet! .. LocalWords: YASnippet SQL LaTeX CSS yasnippet el eval html ido RET wiki