Magnificent app which corrects your previous console command.

Related tags

python shell
Overview

The Fuck Version Build Status Coverage MIT License

The Fuck is a magnificent app, inspired by a @liamosaur tweet, that corrects errors in previous console commands.

Is The Fuck too slow? Try the experimental instant mode!

gif with examples

More examples:

➜ 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 [enter/↑/↓/ctrl+c]
[sudo] password for nvbn:
Reading package lists... Done
...
➜ git push
fatal: 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 [enter/↑/↓/ctrl+c]
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 [enter/↑/↓/ctrl+c]
Python 3.4.2 (default, Oct  8 2014, 13:08:17)
...
➜ git brnch
git: 'brnch' is not a git command. See 'git --help'.

Did you mean this?
    branch

➜ fuck
git branch [enter/↑/↓/ctrl+c]
* master
➜ lein rpl
'rpl' is not a task. See 'lein help'.

Did you mean this?
         repl

➜ fuck
lein repl [enter/↑/↓/ctrl+c]
nREPL server started on port 54848 on host 127.0.0.1 - nrepl://127.0.0.1:54848
REPL-y 0.3.1
...

If you're not afraid of blindly running corrected commands, the require_confirmation settings option can be disabled:

➜ 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
...

Contents

  1. Requirements
  2. Installations
  3. Updating
  4. How it works
  5. Creating your own rules
  6. Settings
  7. Third party packages with rules
  8. Experimental instant mode
  9. Developing
  10. License

Requirements

  • python (3.4+)
  • pip
  • python-dev
Back to Contents

Installation

On OS X, you can install The Fuck via Homebrew (or via Linuxbrew on Linux):

brew install thefuck

On Ubuntu / Mint, install The Fuck with the following commands:

sudo apt update
sudo apt install python3-dev python3-pip python3-setuptools
sudo pip3 install thefuck

On FreeBSD, install The Fuck with the following commands:

pkg install thefuck

On ChromeOS, install The Fuck using chromebrew with the following command:

crew install thefuck

On other systems, install The Fuck by using pip:

pip install thefuck

Alternatively, you may use an OS package manager (OS X, Ubuntu, Arch).

# It is recommended that you place this command in your .bash_profile, .bashrc, .zshrc or other startup script:

eval $(thefuck --alias)
# You can use whatever you want as an alias, like for Mondays:
eval $(thefuck --alias FUCK)

Or in your shell config (Bash, Zsh, Fish, Powershell, tcsh).

Changes are only available in a new shell session. To make changes immediately available, run source ~/.bashrc (or your shell config file like .zshrc).

