mirror of
				https://github.com/nvbn/thefuck.git
				synced 2025-10-31 07:04:12 +00:00 
			
		
		
		
	Merge pull request #598 from josephfrazier/git_add_force
Add git_add_force rule
This commit is contained in:
		| @@ -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`; | * `fix_file` – opens a file with an error in your `$EDITOR`; | ||||||
| * `gem_unknown_command` – fixes wrong `gem` commands; | * `gem_unknown_command` – fixes wrong `gem` commands; | ||||||
| * `git_add` – fixes *"pathspec 'foo' did not match any file(s) known to git."*; | * `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_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_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; | * `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') | ||||||
		Reference in New Issue
	
	Block a user