From 4d0388b53cf452ba5e7acbccb833d41cdddd97b1 Mon Sep 17 00:00:00 2001 From: Joseph Frazier <1212jtraceur@gmail.com> Date: Sat, 28 Jan 2017 13:18:23 -0500 Subject: [PATCH] Add git_add_force rule MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This adds `--force` to `git add` when needed. For example: $ git add dist/*.js The following paths are ignored by one of your .gitignore files: dist/app.js dist/background.js dist/options.js Use -f if you really want to add them. $ fuck git add --force dist/app.js dist/background.js dist/options.js [enter/↑/↓/ctrl+c] $ --- README.md | 1 + tests/rules/test_git_add_force.py | 22 ++++++++++++++++++++++ thefuck/rules/git_add_force.py | 13 +++++++++++++ 3 files changed, 36 insertions(+) create mode 100644 tests/rules/test_git_add_force.py create mode 100644 thefuck/rules/git_add_force.py diff --git a/README.md b/README.md index 292431fd..4b179e8b 100644 --- a/README.md +++ b/README.md @@ -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 ...` 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; diff --git a/tests/rules/test_git_add_force.py b/tests/rules/test_git_add_force.py new file mode 100644 index 00000000..abe2bd79 --- /dev/null +++ b/tests/rules/test_git_add_force.py @@ -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" diff --git a/thefuck/rules/git_add_force.py b/thefuck/rules/git_add_force.py new file mode 100644 index 00000000..9adc0725 --- /dev/null +++ b/thefuck/rules/git_add_force.py @@ -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')