Mercurial > dotfiles
view .shell.d/99.mcfly.zsh @ 527:e69d3e15b1b7 default tip
prompt: xterm-ghostty is good too
author | Augie Fackler <raf@durin42.com> |
---|---|
date | Mon, 06 Jan 2025 11:10:48 -0500 |
parents | ea947b2b04a0 |
children |
line wrap: on
line source
#!/bin/zsh # Ensure stdin is a tty [[ -t 0 ]] || return # Make sure mcfly is installed if ! which mcfly > /dev/null ; then return 0 fi # Avoid loading this file more than once if [[ "$__MCFLY_LOADED" == "loaded" ]]; then return 0 fi __MCFLY_LOADED="loaded" emulate -L zsh # Ensure HISTFILE exists. export HISTFILE="${HISTFILE:-$HOME/.zsh_history}" if [[ ! -r "${HISTFILE}" ]]; then echo "McFly: ${HISTFILE} does not exist or is not readable. Please fix this or set HISTFILE to something else before using McFly." return 1 fi # MCFLY_SESSION_ID is used by McFly internally to keep track of the commands from a particular terminal session. export MCFLY_SESSION_ID=$(dd if=/dev/urandom bs=256 count=1 2> /dev/null | env LC_ALL=C tr -dc 'a-zA-Z0-9' | head -c 24) # Find the binary MCFLY_PATH=${MCFLY_PATH:-$(which mcfly)} if [[ -z "$MCFLY_PATH" || "$MCFLY_PATH" == "mcfly not found" ]]; then echo "Cannot find the mcfly binary, please make sure that mcfly is in your path before sourcing mcfly.bash." return 1 fi # Required for commented out mcfly search commands to work. setopt interactive_comments # allow comments in interactive shells (like Bash does) # McFly's temporary, per-session history file. if [[ ! -f "${MCFLY_HISTORY}" ]]; then export MCFLY_HISTORY=$(mktemp -t mcfly.XXXXXXXX) fi # Setup a function to be used by $PROMPT_COMMAND. function mcfly_prompt_command { local exit_code=$? # Record exit status of previous command. # Populate McFly's temporary, per-session history file from recent commands in the shell's primary HISTFILE. if [[ ! -f "${MCFLY_HISTORY}" ]]; then export MCFLY_HISTORY=$(mktemp -t mcfly.XXXXXXXX) tail -n100 "${HISTFILE}" >| ${MCFLY_HISTORY} fi # Write history to $MCFLY_HISTORY. fc -W "${MCFLY_HISTORY}" # Run mcfly with the saved code. It fill find the text of the last command in $MCFLY_HISTORY and save it to the database. [ -n "$MCFLY_DEBUG" ] && echo "mcfly.zsh: Run mcfly add --exit ${exit_code}" $MCFLY_PATH --history_format zsh add --exit ${exit_code} return ${exit_code} # Restore the original exit code by returning it. } precmd_functions+=(mcfly_prompt_command) # Cleanup $MCFLY_HISTORY tmp files on exit. exit_logger() { [ -n "$MCFLY_DEBUG" ] && echo "mcfly.zsh: Exiting and removing $MCFLY_HISTORY" rm -f $MCFLY_HISTORY } zshexit_functions+=(exit_logger) # If this is an interactive shell, take ownership of ctrl-r. if [[ $- =~ .*i.* ]]; then mcfly-history-widget() { () { echoti rmkx exec </dev/tty local mcfly_output=$(mktemp -t mcfly.output.XXXXXXXX) $MCFLY_PATH --history_format zsh search -o "${mcfly_output}" "${LBUFFER}" echoti smkx # Interpret commandline/run requests from McFly while read -r key val; do if [[ "$key" = "mode" ]]; then local mode="$val"; fi if [[ "$key" = "commandline" ]]; then local commandline="$val"; fi done < "${mcfly_output}" rm -f $mcfly_output if [[ -n $commandline ]]; then RBUFFER="" LBUFFER="${commandline}" fi if [[ "${mode}" == "run" ]]; then zle accept-line fi zle redisplay } } zle -N mcfly-history-widget bindkey '^[OP' mcfly-history-widget fi