Skip to content

Marks staged lines in the gutter and allows moving partial hunks back and forth

License

Notifications You must be signed in to change notification settings

artarf/git-diff-staged

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Git Diff Staged package

Marks staged lines in the gutter and allows moving partial hunks back and forth.

Fixes some issues in other packages that rely on atom.GitRepository.onDidChangeStatuses() (tree-view and git-diff for example). It does not detect all status changes, but this package notifies it of every missing index change.

Installation

apm install git-diff-staged

Styles

This plugin extends styles in core package git-diff. Visual distinction is implemented only with no icons (Show Icons In Editor Gutter disabled), i.e. with the left borders and small triangles.

Staged changes are indicated with dotted left borders. Staged deletions are marked by changing the color of the triangle.

Inconsistencies between index and current file are marked with white color and dotted thinner border. You can see this when you stage a change and then undo it. You can correct these by toggling the staged state.

Commands

  • git-diff-staged:toggle-selected

    Adds all changed lines within selection to index, unless all changed lines already are in index, in which case they are removed from index. If selection contains no changes, staged or not, nothing is done.

  • git-diff-staged:toggle-hunk-at-cursor

    Similar to toggle-selected, instead of selected lines this variation uses the hunk surrounding cursor, if there are changes at that position.

vim-mode-plus stuff

Operator to toggle staging status for a movement

  • git-diff-staged:toggle-staged

TextObjects to operate with e.g. toggle-staged Operator. Both work identically.

  • git-diff-staged:inner-hunk
  • git-diff-staged:a-hunk

Motions to move forward/backward by hunk(s)

  • git-diff-staged:move-to-next-hunk
  • git-diff-staged:move-to-previous-hunk

Note that you don't need to save the file to modify the index.

Keys

No default keymap provided.

Example keymap:

'atom-workspace atom-text-editor':
  'ctrl-alt-shift-cmd-s': 'git-diff-staged:toggle-selected'
  'ctrl-alt-shift-cmd-h': 'git-diff-staged:toggle-hunk-at-cursor'

# vim-mode-plus:

'atom-text-editor.vim-mode-plus.operator-pending-mode, atom-text-editor.vim-mode-plus.visual-mode':
  'i h': 'git-diff-staged:inner-hunk'
  'a h': 'git-diff-staged:a-hunk'

'atom-workspace atom-text-editor:not([mini]):not(.insert-mode).vim-mode-plus':
  'g s s': 'git-diff-staged:toggle-staged'
  'g s j': 'git-diff-staged:move-to-next-hunk'
  'g s k': 'git-diff-staged:move-to-previous-hunk'

Caveats

Indicator of modified lines makes no difference for lines that are not in index and lines that are in index but are different from the current buffer.

Configuration

You may customize the git command path with git-diff-staged.gitPath. If you are using git-plus package, it's configuration git-plus.general.gitPath is used (unless you want to override it).

By default preceding deletions are included when the first line to staged is a modification. You can prevent that with git-diff-staged.ignorePrecedingDeletion.

Contributing

I'd like to keep this package as simple as possible so new features are critically observed. Creating an issue before creating a pull request is good practice.

Particularly help with styles is greatly appreciated. I don't have the necessary skills to get good defaults that work with various themes.

About

Marks staged lines in the gutter and allows moving partial hunks back and forth

Resources

License

Stars

Watchers

Forks

Packages

No packages published