Mercurial > dotfiles
comparison .shell.d/99.iterm2_integration.zsh @ 520:9af1fc9b713c
zsh: enable iterm2 integration
This is the iterm2 integration script as of today. Squinting a bit,
this looks like the version of the file from
https://github.com/gnachman/iTerm2/commit/3d8173763e1e7f53c08a7da52fc92db4e036395a,
which is the most recent edit to the file on github.
| author | Augie Fackler <raf@durin42.com> |
|---|---|
| date | Thu, 14 Jul 2022 14:08:25 -0400 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| 519:d3219c644f43 | 520:9af1fc9b713c |
|---|---|
| 1 # This program is free software; you can redistribute it and/or | |
| 2 # modify it under the terms of the GNU General Public License | |
| 3 # as published by the Free Software Foundation; either version 2 | |
| 4 # of the License, or (at your option) any later version. | |
| 5 # | |
| 6 # This program is distributed in the hope that it will be useful, | |
| 7 # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 8 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 9 # GNU General Public License for more details. | |
| 10 # | |
| 11 # You should have received a copy of the GNU General Public License | |
| 12 # along with this program; if not, write to the Free Software | |
| 13 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | |
| 14 | |
| 15 if [[ -o interactive ]]; then | |
| 16 if [ "${ITERM_ENABLE_SHELL_INTEGRATION_WITH_TMUX-}""$TERM" != "screen" -a "${ITERM_SHELL_INTEGRATION_INSTALLED-}" = "" -a "$TERM" != linux -a "$TERM" != dumb ]; then | |
| 17 ITERM_SHELL_INTEGRATION_INSTALLED=Yes | |
| 18 ITERM2_SHOULD_DECORATE_PROMPT="1" | |
| 19 # Indicates start of command output. Runs just before command executes. | |
| 20 iterm2_before_cmd_executes() { | |
| 21 if [ "$TERM_PROGRAM" = "iTerm.app" ]; then | |
| 22 printf "\033]133;C;\r\007" | |
| 23 else | |
| 24 printf "\033]133;C;\007" | |
| 25 fi | |
| 26 } | |
| 27 | |
| 28 iterm2_set_user_var() { | |
| 29 printf "\033]1337;SetUserVar=%s=%s\007" "$1" $(printf "%s" "$2" | base64 | tr -d '\n') | |
| 30 } | |
| 31 | |
| 32 # Users can write their own version of this method. It should call | |
| 33 # iterm2_set_user_var but not produce any other output. | |
| 34 # e.g., iterm2_set_user_var currentDirectory $PWD | |
| 35 # Accessible in iTerm2 (in a badge now, elsewhere in the future) as | |
| 36 # \(user.currentDirectory). | |
| 37 whence -v iterm2_print_user_vars > /dev/null 2>&1 | |
| 38 if [ $? -ne 0 ]; then | |
| 39 iterm2_print_user_vars() { | |
| 40 true | |
| 41 } | |
| 42 fi | |
| 43 | |
| 44 iterm2_print_state_data() { | |
| 45 local _iterm2_hostname="${iterm2_hostname-}" | |
| 46 if [ -z "${iterm2_hostname:-}" ]; then | |
| 47 _iterm2_hostname=$(hostname -f 2>/dev/null) | |
| 48 fi | |
| 49 printf "\033]1337;RemoteHost=%s@%s\007" "$USER" "${_iterm2_hostname-}" | |
| 50 printf "\033]1337;CurrentDir=%s\007" "$PWD" | |
| 51 iterm2_print_user_vars | |
| 52 } | |
| 53 | |
| 54 # Report return code of command; runs after command finishes but before prompt | |
| 55 iterm2_after_cmd_executes() { | |
| 56 printf "\033]133;D;%s\007" "$STATUS" | |
| 57 iterm2_print_state_data | |
| 58 } | |
| 59 | |
| 60 # Mark start of prompt | |
| 61 iterm2_prompt_mark() { | |
| 62 printf "\033]133;A\007" | |
| 63 } | |
| 64 | |
| 65 # Mark end of prompt | |
| 66 iterm2_prompt_end() { | |
| 67 printf "\033]133;B\007" | |
| 68 } | |
| 69 | |
| 70 # There are three possible paths in life. | |
| 71 # | |
| 72 # 1) A command is entered at the prompt and you press return. | |
| 73 # The following steps happen: | |
| 74 # * iterm2_preexec is invoked | |
| 75 # * PS1 is set to ITERM2_PRECMD_PS1 | |
| 76 # * ITERM2_SHOULD_DECORATE_PROMPT is set to 1 | |
| 77 # * The command executes (possibly reading or modifying PS1) | |
| 78 # * iterm2_precmd is invoked | |
| 79 # * ITERM2_PRECMD_PS1 is set to PS1 (as modified by command execution) | |
| 80 # * PS1 gets our escape sequences added to it | |
| 81 # * zsh displays your prompt | |
| 82 # * You start entering a command | |
| 83 # | |
| 84 # 2) You press ^C while entering a command at the prompt. | |
| 85 # The following steps happen: | |
| 86 # * (iterm2_preexec is NOT invoked) | |
| 87 # * iterm2_precmd is invoked | |
| 88 # * iterm2_before_cmd_executes is called since we detected that iterm2_preexec was not run | |
| 89 # * (ITERM2_PRECMD_PS1 and PS1 are not messed with, since PS1 already has our escape | |
| 90 # sequences and ITERM2_PRECMD_PS1 already has PS1's original value) | |
| 91 # * zsh displays your prompt | |
| 92 # * You start entering a command | |
| 93 # | |
| 94 # 3) A new shell is born. | |
| 95 # * PS1 has some initial value, either zsh's default or a value set before this script is sourced. | |
| 96 # * iterm2_precmd is invoked | |
| 97 # * ITERM2_SHOULD_DECORATE_PROMPT is initialized to 1 | |
| 98 # * ITERM2_PRECMD_PS1 is set to the initial value of PS1 | |
| 99 # * PS1 gets our escape sequences added to it | |
| 100 # * Your prompt is shown and you may begin entering a command. | |
| 101 # | |
| 102 # Invariants: | |
| 103 # * ITERM2_SHOULD_DECORATE_PROMPT is 1 during and just after command execution, and "" while the prompt is | |
| 104 # shown and until you enter a command and press return. | |
| 105 # * PS1 does not have our escape sequences during command execution | |
| 106 # * After the command executes but before a new one begins, PS1 has escape sequences and | |
| 107 # ITERM2_PRECMD_PS1 has PS1's original value. | |
| 108 iterm2_decorate_prompt() { | |
| 109 # This should be a raw PS1 without iTerm2's stuff. It could be changed during command | |
| 110 # execution. | |
| 111 ITERM2_PRECMD_PS1="$PS1" | |
| 112 ITERM2_SHOULD_DECORATE_PROMPT="" | |
| 113 | |
| 114 # Add our escape sequences just before the prompt is shown. | |
| 115 # Use ITERM2_SQUELCH_MARK for people who can't mdoify PS1 directly, like powerlevel9k users. | |
| 116 # This is gross but I had a heck of a time writing a correct if statetment for zsh 5.0.2. | |
| 117 local PREFIX="" | |
| 118 if [[ $PS1 == *"$(iterm2_prompt_mark)"* ]]; then | |
| 119 PREFIX="" | |
| 120 elif [[ "${ITERM2_SQUELCH_MARK-}" != "" ]]; then | |
| 121 PREFIX="" | |
| 122 else | |
| 123 PREFIX="%{$(iterm2_prompt_mark)%}" | |
| 124 fi | |
| 125 PS1="$PREFIX$PS1%{$(iterm2_prompt_end)%}" | |
| 126 ITERM2_DECORATED_PS1="$PS1" | |
| 127 } | |
| 128 | |
| 129 iterm2_precmd() { | |
| 130 local STATUS="$?" | |
| 131 if [ -z "${ITERM2_SHOULD_DECORATE_PROMPT-}" ]; then | |
| 132 # You pressed ^C while entering a command (iterm2_preexec did not run) | |
| 133 iterm2_before_cmd_executes | |
| 134 if [ "$PS1" != "${ITERM2_DECORATED_PS1-}" ]; then | |
| 135 # PS1 changed, perhaps in another precmd. See issue 9938. | |
| 136 ITERM2_SHOULD_DECORATE_PROMPT="1" | |
| 137 fi | |
| 138 fi | |
| 139 | |
| 140 iterm2_after_cmd_executes "$STATUS" | |
| 141 | |
| 142 if [ -n "$ITERM2_SHOULD_DECORATE_PROMPT" ]; then | |
| 143 iterm2_decorate_prompt | |
| 144 fi | |
| 145 } | |
| 146 | |
| 147 # This is not run if you press ^C while entering a command. | |
| 148 iterm2_preexec() { | |
| 149 # Set PS1 back to its raw value prior to executing the command. | |
| 150 PS1="$ITERM2_PRECMD_PS1" | |
| 151 ITERM2_SHOULD_DECORATE_PROMPT="1" | |
| 152 iterm2_before_cmd_executes | |
| 153 } | |
| 154 | |
| 155 # If hostname -f is slow on your system set iterm2_hostname prior to | |
| 156 # sourcing this script. We know it is fast on macOS so we don't cache | |
| 157 # it. That lets us handle the hostname changing like when you attach | |
| 158 # to a VPN. | |
| 159 if [ -z "${iterm2_hostname-}" ]; then | |
| 160 if [ "$(uname)" != "Darwin" ]; then | |
| 161 iterm2_hostname=`hostname -f 2>/dev/null` | |
| 162 # Some flavors of BSD (i.e. NetBSD and OpenBSD) don't have the -f option. | |
| 163 if [ $? -ne 0 ]; then | |
| 164 iterm2_hostname=`hostname` | |
| 165 fi | |
| 166 fi | |
| 167 fi | |
| 168 | |
| 169 [[ -z ${precmd_functions-} ]] && precmd_functions=() | |
| 170 precmd_functions=($precmd_functions iterm2_precmd) | |
| 171 | |
| 172 [[ -z ${preexec_functions-} ]] && preexec_functions=() | |
| 173 preexec_functions=($preexec_functions iterm2_preexec) | |
| 174 | |
| 175 iterm2_print_state_data | |
| 176 printf "\033]1337;ShellIntegrationVersion=13;shell=zsh\007" | |
| 177 fi | |
| 178 fi |
