mirror of
https://github.com/nvbn/thefuck.git
synced 2025-01-18 20:11:17 +00:00
Merge pull request #598 from josephfrazier/git_add_force
Add git_add_force rule
This commit is contained in:
commit
4748776296
@ -166,6 +166,7 @@ using the matched rule and runs it. Rules enabled by default are as follows:
|
||||
* `fix_file` – opens a file with an error in your `$EDITOR`;
|
||||
* `gem_unknown_command` – fixes wrong `gem` commands;
|
||||
* `git_add` – fixes *"pathspec 'foo' did not match any file(s) known to git."*;
|
||||
* `git_add_force` – adds `--force` to `git add <pathspec>...` when paths are .gitignore'd;
|
||||
* `git_bisect_usage` – fixes `git bisect strt`, `git bisect goood`, `git bisect rset`, etc. when bisecting;
|
||||
* `git_branch_delete` – changes `git branch -d` to `git branch -D`;
|
||||
* `git_branch_exists` – offers `git branch -d foo`, `git branch -D foo` or `git checkout foo` when creating a branch that already exists;
|
||||
|
22
tests/rules/test_git_add_force.py
Normal file
22
tests/rules/test_git_add_force.py
Normal file
@ -0,0 +1,22 @@
|
||||
import pytest
|
||||
from thefuck.rules.git_add_force import match, get_new_command
|
||||
from tests.utils import Command
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def stderr():
|
||||
return ('The following paths are ignored by one of your .gitignore files:\n'
|
||||
'dist/app.js\n'
|
||||
'dist/background.js\n'
|
||||
'dist/options.js\n'
|
||||
'Use -f if you really want to add them.\n')
|
||||
|
||||
|
||||
def test_match(stderr):
|
||||
assert match(Command('git add dist/*.js', stderr=stderr))
|
||||
assert not match(Command('git add dist/*.js'))
|
||||
|
||||
|
||||
def test_get_new_command(stderr):
|
||||
assert get_new_command(Command('git add dist/*.js', stderr=stderr)) \
|
||||
== "git add --force dist/*.js"
|
13
thefuck/rules/git_add_force.py
Normal file
13
thefuck/rules/git_add_force.py
Normal file
@ -0,0 +1,13 @@
|
||||
from thefuck.utils import replace_argument
|
||||
from thefuck.specific.git import git_support
|
||||
|
||||
|
||||
@git_support
|
||||
def match(command):
|
||||
return ('add' in command.script_parts
|
||||
and 'Use -f if you really want to add them.' in command.stderr)
|
||||
|
||||
|
||||
@git_support
|
||||
def get_new_command(command):
|
||||
return replace_argument(command.script, 'add', 'add --force')
|
Loading…
x
Reference in New Issue
Block a user