Skip to the content.

License GPL 3 MELPA MELPA Stable Build Status Patreon

Synopsis

Projectile is a project interaction library for Emacs. Its goal is to provide a nice set of features operating on a project level without introducing external dependencies (when feasible). For instance - finding project files has a portable implementation written in pure Emacs Lisp without the use of GNU find (but for performance sake an indexing mechanism backed by external commands exists as well).

Projectile tries to be practical - portability is great, but if some external tools could speed up some task substantially and the tools are available, Projectile will leverage them.

This library provides easy project management and navigation. The concept of a project is pretty basic - just a folder containing a special file or a directory. Currently git, mercurial, darcs and bazaar repos are considered projects by default. So are lein, maven, sbt, scons, rebar and bundler projects. If you want to mark a folder manually as a project just create an empty .projectile file in it. Some of Projectile’s features:

Here’s a glimpse of Projectile in action:

Projectile Screenshot

You can support my work on Projectile via PayPal, Patreon and Salt.

Quickstart

The instructions that follow are meant to get you from zero to a running Projectile setup in a minute. See the official manual for (way) more details.

Installation

package.el is the built-in package manager in Emacs.

Projectile is available on the two major package.el community maintained repos - MELPA Stable and MELPA.

You can install Projectile with the following command:

M-x package-install [RET] projectile [RET]

Alternatively, users of Debian 9 or later or Ubuntu 16.04 or later may simply apt-get install elpa-projectile.

Finally add this to your Emacs config:

(projectile-mode +1)
(define-key projectile-mode-map (kbd "s-p") 'projectile-command-map)
(define-key projectile-mode-map (kbd "C-c p") 'projectile-command-map)

Those keymap prefixes are just a suggestion. Feel free to put there whatever works best for you.

Basic Usage

Enable projectile-mode, open a file in one of your projects and type a command such as C-c p f.

See the user manual for more details.

Caveats

Known issues

Check out the project’s issue list a list of unresolved issues. By the way - feel free to fix any of them and sent me a pull request. :-)

Contributors

Here’s a list of all the people who have contributed to the development of Projectile.

Changelog

A fairly extensive changelog is available here.

License

Copyright © 2011-2019 Bozhidar Batsov and contributors.

Distributed under the GNU General Public License, version 3