summaryrefslogtreecommitdiff
path: root/Completion/Unix
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2011-01-05 17:26:17 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2011-01-05 17:26:17 +0000
commit564fd4e8db65f4da6a80c93a492b46ff748d1f28 (patch)
tree8f3d76ce66971cdb5712b0977637457324856f97 /Completion/Unix
parent24622be01ce295932f7f77b688100d21b153399e (diff)
downloadzsh-564fd4e8db65f4da6a80c93a492b46ff748d1f28.tar.gz
zsh-564fd4e8db65f4da6a80c93a492b46ff748d1f28.zip
28557: Alexey: update
Diffstat (limited to 'Completion/Unix')
-rw-r--r--Completion/Unix/Command/_ri18
1 files changed, 12 insertions, 6 deletions
diff --git a/Completion/Unix/Command/_ri b/Completion/Unix/Command/_ri
index a7f26923c..747437439 100644
--- a/Completion/Unix/Command/_ri
+++ b/Completion/Unix/Command/_ri
@@ -21,17 +21,23 @@ _arguments \
'*:ri name:->ri-name' && ret=0
if [[ "$state" = ri-name ]]; then
- local -a ri_dirs ri_names ri_wants ri_names
+ local -a ri_dirs ri_ext ri_names ri_wants ri_names
local class_dir esc_name dir curtag tag descr expl
ret=1
- if "ruby${words[1]#ri}" -rrdoc/ri/ri_options.rb -e 1 >/dev/null 2>&1; then
+ if "ruby${words[1]#ri}" -rrdoc/ri/ri_options -e 1 >/dev/null 2>&1; then
# Old-style Ruby 1.8.x RI
ri_dirs=( ${(f)"$(_call_program ri-names "ruby${words[1]#ri}" -rrdoc/ri/ri_options -e '"o = RI::Options.instance; o.parse(ARGV); o.path.each { |p| puts p }"' -- ${(kv)opt_args[(I)-d|--doc-dir|--(system|site|gems|home)]})"} )
+ ri_ext=yaml
+ elif "ruby${words[1]#ri}" -rrdoc/ri -rrdoc/ri/store -e 1 >/dev/null 2>&1; then
+ # Newer-style Ruby 1.9.2 RI
+ ri_dirs=( ${(f)"$(_call_program ri-names "$words[1]" ${(kv)opt_args[(I)-d|--doc-dir|--((no-|)(system|site|gems|home)|standard-docs)]} --list-doc-dirs -f plain -T)"} )
+ ri_ext=ri
else
# New-style Ruby 1.9+ RI
ri_dirs=( ${(f)"$(_call_program ri-names "$words[1]" ${(kv)opt_args[(I)-d|--doc-dir|--((no-|)(system|site|gems|home)|standard-docs)]} --list-doc-dirs -f plain -T)"} )
+ ri_ext=yaml
fi
if compset -P '?*(::|\#|.)'; then
@@ -64,14 +70,14 @@ if [[ "$state" = ri-name ]]; then
;;
(class-methods)
for dir in $ri_dirs[@]; do
- fnames=( $dir/$class_dir*-c.yaml(-.:t) )
- ri_wants+=( ${${fnames%-c.yaml}//(#b)%(??)/$(print "\\x$match[1]")} )
+ fnames=( $dir/$class_dir*-c.$ri_ext(-.:t) )
+ ri_wants+=( ${${fnames%-c.$ri_ext}//(#b)%(??)/$(print "\\x$match[1]")} )
done
;;
(instance-methods)
for dir in $ri_dirs[@]; do
- fnames=( $dir/$class_dir*-i.yaml(-.:t) )
- ri_wants+=( ${${fnames%-i.yaml}//(#b)%(??)/$(print "\\x$match[1]")} )
+ fnames=( $dir/$class_dir*-i.$ri_ext(-.:t) )
+ ri_wants+=( ${${fnames%-i.$ri_ext}//(#b)%(??)/$(print "\\x$match[1]")} )
done
;;
esac