summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAaron Peschel <aaron.peschel@gmail.com>2013-12-13 22:51:09 -0800
committerBarton E. Schaefer <schaefer@zsh.org>2013-12-13 22:51:09 -0800
commit8ffba43be97e90be5753a90e3b5869450f108c79 (patch)
tree8b0348271e03bc42d5ceb6e48f9535a714f95e35
parentbcda34a0b39e2bca669c2ae1c6f203e175059a02 (diff)
downloadzsh-8ffba43be97e90be5753a90e3b5869450f108c79.tar.gz
zsh-8ffba43be97e90be5753a90e3b5869450f108c79.zip
32103: parse host:port format in ssh known_hosts files.
-rw-r--r--ChangeLog5
-rw-r--r--Completion/Unix/Type/_hosts15
2 files changed, 18 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 96dafe44e..ae9c163d3 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2013-12-13 Barton E. Schaefer <schaefer@zsh.org>
+
+ * Aaron Peschel: 32103: Completion/Unix/Type/_hosts: parse
+ host:port format in ssh known_hosts files.
+
2013-12-10 Barton E. Schaefer <schaefer@zsh.org>
* 32099: Src/init.c: fix pointer declaration to avoid compile
diff --git a/Completion/Unix/Type/_hosts b/Completion/Unix/Type/_hosts
index 499caede1..c3133dc68 100644
--- a/Completion/Unix/Type/_hosts
+++ b/Completion/Unix/Type/_hosts
@@ -41,9 +41,20 @@ if ! zstyle -a ":completion:${curcontext}:hosts" hosts _hosts; then
for khostfile in $khostfiles; do
if [[ -r $khostfile ]]; then
- khosts=(${${(s:,:)${(j:,:)${(u)${(f)"$(<$khostfile)"}%%[ |#]*}}}:#*[\[\]]*})
+ khosts=(${(s/,/j/,/u)${(f)"$(<$khostfile)"}%%[ |#]*})
+
+ # known_hosts syntax supports the host being in the form [hostname]:port
+ # The filter below extracts the hostname from lines using this format.
+ khosts=($(for host ($khosts); do
+ if [[ $host =~ "\[(.*)\]:\d*" ]]; then
+ echo $match
+ else
+ echo $host
+ fi
+ done))
+
if [[ -z $useip ]]; then
- khosts=(${${${khosts:#(#s)[0-9]##.[0-9]##.[0-9]##.[0-9]##(#e)}:#(#s)[0-9a-f:]##(#e)}:#*[\[\]]*})
+ khosts=(${${khosts:#(#s)[0-9]##.[0-9]##.[0-9]##.[0-9]##(#e)}:#(#s)[0-9a-f:]##(#e)})
fi
_cache_hosts+=($khosts)
fi