The Fuck - Shell 命令行扩展


MIT
Linux
Python

软件简介

开发者都或多或少接触过 linux 接触过命令行,当然肯定也都被命令行狠狠地“fuck”过。我很多时候都是微不足道的原因导致了命令行出错,例如将
python 输入成 ptyhon,例如将 ls -alh 输入成 ls a-lh而导致出错,这个时候我会想说:“fuck”。

起源

开发 thefuck 的这位同仁,恐怕也经常会有这种不和谐的情况。因此开发了这个软件 thefuck。

thefuck 不仅仅能修复字符输入顺序的错误,在很多别的你想说“fuck”的情况下,thefuck 依然有效。

例如以下情况。

案例

任何情况下你想说“我操”,你都可以用得到 thefuck。

例如:

ls 和 sl

使用过 ubuntu 的开发者很多都知道有这么一条命令:sl。这条命令是在你将 ls 错误地输成 sl 时,会在屏幕上快速驶过一辆火车。当然,有了
thefuck,sl 似乎也可以退休了。

➜ sl
The program 'sl' is currently not installed. You can install it by typing:
sudo apt-get install sl
➜ fuck
ls #修正
a.go                   b.php           dockerui      jekyll-casper  main.go  PureBlog   sss.png                              typecho
a.php                  c-hash          Font-Awesome  jekyll-pure    mili     signal.c   TeamTalk                             upload
bii-ubuntu-64_3_0.deb  Dockerfile      harmony       JekyllPure     ngircd   signal.c~  tingyun-agent-php-latest.x86_64.deb  web.goblog                   Dockerfile.bak  hashmap       kasper         php-src  sss.jpg    tipi                                 zerver

忘记 sudo

➜ apt-get install vim
E: Could not open lock file /var/lib/dpkg/lock - open (13: Permission denied)
E: Unable to lock the administration directory (/var/lib/dpkg/), are you root?

➜ fuck
sudo apt-get install vim
[sudo] password for nvbn:
Reading package lists... Done

操作 git

➜ git pushfatal: The current branch master has no upstream branch.
To push the current branch and set the remote as upstream, use

    git push --set-upstream origin master


➜ fuck
git push --set-upstream origin master
Counting objects: 9, done.
...

错输命令

➜ puthon
No command 'puthon' found, did you mean:
 Command 'python' from package 'python-minimal' (main)
 Command 'python' from package 'python3' (main)
zsh: command not found: puthon

➜ fuck
python
Python 3.4.2 (default, Oct  8 2014, 13:08:17)
...

选项修正

➜ git brnchgit: 'brnch' is not a git command. See 'git --help'.

Did you mean this?
    branch

➜ fuck
git branch
* master

其他

thefuck 还有其他很多种用法,就等着你去发现。

安装

安装需求

  • python (2.7+ or 3.3+)

  • pip

  • python-dev

安装方法

  1. 可以使用 pip 安装:sudo pip install thefuck
    或者使用 OS X、Ubuntu、Arch
    的包管理器安装

  2. 安装后配置
    bash:

    alias fuck='eval $(thefuck $(fc -ln -1)); history -r'
    

Zsh、Fish 和 PowerShell 的 配置方法见这里

更新

更新到最新的 thefuck 的方法非常简单:

sudo pip install thefuck --upgrade

其他

软件原理

前面说了那么多用法,
那么有人觉得 thefuck 可能只是一个用来
thefuck 进行命令修复的模块名和对应的修复原理如下:

  1. brew_unknown_command:修复 brew 命令,例如将 brew docto 修复为 brew doctor

  2. cd_parent:将 cd.. 修正为 cd ..

  3. cd_mkdir:cd 进入不存在的目录时尝试创建目录。

  4. cp_omitting_directory:cp 时添加 -a 选项

  5. fix_alt_space:将所有的的Alt+Space修正为Space

  6. git_add:修正没有 git add 的情况。

  7. git_checkout:git checkout 不存在的分支之前尝试创建分支。

  8. git_no_command:修正错误的选项,例如 git brnch

  9. git_push:如果 push 失败,尝试将 git push 修正为 git push --set-upstream origin $branch

  10. has_exists_script:为所有的提示不存在的命令尝试添加 ./ 前缀。

  11. lein_not_task:修正 lein,例如 lein rpl

  12. mkdir_p:mkdir 时尝试添加 -p 选项。

  13. no_command:修正不存在的命令,例如 vom 修正为 vim

  14. man_no_space:将没有空格的 man 命令添加空格,例如 mandiff 修正为 man diff

  15. pacman:arch 系统上,如果使用没有安装的软件,尝试使用 pacman 或者 yaourt 安装。

  16. pip_unknown_command:修正错误的 pip 命令,例如 pip isntall 修正为 pip install

  17. python_command:当前目录试图执行没有 x 权限的 python 程序时,修复为添加 python 前缀

  18. sl_ls:sl 修正为 ls

  19. rm_dir:如果删除文件夹,为 rm 添加 -rf 选项。

  20. ssh_known_hosts:如果远程主机公钥不匹配,尝试将远程主机公钥从 know_hosts 中移除。

  21. sudo:如果提示没有权限,尝试添加 sudo

  22. switch_layout:将键盘布局修正为英语布局。

  23. apt_get:如果不存在命令,尝试使用 apt-get 包管理器安装。

  24. brew_install:修正 brew install 的格式。

  25. composer_not_command:修正 composer 命令。

没有启用的模块:

  1. ls_lah:为 ls 添加 -alh 选项。

  2. rm_root:为 rm -rf / 添加 --no-preserve-root 选项。

自定义规则

当然,你也可以自定义修正规则
一个自定义规则的案例:

def match(command, settings):
    return ('permission denied' in command.stderr.lower()            or 'EACCES' in command.stderr)# 获取 stderr 中的字符串和程序返回值(errno),# 修正规则(命令前添加 sudo)def get_new_command(command, settings):
    return 'sudo {}'.format(command.script)# 以下为可选项# 默认是否开启enabled_by_default = True# 附加命令def side_effect(command, settings):
    subprocess.call('chmod 777 .', shell=True)# 优先级,数字越大优先级越低。priority = 1000

使用须知

虽然 thefuck 带来了很多便利,不过仍然建议注意这件事情:

thefuck 会给出的修正后的命令,但是默认情况下你看到它们的时候,命令都已经默认执行了。
大部分情况下,thefuck 可能给出的是正确的修正,但是小部分情况下,给出的修正并不是你想要的。
所以建议将 ~/.thefuck/settings.py 中的设置改为 require_confirmation = True,这样可以自己决定是否执行修正后的命令。

介绍内容来自 segmentfault