updated to use ack completion module style version checking

-- instead of looking at major and minor, we'll do what the ack completion
   module does: produce an x.y version number that we then compare directly to,
   to avoid complicated "if major version OR minor version" checking
This commit is contained in:
Viktor Haag 2016-12-01 14:18:35 -05:00
parent febd404323
commit 080d0b70f1
1 changed files with 14 additions and 22 deletions

36
src/_ag
View File

@ -40,20 +40,12 @@
# -*- mode: zsh; sh-indentation: 2; indent-tabs-mode: nil; sh-basic-offset: 2; -*- # -*- mode: zsh; sh-indentation: 2; indent-tabs-mode: nil; sh-basic-offset: 2; -*-
# vim: ft=zsh sw=2 ts=2 et # vim: ft=zsh sw=2 ts=2 et
# ------------------------------------------------------------------------------ # ------------------------------------------------------------------------------
_ag_minor_version() {
local version
version=( $($words[1] --version) )
version=${version[@]:2:1}
version=( "${(@s/./)version}" )
echo "${version[2]}"
}
_ag_major_version() { _ag_version() {
local version local version
version=( $($words[1] --version) ) version=( $($words[1] --version) )
version=${version[@]:2:1} version=${${(z)${version[1]}}[2]}
version=( "${(@s/./)version}" ) echo $version
echo "${version[1]}"
} }
@ -78,10 +70,9 @@ _ag_add_file_types() {
# Add version appropriate options above base # Add version appropriate options above base
# Modifies the global $AG_OPTS array # Modifies the global $AG_OPTS array
_ag_add_version_opts() { _ag_add_version_opts() {
local minor=$(_ag_minor_version) local ag_version=$(_ag_version)
local major=$(_ag_major_version)
if [[ $major -ge 1 || $minor -gt 21 ]];then if [[ ag_version > 0.22 ]]; then
_ag_add_file_types _ag_add_file_types
AG_OPTS+=( AG_OPTS+=(
'(- 1 *)--list-file-types[list supported filetypes to search]' '(- 1 *)--list-file-types[list supported filetypes to search]'
@ -89,19 +80,20 @@ _ag_add_version_opts() {
) )
fi fi
if [[ $major -ge 1 || $minor -gt 22 ]];then
if [[ ag_version > 0.22 ]]; then
AG_OPTS+=( AG_OPTS+=(
'(-z --search-zip)'{-z,--search-zip}'[search contents of compressed files]' '(-z --search-zip)'{-z,--search-zip}'[search contents of compressed files]'
) )
fi fi
if [[ $major -lt 1 && $minor -le 24 ]];then if [[ ag_version <= 0.24 ]]; then
AG_OPTS+=( AG_OPTS+=(
'(-s --case-sensitive)'{-s,--case-sensitive}'[match case sensitively]' '(-s --case-sensitive)'{-s,--case-sensitive}'[match case sensitively]'
'(--noheading --heading)'{--noheading,--heading}'[print file names above matching contents]' '(--noheading --heading)'{--noheading,--heading}'[print file names above matching contents]'
) )
fi fi
if [[ $major -ge 1 || $minor -gt 24 ]];then if [[ ag_version > 0.24 ]]; then
AG_OPTS+=( AG_OPTS+=(
'(-s --case-sensitive)'{-s,--case-sensitive}'[Match case sensitively. Default on.]' '(-s --case-sensitive)'{-s,--case-sensitive}'[Match case sensitively. Default on.]'
'(-H --noheading --heading)'{-H,--noheading,--heading}'[print file names above matching contents]' '(-H --noheading --heading)'{-H,--noheading,--heading}'[print file names above matching contents]'
@ -109,18 +101,18 @@ _ag_add_version_opts() {
) )
fi fi
if [[ $major -ge 1 || $minor -gt 26 ]];then if [[ ag_version > 0.26 ]]; then
AG_OPTS+=( AG_OPTS+=(
'(-0 --null --print0)'{-0,--null,--print0}'[separate the filenames with \\0, rather than \\n]' '(-0 --null --print0)'{-0,--null,--print0}'[separate the filenames with \\0, rather than \\n]'
) )
fi fi
if [[ $major -lt 1 && $minor -le 27 ]];then if [[ ag_version <= 0.27 ]]; then
AG_OPTS+=( AG_OPTS+=(
'--depth[Search up to NUM directories deep. Default is 25.]:number' '--depth[Search up to NUM directories deep. Default is 25.]:number'
) )
fi fi
if [[ $major -ge 1 || $minor -gt 27 ]];then if [[ ag_version > 0.27 ]]; then
AG_OPTS+=( AG_OPTS+=(
'(-c --count)'{-c,--count}'[only print the number of matches in each file]' '(-c --count)'{-c,--count}'[only print the number of matches in each file]'
'--depth[Search up to NUM directories deep, -1 for unlimited. Default is 25.]:number' '--depth[Search up to NUM directories deep, -1 for unlimited. Default is 25.]:number'
@ -128,12 +120,12 @@ _ag_add_version_opts() {
) )
fi fi
if [[ $major -lt 1 && $minor -le 28 ]];then if [[ ag_version <= 0.28 ]]; then
AG_OPTS+=( AG_OPTS+=(
'(--no-numbers)--no-numbers[don´t show line numbers]' '(--no-numbers)--no-numbers[don´t show line numbers]'
) )
fi fi
if [[ $major -ge 1 || $minor -gt 28 ]];then if [[ ag_version > 0.28 ]]; then
AG_OPTS+=( AG_OPTS+=(
'(--nofilename --filename)'{--nofilename,--filename}'[Print file names. Default on, except when searching a single file.]' '(--nofilename --filename)'{--nofilename,--filename}'[Print file names. Default on, except when searching a single file.]'
'(--nonumbers --numbers)'{--nonumbers,--numbers}'[Print line numbers. Default is to omit line numbers when searching streams]' '(--nonumbers --numbers)'{--nonumbers,--numbers}'[Print line numbers. Default is to omit line numbers when searching streams]'