e502cff8cb
- conf.d/fzf.fish: skip fzf_configure_bindings if fzf is not in PATH - key_bindings.fish: only bind Ctrl+Alt+= when qalc is installed - _qalc_eval: return 1 early if qalc is absent so callers can react - _smart_execute: fall back to normal execute when _qalc_eval returns 1 - integrations/fzf.fish: replace bg-transform with transform (available since fzf 0.53; bg-transform requires a newer version and caused "unknown action" errors on fzf 0.60 devel)
68 lines
4.1 KiB
Fish
68 lines
4.1 KiB
Fish
# Copyright (C) 2026 Rootiest
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
#
|
|
# ╭──────────────────────────────────────────────────────────╮
|
|
# │ Fish User Key Bindings │
|
|
# ╰──────────────────────────────────────────────────────────╯
|
|
#
|
|
# This file defines custom key bindings for the Fish shell.
|
|
# It is sourced by Fish on startup.
|
|
|
|
# ────────────────── Bind Prewious Path Head to Ctrl+G ─────────────────
|
|
# Bindings to insert the previous path head into the command line
|
|
# Behaves like `!$:h` does in bash
|
|
#
|
|
# Example: If the previous command was `cd /usr/local/bin`
|
|
# pressing Ctrl+G will insert `/usr/local` into the command line.
|
|
# ──────────────────────────────────────────────────────────────────────
|
|
|
|
# ──────────── Bind Interactive History Substitution to Ctrl+F ─────────
|
|
# Bindings to perform substitution on the previous command in the history
|
|
# Behaves like `!!:s/old/new/` does in bash
|
|
#
|
|
# Example: If the previous command was `echo this is a test`
|
|
# typing `this is/that was` and pressing Ctrl+F
|
|
# will insert `echo that was a test` into the command line.
|
|
# ──────────────────────────────────────────────────────────────────────
|
|
|
|
# ────────── Bind Replace First Command Token to Ctrl+Alt+U ────────────
|
|
# Strips the first command token and places cursor at start to retype it
|
|
#
|
|
# Example: If the current command text is `mkdir new_folder`
|
|
# pressing Ctrl+Alt+U will change the command line to ` new_folder`
|
|
# with the cursor at the start, allowing you to quickly change the command
|
|
# while keeping the arguments intact.
|
|
# To produce `cd new_folder` or `rm new_folder` etc.
|
|
# If the current command text is empty, the previous command's first token will be used instead.
|
|
# ──────────────────────────────────────────────────────────────────────
|
|
|
|
# ────────────── Bind Quick Qalc Evaluation to Ctrl+Alt+= ──────────────
|
|
# Passes the current command line buffer to the Qalculate! CLI (qalc)
|
|
#
|
|
# Example: If you type `150 * 1.08` and press Ctrl+Alt+=,
|
|
# it will print the result (162) and clear the command line.
|
|
# This allows for rapid-fire math without leaving the current shell.
|
|
# ──────────────────────────────────────────────────────────────────────
|
|
|
|
function fish_user_key_bindings
|
|
|
|
# ───────────────────────────── Set Bindings ─────────────────────────────
|
|
#
|
|
# Set Emacs mode bindings:
|
|
bind ctrl-g __insert_previous_path_head
|
|
bind ctrl-f __interactive_history_sub
|
|
bind ctrl-alt-u _replace_command_token
|
|
type -q qalc && bind ctrl-alt-= _qalc_eval
|
|
bind ctrl-enter _smart_execute
|
|
|
|
# Set bindings for all Vi modes:
|
|
# 'default' is Vi-Command, 'insert' is Vi-Insert, 'visual' is Vi-Visual
|
|
for mode in default insert visual
|
|
bind --mode $mode ctrl-g __insert_previous_path_head
|
|
bind --mode $mode ctrl-f __interactive_history_sub
|
|
bind --mode $mode ctrl-alt-u _replace_command_token
|
|
type -q qalc && bind --mode $mode ctrl-alt-= _qalc_eval
|
|
bind --mode $mode ctrl-enter _smart_execute
|
|
end
|
|
end
|