To run fixed commands without confirmation, use the --yeah option (or just -y for short, or --hard if you're especially frustrated):

fuck --yeah

To fix commands recursively until succeeding, use the -r option:

fuck -r
Back to Contents

Updating

pip3 install thefuck --upgrade

Note: Alias functionality was changed in v1.34 of The Fuck

How it works

The Fuck attempts to match the previous command with a rule. If a match is found, a new command is created using the matched rule and executed. The following rules are enabled by default:

  • adb_unknown_command – fixes misspelled commands like adb logcta;
  • ag_literal – adds -Q to ag when suggested;
  • aws_cli – fixes misspelled commands like aws dynamdb scan;
  • az_cli – fixes misspelled commands like az providers;
  • cargo – runs cargo build instead of cargo;
  • cargo_no_command – fixes wrongs commands like cargo buid;
  • cat_dir – replaces cat with ls when you try to cat a directory;
  • cd_correction – spellchecks and correct failed cd commands;
  • cd_cs – changes cs to cd;
  • cd_mkdir – creates directories before cd'ing into them;
  • cd_parent – changes cd.. to cd ..;
  • chmod_x – add execution bit;
  • choco_install – append common suffixes for chocolatey packages;
  • composer_not_command – fixes composer command name;
  • conda_mistype – fixes conda commands;
  • cp_create_destination – creates a new directory when you attempt to cp or mv to a non existent one
  • cp_omitting_directory – adds -a when you cp directory;
  • cpp11 – adds missing -std=c++11 to g++ or clang++;
  • dirty_untar – fixes tar x command that untarred in the current directory;
  • dirty_unzip – fixes unzip command that unzipped in the current directory;
  • django_south_ghost – adds --delete-ghost-migrations to failed because ghosts django south migration;
  • django_south_merge – adds --merge to inconsistent django south migration;
  • docker_login – executes a docker login and repeats the previous command;
  • docker_not_command – fixes wrong docker commands like docker tags;
  • docker_image_being_used_by_container ‐ removes the container that is using the image before removing the image;
  • dry – fixes repetitions like git git push;
  • fab_command_not_found – fix misspelled fabric commands;
  • fix_alt_space – replaces Alt+Space with Space character;
  • 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_delete_checked_out – changes git branch -d to git checkout master && git branch -D when trying to delete a checked out branch;
  • 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_list – catches git branch list in place of git branch and removes created branch;
  • git_checkout – fixes branch name or creates new branch;
  • git_clone_git_clone – replaces git clone git clone ... with git clone ...
  • git_commit_amend – offers git commit --amend after previous commit;
  • git_commit_reset – offers git reset HEAD~ after previous commit;
  • git_diff_no_index – adds --no-index to previous git diff on untracked files;
  • git_diff_staged – adds --staged to previous git diff with unexpected output;
  • git_fix_stash – fixes git stash commands (misspelled subcommand and missing save);
  • git_flag_after_filename – fixes fatal: bad flag '...' after filename
  • git_help_aliased – fixes git help <alias> commands replacing with the aliased command;
  • git_hook_bypass – adds --no-verify flag previous to git am, git commit, or git push command;
  • git_lfs_mistype – fixes mistyped git lfs <command> commands;
  • git_merge – adds remote to branch names;
  • git_merge_unrelated – adds --allow-unrelated-histories when required
  • git_not_command – fixes wrong git commands like git brnch;
  • git_pull – sets upstream before executing previous git pull;
  • git_pull_clone – clones instead of pulling when the repo does not exist;
  • git_pull_uncommitted_changes – stashes changes before pulling and pops them afterwards;
  • git_push – adds --set-upstream origin $branch to previous failed git push;
  • git_push_different_branch_names – fixes pushes when local brach name does not match remote branch name;
  • git_push_pull – runs git pull when push was rejected;
  • git_push_without_commits – Creates an initial commit if you forget and only git add ., when setting up a new project;
  • git_rebase_no_changes – runs git rebase --skip instead of git rebase --continue when there are no changes;
  • git_remote_delete – replaces git remote delete remote_name with git remote remove remote_name;
  • git_rm_local_modifications – adds -f or --cached when you try to rm a locally modified file;
  • git_rm_recursive – adds -r when you try to rm a directory;
  • git_rm_staged – adds -f or --cached when you try to rm a file with staged changes
  • git_rebase_merge_dir – offers git rebase (--continue | --abort | --skip) or removing the .git/rebase-merge dir when a rebase is in progress;
  • git_remote_seturl_add – runs git remote add when git remote set_url on nonexistent remote;
  • git_stash – stashes your local modifications before rebasing or switching branch;
  • git_stash_pop – adds your local modifications before popping stash, then resets;
  • git_tag_force – adds --force to git tag <tagname> when the tag already exists;
  • git_two_dashes – adds a missing dash to commands like git commit -amend or git rebase -continue;
  • go_run – appends .go extension when compiling/running Go programs;
  • go_unknown_command – fixes wrong go commands, for example go bulid;
  • gradle_no_task – fixes not found or ambiguous gradle task;
  • gradle_wrapper – replaces gradle with ./gradlew;
  • grep_arguments_order – fixes grep arguments order for situations like grep -lir . test;
  • grep_recursive – adds -r when you try to grep directory;
  • grunt_task_not_found – fixes misspelled grunt commands;
  • gulp_not_task – fixes misspelled gulp tasks;
  • has_exists_script – prepends ./ when script/binary exists;
  • heroku_multiple_apps – add --app <app> to heroku commands like heroku pg;
  • heroku_not_command – fixes wrong heroku commands like heroku log;
  • history – tries to replace command with most similar command from history;
  • hostscli – tries to fix hostscli usage;
  • ifconfig_device_not_found – fixes wrong device names like wlan0 to wlp2s0;
  • java – removes .java extension when running Java programs;
  • javac – appends missing .java when compiling Java files;
  • lein_not_task – fixes wrong lein tasks like lein rpl;
  • long_form_help – changes -h to --help when the short form version is not supported
  • ln_no_hard_link – catches hard link creation on directories, suggest symbolic link;
  • ln_s_order – fixes ln -s arguments order;
  • ls_all – adds -A to ls when output is empty;
  • ls_lah – adds -lah to ls;
  • man – changes manual section;
  • man_no_space – fixes man commands without spaces, for example mandiff;
  • mercurial – fixes wrong hg commands;
  • missing_space_before_subcommand – fixes command with missing space like npminstall;
  • mkdir_p – adds -p when you try to create a directory without parent;
  • mvn_no_command – adds clean package to mvn;
  • mvn_unknown_lifecycle_phase – fixes misspelled life cycle phases with mvn;
  • npm_missing_script – fixes npm custom script name in npm run-script <script>;
  • npm_run_script – adds missing run-script for custom npm scripts;
  • npm_wrong_command – fixes wrong npm commands like npm urgrade;
  • no_command – fixes wrong console commands, for example vom/vim;
  • no_such_file – creates missing directories with mv and cp commands;
  • omnienv_no_such_command – fixes wrong commands for goenv, nodenv, pyenv and rbenv (eg.: pyenv isntall or goenv list);
  • open – either prepends http:// to address passed to open or create a new file or directory and passes it to open;
  • pip_install – fixes permission issues with pip install commands by adding --user or prepending sudo if necessary;
  • pip_unknown_command – fixes wrong pip commands, for example pip instatl/pip install;
  • php_s – replaces -s by -S when trying to run a local php server;
  • port_already_in_use – kills process that bound port;
  • prove_recursively – adds -r when called with directory;
  • python_command – prepends python when you try to run non-executable/without ./ python script;
  • python_execute – appends missing .py when executing Python files;
  • python_module_error – fixes ModuleNotFoundError by trying to pip install that module;
  • quotation_marks – fixes uneven usage of ' and " when containing args';
  • path_from_history – replaces not found path with similar absolute path from history;
  • react_native_command_unrecognized – fixes unrecognized react-native commands;
  • remove_shell_prompt_literal – remove leading shell prompt symbol $, common when copying commands from documentations;
  • remove_trailing_cedilla – remove trailing cedillas ç, a common typo for european keyboard layouts;
  • rm_dir – adds -rf when you try to remove a directory;
  • scm_correction – corrects wrong scm like hg log to git log;
  • sed_unterminated_s – adds missing '/' to sed's s commands;
  • sl_ls – changes sl to ls;
  • ssh_known_hosts – removes host from known_hosts on warning;
  • sudo – prepends sudo to previous command if it failed because of permissions;
  • sudo_command_from_user_path – runs commands from users $PATH with sudo;
  • switch_lang – switches command from your local layout to en;
  • systemctl – correctly orders parameters of confusing systemctl;
  • terraform_init.py – run terraform init before plan or apply;
  • test.py – runs py.test instead of test.py;
  • touch – creates missing directories before "touching";
  • tsuru_login – runs tsuru login if not authenticated or session expired;
  • tsuru_not_command – fixes wrong tsuru commands like tsuru shell;
  • tmux – fixes tmux commands;
  • unknown_command – fixes hadoop hdfs-style "unknown command", for example adds missing '-' to the command on hdfs dfs ls;
  • unsudo – removes sudo from previous command if a process refuses to run on super user privilege.
  • vagrant_up – starts up the vagrant instance;
  • whois – fixes whois command;
  • workon_doesnt_exists – fixes virtualenvwrapper env name os suggests to create new.
  • yarn_alias – fixes aliased yarn commands like yarn ls;
  • yarn_command_not_found – fixes misspelled yarn commands;
  • yarn_command_replaced – fixes replaced yarn commands;
  • yarn_help – makes it easier to open yarn documentation;
Back to Contents

The following rules are enabled by default on specific platforms only:

  • apt_get – installs app from apt if it not installed (requires python-commandnotfound / python3-commandnotfound);
  • apt_get_search – changes trying to search using apt-get with searching using apt-cache;
  • apt_invalid_operation – fixes invalid apt and apt-get calls, like apt-get isntall vim;
  • apt_list_upgradable – helps you run apt list --upgradable after apt update;
  • apt_upgrade – helps you run apt upgrade after apt list --upgradable;
  • brew_cask_dependency – installs cask dependencies;
  • brew_install – fixes formula name for brew install;
  • brew_reinstall – turns brew install <formula> into brew reinstall <formula>;
  • brew_link – adds --overwrite --dry-run if linking fails;
  • brew_uninstall – adds --force to brew uninstall if multiple versions were installed;
  • brew_unknown_command – fixes wrong brew commands, for example brew docto/brew doctor;
  • brew_update_formula – turns brew update <formula> into brew upgrade <formula>;
  • dnf_no_such_command – fixes mistyped DNF commands;
  • nixos_cmd_not_found – installs apps on NixOS;
  • pacman – installs app with pacman if it is not installed (uses yay or yaourt if available);
  • pacman_invalid_option – replaces lowercase pacman options with uppercase.
  • pacman_not_found – fixes package name with pacman, yay or yaourt.
  • yum_invalid_operation – fixes invalid yum calls, like yum isntall vim;

The following commands are bundled with The Fuck, but are not enabled by default:

  • git_push_force – adds --force-with-lease to a git push (may conflict with git_push_pull);
  • rm_root – adds --no-preserve-root to rm -rf / command.
Back to Contents

Creating your own rules

To add your own rule, create a file named your-rule-name.py in ~/.config/thefuck/rules. The rule file must contain two functions:

match(command: Command) -> bool
get_new_command(command: Command) -> str | list[str]

Additionally, rules can contain optional functions:

side_effect(old_command: Command, fixed_command: str) -> None

Rules can also contain the optional variables enabled_by_default, requires_output and priority.

Command has three attributes: script, output and script_parts. Your rule should not change Command.

Rules api changed in 3.0: To access a rule's settings, import it with from thefuck.conf import settings

settings is a special object assembled from ~/.config/thefuck/settings.py, and values from env (see more below).

A simple example rule for running a script with sudo:

def match(command):
    return ('permission denied' in command.output.lower()
            or 'EACCES' in command.output)


def get_new_command(command):
    return 'sudo {}'.format(command.script)

# Optional:
enabled_by_default = True

def side_effect(command, fixed_command):
    subprocess.call('chmod 777 .', shell=True)

priority = 1000  # Lower first, default is 1000

requires_output = True

More examples of rules, utility functions for rules, app/os-specific helpers.

Back to Contents

Settings

Several The Fuck parameters can be changed in the file $XDG_CONFIG_HOME/thefuck/settings.py ($XDG_CONFIG_HOME defaults to ~/.config):

  • rules – list of enabled rules, by default thefuck.const.DEFAULT_RULES;
  • exclude_rules – list of disabled rules, by default [];
  • require_confirmation – requires confirmation before running new command, by default True;
  • wait_command – max amount of time in seconds for getting previous command output;
  • no_colors – disable colored output;
  • priority – dict with rules priorities, rule with lower priority will be matched first;
  • debug – enables debug output, by default False;
  • history_limit – numeric value of how many history commands will be scanned, like 2000;
  • alter_history – push fixed command to history, by default True;
  • wait_slow_command – max amount of time in seconds for getting previous command output if it in slow_commands list;
  • slow_commands – list of slow commands;
  • num_close_matches – maximum number of close matches to suggest, by default 3.
  • excluded_search_path_prefixes – path prefixes to ignore when searching for commands, by default [].

An example of settings.py:

rules = ['sudo', 'no_command']
exclude_rules = ['git_push']
require_confirmation = True
wait_command = 10
no_colors = False
priority = {'sudo': 100, 'no_command': 9999}
debug = False
history_limit = 9999
wait_slow_command = 20
slow_commands = ['react-native', 'gradle']
num_close_matches = 5

Or via environment variables:

  • THEFUCK_RULES – list of enabled rules, like DEFAULT_RULES:rm_root or sudo:no_command;
  • THEFUCK_EXCLUDE_RULES – list of disabled rules, like git_pull:git_push;
  • THEFUCK_REQUIRE_CONFIRMATION – require confirmation before running new command, true/false;
  • THEFUCK_WAIT_COMMAND – max amount of time in seconds for getting previous command output;
  • THEFUCK_NO_COLORS – disable colored output, true/false;
  • THEFUCK_PRIORITY – priority of the rules, like no_command=9999:apt_get=100, rule with lower priority will be matched first;
  • THEFUCK_DEBUG – enables debug output, true/false;
  • THEFUCK_HISTORY_LIMIT – how many history commands will be scanned, like 2000;
  • THEFUCK_ALTER_HISTORY – push fixed command to history true/false;
  • THEFUCK_WAIT_SLOW_COMMAND – max amount of time in seconds for getting previous command output if it in slow_commands list;
  • THEFUCK_SLOW_COMMANDS – list of slow commands, like lein:gradle;
  • THEFUCK_NUM_CLOSE_MATCHES – maximum number of close matches to suggest, like 5.
  • THEFUCK_EXCLUDED_SEARCH_PATH_PREFIXES – path prefixes to ignore when searching for commands, by default [].

For example:

export THEFUCK_RULES='sudo:no_command'
export THEFUCK_EXCLUDE_RULES='git_pull:git_push'
export THEFUCK_REQUIRE_CONFIRMATION='true'
export THEFUCK_WAIT_COMMAND=10
export THEFUCK_NO_COLORS='false'
export THEFUCK_PRIORITY='no_command=9999:apt_get=100'
export THEFUCK_HISTORY_LIMIT='2000'
export THEFUCK_NUM_CLOSE_MATCHES='5'
Back to Contents

Third-party packages with rules

If you'd like to make a specific set of non-public rules, but would still like to share them with others, create a package named thefuck_contrib_* with the following structure:

thefuck_contrib_foo
  thefuck_contrib_foo
    rules
      __init__.py
      *third-party rules*
    __init__.py
    *third-party-utils*
  setup.py

The Fuck will find rules located in the rules module.

Back to Contents

Experimental instant mode

The default behavior of The Fuck requires time to re-run previous commands. When in instant mode, The Fuck saves time by logging output with script, then reading the log.

gif with instant mode

Currently, instant mode only supports Python 3 with bash or zsh. zsh's autocorrect function also needs to be disabled in order for thefuck to work properly.

To enable instant mode, add --enable-experimental-instant-mode to the alias initialization in .bashrc, .bash_profile or .zshrc.

For example:

eval $(thefuck --alias --enable-experimental-instant-mode)
Back to Contents

Developing

See CONTRIBUTING.md

License MIT

Project License can be found here.

Back to Contents
Issues
  • Change readme installation to have WSL section

    Change readme installation to have WSL section

    Add installation to have a WSL section so that WSL users don't need to start debugging the slowness after installation. Now it's stated explicitly.

    opened by Temez1 1
  • Change readme more examples to have own section

    Change readme more examples to have own section

    The more examples in beginning was cluttering the readme. It takes too much time to scroll to contents. I don't see that it's necessary to have so many examples in the beginning.

    opened by Temez1 0
  • Feature request: master to main

    Feature request: master to main

    Now that github has made the default branch been named main instead of master, developers in the world waist precious seconds of their live rebasing master, then swear out loud, then type the same command replacing master by main

    AC:

    • developer types git rebase master
    • developer types his swear world instead of saying it
    • developer accepts the new proposition to git rebase main
    • developer smiles

    The output of thefuck --version (something like The Fuck 3.1 using Python 3.5.0 and Bash 4.4.12(1)-release):

    The Fuck 3.30 using Python 3.8.10 and ZSH 5.8

    Your system (Debian 7, ArchLinux, Windows, etc.):

    Ubuntu 20.04

    new rule 
    opened by lenimartin 1
  • fuck takes about 10s to show corrected commands, annoying. why fuck so slow? ubuntu18, pip3 install

    fuck takes about 10s to show corrected commands, annoying. why fuck so slow? ubuntu18, pip3 install

    The output of thefuck --version (something like The Fuck 3.1 using Python 3.5.0 and Bash 4.4.12(1)-release):

    FILL THIS IN
    

    Your system (Debian 7, ArchLinux, Windows, etc.):

    FILL THIS IN
    

    How to reproduce the bug:

    FILL THIS IN
    

    The output of The Fuck with THEFUCK_DEBUG=true exported (typically execute export THEFUCK_DEBUG=true in your shell before The Fuck):

    FILL THIS IN
    

    If the bug only appears with a specific application, the output of that application and its version:

    FILL THIS IN
    

    Anything else you think is relevant:

    FILL THIS IN
    
    opened by luckyhang 1
  • Command Format

    Command Format

    The output of thefuck --version (something like The Fuck 3.1 using Python 3.5.0 and Bash 4.4.12(1)-release):

    The Fuck 3.31 using Python 3.9.2 and ZSH 5.8
    

    Your system (Debian 7, ArchLinux, Windows, etc.):

    Debian
    

    How to reproduce the bug: I was exploring the codebase and was wondering what is the argument format passed here in this code. From the docs i could figure out that it takes script, output and script_parts. It would be a great help if someone can give an example of the command passed in the below function.

    def match(command):
        if command.script_parts and '&&' not in command.script_parts and command.script_parts[0] == 'sudo':
            return False
    
        for pattern in patterns:
            if pattern in command.output.lower():
                return True
        return False
    

    Thanks

    question 
    opened by avishmehta68710 1
  • sudo.py assumes && for shell 'and'

    sudo.py assumes && for shell 'and'

    The sudo.py rule assumes that '&&' is every shells 'and' operator. This is not the case for fish shell v2.

    bug help wanted fish 
    opened by djh82 7
  • Pushing new branches no longer works

    Pushing new branches no longer works

    The output of thefuck --version (something like The Fuck 3.1 using Python 3.5.0 and Bash 4.4.12(1)-release):

    The Fuck 3.31 using Python 3.9.6 and Bash 5.1.8(1)-release
    

    Your system (Debian 7, ArchLinux, Windows, etc.):

    Manjaro
    

    How to reproduce the bug:

    I always "git push + fuck" to push new branches. However, as of recently this no longer works because fuck tries to execute the wrong command:

    $ git checkout -b fuckme
    $ git push
    fatal: The current branch fuckme has no upstream branch.
    To push the current branch and set the remote as upstream, use
    
        git push --set-upstream origin fuckme
    
    $ fuck
    git push --no-verify [enter/↑/↓/ctrl+c]
    
    fatal: The current branch fuckme has no upstream branch.
    To push the current branch and set the remote as upstream, use
    
        git push --set-upstream origin fuckme
    

    The output of The Fuck with THEFUCK_DEBUG=true exported (typically execute export THEFUCK_DEBUG=true in your shell before The Fuck):

    ✗ fuck
    DEBUG: Run with settings: {'alter_history': True,
     'debug': True,
     'env': {'GIT_TRACE': '1', 'LANG': 'C', 'LC_ALL': 'C'},
     'exclude_rules': [],
     'excluded_search_path_prefixes': [],
     'history_limit': None,
     'instant_mode': False,
     'no_colors': False,
     'num_close_matches': 3,
     'priority': {},
     'repeat': False,
     'require_confirmation': True,
     'rules': [<const: All rules enabled>],
     'slow_commands': ['lein', 'react-native', 'gradle', './gradlew', 'vagrant'],
     'user_dir': PosixPath('/home/ingo/.config/thefuck'),
     'wait_command': 3,
     'wait_slow_command': 15}
    DEBUG: Received output: 14:23:37.834998 git.c:743               trace: exec: git-p
    14:23:37.835020 run-command.c:667       trace: run_command: git-p
    14:23:37.835082 git.c:396               trace: alias expansion: p => push
    14:23:37.835085 git.c:804               trace: exec: git push
    14:23:37.835087 run-command.c:667       trace: run_command: git push
    14:23:37.835769 git.c:455               trace: built-in: git push
    fatal: The current branch test has no upstream branch.
    To push the current branch and set the remote as upstream, use
    
        git push --set-upstream origin test
    
    
    DEBUG: Call: git p; with env: {'SHELL': '/bin/bash', 'WINDOWID': '88080387', 'TF_SHELL': 'bash', 'COLORTERM': 'truecolor', 'HISTCONTROL': 'ignoreboth', 'HISTSIZE': '10000', 'I3SOCK': '/run/user/1000/i3/ipc-socket.1366', 'LC_ADDRESS': 'de_DE.UTF-8', 'SSH_AUTH_SOCK': '/run/user/1000/keyring/ssh', 'GRADLE_HOME': '/usr/share/java/gradle', 'LC_MONETARY': 'de_DE.UTF-8', 'SSH_AGENT_PID': '1333', 'CLOUDSDK_PYTHON_ARGS': '-S', 'EDITOR': '/usr/bin/vim', 'GTK_MODULES': 'canberra-gtk-module', 'XDG_SEAT': 'seat0', 'PWD': '/home/ingo/repos/blog-imap', 'LOGNAME': 'ingo', 'XDG_SESSION_TYPE': 'tty', 'SYSTEMD_EXEC_PID': '868', 'XAUTHORITY': '/home/ingo/.Xauthority', 'WINDOWPATH': '1', 'MOTD_SHOWN': 'pam', 'HOME': '/home/ingo', 'LC_PAPER': 'de_DE.UTF-8', 'LANG': 'C', 'STARSHIP_SHELL': 'bash', 'VTE_VERSION': '5602', 'CLOUDSDK_ROOT_DIR': '/opt/google-cloud-sdk', 'INVOCATION_ID': '4132cdddade74087a9ed3b23c44181bf', 'FIGNORE': '.o:.trs:~', 'STARSHIP_SESSION_KEY': '2379282121040246', 'TF_ALIAS': 'fuck', 'CLOUDSDK_PYTHON': 'python', 'XDG_SESSION_CLASS': 'user', 'TERM': 'xterm-termite', 'TF_HISTORY': '\t thefuck --version\n\t vim .bash.d/fuck \n\t cd repos/blog-imap/\n\t git p\n\t fuck\n\t fuck --version\n\t rclear \n\t export THEFUCK_DEBUG=true\n\t rclear \n\t git p', 'npm_config_prefix': '/home/ingo/.npm-global', 'GOOGLE_CLOUD_SDK_HOME': '/opt/google-cloud-sdk', 'USER': 'ingo', 'PYTHONIOENCODING': 'utf-8', 'TF_SHELL_ALIASES': 'alias beerme=\'yay --answerclean None --answerdiff None --answeredit None -Syyu ; pkill -RTMIN+3 i3blocks\'\nalias bell=\'echo -e \'\\\'\'\\a\'\\\'\'\'\nalias cdf=\'cd /home/ingo/repos/flink\'\nalias cds=\'cd /home/ingo/repos/vvp-services\'\nalias cdui=\'cd /home/ingo/repos/vvp-ui\'\nalias cp=\'cp -i\'\nalias df=\'df -h\'\nalias fixit=\'sudo rm -f /var/lib/pacman/db.lck && sudo pacman-mirrors -g && sudo pacman -Syyuu  && \nsudo pacman -Suu\'\nalias free=\'free -m\'\nalias g=\'./gradlew\'\nalias ga=\'./gradlew assemble\'\nalias gca=\'./gradlew clean assemble\'\nalias gcacc=\'gca && ./gradlew :vvp-sql-connectors:copyConnectors\'\nalias gp=\'./gradlew :vvp-core:generateProto\'\nalias grep=\'grep --color=tty -d skip\'\nalias gsp=\'./gradlew spotlessApply\'\nalias k=\'kubectl\'\nalias ls=\'ls --group-directories-first --time-style=+"%d.%m.%Y %H:%M" --color=auto -F\'\nalias mcp=\'mvn clean package -DskipTests -Dfast -Pskip-webui-build\'\nalias mmi=\'make && sudo make install\'\nalias rclear=\'tput reset && source ~/.bashrc\'\nalias sshme=\'ssh-add ~/.ssh/*.sshkey\'\nalias ydl=\'youtube-dl -o "%(title)s.%(ext)s" -x --audio-format "mp3" --audio-quality 0\'', 'DISPLAY': ':0', 'SHLVL': '3', 'LC_MESSAGES': 'en_US.UTF-8', 'LC_MEASUREMENT': 'de_DE.UTF-8', 'XDG_VTNR': '1', 'XDG_SESSION_ID': '1', 'XDG_RUNTIME_DIR': '/run/user/1000', 'JAVA_FONTS': '/usr/share/fonts/TTF', 'LC_TIME': 'de_DE.UTF-8', 'JOURNAL_STREAM': '8:18712', 'XDG_DATA_DIRS': '/usr/local/share:/usr/share:/var/lib/snapd/desktop', 'BROWSER': '', 'PATH': '/home/ingo/.npm-global/bin:/home/ingo/.npm-global/bin:/home/ingo/.npm-global/bin:/home/ingo/.local/bin:/opt/google-cloud-sdk/bin:/usr/local/sbin:/usr/local/bin:/usr/bin:/usr/lib/jvm/default/bin:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl:/var/lib/snapd/snap/bin', 'HISTFILESIZE': '10000', 'THEFUCK_DEBUG': 'true', 'DBUS_SESSION_BUS_ADDRESS': 'unix:path=/run/user/1000/bus', 'MAIL': '/var/spool/mail/ingo', 'OLDPWD': '/home/ingo', '_': '/usr/bin/thefuck', 'LC_ALL': 'C', 'GIT_TRACE': '1'}; is slow: False took: 0:00:00.005015
    DEBUG: Importing rule: adb_unknown_command; took: 0:00:00.000201
    DEBUG: Importing rule: ag_literal; took: 0:00:00.000265
    DEBUG: Importing rule: apt_get; took: 0:00:00.000519
    DEBUG: Importing rule: apt_get_search; took: 0:00:00.000132
    DEBUG: Importing rule: apt_invalid_operation; took: 0:00:00.000334
    DEBUG: Importing rule: apt_list_upgradable; took: 0:00:00.000143
    DEBUG: Importing rule: apt_upgrade; took: 0:00:00.000217
    DEBUG: Importing rule: aws_cli; took: 0:00:00.000132
    DEBUG: Importing rule: az_cli; took: 0:00:00.000127
    DEBUG: Importing rule: brew_cask_dependency; took: 0:00:00.000366
    DEBUG: Importing rule: brew_install; took: 0:00:00.000098
    DEBUG: Importing rule: brew_link; took: 0:00:00.000131
    DEBUG: Importing rule: brew_reinstall; took: 0:00:00.000331
    DEBUG: Importing rule: brew_uninstall; took: 0:00:00.000130
    DEBUG: Importing rule: brew_unknown_command; took: 0:00:00.000106
    DEBUG: Importing rule: brew_update_formula; took: 0:00:00.000159
    DEBUG: Importing rule: cargo; took: 0:00:00.000080
    DEBUG: Importing rule: cargo_no_command; took: 0:00:00.000121
    DEBUG: Importing rule: cat_dir; took: 0:00:00.000121
    DEBUG: Importing rule: cd_correction; took: 0:00:00.000512
    DEBUG: Importing rule: cd_cs; took: 0:00:00.000145
    DEBUG: Importing rule: cd_mkdir; took: 0:00:00.000142
    DEBUG: Importing rule: cd_parent; took: 0:00:00.000180
    DEBUG: Importing rule: chmod_x; took: 0:00:00.000083
    DEBUG: Importing rule: choco_install; took: 0:00:00.000221
    DEBUG: Importing rule: composer_not_command; took: 0:00:00.000130
    DEBUG: Importing rule: conda_mistype; took: 0:00:00.000122
    DEBUG: Importing rule: cp_create_destination; took: 0:00:00.000123
    DEBUG: Importing rule: cp_omitting_directory; took: 0:00:00.000181
    DEBUG: Importing rule: cpp11; took: 0:00:00.000119
    DEBUG: Importing rule: dirty_untar; took: 0:00:00.000783
    DEBUG: Importing rule: dirty_unzip; took: 0:00:00.000928
    DEBUG: Importing rule: django_south_ghost; took: 0:00:00.000093
    DEBUG: Importing rule: django_south_merge; took: 0:00:00.000150
    DEBUG: Importing rule: dnf_no_such_command; took: 0:00:00.000401
    DEBUG: Importing rule: docker_image_being_used_by_container; took: 0:00:00.000134
    DEBUG: Importing rule: docker_login; took: 0:00:00.000123
    DEBUG: Importing rule: docker_not_command; took: 0:00:00.000219
    DEBUG: Importing rule: dry; took: 0:00:00.000086
    DEBUG: Importing rule: fab_command_not_found; took: 0:00:00.000144
    DEBUG: Importing rule: fix_alt_space; took: 0:00:00.000118
    DEBUG: Importing rule: fix_file; took: 0:00:00.001263
    DEBUG: Importing rule: gem_unknown_command; took: 0:00:00.000290
    DEBUG: Importing rule: git_add; took: 0:00:00.000259
    DEBUG: Importing rule: git_add_force; took: 0:00:00.000120
    DEBUG: Importing rule: git_bisect_usage; took: 0:00:00.000119
    DEBUG: Importing rule: git_branch_delete; took: 0:00:00.000112
    DEBUG: Importing rule: git_branch_delete_checked_out; took: 0:00:00.000116
    DEBUG: Importing rule: git_branch_exists; took: 0:00:00.000169
    DEBUG: Importing rule: git_branch_list; took: 0:00:00.000112
    DEBUG: Importing rule: git_checkout; took: 0:00:00.000125
    DEBUG: Importing rule: git_clone_git_clone; took: 0:00:00.000126
    DEBUG: Importing rule: git_commit_amend; took: 0:00:00.000110
    DEBUG: Importing rule: git_commit_reset; took: 0:00:00.000110
    DEBUG: Importing rule: git_diff_no_index; took: 0:00:00.000113
    DEBUG: Importing rule: git_diff_staged; took: 0:00:00.000110
    DEBUG: Importing rule: git_fix_stash; took: 0:00:00.000116
    DEBUG: Importing rule: git_flag_after_filename; took: 0:00:00.000145
    DEBUG: Importing rule: git_help_aliased; took: 0:00:00.000113
    DEBUG: Importing rule: git_hook_bypass; took: 0:00:00.000117
    DEBUG: Importing rule: git_lfs_mistype; took: 0:00:00.000114
    DEBUG: Importing rule: git_merge; took: 0:00:00.000113
    DEBUG: Importing rule: git_merge_unrelated; took: 0:00:00.000116
    DEBUG: Importing rule: git_not_command; took: 0:00:00.000118
    DEBUG: Importing rule: git_pull; took: 0:00:00.000184
    DEBUG: Importing rule: git_pull_clone; took: 0:00:00.000114
    DEBUG: Importing rule: git_pull_uncommitted_changes; took: 0:00:00.000116
    DEBUG: Importing rule: git_push; took: 0:00:00.000120
    DEBUG: Importing rule: git_push_different_branch_names; took: 0:00:00.000110
    DEBUG: Importing rule: git_push_force; took: 0:00:00.000113
    DEBUG: Importing rule: git_push_pull; took: 0:00:00.000118
    DEBUG: Importing rule: git_push_without_commits; took: 0:00:00.000184
    DEBUG: Importing rule: git_rebase_merge_dir; took: 0:00:00.000129
    DEBUG: Importing rule: git_rebase_no_changes; took: 0:00:00.000137
    DEBUG: Importing rule: git_remote_delete; took: 0:00:00.000114
    DEBUG: Importing rule: git_remote_seturl_add; took: 0:00:00.000149
    DEBUG: Importing rule: git_rm_local_modifications; took: 0:00:00.000172
    DEBUG: Importing rule: git_rm_recursive; took: 0:00:00.000123
    DEBUG: Importing rule: git_rm_staged; took: 0:00:00.000118
    DEBUG: Importing rule: git_stash; took: 0:00:00.000120
    DEBUG: Importing rule: git_stash_pop; took: 0:00:00.000113
    DEBUG: Importing rule: git_tag_force; took: 0:00:00.000118
    DEBUG: Importing rule: git_two_dashes; took: 0:00:00.000114
    DEBUG: Importing rule: go_run; took: 0:00:00.000125
    DEBUG: Importing rule: go_unknown_command; took: 0:00:00.000189
    DEBUG: Importing rule: gradle_no_task; took: 0:00:00.000312
    DEBUG: Importing rule: gradle_wrapper; took: 0:00:00.000133
    DEBUG: Importing rule: grep_arguments_order; took: 0:00:00.000130
    DEBUG: Importing rule: grep_recursive; took: 0:00:00.000153
    DEBUG: Importing rule: grunt_task_not_found; took: 0:00:00.000230
    DEBUG: Importing rule: gulp_not_task; took: 0:00:00.000156
    DEBUG: Importing rule: has_exists_script; took: 0:00:00.000133
    DEBUG: Importing rule: heroku_multiple_apps; took: 0:00:00.000125
    DEBUG: Importing rule: heroku_not_command; took: 0:00:00.000122
    DEBUG: Importing rule: history; took: 0:00:00.000082
    DEBUG: Importing rule: hostscli; took: 0:00:00.000144
    DEBUG: Importing rule: ifconfig_device_not_found; took: 0:00:00.000142
    DEBUG: Importing rule: java; took: 0:00:00.000119
    DEBUG: Importing rule: javac; took: 0:00:00.000121
    DEBUG: Importing rule: lein_not_task; took: 0:00:00.000140
    DEBUG: Importing rule: ln_no_hard_link; took: 0:00:00.000117
    DEBUG: Importing rule: ln_s_order; took: 0:00:00.000119
    DEBUG: Importing rule: long_form_help; took: 0:00:00.000085
    DEBUG: Importing rule: ls_all; took: 0:00:00.000125
    DEBUG: Importing rule: ls_lah; took: 0:00:00.000154
    DEBUG: Importing rule: man; took: 0:00:00.000188
    DEBUG: Importing rule: man_no_space; took: 0:00:00.000081
    DEBUG: Importing rule: mercurial; took: 0:00:00.000126
    DEBUG: Importing rule: missing_space_before_subcommand; took: 0:00:00.000090
    DEBUG: Importing rule: mkdir_p; took: 0:00:00.000116
    DEBUG: Importing rule: mvn_no_command; took: 0:00:00.000124
    DEBUG: Importing rule: mvn_unknown_lifecycle_phase; took: 0:00:00.000124
    DEBUG: Importing rule: nixos_cmd_not_found; took: 0:00:00.000320
    DEBUG: Importing rule: no_command; took: 0:00:00.000138
    DEBUG: Importing rule: no_such_file; took: 0:00:00.000087
    DEBUG: Importing rule: npm_missing_script; took: 0:00:00.000268
    DEBUG: Importing rule: npm_run_script; took: 0:00:00.000129
    DEBUG: Importing rule: npm_wrong_command; took: 0:00:00.000154
    DEBUG: Importing rule: omnienv_no_such_command; took: 0:00:00.000316
    DEBUG: Importing rule: open; took: 0:00:00.000153
    DEBUG: Importing rule: pacman; took: 0:00:00.000321
    DEBUG: Importing rule: pacman_invalid_option; took: 0:00:00.000151
    DEBUG: Importing rule: pacman_not_found; took: 0:00:00.000214
    DEBUG: Importing rule: path_from_history; took: 0:00:00.000114
    DEBUG: Importing rule: php_s; took: 0:00:00.000134
    DEBUG: Importing rule: pip_install; took: 0:00:00.000133
    DEBUG: Importing rule: pip_unknown_command; took: 0:00:00.000136
    DEBUG: Importing rule: port_already_in_use; took: 0:00:00.000150
    DEBUG: Importing rule: prove_recursively; took: 0:00:00.000135
    DEBUG: Importing rule: python_command; took: 0:00:00.000117
    DEBUG: Importing rule: python_execute; took: 0:00:00.000121
    DEBUG: Importing rule: python_module_error; took: 0:00:00.000084
    DEBUG: Importing rule: quotation_marks; took: 0:00:00.000074
    DEBUG: Importing rule: react_native_command_unrecognized; took: 0:00:00.000149
    DEBUG: Importing rule: remove_shell_prompt_literal; took: 0:00:00.000082
    DEBUG: Importing rule: remove_trailing_cedilla; took: 0:00:00.000082
    DEBUG: Importing rule: rm_dir; took: 0:00:00.000115
    DEBUG: Importing rule: rm_root; took: 0:00:00.000116
    DEBUG: Importing rule: scm_correction; took: 0:00:00.000141
    DEBUG: Importing rule: sed_unterminated_s; took: 0:00:00.000199
    DEBUG: Importing rule: sl_ls; took: 0:00:00.000084
    DEBUG: Importing rule: ssh_known_hosts; took: 0:00:00.000129
    DEBUG: Importing rule: sudo; took: 0:00:00.000086
    DEBUG: Importing rule: sudo_command_from_user_path; took: 0:00:00.000127
    DEBUG: Importing rule: switch_lang; took: 0:00:00.000137
    DEBUG: Importing rule: systemctl; took: 0:00:00.000147
    DEBUG: Importing rule: terraform_init; took: 0:00:00.000127
    DEBUG: Importing rule: test.py; took: 0:00:00.000080
    DEBUG: Importing rule: tmux; took: 0:00:00.000122
    DEBUG: Importing rule: touch; took: 0:00:00.000125
    DEBUG: Importing rule: tsuru_login; took: 0:00:00.000122
    DEBUG: Importing rule: tsuru_not_command; took: 0:00:00.000121
    DEBUG: Importing rule: unknown_command; took: 0:00:00.000079
    DEBUG: Importing rule: unsudo; took: 0:00:00.000079
    DEBUG: Importing rule: vagrant_up; took: 0:00:00.000125
    DEBUG: Importing rule: whois; took: 0:00:00.000232
    DEBUG: Importing rule: workon_doesnt_exists; took: 0:00:00.000154
    DEBUG: Importing rule: yarn_alias; took: 0:00:00.000165
    DEBUG: Importing rule: yarn_command_not_found; took: 0:00:00.000291
    DEBUG: Importing rule: yarn_command_replaced; took: 0:00:00.000199
    DEBUG: Importing rule: yarn_help; took: 0:00:00.000132
    DEBUG: Importing rule: yum_invalid_operation; took: 0:00:00.000314
    DEBUG: Trying rule: path_from_history; took: 0:00:00.000358
    DEBUG: Trying rule: cd_cs; took: 0:00:00.000039
    DEBUG: Trying rule: dry; took: 0:00:00.000002
    DEBUG: Trying rule: git_hook_bypass; took: 0:00:00.000174
    git push --no-verify [enter/↑/↓/ctrl+c]
    
    opened by Airblader 2
  • no_command rule doesn't work properly with executables that have an uppercase name

    no_command rule doesn't work properly with executables that have an uppercase name

    The output of thefuck --version (something like The Fuck 3.1 using Python 3.5.0 and Bash 4.4.12(1)-release):

    The Fuck 3.31 using Python 3.9.5 and PowerShell 5.1.19041.1023
    

    Your system (Debian 7, ArchLinux, Windows, etc.):

    Windows 10
    

    How to reproduce the bug:

    On Windows, the ping executable is called PING.EXE (uppercase). It doesn't work with the no_command rule, as shown:
    
    ~
    -> pingg
    pingg: The term 'pingg' is not recognized as a name of a cmdlet, function, script file, or executable program.
    Check the spelling of the name, or if a path was included, verify that the path is correct and try again.
    
    ~
    -> fuck
    No fucks given
    
    ~ took 2s
    -> PINGG
    PINGG: The term 'PINGG' is not recognized as a name of a cmdlet, function, script file, or executable program.
    Check the spelling of the name, or if a path was included, verify that the path is correct and try again.
    
    ~
    -> fuck
    PING.EXE [enter/↑/↓/ctrl+c]
    Aborted
    

    The output of The Fuck with THEFUCK_DEBUG=true exported (typically execute export THEFUCK_DEBUG=true in your shell before The Fuck):

    ~
    -> pingg
    pingg: The term 'pingg' is not recognized as a name of a cmdlet, function, script file, or executable program.
    Check the spelling of the name, or if a path was included, verify that the path is correct and try again.
    
    ~
    -> fuck
    DEBUG: Run with settings: {'alter_history': True,
     'debug': True,
     'env': {'GIT_TRACE': '1', 'LANG': 'C', 'LC_ALL': 'C'},
     'exclude_rules': [],
     'excluded_search_path_prefixes': [],
     'history_limit': None,
     'instant_mode': False,
     'no_colors': False,
     'num_close_matches': 3,
     'priority': {},
     'repeat': False,
     'require_confirmation': True,
     'rules': [<const: All rules enabled>],
     'slow_commands': ['lein', 'react-native', 'gradle', './gradlew', 'vagrant'],
     'user_dir': WindowsPath('C:/Users/nsdjs/.config/thefuck'),
     'wait_command': 3,
     'wait_slow_command': 15}
    DEBUG: Received output: 'pingg' is not recognized as an internal or external command,
    operable program or batch file.
    
    DEBUG: Call: pingg; with env: {'ALLUSERSPROFILE': 'C:\\ProgramData', 'ANDROID_HOME': 'C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk', 'ANDROID_SDK_ROOT': 'C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk', 'APPDATA': 'C:\\Users\\nsdjs\\AppData\\Roaming', 'CC': 'clang', 'CHOCOLATEYINSTALL': 'C:\\ProgramData\\chocolatey', 'CHOCOLATEYLASTPATHUPDATE': '132665810047181697', 'CHOCOLATEYTOOLSLOCATION': 'C:\\tools', 'COMMONPROGRAMFILES': 'C:\\Program Files\\Common Files', 'COMMONPROGRAMFILES(X86)': 'C:\\Program Files (x86)\\Common Files', 'COMMONPROGRAMW6432': 'C:\\Program Files\\Common Files', 'COMPUTERNAME': 'LAPTOP-EMBTSD2M', 'COMSPEC': 'C:\\WINDOWS\\system32\\cmd.exe', 'DRIVERDATA': 'C:\\Windows\\System32\\Drivers\\DriverData', 'EDITOR': 'nvim', 'FNM_ARCH': 'x64', 'FNM_DIR': 'C:\\Users\\nsdjs\\.fnm', 'FNM_LOGLEVEL': 'info', 'FNM_MULTISHELL_PATH': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp\\fnm_multishells\\21456_1624074310240', 'FNM_NODE_DIST_MIRROR': 'https://nodejs.org/dist', 'FZF_DEFAULT_COMMAND': 'rg --files', 'GOPATH': 'C:\\Users\\nsdjs\\go', 'HOMEDRIVE': 'C:', 'HOMEPATH': '\\Users\\nsdjs', 'INTEL_DEV_REDIST': 'C:\\Program Files (x86)\\Common Files\\Intel\\Shared Libraries\\', 'JAVA_HOME': 'C:\\Program Files\\OpenJDK\\openjdk-8u292-b10', 'LOCALAPPDATA': 'C:\\Users\\nsdjs\\AppData\\Local', 'LOGONSERVER': '\\\\LAPTOP-EMBTSD2M', 'MIC_LD_LIBRARY_PATH': 'C:\\Program Files (x86)\\Common Files\\Intel\\Shared Libraries\\compiler\\lib\\mic', 'NUMBER_OF_PROCESSORS': '8', 'ONEDRIVE': 'C:\\Users\\nsdjs\\OneDrive - NSW Department of Education', 'ONEDRIVECOMMERCIAL': 'C:\\Users\\nsdjs\\OneDrive - NSW Department of Education', 'ONEDRIVECONSUMER': 'C:\\Users\\nsdjs\\OneDrive', 'OPENCV_DIR': 'C:\\tools\\opencv\\build\\', 'OS': 'Windows_NT', 'PATH': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp\\fnm_multishells\\21456_1624074310240;C:\\Program Files\\PowerShell\\7;C:\\Python39\\Scripts\\;C:\\Python39\\;C:\\Program Files (x86)\\Common Files\\Oracle\\Java\\javapath;C:\\ProgramData\\Oracle\\Java\\javapath;C:\\Program Files (x86)\\Common Files\\Intel\\Shared Libraries\\redist\\intel64\\compiler;C:\\Windows\\System32;C:\\Windows;C:\\Windows\\System32\\wbem;C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\;C:\\Windows\\System32\\OpenSSH\\;C:\\Program Files\\Microsoft SQL Server\\120\\Tools\\Binn\\;C:\\src\\flutter\\bin;C:\\Users\\nsdjs\\platform-tools;C:\\Program Files (x86)\\GnuWin32\\bin;C:\\Program Files\\dotnet\\;C:\\src\\flutter\\bin\\cache\\dart-sdk\\bin;C:\\bin;C:\\Program Files\\Java\\jdk1.8.0_271\\bin;C:\\bin\\libwebp-1.1.0-windows-x64\\bin;C:\\ProgramData\\chocolatey\\bin;C:\\Program Files\\Docker\\Docker\\resources\\bin;C:\\ProgramData\\DockerDesktop\\version-bin;C:\\Program Files\\LLVM\\bin;C:\\Program Files\\PowerShell\\7\\;C:\\tools\\opencv\\build\\\\bin;C:\\bin\\lua-language-server\\bin\\Windows;C:\\bin\\danser-go;C:\\Program Files\\PuTTY\\;C:\\WINDOWS\\system32;C:\\WINDOWS;C:\\WINDOWS\\System32\\Wbem;C:\\WINDOWS\\System32\\WindowsPowerShell\\v1.0\\;C:\\WINDOWS\\System32\\OpenSSH\\;C:\\Program Files\\OpenJDK\\openjdk-8u292-b10\\bin;C:\\Program Files\\Git\\cmd;C:\\Program Files\\Go\\bin;C:\\Program Files (x86)\\Gpg4win\\..\\GnuPG\\bin;C:\\Users\\nsdjs\\scoop\\shims;C:\\Users\\nsdjs\\.windows-build-tools\\python27\\;C:\\Users\\nsdjs\\.cargo\\bin;C:\\Users\\nsdjs\\AppData\\Local\\Microsoft\\WindowsApps;C:\\Users\\nsdjs\\AppData\\Local\\Programs\\Microsoft VS Code\\bin;C:\\Users\\nsdjs\\.dotnet\\tools;C:\\Program Files (x86)\\GitHub CLI\\;C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk\\platform-tools;C:\\Users\\nsdjs\\go\\bin;C:\\tools\\neovim\\Neovim\\bin;C:\\Users\\nsdjs\\AppData\\Local\\Yarn\\bin;C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk\\tools;C:\\Users\\nsdjs\\AppData\\Local\\Programs\\hyper\\resources\\bin;C:\\Users\\nsdjs\\Documents\\PowerShell\\Scripts;C:\\Users\\nsdjs\\AppData\\Local\\Microsoft\\WindowsApps;C:\\Users\\nsdjs\\AppData\\Local\\Programs\\Hyper\\resources\\bin;C:\\Users\\nsdjs\\go\\bin', 'PATHEXT': '.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC;.PY;.PYW;.CPL', 'POWERSHELL_DISTRIBUTION_CHANNEL': 'MSI:Windows 10 Home Single Language', 'PROCESSOR_ARCHITECTURE': 'AMD64', 'PROCESSOR_IDENTIFIER': 'AMD64 Family 23 Model 24 Stepping 1, AuthenticAMD', 'PROCESSOR_LEVEL': '23', 'PROCESSOR_REVISION': '1801', 'PROGRAMDATA': 'C:\\ProgramData', 'PROGRAMFILES': 'C:\\Program Files', 'PROGRAMFILES(X86)': 'C:\\Program Files (x86)', 'PROGRAMW6432': 'C:\\Program Files', 'PSMODULEPATH': 'C:\\Users\\nsdjs\\Documents\\PowerShell\\Modules;C:\\Program Files\\PowerShell\\Modules;c:\\program files\\powershell\\7\\Modules;C:\\Program Files\\WindowsPowerShell\\Modules;C:\\WINDOWS\\system32\\WindowsPowerShell\\v1.0\\Modules', 'PUBLIC': 'C:\\Users\\Public', 'PYTHONIOENCODING': 'utf-8', 'STARSHIP_SESSION_KEY': 'Q4FXvAPozU5rnpa9', 'STARSHIP_SHELL': 'powershell', 'SYSTEMDRIVE': 'C:', 'SYSTEMROOT': 'C:\\WINDOWS', 'TEMP': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp', 'THEFUCK_DEBUG': 'true', 'TMP': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp', 'USERDOMAIN': 'LAPTOP-EMBTSD2M', 'USERDOMAIN_ROAMINGPROFILE': 'LAPTOP-EMBTSD2M', 'USERNAME': 'nsdjs', 'USERPROFILE': 'C:\\Users\\nsdjs', 'VBOX_MSI_INSTALL_PATH': 'C:\\Program Files\\Oracle\\VirtualBox\\', 'VIRTUAL_ENV_DISABLE_PROMPT': '1', 'WINDIR': 'C:\\WINDOWS', 'WSLENV': 'WT_SESSION::WT_PROFILE_ID', 'WT_PROFILE_ID': '{574e775e-4f2a-5b96-ac1e-a2962a402336}', 'WT_SESSION': 'c1e82de6-9c5e-4409-904a-b860d166f83c', 'LC_ALL': 'C', 'LANG': 'C', 'GIT_TRACE': '1'}; is slow: False took: 0:00:00.023995
    DEBUG: Importing rule: adb_unknown_command; took: 0:00:00
    DEBUG: Importing rule: ag_literal; took: 0:00:00.001002
    DEBUG: Importing rule: apt_get; took: 0:00:00.026530
    DEBUG: Importing rule: apt_get_search; took: 0:00:00.002000
    DEBUG: Importing rule: apt_invalid_operation; took: 0:00:00.001989
    DEBUG: Importing rule: apt_list_upgradable; took: 0:00:00.001000
    DEBUG: Importing rule: apt_upgrade; took: 0:00:00.000999
    DEBUG: Importing rule: aws_cli; took: 0:00:00.001022
    DEBUG: Importing rule: az_cli; took: 0:00:00.000998
    DEBUG: Importing rule: brew_cask_dependency; took: 0:00:00.024011
    DEBUG: Importing rule: brew_install; took: 0:00:00.001011
    DEBUG: Importing rule: brew_link; took: 0:00:00.000980
    DEBUG: Importing rule: brew_reinstall; took: 0:00:00.001003
    DEBUG: Importing rule: brew_uninstall; took: 0:00:00.001002
    DEBUG: Importing rule: brew_unknown_command; took: 0:00:00.000991
    DEBUG: Importing rule: brew_update_formula; took: 0:00:00.001002
    DEBUG: Importing rule: brew_upgrade; took: 0:00:00
    DEBUG: Importing rule: cargo; took: 0:00:00.001000
    DEBUG: Importing rule: cargo_no_command; took: 0:00:00.001001
    DEBUG: Importing rule: cat_dir; took: 0:00:00.000999
    DEBUG: Importing rule: cd_correction; took: 0:00:00.004995
    DEBUG: Importing rule: cd_cs; took: 0:00:00.001001
    DEBUG: Importing rule: cd_mkdir; took: 0:00:00.000999
    DEBUG: Importing rule: cd_parent; took: 0:00:00.000999
    DEBUG: Importing rule: chmod_x; took: 0:00:00.000998
    DEBUG: Importing rule: choco_install; took: 0:00:00.011994
    DEBUG: Importing rule: composer_not_command; took: 0:00:00.001006
    DEBUG: Importing rule: conda_mistype; took: 0:00:00.001001
    DEBUG: Importing rule: cp_create_destination; took: 0:00:00.000997
    DEBUG: Importing rule: cp_omitting_directory; took: 0:00:00.000998
    DEBUG: Importing rule: cpp11; took: 0:00:00.002004
    DEBUG: Importing rule: dirty_untar; took: 0:00:00.005008
    DEBUG: Importing rule: dirty_unzip; took: 0:00:00.002995
    DEBUG: Importing rule: django_south_ghost; took: 0:00:00.001015
    DEBUG: Importing rule: django_south_merge; took: 0:00:00.001000
    DEBUG: Importing rule: dnf_no_such_command; took: 0:00:00.026003
    DEBUG: Importing rule: docker_image_being_used_by_container; took: 0:00:00.002000
    DEBUG: Importing rule: docker_login; took: 0:00:00.000999
    DEBUG: Importing rule: docker_not_command; took: 0:00:00.012006
    DEBUG: Importing rule: dry; took: 0:00:00.000989
    DEBUG: Importing rule: fab_command_not_found; took: 0:00:00.000999
    DEBUG: Importing rule: fix_alt_space; took: 0:00:00.001000
    DEBUG: Importing rule: fix_file; took: 0:00:00.003009
    DEBUG: Importing rule: gem_unknown_command; took: 0:00:00.021990
    DEBUG: Importing rule: git_add; took: 0:00:00.001000
    DEBUG: Importing rule: git_add_force; took: 0:00:00.001006
    DEBUG: Importing rule: git_bisect_usage; took: 0:00:00.001002
    DEBUG: Importing rule: git_branch_delete; took: 0:00:00.000998
    DEBUG: Importing rule: git_branch_delete_checked_out; took: 0:00:00.001001
    DEBUG: Importing rule: git_branch_exists; took: 0:00:00.001001
    DEBUG: Importing rule: git_branch_list; took: 0:00:00
    DEBUG: Importing rule: git_checkout; took: 0:00:00.001001
    DEBUG: Importing rule: git_clone_git_clone; took: 0:00:00.000999
    DEBUG: Importing rule: git_commit_amend; took: 0:00:00.001001
    DEBUG: Importing rule: git_commit_reset; took: 0:00:00.000998
    DEBUG: Importing rule: git_diff_no_index; took: 0:00:00
    DEBUG: Importing rule: git_diff_staged; took: 0:00:00.001003
    DEBUG: Importing rule: git_fix_stash; took: 0:00:00.001008
    DEBUG: Importing rule: git_flag_after_filename; took: 0:00:00.001002
    DEBUG: Importing rule: git_help_aliased; took: 0:00:00.001004
    DEBUG: Importing rule: git_hook_bypass; took: 0:00:00.001995
    DEBUG: Importing rule: git_lfs_mistype; took: 0:00:00.000999
    DEBUG: Importing rule: git_merge; took: 0:00:00.000997
    DEBUG: Importing rule: git_merge_unrelated; took: 0:00:00.001000
    DEBUG: Importing rule: git_not_command; took: 0:00:00
    DEBUG: Importing rule: git_pull; took: 0:00:00.000999
    DEBUG: Importing rule: git_pull_clone; took: 0:00:00.001001
    DEBUG: Importing rule: git_pull_uncommitted_changes; took: 0:00:00.001022
    DEBUG: Importing rule: git_push; took: 0:00:00.000999
    DEBUG: Importing rule: git_push_different_branch_names; took: 0:00:00.001000
    DEBUG: Importing rule: git_push_force; took: 0:00:00.002006
    DEBUG: Importing rule: git_push_pull; took: 0:00:00.001002
    DEBUG: Importing rule: git_push_without_commits; took: 0:00:00.001007
    DEBUG: Importing rule: git_rebase_merge_dir; took: 0:00:00.001002
    DEBUG: Importing rule: git_rebase_no_changes; took: 0:00:00.000996
    DEBUG: Importing rule: git_remote_delete; took: 0:00:00.000998
    DEBUG: Importing rule: git_remote_seturl_add; took: 0:00:00.001000
    DEBUG: Importing rule: git_rm_local_modifications; took: 0:00:00.001007
    DEBUG: Importing rule: git_rm_recursive; took: 0:00:00.000993
    DEBUG: Importing rule: git_rm_staged; took: 0:00:00
    DEBUG: Importing rule: git_stash; took: 0:00:00.000999
    DEBUG: Importing rule: git_stash_pop; took: 0:00:00.001001
    DEBUG: Importing rule: git_tag_force; took: 0:00:00.001002
    DEBUG: Importing rule: git_two_dashes; took: 0:00:00.001992
    DEBUG: Importing rule: go_run; took: 0:00:00.000998
    DEBUG: Importing rule: go_unknown_command; took: 0:00:00.017000
    DEBUG: Importing rule: gradle_no_task; took: 0:00:00.002004
    DEBUG: Importing rule: gradle_wrapper; took: 0:00:00.000993
    DEBUG: Importing rule: grep_arguments_order; took: 0:00:00.001012
    DEBUG: Importing rule: grep_recursive; took: 0:00:00.000992
    DEBUG: Importing rule: grunt_task_not_found; took: 0:00:00
    DEBUG: Importing rule: gulp_not_task; took: 0:00:00.001002
    DEBUG: Importing rule: has_exists_script; took: 0:00:00.001000
    DEBUG: Importing rule: heroku_multiple_apps; took: 0:00:00.000997
    DEBUG: Importing rule: heroku_not_command; took: 0:00:00.001001
    DEBUG: Importing rule: history; took: 0:00:00.001000
    DEBUG: Importing rule: hostscli; took: 0:00:00.001008
    DEBUG: Importing rule: ifconfig_device_not_found; took: 0:00:00.001003
    DEBUG: Importing rule: java; took: 0:00:00.001000
    DEBUG: Importing rule: javac; took: 0:00:00.000997
    DEBUG: Importing rule: lein_not_task; took: 0:00:00
    DEBUG: Importing rule: ln_no_hard_link; took: 0:00:00.001004
    DEBUG: Importing rule: ln_s_order; took: 0:00:00.000999
    DEBUG: Importing rule: long_form_help; took: 0:00:00.001006
    DEBUG: Importing rule: ls_all; took: 0:00:00.000994
    DEBUG: Importing rule: ls_lah; took: 0:00:00.001002
    DEBUG: Importing rule: man; took: 0:00:00.000999
    DEBUG: Importing rule: man_no_space; took: 0:00:00.000997
    DEBUG: Importing rule: mercurial; took: 0:00:00.000997
    DEBUG: Importing rule: missing_space_before_subcommand; took: 0:00:00.000998
    DEBUG: Importing rule: mkdir_p; took: 0:00:00
    DEBUG: Importing rule: mvn_no_command; took: 0:00:00.000999
    DEBUG: Importing rule: mvn_unknown_lifecycle_phase; took: 0:00:00.001000
    DEBUG: Importing rule: nixos_cmd_not_found; took: 0:00:00.024774
    DEBUG: Importing rule: no_command; took: 0:00:00.001003
    DEBUG: Importing rule: no_such_file; took: 0:00:00.001004
    DEBUG: Importing rule: npm_missing_script; took: 0:00:00.002991
    DEBUG: Importing rule: npm_run_script; took: 0:00:00.001003
    DEBUG: Importing rule: npm_wrong_command; took: 0:00:00.001000
    DEBUG: Importing rule: omnienv_no_such_command; took: 0:00:00.083996
    DEBUG: Importing rule: open; took: 0:00:00.002002
    DEBUG: Importing rule: pacman; took: 0:00:00.070994
    DEBUG: Importing rule: pacman_invalid_option; took: 0:00:00.002004
    DEBUG: Importing rule: pacman_not_found; took: 0:00:00.001000
    DEBUG: Importing rule: path_from_history; took: 0:00:00.001003
    DEBUG: Importing rule: php_s; took: 0:00:00.000998
    DEBUG: Importing rule: pip_install; took: 0:00:00.001004
    DEBUG: Importing rule: pip_unknown_command; took: 0:00:00.000999
    DEBUG: Importing rule: port_already_in_use; took: 0:00:00.023001
    DEBUG: Importing rule: prove_recursively; took: 0:00:00.001005
    DEBUG: Importing rule: pyenv_no_such_command; took: 0:00:00.000996
    DEBUG: Importing rule: python_command; took: 0:00:00.000999
    DEBUG: Importing rule: python_execute; took: 0:00:00.000998
    DEBUG: Importing rule: python_module_error; took: 0:00:00.001005
    DEBUG: Importing rule: quotation_marks; took: 0:00:00.000995
    DEBUG: Importing rule: react_native_command_unrecognized; took: 0:00:00.001000
    DEBUG: Importing rule: remove_shell_prompt_literal; took: 0:00:00
    DEBUG: Importing rule: remove_trailing_cedilla; took: 0:00:00.001000
    DEBUG: Importing rule: rm_dir; took: 0:00:00.001001
    DEBUG: Importing rule: rm_root; took: 0:00:00.000999
    DEBUG: Importing rule: scm_correction; took: 0:00:00.001000
    DEBUG: Importing rule: sed_unterminated_s; took: 0:00:00.001000
    DEBUG: Importing rule: sl_ls; took: 0:00:00.001003
    DEBUG: Importing rule: ssh_known_hosts; took: 0:00:00.001997
    DEBUG: Importing rule: sudo; took: 0:00:00.001001
    DEBUG: Importing rule: sudo_command_from_user_path; took: 0:00:00.001006
    DEBUG: Importing rule: switch_lang; took: 0:00:00.000994
    DEBUG: Importing rule: systemctl; took: 0:00:00
    DEBUG: Importing rule: terraform_init; took: 0:00:00.000998
    DEBUG: Importing rule: test.py; took: 0:00:00.000998
    DEBUG: Importing rule: tmux; took: 0:00:00.000995
    DEBUG: Importing rule: touch; took: 0:00:00.001003
    DEBUG: Importing rule: tsuru_login; took: 0:00:00.001002
    DEBUG: Importing rule: tsuru_not_command; took: 0:00:00.002004
    DEBUG: Importing rule: unknown_command; took: 0:00:00.002000
    DEBUG: Importing rule: unsudo; took: 0:00:00.000991
    DEBUG: Importing rule: vagrant_up; took: 0:00:00
    DEBUG: Importing rule: whois; took: 0:00:00.001003
    DEBUG: Importing rule: workon_doesnt_exists; took: 0:00:00.001005
    DEBUG: Importing rule: yarn_alias; took: 0:00:00
    DEBUG: Importing rule: yarn_command_not_found; took: 0:00:00.001996
    DEBUG: Importing rule: yarn_command_replaced; took: 0:00:00.001001
    DEBUG: Importing rule: yarn_help; took: 0:00:00.001002
    DEBUG: Importing rule: yum_invalid_operation; took: 0:00:00.024000
    DEBUG: Trying rule: path_from_history; took: 0:00:00.000996
    DEBUG: Trying rule: cd_cs; took: 0:00:00
    DEBUG: Trying rule: dry; took: 0:00:00
    DEBUG: Trying rule: git_hook_bypass; took: 0:00:00
    DEBUG: Trying rule: git_stash_pop; took: 0:00:00
    DEBUG: Trying rule: test.py; took: 0:00:00
    DEBUG: Trying rule: adb_unknown_command; took: 0:00:00
    DEBUG: Trying rule: ag_literal; took: 0:00:00
    DEBUG: Trying rule: aws_cli; took: 0:00:00
    DEBUG: Trying rule: az_cli; took: 0:00:00
    DEBUG: Trying rule: brew_link; took: 0:00:00
    DEBUG: Trying rule: brew_reinstall; took: 0:00:00.000996
    DEBUG: Trying rule: brew_uninstall; took: 0:00:00
    DEBUG: Trying rule: brew_update_formula; took: 0:00:00
    DEBUG: Trying rule: cargo; took: 0:00:00
    DEBUG: Trying rule: cargo_no_command; took: 0:00:00
    DEBUG: Trying rule: cat_dir; took: 0:00:00
    DEBUG: Trying rule: cd_correction; took: 0:00:00
    DEBUG: Trying rule: cd_mkdir; took: 0:00:00
    DEBUG: Trying rule: cd_parent; took: 0:00:00
    DEBUG: Trying rule: chmod_x; took: 0:00:00
    DEBUG: Trying rule: choco_install; took: 0:00:00
    DEBUG: Trying rule: composer_not_command; took: 0:00:00
    DEBUG: Trying rule: conda_mistype; took: 0:00:00
    DEBUG: Trying rule: cp_create_destination; took: 0:00:00
    DEBUG: Trying rule: cp_omitting_directory; took: 0:00:00
    DEBUG: Trying rule: cpp11; took: 0:00:00
    DEBUG: Trying rule: dirty_untar; took: 0:00:00
    DEBUG: Trying rule: dirty_unzip; took: 0:00:00
    DEBUG: Trying rule: django_south_ghost; took: 0:00:00
    DEBUG: Trying rule: django_south_merge; took: 0:00:00
    DEBUG: Trying rule: docker_image_being_used_by_container; took: 0:00:00
    DEBUG: Trying rule: docker_login; took: 0:00:00
    DEBUG: Trying rule: docker_not_command; took: 0:00:00
    DEBUG: Trying rule: fab_command_not_found; took: 0:00:00
    DEBUG: Trying rule: fix_alt_space; took: 0:00:00
    DEBUG: Trying rule: fix_file; took: 0:00:00
    DEBUG: Trying rule: gem_unknown_command; took: 0:00:00
    DEBUG: Trying rule: git_add; took: 0:00:00
    DEBUG: Trying rule: git_add_force; took: 0:00:00
    DEBUG: Trying rule: git_bisect_usage; took: 0:00:00
    DEBUG: Trying rule: git_branch_delete; took: 0:00:00
    DEBUG: Trying rule: git_branch_delete_checked_out; took: 0:00:00
    DEBUG: Trying rule: git_branch_exists; took: 0:00:00
    DEBUG: Trying rule: git_branch_list; took: 0:00:00
    DEBUG: Trying rule: git_checkout; took: 0:00:00
    DEBUG: Trying rule: git_clone_git_clone; took: 0:00:00
    DEBUG: Trying rule: git_commit_amend; took: 0:00:00
    DEBUG: Trying rule: git_commit_reset; took: 0:00:00
    DEBUG: Trying rule: git_diff_no_index; took: 0:00:00
    DEBUG: Trying rule: git_diff_staged; took: 0:00:00
    DEBUG: Trying rule: git_fix_stash; took: 0:00:00
    DEBUG: Trying rule: git_flag_after_filename; took: 0:00:00
    DEBUG: Trying rule: git_help_aliased; took: 0:00:00
    DEBUG: Trying rule: git_lfs_mistype; took: 0:00:00
    DEBUG: Trying rule: git_merge; took: 0:00:00
    DEBUG: Trying rule: git_merge_unrelated; took: 0:00:00
    DEBUG: Trying rule: git_not_command; took: 0:00:00
    DEBUG: Trying rule: git_pull; took: 0:00:00
    DEBUG: Trying rule: git_pull_clone; took: 0:00:00
    DEBUG: Trying rule: git_pull_uncommitted_changes; took: 0:00:00
    DEBUG: Trying rule: git_push; took: 0:00:00
    DEBUG: Trying rule: git_push_different_branch_names; took: 0:00:00
    DEBUG: Trying rule: git_push_pull; took: 0:00:00
    DEBUG: Trying rule: git_push_without_commits; took: 0:00:00
    DEBUG: Trying rule: git_rebase_merge_dir; took: 0:00:00
    DEBUG: Trying rule: git_rebase_no_changes; took: 0:00:00
    DEBUG: Trying rule: git_remote_delete; took: 0:00:00
    DEBUG: Trying rule: git_remote_seturl_add; took: 0:00:00
    DEBUG: Trying rule: git_rm_local_modifications; took: 0:00:00
    DEBUG: Trying rule: git_rm_recursive; took: 0:00:00
    DEBUG: Trying rule: git_rm_staged; took: 0:00:00
    DEBUG: Trying rule: git_stash; took: 0:00:00
    DEBUG: Trying rule: git_tag_force; took: 0:00:00
    DEBUG: Trying rule: git_two_dashes; took: 0:00:00
    DEBUG: Trying rule: go_run; took: 0:00:00
    DEBUG: Trying rule: go_unknown_command; took: 0:00:00
    DEBUG: Trying rule: gradle_no_task; took: 0:00:00
    DEBUG: Trying rule: gradle_wrapper; took: 0:00:00
    DEBUG: Trying rule: grep_arguments_order; took: 0:00:00
    DEBUG: Trying rule: grep_recursive; took: 0:00:00
    DEBUG: Trying rule: grunt_task_not_found; took: 0:00:00
    DEBUG: Trying rule: gulp_not_task; took: 0:00:00
    DEBUG: Trying rule: has_exists_script; took: 0:00:00
    DEBUG: Trying rule: heroku_multiple_apps; took: 0:00:00
    DEBUG: Trying rule: heroku_not_command; took: 0:00:00
    DEBUG: Trying rule: hostscli; took: 0:00:00
    DEBUG: Trying rule: ifconfig_device_not_found; took: 0:00:00
    DEBUG: Trying rule: java; took: 0:00:00
    DEBUG: Trying rule: javac; took: 0:00:00
    DEBUG: Trying rule: lein_not_task; took: 0:00:00
    DEBUG: Trying rule: ln_no_hard_link; took: 0:00:00
    DEBUG: Trying rule: ln_s_order; took: 0:00:00
    DEBUG: Trying rule: ls_all; took: 0:00:00
    DEBUG: Trying rule: ls_lah; took: 0:00:00.000998
    DEBUG: Trying rule: man; took: 0:00:00
    DEBUG: Trying rule: mercurial; took: 0:00:00
    DEBUG: Trying rule: mkdir_p; took: 0:00:00
    DEBUG: Trying rule: mvn_no_command; took: 0:00:00
    DEBUG: Trying rule: mvn_unknown_lifecycle_phase; took: 0:00:00
    DEBUG: Trying rule: no_such_file; took: 0:00:00.000999
    DEBUG: Trying rule: npm_missing_script; took: 0:00:00
    DEBUG: Trying rule: npm_run_script; took: 0:00:00
    DEBUG: Trying rule: npm_wrong_command; took: 0:00:00
    DEBUG: Trying rule: open; took: 0:00:00
    DEBUG: Trying rule: pacman_invalid_option; took: 0:00:00
    DEBUG: Trying rule: php_s; took: 0:00:00
    DEBUG: Trying rule: pip_install; took: 0:00:00
    DEBUG: Trying rule: pip_unknown_command; took: 0:00:00
    DEBUG: Trying rule: prove_recursively; took: 0:00:00
    DEBUG: Trying rule: pyenv_no_such_command; took: 0:00:00
    DEBUG: Trying rule: python_command; took: 0:00:00
    DEBUG: Trying rule: python_execute; took: 0:00:00
    DEBUG: Trying rule: python_module_error; took: 0:00:00
    DEBUG: Trying rule: quotation_marks; took: 0:00:00
    DEBUG: Trying rule: react_native_command_unrecognized; took: 0:00:00
    DEBUG: Trying rule: remove_shell_prompt_literal; took: 0:00:00
    DEBUG: Trying rule: remove_trailing_cedilla; took: 0:00:00
    DEBUG: Trying rule: rm_dir; took: 0:00:00
    DEBUG: Trying rule: scm_correction; took: 0:00:00
    DEBUG: Trying rule: sed_unterminated_s; took: 0:00:00
    DEBUG: Trying rule: sl_ls; took: 0:00:00
    DEBUG: Trying rule: ssh_known_hosts; took: 0:00:00
    DEBUG: Trying rule: sudo; took: 0:00:00
    DEBUG: Trying rule: sudo_command_from_user_path; took: 0:00:00.000998
    DEBUG: Trying rule: switch_lang; took: 0:00:00
    DEBUG: Trying rule: systemctl; took: 0:00:00
    DEBUG: Trying rule: terraform_init; took: 0:00:00.001003
    DEBUG: Trying rule: tmux; took: 0:00:00
    DEBUG: Trying rule: touch; took: 0:00:00
    DEBUG: Trying rule: tsuru_login; took: 0:00:00
    DEBUG: Trying rule: tsuru_not_command; took: 0:00:00
    DEBUG: Trying rule: unknown_command; took: 0:00:00
    DEBUG: Trying rule: unsudo; took: 0:00:00
    DEBUG: Trying rule: vagrant_up; took: 0:00:00
    DEBUG: Trying rule: whois; took: 0:00:00
    DEBUG: Trying rule: workon_doesnt_exists; took: 0:00:00
    DEBUG: Trying rule: yarn_alias; took: 0:00:00
    DEBUG: Trying rule: yarn_command_not_found; took: 0:00:00
    DEBUG: Trying rule: yarn_command_replaced; took: 0:00:00
    DEBUG: Trying rule: yarn_help; took: 0:00:00
    DEBUG: Trying rule: man_no_space; took: 0:00:00
    DEBUG: Trying rule: no_command; took: 0:00:01.310566
    DEBUG: Trying rule: missing_space_before_subcommand; took: 0:00:00.002999
    DEBUG: Trying rule: long_form_help; took: 0:00:00.001004
    DEBUG: Trying rule: history; took: 0:00:00.002004
    No fucks given
    DEBUG: Total took: 0:00:01.999125
    
    ~ took 2s
    -> PINGG
    PINGG: The term 'PINGG' is not recognized as a name of a cmdlet, function, script file, or executable program.
    Check the spelling of the name, or if a path was included, verify that the path is correct and try again.
    
    ~
    -> fuck
    DEBUG: Run with settings: {'alter_history': True,
     'debug': True,
     'env': {'GIT_TRACE': '1', 'LANG': 'C', 'LC_ALL': 'C'},
     'exclude_rules': [],
     'excluded_search_path_prefixes': [],
     'history_limit': None,
     'instant_mode': False,
     'no_colors': False,
     'num_close_matches': 3,
     'priority': {},
     'repeat': False,
     'require_confirmation': True,
     'rules': [<const: All rules enabled>],
     'slow_commands': ['lein', 'react-native', 'gradle', './gradlew', 'vagrant'],
     'user_dir': WindowsPath('C:/Users/nsdjs/.config/thefuck'),
     'wait_command': 3,
     'wait_slow_command': 15}
    DEBUG: Received output: 'PINGG' is not recognized as an internal or external command,
    operable program or batch file.
    
    DEBUG: Call: PINGG; with env: {'ALLUSERSPROFILE': 'C:\\ProgramData', 'ANDROID_HOME': 'C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk', 'ANDROID_SDK_ROOT': 'C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk', 'APPDATA': 'C:\\Users\\nsdjs\\AppData\\Roaming', 'CC': 'clang', 'CHOCOLATEYINSTALL': 'C:\\ProgramData\\chocolatey', 'CHOCOLATEYLASTPATHUPDATE': '132665810047181697', 'CHOCOLATEYTOOLSLOCATION': 'C:\\tools', 'COMMONPROGRAMFILES': 'C:\\Program Files\\Common Files', 'COMMONPROGRAMFILES(X86)': 'C:\\Program Files (x86)\\Common Files', 'COMMONPROGRAMW6432': 'C:\\Program Files\\Common Files', 'COMPUTERNAME': 'LAPTOP-EMBTSD2M', 'COMSPEC': 'C:\\WINDOWS\\system32\\cmd.exe', 'DRIVERDATA': 'C:\\Windows\\System32\\Drivers\\DriverData', 'EDITOR': 'nvim', 'FNM_ARCH': 'x64', 'FNM_DIR': 'C:\\Users\\nsdjs\\.fnm', 'FNM_LOGLEVEL': 'info', 'FNM_MULTISHELL_PATH': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp\\fnm_multishells\\21456_1624074310240', 'FNM_NODE_DIST_MIRROR': 'https://nodejs.org/dist', 'FZF_DEFAULT_COMMAND': 'rg --files', 'GOPATH': 'C:\\Users\\nsdjs\\go', 'HOMEDRIVE': 'C:', 'HOMEPATH': '\\Users\\nsdjs', 'INTEL_DEV_REDIST': 'C:\\Program Files (x86)\\Common Files\\Intel\\Shared Libraries\\', 'JAVA_HOME': 'C:\\Program Files\\OpenJDK\\openjdk-8u292-b10', 'LOCALAPPDATA': 'C:\\Users\\nsdjs\\AppData\\Local', 'LOGONSERVER': '\\\\LAPTOP-EMBTSD2M', 'MIC_LD_LIBRARY_PATH': 'C:\\Program Files (x86)\\Common Files\\Intel\\Shared Libraries\\compiler\\lib\\mic', 'NUMBER_OF_PROCESSORS': '8', 'ONEDRIVE': 'C:\\Users\\nsdjs\\OneDrive - NSW Department of Education', 'ONEDRIVECOMMERCIAL': 'C:\\Users\\nsdjs\\OneDrive - NSW Department of Education', 'ONEDRIVECONSUMER': 'C:\\Users\\nsdjs\\OneDrive', 'OPENCV_DIR': 'C:\\tools\\opencv\\build\\', 'OS': 'Windows_NT', 'PATH': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp\\fnm_multishells\\21456_1624074310240;C:\\Program Files\\PowerShell\\7;C:\\Python39\\Scripts\\;C:\\Python39\\;C:\\Program Files (x86)\\Common Files\\Oracle\\Java\\javapath;C:\\ProgramData\\Oracle\\Java\\javapath;C:\\Program Files (x86)\\Common Files\\Intel\\Shared Libraries\\redist\\intel64\\compiler;C:\\Windows\\System32;C:\\Windows;C:\\Windows\\System32\\wbem;C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\;C:\\Windows\\System32\\OpenSSH\\;C:\\Program Files\\Microsoft SQL Server\\120\\Tools\\Binn\\;C:\\src\\flutter\\bin;C:\\Users\\nsdjs\\platform-tools;C:\\Program Files (x86)\\GnuWin32\\bin;C:\\Program Files\\dotnet\\;C:\\src\\flutter\\bin\\cache\\dart-sdk\\bin;C:\\bin;C:\\Program Files\\Java\\jdk1.8.0_271\\bin;C:\\bin\\libwebp-1.1.0-windows-x64\\bin;C:\\ProgramData\\chocolatey\\bin;C:\\Program Files\\Docker\\Docker\\resources\\bin;C:\\ProgramData\\DockerDesktop\\version-bin;C:\\Program Files\\LLVM\\bin;C:\\Program Files\\PowerShell\\7\\;C:\\tools\\opencv\\build\\\\bin;C:\\bin\\lua-language-server\\bin\\Windows;C:\\bin\\danser-go;C:\\Program Files\\PuTTY\\;C:\\WINDOWS\\system32;C:\\WINDOWS;C:\\WINDOWS\\System32\\Wbem;C:\\WINDOWS\\System32\\WindowsPowerShell\\v1.0\\;C:\\WINDOWS\\System32\\OpenSSH\\;C:\\Program Files\\OpenJDK\\openjdk-8u292-b10\\bin;C:\\Program Files\\Git\\cmd;C:\\Program Files\\Go\\bin;C:\\Program Files (x86)\\Gpg4win\\..\\GnuPG\\bin;C:\\Users\\nsdjs\\scoop\\shims;C:\\Users\\nsdjs\\.windows-build-tools\\python27\\;C:\\Users\\nsdjs\\.cargo\\bin;C:\\Users\\nsdjs\\AppData\\Local\\Microsoft\\WindowsApps;C:\\Users\\nsdjs\\AppData\\Local\\Programs\\Microsoft VS Code\\bin;C:\\Users\\nsdjs\\.dotnet\\tools;C:\\Program Files (x86)\\GitHub CLI\\;C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk\\platform-tools;C:\\Users\\nsdjs\\go\\bin;C:\\tools\\neovim\\Neovim\\bin;C:\\Users\\nsdjs\\AppData\\Local\\Yarn\\bin;C:\\Users\\nsdjs\\AppData\\Local\\Android\\Sdk\\tools;C:\\Users\\nsdjs\\AppData\\Local\\Programs\\hyper\\resources\\bin;C:\\Users\\nsdjs\\Documents\\PowerShell\\Scripts;C:\\Users\\nsdjs\\AppData\\Local\\Microsoft\\WindowsApps;C:\\Users\\nsdjs\\AppData\\Local\\Programs\\Hyper\\resources\\bin;C:\\Users\\nsdjs\\go\\bin', 'PATHEXT': '.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC;.PY;.PYW;.CPL', 'POWERSHELL_DISTRIBUTION_CHANNEL': 'MSI:Windows 10 Home Single Language', 'PROCESSOR_ARCHITECTURE': 'AMD64', 'PROCESSOR_IDENTIFIER': 'AMD64 Family 23 Model 24 Stepping 1, AuthenticAMD', 'PROCESSOR_LEVEL': '23', 'PROCESSOR_REVISION': '1801', 'PROGRAMDATA': 'C:\\ProgramData', 'PROGRAMFILES': 'C:\\Program Files', 'PROGRAMFILES(X86)': 'C:\\Program Files (x86)', 'PROGRAMW6432': 'C:\\Program Files', 'PSMODULEPATH': 'C:\\Users\\nsdjs\\Documents\\PowerShell\\Modules;C:\\Program Files\\PowerShell\\Modules;c:\\program files\\powershell\\7\\Modules;C:\\Program Files\\WindowsPowerShell\\Modules;C:\\WINDOWS\\system32\\WindowsPowerShell\\v1.0\\Modules', 'PUBLIC': 'C:\\Users\\Public', 'PYTHONIOENCODING': 'utf-8', 'STARSHIP_SESSION_KEY': 'Q4FXvAPozU5rnpa9', 'STARSHIP_SHELL': 'powershell', 'SYSTEMDRIVE': 'C:', 'SYSTEMROOT': 'C:\\WINDOWS', 'TEMP': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp', 'THEFUCK_DEBUG': 'true', 'TMP': 'C:\\Users\\nsdjs\\AppData\\Local\\Temp', 'USERDOMAIN': 'LAPTOP-EMBTSD2M', 'USERDOMAIN_ROAMINGPROFILE': 'LAPTOP-EMBTSD2M', 'USERNAME': 'nsdjs', 'USERPROFILE': 'C:\\Users\\nsdjs', 'VBOX_MSI_INSTALL_PATH': 'C:\\Program Files\\Oracle\\VirtualBox\\', 'VIRTUAL_ENV_DISABLE_PROMPT': '1', 'WINDIR': 'C:\\WINDOWS', 'WSLENV': 'WT_SESSION::WT_PROFILE_ID', 'WT_PROFILE_ID': '{574e775e-4f2a-5b96-ac1e-a2962a402336}', 'WT_SESSION': 'c1e82de6-9c5e-4409-904a-b860d166f83c', 'LC_ALL': 'C', 'LANG': 'C', 'GIT_TRACE': '1'}; is slow: False took: 0:00:00.024998
    DEBUG: Importing rule: adb_unknown_command; took: 0:00:00.000998
    DEBUG: Importing rule: ag_literal; took: 0:00:00.001003
    DEBUG: Importing rule: apt_get; took: 0:00:00.027001
    DEBUG: Importing rule: apt_get_search; took: 0:00:00.001000
    DEBUG: Importing rule: apt_invalid_operation; took: 0:00:00.001999
    DEBUG: Importing rule: apt_list_upgradable; took: 0:00:00.001001
    DEBUG: Importing rule: apt_upgrade; took: 0:00:00.000999
    DEBUG: Importing rule: aws_cli; took: 0:00:00.001000
    DEBUG: Importing rule: az_cli; took: 0:00:00.001000
    DEBUG: Importing rule: brew_cask_dependency; took: 0:00:00.024999
    DEBUG: Importing rule: brew_install; took: 0:00:00.001004
    DEBUG: Importing rule: brew_link; took: 0:00:00
    DEBUG: Importing rule: brew_reinstall; took: 0:00:00.000998
    DEBUG: Importing rule: brew_uninstall; took: 0:00:00.001000
    DEBUG: Importing rule: brew_unknown_command; took: 0:00:00
    DEBUG: Importing rule: brew_update_formula; took: 0:00:00.000998
    DEBUG: Importing rule: brew_upgrade; took: 0:00:00.001004
    DEBUG: Importing rule: cargo; took: 0:00:00.001002
    DEBUG: Importing rule: cargo_no_command; took: 0:00:00.000997
    DEBUG: Importing rule: cat_dir; took: 0:00:00.000895
    DEBUG: Importing rule: cd_correction; took: 0:00:00.002998
    DEBUG: Importing rule: cd_cs; took: 0:00:00.001001
    DEBUG: Importing rule: cd_mkdir; took: 0:00:00.001001
    DEBUG: Importing rule: cd_parent; took: 0:00:00
    DEBUG: Importing rule: chmod_x; took: 0:00:00.000999
    DEBUG: Importing rule: choco_install; took: 0:00:00.010988
    DEBUG: Importing rule: composer_not_command; took: 0:00:00.001005
    DEBUG: Importing rule: conda_mistype; took: 0:00:00.000997
    DEBUG: Importing rule: cp_create_destination; took: 0:00:00.000999
    DEBUG: Importing rule: cp_omitting_directory; took: 0:00:00.000999
    DEBUG: Importing rule: cpp11; took: 0:00:00
    DEBUG: Importing rule: dirty_untar; took: 0:00:00.004007
    DEBUG: Importing rule: dirty_unzip; took: 0:00:00.002988
    DEBUG: Importing rule: django_south_ghost; took: 0:00:00
    DEBUG: Importing rule: django_south_merge; took: 0:00:00
    DEBUG: Importing rule: dnf_no_such_command; took: 0:00:00.021999
    DEBUG: Importing rule: docker_image_being_used_by_container; took: 0:00:00.001005
    DEBUG: Importing rule: docker_login; took: 0:00:00.001000
    DEBUG: Importing rule: docker_not_command; took: 0:00:00.017006
    DEBUG: Importing rule: dry; took: 0:00:00.000990
    DEBUG: Importing rule: fab_command_not_found; took: 0:00:00.000995
    DEBUG: Importing rule: fix_alt_space; took: 0:00:00.000998
    DEBUG: Importing rule: fix_file; took: 0:00:00.003004
    DEBUG: Importing rule: gem_unknown_command; took: 0:00:00.021998
    DEBUG: Importing rule: git_add; took: 0:00:00.002014
    DEBUG: Importing rule: git_add_force; took: 0:00:00.001001
    DEBUG: Importing rule: git_bisect_usage; took: 0:00:00.000999
    DEBUG: Importing rule: git_branch_delete; took: 0:00:00.001025
    DEBUG: Importing rule: git_branch_delete_checked_out; took: 0:00:00.000984
    DEBUG: Importing rule: git_branch_exists; took: 0:00:00.000998
    DEBUG: Importing rule: git_branch_list; took: 0:00:00.001000
    DEBUG: Importing rule: git_checkout; took: 0:00:00.000998
    DEBUG: Importing rule: git_clone_git_clone; took: 0:00:00.001003
    DEBUG: Importing rule: git_commit_amend; took: 0:00:00.001001
    DEBUG: Importing rule: git_commit_reset; took: 0:00:00
    DEBUG: Importing rule: git_diff_no_index; took: 0:00:00.000999
    DEBUG: Importing rule: git_diff_staged; took: 0:00:00.001000
    DEBUG: Importing rule: git_fix_stash; took: 0:00:00.001009
    DEBUG: Importing rule: git_flag_after_filename; took: 0:00:00.000996
    DEBUG: Importing rule: git_help_aliased; took: 0:00:00.001000
    DEBUG: Importing rule: git_hook_bypass; took: 0:00:00.000550
    DEBUG: Importing rule: git_lfs_mistype; took: 0:00:00.000997
    DEBUG: Importing rule: git_merge; took: 0:00:00.000999
    DEBUG: Importing rule: git_merge_unrelated; took: 0:00:00
    DEBUG: Importing rule: git_not_command; took: 0:00:00.000997
    DEBUG: Importing rule: git_pull; took: 0:00:00.001000
    DEBUG: Importing rule: git_pull_clone; took: 0:00:00.001000
    DEBUG: Importing rule: git_pull_uncommitted_changes; took: 0:00:00.001001
    DEBUG: Importing rule: git_push; took: 0:00:00.001000
    DEBUG: Importing rule: git_push_different_branch_names; took: 0:00:00.001000
    DEBUG: Importing rule: git_push_force; took: 0:00:00.002014
    DEBUG: Importing rule: git_push_pull; took: 0:00:00.000991
    DEBUG: Importing rule: git_push_without_commits; took: 0:00:00.001003
    DEBUG: Importing rule: git_rebase_merge_dir; took: 0:00:00.001988
    DEBUG: Importing rule: git_rebase_no_changes; took: 0:00:00.001001
    DEBUG: Importing rule: git_remote_delete; took: 0:00:00.000998
    DEBUG: Importing rule: git_remote_seturl_add; took: 0:00:00.001000
    DEBUG: Importing rule: git_rm_local_modifications; took: 0:00:00.001000
    DEBUG: Importing rule: git_rm_recursive; took: 0:00:00.001001
    DEBUG: Importing rule: git_rm_staged; took: 0:00:00
    DEBUG: Importing rule: git_stash; took: 0:00:00
    DEBUG: Importing rule: git_stash_pop; took: 0:00:00
    DEBUG: Importing rule: git_tag_force; took: 0:00:00
    DEBUG: Importing rule: git_two_dashes; took: 0:00:00
    DEBUG: Importing rule: go_run; took: 0:00:00.002002
    DEBUG: Importing rule: go_unknown_command; took: 0:00:00.016999
    DEBUG: Importing rule: gradle_no_task; took: 0:00:00.000988
    DEBUG: Importing rule: gradle_wrapper; took: 0:00:00
    DEBUG: Importing rule: grep_arguments_order; took: 0:00:00.000999
    DEBUG: Importing rule: grep_recursive; took: 0:00:00.000998
    DEBUG: Importing rule: grunt_task_not_found; took: 0:00:00.000997
    DEBUG: Importing rule: gulp_not_task; took: 0:00:00.001000
    DEBUG: Importing rule: has_exists_script; took: 0:00:00.001001
    DEBUG: Importing rule: heroku_multiple_apps; took: 0:00:00.000999
    DEBUG: Importing rule: heroku_not_command; took: 0:00:00.001000
    DEBUG: Importing rule: history; took: 0:00:00.001000
    DEBUG: Importing rule: hostscli; took: 0:00:00.002009
    DEBUG: Importing rule: ifconfig_device_not_found; took: 0:00:00.001997
    DEBUG: Importing rule: java; took: 0:00:00.000996
    DEBUG: Importing rule: javac; took: 0:00:00
    DEBUG: Importing rule: lein_not_task; took: 0:00:00.001002
    DEBUG: Importing rule: ln_no_hard_link; took: 0:00:00.001000
    DEBUG: Importing rule: ln_s_order; took: 0:00:00.001002
    DEBUG: Importing rule: long_form_help; took: 0:00:00.000997
    DEBUG: Importing rule: ls_all; took: 0:00:00.001002
    DEBUG: Importing rule: ls_lah; took: 0:00:00.000999
    DEBUG: Importing rule: man; took: 0:00:00.001000
    DEBUG: Importing rule: man_no_space; took: 0:00:00.000536
    DEBUG: Importing rule: mercurial; took: 0:00:00.000985
    DEBUG: Importing rule: missing_space_before_subcommand; took: 0:00:00.001993
    DEBUG: Importing rule: mkdir_p; took: 0:00:00.001002
    DEBUG: Importing rule: mvn_no_command; took: 0:00:00.000996
    DEBUG: Importing rule: mvn_unknown_lifecycle_phase; took: 0:00:00.000997
    DEBUG: Importing rule: nixos_cmd_not_found; took: 0:00:00.024002
    DEBUG: Importing rule: no_command; took: 0:00:00.001010
    DEBUG: Importing rule: no_such_file; took: 0:00:00.001997
    DEBUG: Importing rule: npm_missing_script; took: 0:00:00.004997
    DEBUG: Importing rule: npm_run_script; took: 0:00:00.000999
    DEBUG: Importing rule: npm_wrong_command; took: 0:00:00.000997
    DEBUG: Importing rule: omnienv_no_such_command; took: 0:00:00.087001
    DEBUG: Importing rule: open; took: 0:00:00.001007
    DEBUG: Importing rule: pacman; took: 0:00:00.069010
    DEBUG: Importing rule: pacman_invalid_option; took: 0:00:00.001011
    DEBUG: Importing rule: pacman_not_found; took: 0:00:00
    DEBUG: Importing rule: path_from_history; took: 0:00:00
    DEBUG: Importing rule: php_s; took: 0:00:00.001028
    DEBUG: Importing rule: pip_install; took: 0:00:00.000977
    DEBUG: Importing rule: pip_unknown_command; took: 0:00:00.000999
    DEBUG: Importing rule: port_already_in_use; took: 0:00:00.022002
    DEBUG: Importing rule: prove_recursively; took: 0:00:00.001001
    DEBUG: Importing rule: pyenv_no_such_command; took: 0:00:00.000995
    DEBUG: Importing rule: python_command; took: 0:00:00
    DEBUG: Importing rule: python_execute; took: 0:00:00.001007
    DEBUG: Importing rule: python_module_error; took: 0:00:00.000998
    DEBUG: Importing rule: quotation_marks; took: 0:00:00.001000
    DEBUG: Importing rule: react_native_command_unrecognized; took: 0:00:00
    DEBUG: Importing rule: remove_shell_prompt_literal; took: 0:00:00.000998
    DEBUG: Importing rule: remove_trailing_cedilla; took: 0:00:00.001003
    DEBUG: Importing rule: rm_dir; took: 0:00:00.000999
    DEBUG: Importing rule: rm_root; took: 0:00:00.001000
    DEBUG: Importing rule: scm_correction; took: 0:00:00.001012
    DEBUG: Importing rule: sed_unterminated_s; took: 0:00:00.001993
    DEBUG: Importing rule: sl_ls; took: 0:00:00.001001
    DEBUG: Importing rule: ssh_known_hosts; took: 0:00:00.000992
    DEBUG: Importing rule: sudo; took: 0:00:00.000999
    DEBUG: Importing rule: sudo_command_from_user_path; took: 0:00:00.000995
    DEBUG: Importing rule: switch_lang; took: 0:00:00.001002
    DEBUG: Importing rule: systemctl; took: 0:00:00.001000
    DEBUG: Importing rule: terraform_init; took: 0:00:00.001000
    DEBUG: Importing rule: test.py; took: 0:00:00.001002
    DEBUG: Importing rule: tmux; took: 0:00:00.001001
    DEBUG: Importing rule: touch; took: 0:00:00.000996
    DEBUG: Importing rule: tsuru_login; took: 0:00:00.001000
    DEBUG: Importing rule: tsuru_not_command; took: 0:00:00.000999
    DEBUG: Importing rule: unknown_command; took: 0:00:00.000993
    DEBUG: Importing rule: unsudo; took: 0:00:00.000998
    DEBUG: Importing rule: vagrant_up; took: 0:00:00.001006
    DEBUG: Importing rule: whois; took: 0:00:00.001000
    DEBUG: Importing rule: workon_doesnt_exists; took: 0:00:00.000995
    DEBUG: Importing rule: yarn_alias; took: 0:00:00.001004
    DEBUG: Importing rule: yarn_command_not_found; took: 0:00:00.001995
    DEBUG: Importing rule: yarn_command_replaced; took: 0:00:00.001003
    DEBUG: Importing rule: yarn_help; took: 0:00:00.001001
    DEBUG: Importing rule: yum_invalid_operation; took: 0:00:00.024999
    DEBUG: Trying rule: path_from_history; took: 0:00:00.001002
    DEBUG: Trying rule: cd_cs; took: 0:00:00
    DEBUG: Trying rule: dry; took: 0:00:00
    DEBUG: Trying rule: git_hook_bypass; took: 0:00:00
    DEBUG: Trying rule: git_stash_pop; took: 0:00:00
    DEBUG: Trying rule: test.py; took: 0:00:00
    DEBUG: Trying rule: adb_unknown_command; took: 0:00:00
    DEBUG: Trying rule: ag_literal; took: 0:00:00
    DEBUG: Trying rule: aws_cli; took: 0:00:00
    DEBUG: Trying rule: az_cli; took: 0:00:00
    DEBUG: Trying rule: brew_link; took: 0:00:00
    DEBUG: Trying rule: brew_reinstall; took: 0:00:00
    DEBUG: Trying rule: brew_uninstall; took: 0:00:00
    DEBUG: Trying rule: brew_update_formula; took: 0:00:00
    DEBUG: Trying rule: cargo; took: 0:00:00
    DEBUG: Trying rule: cargo_no_command; took: 0:00:00
    DEBUG: Trying rule: cat_dir; took: 0:00:00
    DEBUG: Trying rule: cd_correction; took: 0:00:00
    DEBUG: Trying rule: cd_mkdir; took: 0:00:00
    DEBUG: Trying rule: cd_parent; took: 0:00:00
    DEBUG: Trying rule: chmod_x; took: 0:00:00
    DEBUG: Trying rule: choco_install; took: 0:00:00
    DEBUG: Trying rule: composer_not_command; took: 0:00:00
    DEBUG: Trying rule: conda_mistype; took: 0:00:00
    DEBUG: Trying rule: cp_create_destination; took: 0:00:00
    DEBUG: Trying rule: cp_omitting_directory; took: 0:00:00
    DEBUG: Trying rule: cpp11; took: 0:00:00
    DEBUG: Trying rule: dirty_untar; took: 0:00:00
    DEBUG: Trying rule: dirty_unzip; took: 0:00:00
    DEBUG: Trying rule: django_south_ghost; took: 0:00:00
    DEBUG: Trying rule: django_south_merge; took: 0:00:00
    DEBUG: Trying rule: docker_image_being_used_by_container; took: 0:00:00
    DEBUG: Trying rule: docker_login; took: 0:00:00
    DEBUG: Trying rule: docker_not_command; took: 0:00:00
    DEBUG: Trying rule: fab_command_not_found; took: 0:00:00.000996
    DEBUG: Trying rule: fix_alt_space; took: 0:00:00
    DEBUG: Trying rule: fix_file; took: 0:00:00
    DEBUG: Trying rule: gem_unknown_command; took: 0:00:00
    DEBUG: Trying rule: git_add; took: 0:00:00
    DEBUG: Trying rule: git_add_force; took: 0:00:00
    DEBUG: Trying rule: git_bisect_usage; took: 0:00:00.001002
    DEBUG: Trying rule: git_branch_delete; took: 0:00:00
    DEBUG: Trying rule: git_branch_delete_checked_out; took: 0:00:00
    DEBUG: Trying rule: git_branch_exists; took: 0:00:00.000996
    DEBUG: Trying rule: git_branch_list; took: 0:00:00
    DEBUG: Trying rule: git_checkout; took: 0:00:00
    DEBUG: Trying rule: git_clone_git_clone; took: 0:00:00.001002
    DEBUG: Trying rule: git_commit_amend; took: 0:00:00
    DEBUG: Trying rule: git_commit_reset; took: 0:00:00
    DEBUG: Trying rule: git_diff_no_index; took: 0:00:00
    DEBUG: Trying rule: git_diff_staged; took: 0:00:00
    DEBUG: Trying rule: git_fix_stash; took: 0:00:00
    DEBUG: Trying rule: git_flag_after_filename; took: 0:00:00
    DEBUG: Trying rule: git_help_aliased; took: 0:00:00
    DEBUG: Trying rule: git_lfs_mistype; took: 0:00:00
    DEBUG: Trying rule: git_merge; took: 0:00:00
    DEBUG: Trying rule: git_merge_unrelated; took: 0:00:00
    DEBUG: Trying rule: git_not_command; took: 0:00:00
    DEBUG: Trying rule: git_pull; took: 0:00:00
    DEBUG: Trying rule: git_pull_clone; took: 0:00:00
    DEBUG: Trying rule: git_pull_uncommitted_changes; took: 0:00:00
    DEBUG: Trying rule: git_push; took: 0:00:00
    DEBUG: Trying rule: git_push_different_branch_names; took: 0:00:00
    DEBUG: Trying rule: git_push_pull; took: 0:00:00
    DEBUG: Trying rule: git_push_without_commits; took: 0:00:00
    DEBUG: Trying rule: git_rebase_merge_dir; took: 0:00:00
    DEBUG: Trying rule: git_rebase_no_changes; took: 0:00:00
    DEBUG: Trying rule: git_remote_delete; took: 0:00:00
    DEBUG: Trying rule: git_remote_seturl_add; took: 0:00:00.000999
    DEBUG: Trying rule: git_rm_local_modifications; took: 0:00:00
    DEBUG: Trying rule: git_rm_recursive; took: 0:00:00
    DEBUG: Trying rule: git_rm_staged; took: 0:00:00
    DEBUG: Trying rule: git_stash; took: 0:00:00
    DEBUG: Trying rule: git_tag_force; took: 0:00:00
    DEBUG: Trying rule: git_two_dashes; took: 0:00:00
    DEBUG: Trying rule: go_run; took: 0:00:00
    DEBUG: Trying rule: go_unknown_command; took: 0:00:00
    DEBUG: Trying rule: gradle_no_task; took: 0:00:00
    DEBUG: Trying rule: gradle_wrapper; took: 0:00:00
    DEBUG: Trying rule: grep_arguments_order; took: 0:00:00
    DEBUG: Trying rule: grep_recursive; took: 0:00:00
    DEBUG: Trying rule: grunt_task_not_found; took: 0:00:00
    DEBUG: Trying rule: gulp_not_task; took: 0:00:00
    DEBUG: Trying rule: has_exists_script; took: 0:00:00
    DEBUG: Trying rule: heroku_multiple_apps; took: 0:00:00
    DEBUG: Trying rule: heroku_not_command; took: 0:00:00.001002
    DEBUG: Trying rule: hostscli; took: 0:00:00
    DEBUG: Trying rule: ifconfig_device_not_found; took: 0:00:00
    DEBUG: Trying rule: java; took: 0:00:00
    DEBUG: Trying rule: javac; took: 0:00:00
    DEBUG: Trying rule: lein_not_task; took: 0:00:00
    DEBUG: Trying rule: ln_no_hard_link; took: 0:00:00
    DEBUG: Trying rule: ln_s_order; took: 0:00:00
    DEBUG: Trying rule: ls_all; took: 0:00:00
    DEBUG: Trying rule: ls_lah; took: 0:00:00
    DEBUG: Trying rule: man; took: 0:00:00
    DEBUG: Trying rule: mercurial; took: 0:00:00
    DEBUG: Trying rule: mkdir_p; took: 0:00:00.000999
    DEBUG: Trying rule: mvn_no_command; took: 0:00:00
    DEBUG: Trying rule: mvn_unknown_lifecycle_phase; took: 0:00:00
    DEBUG: Trying rule: no_such_file; took: 0:00:00.000999
    DEBUG: Trying rule: npm_missing_script; took: 0:00:00
    DEBUG: Trying rule: npm_run_script; took: 0:00:00
    DEBUG: Trying rule: npm_wrong_command; took: 0:00:00
    DEBUG: Trying rule: open; took: 0:00:00
    DEBUG: Trying rule: pacman_invalid_option; took: 0:00:00
    DEBUG: Trying rule: php_s; took: 0:00:00
    DEBUG: Trying rule: pip_install; took: 0:00:00
    DEBUG: Trying rule: pip_unknown_command; took: 0:00:00
    DEBUG: Trying rule: prove_recursively; took: 0:00:00.001019
    DEBUG: Trying rule: pyenv_no_such_command; took: 0:00:00
    DEBUG: Trying rule: python_command; took: 0:00:00
    DEBUG: Trying rule: python_execute; took: 0:00:00
    DEBUG: Trying rule: python_module_error; took: 0:00:00
    DEBUG: Trying rule: quotation_marks; took: 0:00:00
    DEBUG: Trying rule: react_native_command_unrecognized; took: 0:00:00
    DEBUG: Trying rule: remove_shell_prompt_literal; took: 0:00:00
    DEBUG: Trying rule: remove_trailing_cedilla; took: 0:00:00
    DEBUG: Trying rule: rm_dir; took: 0:00:00
    DEBUG: Trying rule: scm_correction; took: 0:00:00
    DEBUG: Trying rule: sed_unterminated_s; took: 0:00:00
    DEBUG: Trying rule: sl_ls; took: 0:00:00
    DEBUG: Trying rule: ssh_known_hosts; took: 0:00:00
    DEBUG: Trying rule: sudo; took: 0:00:00
    DEBUG: Trying rule: sudo_command_from_user_path; took: 0:00:00
    DEBUG: Trying rule: switch_lang; took: 0:00:00
    DEBUG: Trying rule: systemctl; took: 0:00:00
    DEBUG: Trying rule: terraform_init; took: 0:00:00
    DEBUG: Trying rule: tmux; took: 0:00:00
    DEBUG: Trying rule: touch; took: 0:00:00
    DEBUG: Trying rule: tsuru_login; took: 0:00:00
    DEBUG: Trying rule: tsuru_not_command; took: 0:00:00
    DEBUG: Trying rule: unknown_command; took: 0:00:00
    DEBUG: Trying rule: unsudo; took: 0:00:00
    DEBUG: Trying rule: vagrant_up; took: 0:00:00
    DEBUG: Trying rule: whois; took: 0:00:00
    DEBUG: Trying rule: workon_doesnt_exists; took: 0:00:00
    DEBUG: Trying rule: yarn_alias; took: 0:00:00
    DEBUG: Trying rule: yarn_command_not_found; took: 0:00:00
    DEBUG: Trying rule: yarn_command_replaced; took: 0:00:00
    DEBUG: Trying rule: yarn_help; took: 0:00:00
    DEBUG: Trying rule: man_no_space; took: 0:00:00
    DEBUG: Trying rule: no_command; took: 0:00:01.250587
    PING.EXE [enter/↑/↓/ctrl+c]
    Aborted
    DEBUG: Total took: 0:00:03.401632
    

    If the bug only appears with a specific application, the output of that application and its version:

    Nope - this happens with any executables that have uppercase names.
    

    Anything else you think is relevant:

    This is probably an issue with difflib.get_close_matches() as its case-sensitive. Also sorry for the large debug section.
    
    enhancement help wanted hacktoberfest HackIllinois 
    opened by neelkarma 1
  • The Fuck Does not Respect Aliases in Shell

    The Fuck Does not Respect Aliases in Shell

    The output of thefuck --version:

    The Fuck 3.30-3
    Python 3.9.4-1
    Zsh 5.8-1
    

    System:

    Arch Linux (Kernel version 5.11.16.arch1-1)
    

    How to reproduce the bug:

    Run any command which is actually an alias for another. e.g: In my .zshrc, I have a line like this:

    alias ginit="~/.ginit.sh"
    

    If I were to type something like gnit [in this case], then run fuck, The Fuck would find nothing.

    Is there some way for fuck to actively know about typos in aliases or is that a bit far off from its purpose as an application?

    opened by toydotgame 12
  • EOL (end of line) issue on windows

    EOL (end of line) issue on windows

    The output of thefuck --version (something like The Fuck 3.1 using Python 3.5.0 and Bash 4.4.12(1)-release):

    The Fuck 3.30 using Python 3.8.3 and ZSH 5.8
    

    Your system (Debian 7, ArchLinux, Windows, etc.):

    Windows 10 1909, cygwin and conemu
    

    How to reproduce the bug:

    In my environment, the commands generated by thefuck ends with "^M". It seems it's because all the output of thefuck ends with "\r\n" on windows. However, the zsh can only process commands end with "\n".

    For example, when I run eval $(thefuck --alias), the error message is

    zsh: parse error near `^M'
    

    Any idea about this issue? Thank you.

    help wanted windows 
    opened by cy18 1
Releases(3.31)
  • 3.31(Jun 9, 2021)

    • add excluded_search_path_prefixes setting #1165
    • add cd_cs rule #1167
    • extend pyenv rule to include goenv, nodenv and rbenv #1100
    • add conda rule #1138
    • add python_module_error rule #1151
    • fix possible changes in files outside of working directory in dirty_unzip and dirty_untar rules #1206
    • various improvements and bugfixes
    Source code(tar.gz)
    Source code(zip)
  • 3.30(Mar 19, 2020)

    • new nixos_cmd_not_found rule (#912, #922)
    • new terraform_init rule (#924)
    • new docker_image_being_used_by_container rule (#925, #928)
    • new go_unknown_command rule (#933)
    • new yum_invalid_operation rule (#968)
    • new git_branch_delete_checked_out rule (#985)
    • new remove_shell_prompt_literal rule (#996)
    • new choco_install rule (#998)
    • new cp_create_destination rule (#1061)
    • Korean support in switch_lang rule (#880, #981)
    • fix recursive shell nesting (#921, #923)
    • fix support of non-English output in apt_list_upgradable (#931)
    • fix git_checkout with git 2.22.0 (#934)
    • fix docker_not_command with newer docker versions (#937, #940)
    • fix rules_git_checkout with branches with slashes (#944)
    • fix apt_invalid_operation behaviour with apt uninstall (#950)
    • fix slow commands time out (#961)
    • fix powershell support (#1004)
    • fix apt_invalid_operation with newer apt-get versions (#1031)
    • fix pip_unknown_command (#1047, #1059)
    Source code(tar.gz)
    Source code(zip)
  • 3.29(May 27, 2019)

    • new pyenv_no_such_command rule (#918)
    • new pip_install rule (#895)
    • new docker_login rule (#894)
    • new git_commit_reset rule (#886)
    • yay support in pacman and pacman_not_found rules (#907)
    • Greek support in switch_lang rule (#862, #864)
    • support of -y/--yeah command line args in Fish Shell (#900)
    • improved fetching of shells version (#920)
    • improved windows support (#902, #917)
    • bugfixes (#861, #869, #872, #874)
    Source code(tar.gz)
    Source code(zip)
  • 3.28(Nov 29, 2018)

    • Ukrainian layout support in switch_lang rule (#855)
    • pwsh support (#844)
    • BSD style output support in touch rule (#360)
    • --yeah as an alternative arg to -y and --yes (#822)
    • bug fixes: #854, #835, #842, #827, #820, #818, #819
    Source code(tar.gz)
    Source code(zip)
  • 3.27(May 22, 2018)

  • 3.26(Apr 25, 2018)

    • Ubuntu 18.04 support (#786)
    • Improved fish alias (#727)
    • New unsudo rule (#787)
    • New git_merge_unrelated rule (#773)
    • New git_commit_amend rule (#664)
    • New adb_unknown_command rule (#765)
    • New apt_upgrade rule (#761)
    • New git_merge rule (#629)
    • Improved cd_mkdir rule (#784)
    • Improved cd_correction rule (#784)
    • Improved switch_lang rule (#776)
    • Improved git_branch_exists rule (#762)
    • Improved git_push rule (#740)
    • Improved git_checkout rule (#632)
    • No longer rely on $SHELL for detecting shell (#783)
    Source code(tar.gz)
    Source code(zip)
  • 3.25(Nov 23, 2017)

    • add support of third-party packages with rules (#737);
    • fix Windows support (#715);
    • fix zsh alias (#733);
    • new rule: heroku_multiple_apps – add --app <app> to heroku commands like heroku pg (#729);
    • new rule: apt_list_upgradable – helps you run apt list --upgradable after apt update (#732);
    • minor bug fixes.
    Source code(tar.gz)
    Source code(zip)
  • 3.24(Oct 16, 2017)

    • instant fuck mode support on macOS (#682);
    • command selection with ctrl+n and ctrl+p instead of and (#711);
    • improvements in cache (#707);
    • fixed exception in python3 + fish (#708);
    • fixed configuration code for fish shell (#658);
    • support parameters in PowerShell (#696);
    • rules api changed, Command.output instead of stdout/stderr (#682, #691);
    • multiline PS1 with instant mode (#692);
    • add php_s rule that replaces -s by -S when trying to run a local php server (#655);
    • add dnf_no_such_command rule that fixes mistyped DNF commands (#698);
    • add git_remote_delete rule that replaces git remote delete remote_name with git remote remove remote_name (#670);
    • add git_push_different_branch_names rule that fixes pushes when local brach name does not match remote branch name (#652);
    • add prove_recursively rule that adds -r when called with directory;
    • add brew_cask_dependency rule that installs cask dependencies;
    • fix brew_update_formula rule (#710).
    Source code(tar.gz)
    Source code(zip)
  • 3.23(Aug 29, 2017)

  • 3.22(Aug 28, 2017)

  • 3.21(Aug 21, 2017)

    Before:

    thefuck git br THEFUCK_ARGUMENT_PLACEHOLDER -y  0,36s user 0,02s system 97% cpu 0,383 total
    thefuck --alias  0,29s user 0,01s system 99% cpu 0,303 total
    

    After:

    thefuck git br THEFUCK_ARGUMENT_PLACEHOLDER -y  0,19s user 0,03s system 94% cpu 0,234 total
    thefuck --alias  0,13s user 0,02s system 99% cpu 0,149 total
    
    Source code(tar.gz)
    Source code(zip)
  • 3.20(Aug 16, 2017)

  • 3.19(Aug 3, 2017)

  • 3.18(May 10, 2017)

  • 3.17(May 10, 2017)

    • fix support of bash aliases (#549, #645)
    • appropriate message instead of "No fucks given" when alias isn't fuck (#635)
    • fix encoding with bash (#643)
    • fix suggestion on yarn require ... (#637)
    Source code(tar.gz)
    Source code(zip)
  • 3.16(Apr 10, 2017)

    • Repeated fucking fucks up with UnicodeDecodeError (Python 2.7.6) #623
    • Improve handling of command line arguments #620
    • idea: fuck-it repeatedly until command works #614
    • allow for a flag that executes immediately #531
    • Please put eval $(thefuck --alias) in your ~/.zshrc. #585
    Source code(tar.gz)
    Source code(zip)
Owner
Vladimir Iakovlev
Software Developer
Vladimir Iakovlev
Command-line program to download videos from YouTube.com and other video sites

youtube-dl - download videos from youtube.com or other video platforms INSTALLATION DESCRIPTION OPTIONS CONFIGURATION OUTPUT TEMPLATE FORMAT SELECTION

youtube-dl 100.2k Sep 15, 2021
:cherry_blossom: A command-line fuzzy finder

fzf is a general-purpose command-line fuzzy finder. It's an interactive Unix filter for command-line that can be used with any list; files, command hi

Junegunn Choi 39.1k Sep 17, 2021
:mag: Google from the terminal

googler is a power tool to Google (web, news, videos and site search) from the command-line. It shows the title, URL and abstract for each result, whi

Piña Colada 5.3k Sep 18, 2021
A smart and nice Twitter client on terminal written in Python.

A Note about Twitter API Change Heads-up! As Twitter discontinues supporting Stream API, RainbowStream's stream function has been stopped working for

orakaro.targaryen 3.3k Sep 14, 2021
A fast CSV command line toolkit written in Rust.

xsv is a command line program for indexing, slicing, analyzing, splitting and joining CSV files. Commands should be simple, fast and composable: Simpl

Andrew Gallant 7.6k Sep 21, 2021
:bookmark: Browser-independent bookmark manager

buku buku in action! Introduction buku is a powerful bookmark manager written in Python3 and SQLite3. When I started writing it, I couldn't find a fle

Piña Colada 4.7k Sep 17, 2021
:zap: A new cd command that helps you navigate faster by learning your habits.

z.lua A command line tool which helps you navigate faster by learning your habits ⚡ An alternative to z.sh with windows and posix shells support and v

Linwei 2.1k Sep 14, 2021
:duck: DuckDuckGo from the terminal

ddgr ddgr is a cmdline utility to search DuckDuckGo (html version) from the terminal. While googler is extremely popular among cmdline users, in many

Piña Colada 2.1k Sep 22, 2021
A smarter cd command for your terminal

zoxide A smarter cd command for your terminal zoxide is a blazing fast replacement for your cd command, inspired by z and z.lua. It keeps track of the

Ajeet D'Souza 3.7k Sep 15, 2021
htop is an interactive text-mode process viewer for Unix systems. It aims to be a better 'top'.

htop by Hisham Muhammad [email protected] This repository is archived as htop is now maintained by a team of volunteers at htop.dev using an organi

Hisham Muhammad 5.6k Sep 15, 2021
Command-line program to download image galleries and collections from several image hosting sites

gallery-dl gallery-dl is a command-line program to download image galleries and collections from several image hosting sites (see Supported Sites). It

Mike Fährmann 3.8k Sep 17, 2021
A new way to see and navigate directory trees : https://dystroy.org/broot

Broot A better way to navigate directories Install Broot Get an overview of a directory, even a big one br -s Notice the unlisted? That's what makes i

Canop 6.1k Sep 15, 2021
A code-searching tool similar to ack, but faster.

The Silver Searcher A code searching tool similar to ack, with a focus on speed. Do you know C? Want to improve ag? I invite you to pair with me. What

Geoff Greer 22.5k Sep 15, 2021
Glances an Eye on your system. A top/htop alternative for GNU/Linux, BSD, Mac OS and Windows operating systems.

Glances - An eye on your system Summary Glances is a cross-platform monitoring tool which aims to present a large amount of monitoring information thr

Nicolas Hennion 19.2k Sep 15, 2021
A modern replacement for ‘ls’.

exa exa is a modern replacement for ls. README Sections: Options — Installation — Development exa is a modern replacement for the venerable file-listi

Benjamin Sago 14.7k Sep 24, 2021
Linux Kernel Manager and Activity Monitor 🐧💻

Linux Kernel Manager and Activity Monitor ?? ?? The kernel is the part of the operating system that facilitates interactions between hardware and soft

Orhun Parmaksız 1.3k Sep 14, 2021
Terminal-based CPU stress and monitoring utility

The Stress Terminal UI: s-tui Stress-Terminal UI, s-tui, monitors CPU temperature, frequency, power and utilization in a graphical way from the termin

Alex Manuskin 2.7k Sep 14, 2021
An RSS/Atom feed reader for text terminals

Newsboat Newsboat is an RSS/Atom feed reader for the text console. It's an actively maintained fork of Newsbeuter. A feed reader pulls updates directl

Newsboat 1.7k Sep 16, 2021