Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
adam.huang
Ohmyzsh
Commits
841d2b92
Commit
841d2b92
authored
May 18, 2016
by
Robby Russell
Browse files
Merge pull request #5053 from psprint/master
znt: update to v2.1.15
parents
5b9c6c15
e2d157d5
Changes
25
Show whitespace changes
Inline
Side-by-side
plugins/zsh-navigation-tools/n-list-input
View file @
841d2b92
...
@@ -14,6 +14,52 @@ _nlist_compute_first_to_show_idx() {
...
@@ -14,6 +14,52 @@ _nlist_compute_first_to_show_idx() {
from_what_idx_list_is_shown
=
0+
((
current_idx-1
)
/page_height
)
*
page_height+1
from_what_idx_list_is_shown
=
0+
((
current_idx-1
)
/page_height
)
*
page_height+1
}
}
_nlist_update_from_keywords
()
{
keywordisfresh
=
"1"
if
[
"
$nkeywords
"
-gt
0
]
;
then
curkeyword
=
$((
(
curkeyword+1
)
%
(
nkeywords+1
)
))
if
[
"
$curkeyword
"
-eq
"0"
]
;
then
buffer
=
""
else
buffer
=
"
${
keywords
[curkeyword]
}
"
fi
fi
}
_nlist_iterate_theme
()
{
themeisfresh
=
"1"
if
[
"
$1
"
=
"1"
]
;
then
curtheme
=
$((
(
curtheme+1
)
%
(
nthemes+1
)
))
else
curtheme
=
curtheme-1
[
"
$curtheme
"
-lt
0
]
&&
curtheme
=
nthemes
fi
if
[
"
$nthemes
"
-gt
0
]
;
then
local
theme
=
${
themes
[curtheme]
}
[
"
$curtheme
"
-eq
"0"
]
&&
theme
=
"
$backuptheme
"
colorpair
=
"
${
theme
%/*
}
"
bold
=
"
${
theme
##*/
}
"
background
=
"
${
colorpair
#*/
}
"
zcurses
bg
main
"
$colorpair
"
zcurses
bg
inner
"
$colorpair
"
fi
}
_nlist_rotate_buffer
()
{
setopt localoptions noglob
local
-a
words
words
=(
${
(s
:
:
)buffer
}
)
words
=(
${
words
[-1]
}
${
words
[1,-2]
}
)
local
space
=
""
[
"
${
buffer
[-1]
}
"
=
" "
]
&&
space
=
" "
buffer
=
"
${
(j
:
:
)words
}
$space
"
}
typeset
-ga
reply
typeset
-ga
reply
reply
=(
-1
''
)
reply
=(
-1
''
)
integer
current_idx
=
"
$1
"
integer
current_idx
=
"
$1
"
...
@@ -26,6 +72,7 @@ local key="$7"
...
@@ -26,6 +72,7 @@ local key="$7"
integer
search
=
"
$8
"
integer
search
=
"
$8
"
local
buffer
=
"
$9
"
local
buffer
=
"
$9
"
integer
uniq_mode
=
"
$10
"
integer
uniq_mode
=
"
$10
"
integer
f_mode
=
"
$11
"
#
#
# Listening for input
# Listening for input
...
@@ -79,21 +126,36 @@ case "$key" in
...
@@ -79,21 +126,36 @@ case "$key" in
${
NLIST_NONSELECTABLE_ELEMENTS
[(r)
$current_idx
]
}
!=
$current_idx
]]
${
NLIST_NONSELECTABLE_ELEMENTS
[(r)
$current_idx
]
}
!=
$current_idx
]]
then
then
# Save current element in the result variable
# Save current element in the result variable
reply
=(
$current_idx
SELECT
)
reply
=(
$current_idx
"SELECT"
)
fi
;;
(
H|
'?'
)
# This event needs to be enabled
if
[[
"
${
NLIST_ENABLED_EVENTS
[(r)HELP]
}
"
=
"HELP"
]]
;
then
reply
=(
-1
"HELP"
)
fi
fi
;;
;;
(
F1
)
# This event needs to be enabled
if
[[
"
${
NLIST_ENABLED_EVENTS
[(r)F1]
}
"
=
"F1"
]]
;
then
reply
=(
-1
"
$key
"
)
fi
;;
(
F4|F5|F6|F7|F8|F9|F10|DC
)
# ignore; F2, F3 are used below
;;
(
q
)
(
q
)
reply
=(
-1
QUIT
)
reply
=(
-1
"
QUIT
"
)
;;
;;
(
/
)
(
/
)
search
=
1
search
=
1
_nlist_cursor_visibility 1
_nlist_cursor_visibility 1
;;
;;
(
$'
\t
'
)
(
$'
\t
'
)
reply
=(
$current_idx
LEAVE
)
reply
=(
$current_idx
"
LEAVE
"
)
;;
;;
(
$'
\C
-L'
)
(
$'
\C
-L'
)
reply
=(
-1
REDRAW
)
reply
=(
-1
"
REDRAW
"
)
;;
;;
(
\]
)
(
\]
)
[[
"
${
(t)NLIST_HOP_INDEXES
}
"
=
"array"
||
"
${
(t)NLIST_HOP_INDEXES
}
"
=
"array-local"
]]
&&
[[
"
${
(t)NLIST_HOP_INDEXES
}
"
=
"array"
||
"
${
(t)NLIST_HOP_INDEXES
}
"
=
"array-local"
]]
&&
...
@@ -127,9 +189,41 @@ case "$key" in
...
@@ -127,9 +189,41 @@ case "$key" in
(
$'
\E
'
)
(
$'
\E
'
)
buffer
=
""
buffer
=
""
;;
;;
(
F3
)
if
[
"
$search
"
=
"1"
]
;
then
search
=
0
_nlist_cursor_visibility 0
else
search
=
1
_nlist_cursor_visibility 1
fi
;;
(
o|
$'
\C
-O'
)
(
o|
$'
\C
-O'
)
uniq_mode
=
1-uniq_mode
uniq_mode
=
1-uniq_mode
;;
;;
(
f|
$'
\C
-F'
)
((
f_mode
=(
f_mode+1
)
% 3
))
;;
(
$'
\x
1F'
|
F2|
$'
\C
-X'
)
search
=
1
_nlist_cursor_visibility 1
_nlist_update_from_keywords
;;
(
$'
\C
-T'
)
_nlist_iterate_theme 1
;;
(
$'
\C
-G'
)
_nlist_iterate_theme 0
;;
(
$'
\C
-E'
|
e
)
# This event needs to be enabled
if
[[
"
${
NLIST_ENABLED_EVENTS
[(r)EDIT]
}
"
=
"EDIT"
]]
;
then
reply
=(
-1
"EDIT"
)
fi
;;
(
$'
\C
-A'
)
_nlist_rotate_buffer
;;
(
*
)
(
*
)
;;
;;
esac
esac
...
@@ -138,11 +232,19 @@ else
...
@@ -138,11 +232,19 @@ else
case
"
$key
"
in
case
"
$key
"
in
(
$'
\n
'
|
ENTER
)
(
$'
\n
'
|
ENTER
)
if
[
"
$NLIST_INSTANT_SELECT
"
=
"1"
]
;
then
if
[[
"
$NLIST_SEARCH_BUFFER
"
!=
""
||
"
$NLIST_IS_UNIQ_MODE
"
-eq
1
||
${
NLIST_NONSELECTABLE_ELEMENTS
[(r)
$current_idx
]
}
!=
$current_idx
]]
then
reply
=(
$current_idx
"SELECT"
)
fi
else
search
=
0
search
=
0
_nlist_cursor_visibility 0
_nlist_cursor_visibility 0
fi
;;
;;
(
$'
\C
-L'
)
(
$'
\C
-L'
)
reply
=(
-1
REDRAW
)
reply
=(
-1
"
REDRAW
"
)
;;
;;
#
#
...
@@ -192,8 +294,14 @@ case "$key" in
...
@@ -192,8 +294,14 @@ case "$key" in
(
RIGHT
)
(
RIGHT
)
hscroll+
=
7
hscroll+
=
7
;;
;;
(
F1|F2|F3|F4|F5|F6|F7|F8|F9|F10
)
(
F1
)
# ignore
# This event needs to be enabled
if
[[
"
${
NLIST_ENABLED_EVENTS
[(r)F1]
}
"
=
"F1"
]]
;
then
reply
=(
-1
"
$key
"
)
fi
;;
(
F4|F5|F6|F7|F8|F9|F10|DC
)
# ignore; F2, F3 are used below
;;
;;
#
#
...
@@ -214,9 +322,39 @@ case "$key" in
...
@@ -214,9 +322,39 @@ case "$key" in
search
=
0
search
=
0
_nlist_cursor_visibility 0
_nlist_cursor_visibility 0
;;
;;
(
F3
)
if
[
"
$search
"
=
"1"
]
;
then
search
=
0
_nlist_cursor_visibility 0
else
search
=
1
_nlist_cursor_visibility 1
fi
;;
(
$'
\C
-O'
)
(
$'
\C
-O'
)
uniq_mode
=
1-uniq_mode
uniq_mode
=
1-uniq_mode
;;
;;
(
$'
\C
-F'
)
((
f_mode
=(
f_mode+1
)
% 3
))
;;
(
$'
\x
1F'
|
F2|
$'
\C
-X'
)
_nlist_update_from_keywords
;;
(
$'
\C
-T'
)
_nlist_iterate_theme 1
;;
(
$'
\C
-G'
)
_nlist_iterate_theme 0
;;
(
$'
\C
-E'
)
# This event needs to be enabled
if
[[
"
${
NLIST_ENABLED_EVENTS
[(r)EDIT]
}
"
=
"EDIT"
]]
;
then
reply
=(
-1
"EDIT"
)
fi
;;
(
$'
\C
-A'
)
_nlist_rotate_buffer
;;
(
*
)
(
*
)
if
[[
$#key
==
1
&&
$((
#key)) -lt 31 ]]; then
if
[[
$#key
==
1
&&
$((
#key)) -lt 31 ]]; then
# ignore all other control keys
# ignore all other control keys
...
@@ -234,5 +372,6 @@ reply[5]="$hscroll"
...
@@ -234,5 +372,6 @@ reply[5]="$hscroll"
reply[6]
=
"
$search
"
reply[6]
=
"
$search
"
reply[7]
=
"
$buffer
"
reply[7]
=
"
$buffer
"
reply[8]
=
"
$uniq_mode
"
reply[8]
=
"
$uniq_mode
"
reply[9]
=
"
$f_mode
"
# vim: set filetype=zsh:
# vim: set filetype=zsh:
plugins/zsh-navigation-tools/n-options
View file @
841d2b92
...
@@ -14,8 +14,8 @@ local IFS="
...
@@ -14,8 +14,8 @@ local IFS="
unset
NLIST_COLORING_PATTERN
unset
NLIST_COLORING_PATTERN
[
-f
~/.config/znt/n-list.conf
]
&&
.
~/.config/znt/n-list.conf
[
-f
~/.config/znt/n-list.conf
]
&&
builtin source
~/.config/znt/n-list.conf
[
-f
~/.config/znt/n-options.conf
]
&&
.
~/.config/znt/n-options.conf
[
-f
~/.config/znt/n-options.conf
]
&&
builtin source
~/.config/znt/n-options.conf
# TODO restore options
# TODO restore options
unsetopt localoptions
unsetopt localoptions
...
...
plugins/zsh-navigation-tools/n-panelize
View file @
841d2b92
...
@@ -17,8 +17,8 @@ local IFS="
...
@@ -17,8 +17,8 @@ local IFS="
unset
NLIST_COLORING_PATTERN
unset
NLIST_COLORING_PATTERN
[
-f
~/.config/znt/n-list.conf
]
&&
.
~/.config/znt/n-list.conf
[
-f
~/.config/znt/n-list.conf
]
&&
builtin source
~/.config/znt/n-list.conf
[
-f
~/.config/znt/n-panelize.conf
]
&&
.
~/.config/znt/n-panelize.conf
[
-f
~/.config/znt/n-panelize.conf
]
&&
builtin source
~/.config/znt/n-panelize.conf
local
list
local
list
local
selected
local
selected
...
...
plugins/zsh-navigation-tools/znt-history-widget
View file @
841d2b92
...
@@ -4,6 +4,14 @@ local NLIST_START_IN_UNIQ_MODE=1
...
@@ -4,6 +4,14 @@ local NLIST_START_IN_UNIQ_MODE=1
# Only if current $BUFFER doesn't come from history
# Only if current $BUFFER doesn't come from history
if [ "$HISTCMD" = "$HISTNO" ]; then
if [ "$HISTCMD" = "$HISTNO" ]; then
() {
setopt localoptions extendedglob
local -a match mbegin mend
local MATCH; integer MBEGIN MEND
[ -n "$BUFFER" ] && BUFFER="${BUFFER%% ##} "
}
local NLIST_SET_SEARCH_TO="$BUFFER"
local NLIST_SET_SEARCH_TO="$BUFFER"
fi
fi
...
...
plugins/zsh-navigation-tools/zsh-navigation-tools.plugin.zsh
View file @
841d2b92
...
@@ -15,13 +15,21 @@ if ! test -d "$CONFIG_DIR"; then
...
@@ -15,13 +15,21 @@ if ! test -d "$CONFIG_DIR"; then
mkdir
"
$CONFIG_DIR
"
mkdir
"
$CONFIG_DIR
"
fi
fi
# 9 files
set
n-aliases.conf n-env.conf n-history.conf n-list.conf n-panelize.conf n-cd.conf n-functions.conf n-kill.conf n-options.conf
set
n-aliases.conf n-env.conf n-history.conf n-list.conf n-panelize.conf n-cd.conf n-functions.conf n-kill.conf n-options.conf
for
i
;
do
# Check for random 2 files if they exist
# This will shift 0 - 7 elements
shift
$((
RANDOM
%
8
))
if
!
test
-f
"
$CONFIG_DIR
/
$1
"
||
!
test
-f
"
$CONFIG_DIR
/
$2
"
;
then
# Something changed - examine every file
set
n-aliases.conf n-env.conf n-history.conf n-list.conf n-panelize.conf n-cd.conf n-functions.conf n-kill.conf n-options.conf
for
i
;
do
if
!
test
-f
"
$CONFIG_DIR
/
$i
"
;
then
if
!
test
-f
"
$CONFIG_DIR
/
$i
"
;
then
cp
"
$REPO_DIR
/.config/znt/
$i
"
"
$CONFIG_DIR
"
cp
"
$REPO_DIR
/.config/znt/
$i
"
"
$CONFIG_DIR
"
fi
fi
done
done
fi
# Don't leave positional parameters being set
# Don't leave positional parameters being set
set
--
set
--
...
@@ -30,12 +38,13 @@ set --
...
@@ -30,12 +38,13 @@ set --
# Load functions
# Load functions
#
#
autoload n-aliases n-cd n-env n-functions n-history n-kill n-list n-list-draw n-list-input n-options n-panelize
autoload n-aliases n-cd n-env n-functions n-history n-kill n-list n-list-draw n-list-input n-options n-panelize
n-help
autoload znt-usetty-wrapper znt-history-widget znt-cd-widget znt-kill-widget
autoload znt-usetty-wrapper znt-history-widget znt-cd-widget znt-kill-widget
alias
naliases
=
n-aliases
ncd
=
n-cd
nenv
=
n-env
nfunctions
=
n-functions
nhistory
=
n-history
alias
naliases
=
n-aliases
ncd
=
n-cd
nenv
=
n-env
nfunctions
=
n-functions
nhistory
=
n-history
alias
nkill
=
n-kill
noptions
=
n-options
npanelize
=
n-panelize
alias
nkill
=
n-kill
noptions
=
n-options
npanelize
=
n-panelize
nhelp
=
n-help
zle
-N
znt-history-widget
zle
-N
znt-history-widget
bindkey
'^R'
znt-history-widget
bindkey
'^R'
znt-history-widget
setopt AUTO_PUSHD HIST_IGNORE_DUPS PUSHD_IGNORE_DUPS
setopt AUTO_PUSHD HIST_IGNORE_DUPS PUSHD_IGNORE_DUPS
zstyle
':completion::complete:n-kill::bits'
matcher
'r:|=** l:|=*'
Prev
1
2
Next
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment