projectile

Project Interaction Library for Emacs

Github星跟踪图

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
special file. 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:

  • jump to a file in project
  • jump to files at point in project
  • jump to a directory in project
  • jump to a file in a directory
  • jump to a project buffer
  • jump to a test in project
  • toggle between files with same names but different extensions (e.g. .h <-> .c/.cpp, Gemfile <-> Gemfile.lock)
  • toggle between code and its test (e.g. main.service.js <-> main.service.spec.js)
  • jump to recently visited files in the project
  • switch between projects you have worked on
  • kill all project buffers
  • replace in project
  • multi-occur in project buffers
  • grep in project
  • regenerate project etags or gtags (requires ggtags).
  • visit project in dired
  • run make in a project with a single key chord
  • check for dirty repositories
  • toggle read-only mode for the entire project

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

  • Some operations like search (grep) depend (presently) on external
    utilities such as find.

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-2020 Bozhidar Batsov and
contributors.

Distributed under the GNU General Public License, version 3

主要指标

概览
名称与所有者bbatsov/projectile
主编程语言Emacs Lisp
编程语言Emacs Lisp (语言数: 1)
平台
许可证GNU General Public License v3.0
所有者活动
创建于2011-07-31 19:12:31
推送于2025-06-18 09:11:49
最后一次提交2025-06-18 11:11:49
发布数26
最新版本名称v2.9.1 (发布于 )
第一版名称v0.1 (发布于 )
用户参与
星数4.1k
关注者数72
派生数584
提交数2.4k
已启用问题?
问题数1042
打开的问题数86
拉请求数734
打开的拉请求数4
关闭的拉请求数150
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?