1===========
2IDE Plugins
3===========
4
5Emacs
6=====
7
8The ``Emacs`` plugin is maintained separately. Installation directions can be
9found here: https://github.com/paetzke/py-yapf.el
10
11VIM
12===
13
14The ``vim`` plugin allows you to reformat a range of code. Copy ``plugin`` and
15``autoload`` directories into your ~/.vim or use ``:packadd`` in Vim 8. Or use
16a plugin manager like Plug or Vundle:
17
18.. code-block:: vim
19
20     " Plug
21     Plug 'google/yapf', { 'rtp': 'plugins/vim', 'for': 'python' }
22
23     " Vundle
24     Plugin 'google/yapf', { 'rtp': 'plugins/vim' }
25
26
27You can add key bindings in the ``.vimrc`` file:
28
29.. code-block:: vim
30
31    map <C-Y> :call yapf#YAPF()<cr>
32    imap <C-Y> <c-o>:call yapf#YAPF()<cr>
33
34Alternatively, you can call the command ``YAPF``. If you omit the range, it
35will reformat the whole buffer.
36
37example:
38
39.. code-block:: vim
40
41    :YAPF       " formats whole buffer
42    :'<,'>YAPF  " formats lines selected in visual mode
43
44Sublime Text
45============
46
47The ``Sublime Text`` plugin is also maintained separately. It is compatible
48with both Sublime Text 2 and 3.
49
50The plugin can be easily installed by using *Sublime Package Control*. Check
51the project page of the plugin for more information:
52https://github.com/jason-kane/PyYapf
53
54===================
55git Pre-Commit Hook
56===================
57
58The ``git`` pre-commit hook automatically formats your Python files before they
59are committed to your local repository. Any changes ``yapf`` makes to the files
60will stay unstaged so that you can diff them manually.
61
62To install, simply download the raw file and copy it into your git hooks
63directory:
64
65.. code-block:: bash
66
67    # From the root of your git project.
68    curl -o pre-commit.sh https://raw.githubusercontent.com/google/yapf/master/plugins/pre-commit.sh
69    chmod a+x pre-commit.sh
70    mv pre-commit.sh .git/hooks/pre-commit
71
72==========
73Textmate 2
74==========
75
76Plugin for ``Textmate 2`` requires ``yapf`` Python package installed on your
77system:
78
79.. code-block:: shell
80
81    pip install yapf
82
83Also, you will need to activate ``Python`` bundle from ``Preferences >>
84Bundles``.
85
86Finally, create a ``~/Library/Application
87Support/TextMate/Bundles/Python.tmbundle/Commands/YAPF.tmCommand`` file with
88the following content:
89
90.. code-block:: xml
91
92    <?xml version="1.0" encoding="UTF-8"?>
93    <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
94    <plist version="1.0">
95    <dict>
96      <key>beforeRunningCommand</key>
97      <string>saveActiveFile</string>
98      <key>command</key>
99      <string>#!/bin/bash
100
101    TPY=${TM_PYTHON:-python}
102
103    "$TPY" "/usr/local/bin/yapf" "$TM_FILEPATH"</string>
104      <key>input</key>
105      <string>document</string>
106      <key>name</key>
107      <string>YAPF</string>
108      <key>scope</key>
109      <string>source.python</string>
110      <key>uuid</key>
111      <string>297D5A82-2616-4950-9905-BD2D1C94D2D4</string>
112    </dict>
113    </plist>
114
115You will see a new menu item ``Bundles > Python > YAPF``.
116