1
0
mirror of https://github.com/nvbn/thefuck.git synced 2025-01-31 02:01:13 +00:00

Add python 2 support

This commit is contained in:
nvbn 2015-04-17 16:24:03 +02:00
parent 282217fd02
commit 2eb777a5bb
9 changed files with 19 additions and 15 deletions

View File

@ -1,6 +1,8 @@
language: python
python:
- "3.4"
- "3.3"
- "2.7"
install:
- python setup.py develop
- pip install -r requirements.txt

View File

@ -52,7 +52,7 @@ Did you mean this?
Install `The Fuck`:
```bash
sudo pip3 install thefuck
sudo pip install thefuck
```
And add to `.bashrc` or `.zshrc`:
@ -66,8 +66,8 @@ alias fuck='$(thefuck $(fc -ln -1))'
Install `The Fuck` for development:
```bash
pip3 install -r requirements.txt
python3 setup.py develop
pip install -r requirements.txt
python setup.py develop
```
Run tests:

View File

@ -1 +1,2 @@
pytest
mock

View File

@ -11,5 +11,6 @@ setup(name='thefuck',
packages=find_packages(exclude=['ez_setup', 'examples', 'tests']),
include_package_data=True,
zip_safe=False,
install_requires=['pathlib'],
entry_points={'console_scripts': [
'thefuck = thefuck.main:main']})

View File

@ -1,6 +1,6 @@
from unittest.mock import patch, Mock
import pytest
from subprocess import PIPE
from mock import patch, Mock
import pytest
from thefuck.rules.no_command import match, get_new_command
from thefuck.main import Command

View File

@ -1,6 +1,6 @@
from unittest.mock import patch, Mock
from subprocess import PIPE
from pathlib import PosixPath, Path
from mock import patch, Mock
from thefuck import main

0
thefuck/__init__.py Normal file
View File

View File

@ -10,7 +10,7 @@ Command = namedtuple('Command', ('script', 'stdout', 'stderr'))
Rule = namedtuple('Rule', ('match', 'get_new_command'))
def setup_user_dir() -> Path:
def setup_user_dir():
"""Returns user config dir, create it when it doesn't exists."""
user_dir = Path(expanduser('~/.thefuck'))
if not user_dir.is_dir():
@ -20,7 +20,7 @@ def setup_user_dir() -> Path:
return user_dir
def get_settings(user_dir: Path):
def get_settings(user_dir):
"""Returns prepared settings module."""
settings = load_source('settings',
str(user_dir.joinpath('settings.py')))
@ -29,7 +29,7 @@ def get_settings(user_dir: Path):
return settings
def is_rule_enabled(settings, rule: Path) -> bool:
def is_rule_enabled(settings, rule):
"""Returns `True` when rule mentioned in `rules` or `rules`
isn't defined.
@ -37,23 +37,23 @@ def is_rule_enabled(settings, rule: Path) -> bool:
return settings.rules is None or rule.name[:-3] in settings.rules
def load_rule(rule: Path) -> Rule:
def load_rule(rule):
"""Imports rule module and returns it."""
rule_module = load_source(rule.name[:-3], str(rule))
return Rule(rule_module.match, rule_module.get_new_command)
def get_rules(user_dir: Path, settings) -> [Rule]:
def get_rules(user_dir, settings):
"""Returns all enabled rules."""
bundled = Path(__file__).parent\
.joinpath('rules')\
.glob('*.py')
user = user_dir.joinpath('rules').glob('*.py')
return [load_rule(rule) for rule in list(bundled) + list(user)
if is_rule_enabled(settings, rule)]
if rule.name != '__init__.py' and is_rule_enabled(settings, rule)]
def get_command(args: [str]) -> Command:
def get_command(args):
"""Creates command from `args` and executes it."""
script = ' '.join(args[1:])
result = Popen(script, shell=True, stdout=PIPE, stderr=PIPE)
@ -61,14 +61,14 @@ def get_command(args: [str]) -> Command:
result.stderr.read().decode())
def get_matched_rule(command: Command, rules: [Rule], settings) -> Rule:
def get_matched_rule(command, rules, settings):
"""Returns first matched rule for command."""
for rule in rules:
if rule.match(command, settings):
return rule
def run_rule(rule: Rule, command: Command, settings):
def run_rule(rule, command, settings):
"""Runs command from rule for passed command."""
new_command = rule.get_new_command(command, settings)
print(new_command)

View File