92

GitHub - emacs-helm/helm-ls-git: Yet another helm to list git file.

 5 years ago
source link: https://github.com/emacs-helm/helm-ls-git
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

README.md

License GPL 3 MELPA MELPA Stable

helm-ls-git

Yet another helm for listing the files in a git repo.

Features:

  • Display the open buffers in project.

  • Display a status source showing state of project (modified files etc...).

  • Display a list of all files in project under git control.

  • Allow looking quickly at diff on modified files.

  • Allow switching to git status with your prefered frontend (vc-dir, magit,etc...)

  • Full integration of git-grep, allow also usage of helm-grep (you can use ack-grep instead of grep).

  • Integrate usage of gid from id-utils.

  • Full integration with helm-find-files, allow you to browse project unrelated to current-buffer.

  • In addition, all actions of type files and buffers are provided.

Installation

  • We assume that you have git installed and that OSX users have solved any $PATH issues that prevent them being able to call git from emacs.

  • Ensure you are running at least >= Emacs-24.3.

  • Install helm according to the instructions on its repo page

  • If you are using the MELPA package manager then M-x list-packages and install helm-ls-git.

  • Or, if you are using el-get then invoke M-x el-get-install and at the Install package: prompt type helm-ls-git and hit enter.

  • Otherwise, clone this repo and put helm-ls-git.el somewhere on the emacs load-path.

  • Finally, add to your .emacs.el:

Assuming you are already using helm and it is installed properly (See Install helm)

(require 'helm-ls-git)

And then bind the command helm-ls-git-ls to a keybinding of your choice; for example:

(global-set-key (kbd "C-<f6>") 'helm-ls-git-ls)

Or even better use M-x helm-browse-project or bind it to a key, for example:

(global-set-key (kbd "C-x C-d") 'helm-browse-project)

If you are using helm-find-files you will be able to browse any git repo unrelated to the current-buffer: M-x helm-find-files navigate to some git repo and hit C-x C-d

If you want to use the helm-ls-git sources somewhere else, you can build them individually with functions helm-ls-git-build-git-status-source, helm-ls-git-build-buffers-source and helm-ls-git-build-ls-git-source.

As these sources are built with their own classes, they can be configured with defmethod helm-setup-user-source, see FAQ.

Usage

  • By calling helm-ls-git-ls or helm-browse-project in any buffer that is a part of a git repo (or if you have navigated to a git repo from helm-find-files), you will be presented with a corresponding helm buffer containing a list of all the files currently in that same repository. In the usual helm style you can just type at the prompt in the minibuffer and see the results narrow according to the input of your search pattern.

  • When the helm-buffer is active and displaying results, the user can invoke C-] to toggle between showing filenames or full pathnames for the data that helm is listing.


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK