mirror of
https://github.com/Jguer/yay
synced 2024-09-14 13:51:12 +00:00
Completions moved
This commit is contained in:
parent
c67e0b7bca
commit
c2ed3e373f
142
yay.fish
Normal file
142
yay.fish
Normal file
|
@ -0,0 +1,142 @@
|
|||
# Completions for apacman
|
||||
# Original Author for pacman: Giorgio Lando <patroclo7@gmail.com>
|
||||
# Updated for pacman by maxfl, SanskritFritz, faho, f1u77y
|
||||
# Updated for apacman by jguer
|
||||
|
||||
set -l progname yay
|
||||
|
||||
set -l listinstalled "(pacman -Q | string replace ' ' \t)"
|
||||
# This might be an issue if another package manager is also installed (e.g. for containers)
|
||||
set -l listall "(__fish_print_packages)"
|
||||
set -l listrepos "(__fish_print_pacman_repos)"
|
||||
set -l listgroups "(pacman -Sg)\t'Package Group'"
|
||||
|
||||
set -l noopt 'not __fish_contains_opt -s S -s D -s Q -s R -s U -s T -s F database query sync remove upgrade deptest files'
|
||||
set -l database '__fish_contains_opt -s D database'
|
||||
set -l query '__fish_contains_opt -s Q query'
|
||||
set -l remove '__fish_contains_opt -s R remove'
|
||||
set -l sync '__fish_contains_opt -s S sync'
|
||||
set -l upgrade '__fish_contains_opt -s U upgrade'
|
||||
set -l files '__fish_contains_opt -s F files'
|
||||
|
||||
complete -c pacman -e
|
||||
complete -c pacman -f
|
||||
|
||||
# HACK: We only need these two to coerce fish to stop file completion and complete options
|
||||
complete -c $progname -n $noopt -a "-D" -d "Modify the package database"
|
||||
complete -c $progname -n $noopt -a "-Q" -d "Query the package database"
|
||||
# Primary operations
|
||||
complete -c $progname -s D -f -l database -n $noopt -d 'Modify the package database'
|
||||
complete -c $progname -s Q -f -l query -n $noopt -d 'Query the package database'
|
||||
complete -c $progname -s R -f -l remove -n $noopt -d 'Remove packages from the system'
|
||||
complete -c $progname -s S -f -l sync -n $noopt -d 'Synchronize packages'
|
||||
complete -c $progname -s T -f -l deptest -n $noopt -d 'Check if dependencies are installed'
|
||||
complete -c $progname -s U -f -l upgrade -n $noopt -d 'Upgrade or add a local package'
|
||||
complete -c $progname -s F -f -l files -n $noopt -d 'Query the files database'
|
||||
complete -c $progname -s V -f -l version -d 'Display version and exit'
|
||||
complete -c $progname -s h -f -l help -d 'Display help'
|
||||
|
||||
# General options
|
||||
# Only offer these once a command has been given so they get prominent display
|
||||
complete -c $progname -n "not $noopt" -s b -l dbpath -d 'Alternative database location' -xa '(__fish_complete_directories)'
|
||||
complete -c $progname -n "not $noopt" -s r -l root -d 'Alternative installation root'
|
||||
complete -c $progname -n "not $noopt" -s v -l verbose -d 'Output more status messages'
|
||||
complete -c $progname -n "not $noopt" -s h -l help -d 'Display syntax for the given operation'
|
||||
complete -c $progname -n "not $noopt" -l arch -d 'Alternate architecture' -f
|
||||
complete -c $progname -n "not $noopt" -l cachedir -d 'Alternative package cache location'
|
||||
complete -c $progname -n "not $noopt" -l color -d 'Colorize the output'
|
||||
complete -c $progname -n "not $noopt" -l config -d 'Alternate config file'
|
||||
complete -c $progname -n "not $noopt" -l debug -d 'Display debug messages' -f
|
||||
complete -c $progname -n "not $noopt" -l gpgdir -d 'GPG directory to verify signatures'
|
||||
complete -c $progname -n "not $noopt" -l hookdir -d 'Hook file directory'
|
||||
complete -c $progname -n "not $noopt" -l logfile -d 'Specify alternative log file'
|
||||
complete -c $progname -n "not $noopt" -l noconfirm -d 'Bypass any question' -f
|
||||
|
||||
# Transaction options (sync, remove, upgrade)
|
||||
for condition in sync remove upgrade
|
||||
complete -c $progname -n $$condition -s d -l nodeps -d 'Skip [all] dependency checks' -f
|
||||
complete -c $progname -n $$condition -l dbonly -d 'Modify database entry only' -f
|
||||
complete -c $progname -n $$condition -l noprogressbar -d 'Do not display progress bar' -f
|
||||
complete -c $progname -n $$condition -l noscriptlet -d 'Do not execute install script' -f
|
||||
complete -c $progname -n $$condition -s p -l print -d 'Dry run, only print targets' -f
|
||||
complete -c $progname -n $$condition -l print-format -x -d 'Specify printf-like format' -f
|
||||
end
|
||||
|
||||
# Database and upgrade options (database, sync, upgrade)
|
||||
for condition in database sync upgrade
|
||||
complete -c $progname -n $$condition -l asdeps -d 'Mark PACKAGE as dependency' -f
|
||||
complete -c $progname -n $$condition -l asexplicit -d 'Mark PACKAGE as explicitly installed' -f
|
||||
end
|
||||
|
||||
# Upgrade options (sync, upgrade)
|
||||
for condition in sync upgrade
|
||||
complete -c $progname -n $$condition -l force -d 'Bypass file conflict checks' -f
|
||||
complete -c $progname -n $$condition -l ignore -d 'Ignore upgrade of PACKAGE' -xa "$listinstalled" -f
|
||||
complete -c $progname -n $$condition -l ignoregroup -d 'Ignore upgrade of GROUP' -xa "$listgroups" -f
|
||||
complete -c $progname -n $$condition -l needed -d 'Do not reinstall up-to-date targets' -f
|
||||
complete -c $progname -n $$condition -l recursive -d 'Recursively reinstall all dependencies' -f
|
||||
end
|
||||
|
||||
# Query and sync options
|
||||
for condition in query sync
|
||||
complete -c $progname -n $$condition -s g -l groups -d 'Display all packages in GROUP' -xa "$listgroups" -f
|
||||
complete -c $progname -n $$condition -s i -l info -d 'Display information on PACKAGE' -f
|
||||
complete -c $progname -n $$condition -s q -l quiet -d 'Show less information' -f
|
||||
complete -c $progname -n $$condition -s s -l search -r -d 'Search packages for regexp' -f
|
||||
end
|
||||
|
||||
# Query options
|
||||
complete -c $progname -n $query -s c -l changelog -d 'View the change log of PACKAGE' -f
|
||||
complete -c $progname -n $query -s d -l deps -d 'List only non-explicit packages (dependencies)' -f
|
||||
complete -c $progname -n $query -s e -l explicit -d 'List only explicitly installed packages' -f
|
||||
complete -c $progname -n $query -s k -l check -d 'Check if all files owned by PACKAGE are present' -f
|
||||
complete -c $progname -n $query -s l -l list -d 'List all files owned by PACKAGE' -f
|
||||
complete -c $progname -n $query -s m -l foreign -d 'List all packages not in the database' -f
|
||||
complete -c $progname -n $query -s o -l owns -r -d 'Search for the package that owns FILE' -xa '' -f
|
||||
complete -c $progname -n $query -s p -l file -d 'Apply the query to a package file, not package' -xa '' -f
|
||||
complete -c $progname -n $query -s t -l unrequired -d 'List only unrequired packages' -f
|
||||
complete -c $progname -n $query -s u -l upgrades -d 'List only out-of-date packages' -f
|
||||
complete -c $progname -n "$query" -d 'Installed package' -xa $listinstalled -f
|
||||
|
||||
# Remove options
|
||||
complete -c $progname -n $remove -s c -l cascade -d 'Also remove packages depending on PACKAGE' -f
|
||||
complete -c $progname -n $remove -s n -l nosave -d 'Ignore file backup designations' -f
|
||||
complete -c $progname -n $remove -s s -l recursive -d 'Also remove dependencies of PACKAGE' -f
|
||||
complete -c $progname -n $remove -s u -l unneeded -d 'Only remove targets not required by PACKAGE' -f
|
||||
complete -c $progname -n "$remove" -d 'Installed package' -xa $listinstalled -f
|
||||
|
||||
# Sync options
|
||||
complete -c $progname -n $sync -s c -l clean -d 'Remove [all] packages from cache'
|
||||
complete -c $progname -n $sync -s l -l list -xa "$listrepos" -d 'List all packages in REPOSITORY'
|
||||
complete -c $progname -n "$sync; and not __fish_contains_opt -s u sysupgrade" -s u -l sysupgrade -d 'Upgrade all packages that are out of date'
|
||||
complete -c $progname -n "$sync; and __fish_contains_opt -s u sysupgrade" -s u -l sysupgrade -d 'Also downgrade packages'
|
||||
complete -c $progname -n $sync -s w -l downloadonly -d 'Only download the target packages'
|
||||
complete -c $progname -n $sync -s y -l refresh -d 'Download fresh copy of the package list'
|
||||
complete -c $progname -n "$sync" -xa "$listall $listgroups"
|
||||
|
||||
# Database options
|
||||
set -l has_db_opt '__fish_contains_opt asdeps asexplicit'
|
||||
complete -c $progname -n "$database; and not $has_db_opt" -xa --asdeps -d 'Mark PACKAGE as dependency'
|
||||
complete -c $progname -n "$database; and not $has_db_opt" -xa --asexplicit -d 'Mark PACKAGE as explicitly installed'
|
||||
complete -c $progname -n "$database; and not $has_db_opt" -s k -l check -d 'Check database validity'
|
||||
complete -c $progname -n "$has_db_opt; and $database" -xa "$listinstalled"
|
||||
|
||||
# File options - since pacman 5
|
||||
set -l has_file_opt '__fish_contains_opt list search -s l -s s'
|
||||
complete -c $progname -n "$files; and not $has_file_opt" -xa --list -d 'List files owned by given packages'
|
||||
complete -c $progname -n "$files; and not $has_file_opt" -xa -l -d 'List files owned by given packages'
|
||||
complete -c $progname -n "$files; and not $has_file_opt" -xa --search -d 'Search packages for matching files'
|
||||
complete -c $progname -n "$files; and not $has_file_opt" -xa -s -d 'Search packages for matching files'
|
||||
complete -c $progname -n "$files" -s y -l refresh -d 'Refresh the files database' -f
|
||||
complete -c $progname -n "$files" -s l -l list -d 'List files owned by given packages' -xa $listall
|
||||
complete -c $progname -n "$files" -s s -l search -d 'Search packages for matching files'
|
||||
complete -c $progname -n "$files" -s o -l owns -d 'Search for packages that include the given files'
|
||||
complete -c $progname -n "$files" -s q -l quiet -d 'Show less information' -f
|
||||
complete -c $progname -n "$files" -l machinereadable -d 'Show in machine readable format: repo\0pkgname\0pkgver\0path\n' -f
|
||||
|
||||
# Upgrade options
|
||||
# Theoretically, pacman reads packages in all formats that libarchive supports
|
||||
# In practice, it's going to be tar.xz or tar.gz
|
||||
# Using "pkg.tar.*" here would change __fish_complete_suffix's descriptions to "unknown"
|
||||
complete -c $progname -n "$upgrade" -xa '(__fish_complete_suffix pkg.tar.xz)' -d 'Package file'
|
||||
complete -c $progname -n "$upgrade" -xa '(__fish_complete_suffix pkg.tar.gz)' -d 'Package file'
|
662
zsh-completion
Normal file
662
zsh-completion
Normal file
|
@ -0,0 +1,662 @@
|
|||
#compdef pacman pacman.static=pacman pacman-key makepkg
|
||||
|
||||
typeset -A opt_args
|
||||
setopt extendedglob
|
||||
|
||||
# options for passing to _arguments: main pacman commands
|
||||
_pacman_opts_commands=(
|
||||
{-D,--database}'[Modify database]'
|
||||
{-Q,--query}'[Query the package database]'
|
||||
{-R,--remove}'[Remove a package from the system]'
|
||||
{-S,--sync}'[Synchronize packages]'
|
||||
{-T,--deptest}'[Check if dependencies are installed]'
|
||||
{-U,--upgrade}'[Upgrade a package]'
|
||||
{-V,--version}'[Display version and exit]'
|
||||
'(-h --help)'{-h,--help}'[Display usage]'
|
||||
)
|
||||
|
||||
# options for passing to _arguments: options common to all commands
|
||||
_pacman_opts_common=(
|
||||
{-b,--dbpath}'[Alternate database location]:database_location:_files -/'
|
||||
'--color[colorize the output]:color options:(always never auto)'
|
||||
{-h,--help}'[Display syntax for the given operation]'
|
||||
{-r,--root}'[Set alternate installation root]:installation root:_files -/'
|
||||
{-v,--verbose}'[Be more verbose]'
|
||||
'--cachedir[Alternate package cache location]:cache_location:_files -/'
|
||||
'--config[An alternate configuration file]:config file:_files'
|
||||
'--logfile[An alternate log file]:config file:_files'
|
||||
'--noconfirm[Do not ask for confirmation]'
|
||||
'--noprogressbar[Do not show a progress bar when downloading files]'
|
||||
'--noscriptlet[Do not execute the install scriptlet if one exists]'
|
||||
'--print[Only print the targets instead of performing the operation]'
|
||||
)
|
||||
|
||||
# options for passing to _arguments: options for --upgrade commands
|
||||
_pacman_opts_pkgfile=(
|
||||
'*-d[Skip dependency checks]'
|
||||
'*--nodeps[Skip dependency checks]'
|
||||
'--dbonly[Only remove database entry, do not remove files]'
|
||||
'--force[Overwrite conflicting files]'
|
||||
'--needed[Do not reinstall up to date packages]'
|
||||
'*:package file:_files -g "*.pkg.tar*~*.sig(.,@)"'
|
||||
)
|
||||
|
||||
# options for passing to _arguments: subactions for --query command
|
||||
_pacman_opts_query_actions=(
|
||||
'(-Q --query)'{-Q,--query}
|
||||
{-g,--groups}'[View all members of a package group]:*:package groups:->query_group'
|
||||
{-o,--owns}'[Query the package that owns a file]:file:_files'
|
||||
{-p,--file}'[Package file to query]:*:package file:->query_file'
|
||||
{-s,--search}'[Search package names and descriptions]:*:search text:->query_search'
|
||||
)
|
||||
|
||||
# options for passing to _arguments: options for --query and subcommands
|
||||
_pacman_opts_query_modifiers=(
|
||||
{-c,--changelog}'[List package changelog]'
|
||||
{-d,--deps}'[List packages installed as dependencies]'
|
||||
{-e,--explicit}'[List packages explicitly installed]'
|
||||
{\*-i,\*--info}'[View package information]'
|
||||
{\*-k,\*--check}'[Check package files]'
|
||||
{-l,--list}'[List package contents]'
|
||||
{-m,--foreign}'[List installed packages not found in sync db(s)]'
|
||||
{-n,--native}'[List installed packages found in sync db(s)]'
|
||||
{-t,--unrequired}'[List packages not required by any package]'
|
||||
{-u,--upgrades}'[List packages that can be upgraded]'
|
||||
)
|
||||
|
||||
# options for passing to _arguments: options for --remove command
|
||||
_pacman_opts_remove=(
|
||||
{-c,--cascade}'[Remove all dependent packages]'
|
||||
{*-d,*--nodeps}'[Skip dependency checks]'
|
||||
{-n,--nosave}'[Remove protected configuration files]'
|
||||
{\*-s,\*--recursive}'[Remove dependencies not required by other packages]'
|
||||
'--dbonly[Only remove database entry, do not remove files]'
|
||||
'*:installed package:_pacman_completions_installed_packages'
|
||||
)
|
||||
|
||||
_pacman_opts_database=(
|
||||
'--asdeps[mark packages as non-explicitly installed]'
|
||||
'--asexplicit[mark packages as explicitly installed]'
|
||||
'*:installed package:_pacman_completions_installed_packages'
|
||||
)
|
||||
|
||||
# options for passing to _arguments: options for --sync command
|
||||
_pacman_opts_sync_actions=(
|
||||
'(-S --sync)'{-S,--sync}
|
||||
{\*-c,\*--clean}'[Remove old packages from cache]:\*:clean:->sync_clean'
|
||||
{-g,--groups}'[View all members of a package group]:*:package groups:->sync_group'
|
||||
{-s,--search}'[Search package names and descriptions]:*:search text:->sync_search'
|
||||
'--dbonly[Only remove database entry, do not remove files]'
|
||||
'--needed[Do not reinstall up to date packages]'
|
||||
'--recursive[Reinstall all dependencies of target packages]'
|
||||
)
|
||||
|
||||
# options for passing to _arguments: options for --sync command
|
||||
_pacman_opts_sync_modifiers=(
|
||||
{\*-d,\*--nodeps}'[Skip dependency checks]'
|
||||
{\*-i,\*--info}'[View package information]'
|
||||
{-l,--list}'[List all packages in a repository]'
|
||||
{-p,--print}'[Print download URIs for each package to be installed]'
|
||||
{\*-u,\*--sysupgrade}'[Upgrade all out-of-date packages]'
|
||||
{-w,--downloadonly}'[Download packages only]'
|
||||
{\*-y,\*--refresh}'[Download fresh package databases]'
|
||||
'*--ignore[Ignore a package upgrade]:package: _pacman_completions_all_packages'
|
||||
'*--ignoregroup[Ignore a group upgrade]:package group:_pacman_completions_all_groups'
|
||||
'--asdeps[Install packages as non-explicitly installed]'
|
||||
'--asexplicit[Install packages as explicitly installed]'
|
||||
'--force[Overwrite conflicting files]'
|
||||
)
|
||||
|
||||
# handles --help subcommand
|
||||
_pacman_action_help() {
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_commands[@]"
|
||||
}
|
||||
|
||||
# handles cases where no subcommand has yet been given
|
||||
_pacman_action_none() {
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_commands[@]"
|
||||
}
|
||||
|
||||
# handles --query subcommand
|
||||
_pacman_action_query() {
|
||||
local context state line
|
||||
typeset -A opt_args
|
||||
|
||||
case $state in
|
||||
query_file)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:package file:_files -g "*.pkg.tar*~*.sig(.,@)"'
|
||||
;;
|
||||
query_group)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:groups:_pacman_completions_installed_groups'
|
||||
;;
|
||||
query_owner)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:file:_files'
|
||||
;;
|
||||
query_search)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:search text: '
|
||||
;;
|
||||
*)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_actions[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:package:_pacman_completions_installed_packages'
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
# handles --remove subcommand
|
||||
_pacman_action_remove() {
|
||||
_arguments -s : \
|
||||
'(--remove -R)'{-R,--remove} \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_remove[@]"
|
||||
}
|
||||
|
||||
# handles --database subcommand
|
||||
_pacman_action_database() {
|
||||
_arguments -s : \
|
||||
'(--database -D)'{-D,--database} \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_database[@]"
|
||||
}
|
||||
|
||||
_pacman_action_deptest () {
|
||||
_arguments -s : \
|
||||
'(--deptest)-T' \
|
||||
"$_pacman_opts_common[@]" \
|
||||
":packages:_pacman_all_packages"
|
||||
}
|
||||
|
||||
|
||||
# handles --sync subcommand
|
||||
_pacman_action_sync() {
|
||||
local context state line
|
||||
typeset -A opt_args
|
||||
if (( $+words[(r)--clean] )); then
|
||||
state=sync_clean
|
||||
elif (( $+words[(r)--groups] )); then
|
||||
state=sync_group
|
||||
elif (( $+words[(r)--search] )); then
|
||||
state=sync_search
|
||||
fi
|
||||
|
||||
case $state in
|
||||
sync_clean)
|
||||
_arguments -s : \
|
||||
{\*-c,\*--clean}'[Remove old packages from cache]' \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_sync_modifiers[@]"
|
||||
;;
|
||||
sync_group)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_sync_modifiers[@]" \
|
||||
'(-g --group)'{-g,--groups} \
|
||||
'*:package group:_pacman_completions_all_groups'
|
||||
;;
|
||||
sync_search)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_sync_modifiers[@]" \
|
||||
'*:search text: '
|
||||
;;
|
||||
*)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_sync_actions[@]" \
|
||||
"$_pacman_opts_sync_modifiers[@]" \
|
||||
'*:package:_pacman_completions_all_packages'
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
# handles --upgrade subcommand
|
||||
_pacman_action_upgrade() {
|
||||
_arguments -s : \
|
||||
'(-U --upgrade)'{-U,--upgrade} \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_pkgfile[@]"
|
||||
}
|
||||
|
||||
# handles --version subcommand
|
||||
_pacman_action_version() {
|
||||
# no further arguments
|
||||
return 0
|
||||
}
|
||||
|
||||
# provides completions for package groups
|
||||
_pacman_completions_all_groups() {
|
||||
local -a cmd groups
|
||||
_pacman_get_command
|
||||
groups=( $(_call_program groups $cmd[@] -Sg) )
|
||||
typeset -U groups
|
||||
compadd "$@" -a groups
|
||||
}
|
||||
|
||||
# provides completions for packages available from repositories
|
||||
# these can be specified as either 'package' or 'repository/package'
|
||||
_pacman_completions_all_packages() {
|
||||
local -a cmd packages repositories packages_long
|
||||
_pacman_get_command
|
||||
|
||||
if compset -P1 '*/*'; then
|
||||
packages=( $(_call_program packages $cmd[@] -Sql ${words[CURRENT]%/*}) )
|
||||
typeset -U packages
|
||||
_wanted repo_packages expl "repository/package" compadd ${(@)packages}
|
||||
else
|
||||
packages=( $(_call_program packages $cmd[@] -Sql) )
|
||||
typeset -U packages
|
||||
_wanted packages expl "packages" compadd - "${(@)packages}"
|
||||
|
||||
repositories=(${(o)${${${(M)${(f)"$(<@sysconfdir@/pacman.conf)"}:#\[*}/\[/}/\]/}:#options})
|
||||
typeset -U repositories
|
||||
_wanted repo_packages expl "repository/package" compadd -S "/" $repositories
|
||||
fi
|
||||
}
|
||||
|
||||
# provides completions for package groups
|
||||
_pacman_completions_installed_groups() {
|
||||
local -a cmd groups
|
||||
_pacman_get_command
|
||||
groups=(${(o)${(f)"$(_call_program groups $cmd[@] -Qg)"}% *})
|
||||
typeset -U groups
|
||||
compadd "$@" -a groups
|
||||
}
|
||||
|
||||
# provides completions for installed packages
|
||||
_pacman_completions_installed_packages() {
|
||||
local -a cmd packages packages_long
|
||||
packages_long=(@localstatedir@/lib/pacman/local/*(/))
|
||||
packages=( ${${packages_long#@localstatedir@/lib/pacman/local/}%-*-*} )
|
||||
compadd "$@" -a packages
|
||||
}
|
||||
|
||||
_pacman_all_packages() {
|
||||
_alternative : \
|
||||
'localpkgs:local packages:_pacman_completions_installed_packages' \
|
||||
'repopkgs:repository packages:_pacman_completions_all_packages'
|
||||
}
|
||||
|
||||
# provides completions for repository names
|
||||
_pacman_completions_repositories() {
|
||||
local -a cmd repositories
|
||||
repositories=(${(o)${${${(M)${(f)"$(<@sysconfdir@/pacman.conf)"}:#\[*}/\[/}/\]/}:#options})
|
||||
# Uniq the array
|
||||
typeset -U repositories
|
||||
compadd "$@" -a repositories
|
||||
}
|
||||
|
||||
# builds command for invoking pacman in a _call_program command - extracts
|
||||
# relevant options already specified (config file, etc)
|
||||
# $cmd must be declared by calling function
|
||||
_pacman_get_command() {
|
||||
# this is mostly nicked from _perforce
|
||||
cmd=( "pacman" "2>/dev/null")
|
||||
integer i
|
||||
for (( i = 2; i < CURRENT - 1; i++ )); do
|
||||
if [[ ${words[i]} = "--config" || ${words[i]} = "--root" ]]; then
|
||||
cmd+=( ${words[i,i+1]} )
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
# main dispatcher
|
||||
_pacman_zsh_comp() {
|
||||
local -a args cmds;
|
||||
local tmp
|
||||
args=( ${${${(M)words:#-*}#-}:#-*} )
|
||||
for tmp in $words; do
|
||||
cmds+=("${${_pacman_opts_commands[(r)*$tmp\[*]%%\[*}#*\)}")
|
||||
done
|
||||
case $args in #$words[2] in
|
||||
h*)
|
||||
if (( ${(c)#args} <= 1 && ${(w)#cmds} <= 1 )); then
|
||||
_pacman_action_help
|
||||
else
|
||||
_message "no more arguments"
|
||||
fi
|
||||
;;
|
||||
*h*)
|
||||
_message "no more arguments"
|
||||
;;
|
||||
D*)
|
||||
_pacman_action_database
|
||||
;;
|
||||
Q*g*) # ipkg groups
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:groups:_pacman_completions_installed_groups'
|
||||
;;
|
||||
Q*o*) # file
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:package file:_files'
|
||||
;;
|
||||
Q*p*) # file *.pkg.tar*
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_query_modifiers[@]" \
|
||||
'*:package file:_files -g "*.pkg.tar*~*.sig(.,@)"'
|
||||
;;
|
||||
T*)
|
||||
_pacman_action_deptest
|
||||
;;
|
||||
Q*)
|
||||
_pacman_action_query
|
||||
;;
|
||||
R*)
|
||||
_pacman_action_remove
|
||||
;;
|
||||
S*c*) # no completion
|
||||
_arguments -s : \
|
||||
'(-c --clean)'{\*-c,\*--clean}'[Remove all files from the cache]' \
|
||||
"$_pacman_opts_common[@]"
|
||||
;;
|
||||
S*l*) # repos
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_sync_modifiers[@]" \
|
||||
'*:package repo:_pacman_completions_repositories' \
|
||||
;;
|
||||
S*g*) # pkg groups
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_sync_modifiers[@]" \
|
||||
'*:package group:_pacman_completions_all_groups'
|
||||
;;
|
||||
S*s*)
|
||||
_arguments -s : \
|
||||
"$_pacman_opts_common[@]" \
|
||||
"$_pacman_opts_sync_modifiers[@]" \
|
||||
'*:search text: '
|
||||
;;
|
||||
S*)
|
||||
_pacman_action_sync
|
||||
;;
|
||||
T*)
|
||||
_arguments -s : \
|
||||
'-T' \
|
||||
"$_pacman_opts_common[@]" \
|
||||
":packages:_pacman_all_packages"
|
||||
;;
|
||||
U*)
|
||||
_pacman_action_upgrade
|
||||
;;
|
||||
V*)
|
||||
_pacman_action_version
|
||||
;;
|
||||
*)
|
||||
|
||||
case ${(M)words:#--*} in
|
||||
*--help*)
|
||||
if (( ${(w)#cmds} == 1 )); then
|
||||
_pacman_action_help
|
||||
else
|
||||
return 0;
|
||||
fi
|
||||
;;
|
||||
*--sync*)
|
||||
_pacman_action_sync
|
||||
;;
|
||||
*--query*)
|
||||
_pacman_action_query
|
||||
;;
|
||||
*--remove*)
|
||||
_pacman_action_remove
|
||||
;;
|
||||
*--deptest*)
|
||||
_pacman_action_deptest
|
||||
;;
|
||||
*--database*)
|
||||
_pacman_action_database
|
||||
;;
|
||||
*--version*)
|
||||
_pacman_action_version
|
||||
;;
|
||||
*--upgrade*)
|
||||
_pacman_action_upgrade
|
||||
;;
|
||||
*)
|
||||
_pacman_action_none
|
||||
;;
|
||||
esac
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
_key_shortopts=(
|
||||
'-h[show help]'
|
||||
'-a[Add the specified keys (empty for stdin)]: :_files'
|
||||
'-d[Remove the Specified keyids]:*: :_keys'
|
||||
'-e[Export the specified or all keyids]:*: :_keys'
|
||||
'-f[List fingreprint for specidied or all keyids]:*: :_keys'
|
||||
'-l[List the specified or all keys]:*: :_keys'
|
||||
'-r[Fetch the specified keyids]:*: :_keys'
|
||||
'-u[Update the trustdb of pacman]'
|
||||
'-v[Verify the file specified by the signature]: :_files -g "*.sig"'
|
||||
'-V[Show program version]'
|
||||
)
|
||||
|
||||
_key_longopts=(
|
||||
'--help[show help]'
|
||||
'--add[Add the specified keys (empty for stdin)]: :_files'
|
||||
'--delete[Remove the Specified keyids]:*: :_keys'
|
||||
'--export[Export the specified or all keyids]:*: :_keys'
|
||||
'--finger[List fingreprint for specidied or all keyids]:*: :_keys'
|
||||
'--list-keys[List the specified or all keys]:*: :_keys'
|
||||
'--recv-keys[Fetch the specified keyids]:*: :_keys'
|
||||
'--updatedb[Update the trustdb of pacman]'
|
||||
'--verify[Verify the file specified by the signature]: :_files -g "*.sig"'
|
||||
'--version[Show program version]'
|
||||
'--edit-key[Present a menu for key management task on keyids]:*: :_keys'
|
||||
'--import[Imports pubring.gpg from dir(s)]: :_files -g "*.gpg"'
|
||||
'--import-tb[Imports ownertrust values from trustdb.gpg in dir(s)]: :_files -g "*.gpg"'
|
||||
'--init[Ensure the keyring is properly initialized]'
|
||||
'--list-sigs[List keys and their signatures]:*: :_keys'
|
||||
'--lsign-key[Locally sign the specified keyid]:*: :_keys'
|
||||
'--populate[Reload the default keys from the (given) keyrings in '/usr/share/pacman/keyrings']: :_path_files -W /usr/share/pacman/keyrings'
|
||||
'--refresh-keys[Update specified or all keys from a keyserver]:*: :_keys'
|
||||
)
|
||||
|
||||
_pacman_key_options=(
|
||||
'--config[Use an alternate config file (instead of @sysconfdir@/pacman.conf)]: :_files'
|
||||
'--gpgdir[Set an alternate directory for GnuPG (instead of @sysconfdir@/pacman.d/gnupg)]: :_files -/'
|
||||
'--keyserver[Specify a keyserver to use if necessary]'
|
||||
)
|
||||
|
||||
_pacman_key() {
|
||||
case $words[CURRENT] in
|
||||
--*)
|
||||
_arguments -s : \
|
||||
"$_pacman_key_options[@]" \
|
||||
"$_key_longopts[@]"
|
||||
;;
|
||||
-*)
|
||||
_arguments -s : \
|
||||
"$_pacman_key_options[@]" \
|
||||
"$_key_shortopts[@]" \
|
||||
"$_key_longopts[@]"
|
||||
;;
|
||||
*)
|
||||
i=$#;
|
||||
while [[ $words[$i] != -* ]] && [[ $words[$i] != "pacman-key" ]];do
|
||||
i=$(($i-1))
|
||||
done
|
||||
case $i in
|
||||
--*)
|
||||
_arguments -s : \
|
||||
"$_pacman_key_options[@]" \
|
||||
"$_key_longopts[@]"
|
||||
;;
|
||||
-*)
|
||||
_arguments -s : \
|
||||
"$_pacman_key_options[@]" \
|
||||
"$_key_shortopts[@]" \
|
||||
"$_key_longopts[@]"
|
||||
;;
|
||||
*)
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
_keys() {
|
||||
local keylist keys
|
||||
keylist=$(pacman-key --list-keys 2>/dev/null | awk '
|
||||
$1 == "pub" {
|
||||
# key id
|
||||
split($2, a, "/"); print a[2]
|
||||
}
|
||||
$1 == "uid" {
|
||||
# email
|
||||
if (match($NF, /<[^>]+>/))
|
||||
print substr($NF, RSTART + 1, RLENGTH - 2)
|
||||
#this adds support for names as well if that is ever added
|
||||
}
|
||||
$1 == "uid" {
|
||||
for (i=2;i<NF;i++) {printf "%s%s",sep, $i;sep=" "}; printf "\n"
|
||||
}' |sed -e 's/(.*)//g' -e 's/^\ //g' -e 's/\ *$//g' |uniq
|
||||
)
|
||||
keys=(${(s:/:)${keylist//$'\n'/\/}})
|
||||
_describe -t modules 'keys in keyring' keys && return 0
|
||||
}
|
||||
|
||||
_makepkg_shortopts=(
|
||||
'-s[Install missing dependencies with pacman]'
|
||||
'-i[Install package after successful build]'
|
||||
'-A[Ignore incomplete arch field in PKGBUILD]'
|
||||
'-c[Clean up work files after build]'
|
||||
'-d[Skip all dependency checks]'
|
||||
'-e[Do not extract source files (use existing src/ dir)]'
|
||||
'-f[Overwrite existing package]'
|
||||
'-g[Generate integrity checks for source files]'
|
||||
'-h[Show help message and exit]'
|
||||
'-L[Log package build process]'
|
||||
'-m[Disable colorized output messages]'
|
||||
'-o[Download and extract files only]'
|
||||
'-p[Use an alternate build script (instead of 'PKGBUILD')]: :_files'
|
||||
'-r[Remove installed dependencies after a successful build]'
|
||||
'-R[Repackage contents of the package without rebuilding]'
|
||||
'-S[Generate a source-only tarball without downloading sources]'
|
||||
)
|
||||
|
||||
_makepkg_action_none(){
|
||||
_arguments \
|
||||
"$_makepkg_shortopts[@]" \
|
||||
"$_makepkg_longopts[@]"
|
||||
}
|
||||
_makepkg_longopts=(
|
||||
'--ignorearch[Ignore incomplete arch field in PKGBUILD]'
|
||||
'--clean[Clean up work files after build]'
|
||||
'--nodeps[Skip all dependency checks]'
|
||||
'--noextract[Do not extract source files (use existing src/ dir)]'
|
||||
'--force[Overwrite existing package]'
|
||||
'--geninteg[Generate integrity checks for source files]'
|
||||
'--help[Show help message and exit]'
|
||||
'--install[Install package after successful build]'
|
||||
'--log[Log package build process]'
|
||||
'--nocolor[Disable colorized output messages]'
|
||||
'--nobuild[Download and extract files only]'
|
||||
'--rmdeps[Remove installed dependencies after a successful build]'
|
||||
'--repackage[Repackage contents of the package without rebuilding]'
|
||||
'--syncdeps[Install missing dependencies with pacman]'
|
||||
'--source[Generate a source-only tarball without downloading sources]'
|
||||
'--allsource[Generate a source-only tarball including downloaded source]'
|
||||
'--asroot[Allow makepkg to run as root user]'
|
||||
'--check[Run check() function in the PKGBUILD]'
|
||||
'--config[Use an alternate config file instead of '@sysconfdir@/makepkg.conf']: :_files'
|
||||
'--holdver[Prevent automatic version bumping for development PKGBUILDs]'
|
||||
'--key[Specify key to use for gpg signing instead of the default]: :_keys'
|
||||
'--nocheck[Do not run the check() function in the PKGBUILD]'
|
||||
'--noprepare[Do not run the prepare() function in the PKGBUILD]'
|
||||
'--nosign[Do not create a signature for the package]'
|
||||
'--pkg[Only build listed packages from a split package]'
|
||||
'--sign[Sign the resulting package with gpg]'
|
||||
'--skipchecksums[Do not verify checksums of the source files]'
|
||||
'--skipinteg[do not perform any verification checks on source files]'
|
||||
'--skippgpcheck[Do not verify source files with PGP signatures]'
|
||||
'--noconfirm[do not ask for confirmation when resolving dependencies]'
|
||||
'--asdeps[Install packages as non-explicitly installed]'
|
||||
'--noprogressbar[Do not show a progress bar when downloading files]'
|
||||
'--needed[Do not reinstall up-to-date packages]'
|
||||
'--verifysource[Only download sources and verify checksums]'
|
||||
)
|
||||
_makepkg(){
|
||||
case $words[CURRENT] in
|
||||
-*)
|
||||
_arguments -s -w : \
|
||||
"$_makepkg_shortopts[@]" \
|
||||
"$_makepkg_longopts[@]"
|
||||
;;
|
||||
--* )
|
||||
_arguments -s \
|
||||
"$_makepkg_longopts[@]"
|
||||
;;
|
||||
- )
|
||||
_makepkg_action_none
|
||||
;;
|
||||
*)
|
||||
i=$#
|
||||
while [[ $words[i] != -* ]] && [[ $words[$i] != "makepkg" ]];do
|
||||
i=$((i-1));
|
||||
done
|
||||
case $words[$i] in
|
||||
-*)
|
||||
_arguments -s -w : \
|
||||
"$_makepkg_shortopts[@]" \
|
||||
"$_makepkg_longopts[@]"
|
||||
;;
|
||||
--* )
|
||||
_arguments -s \
|
||||
"$_makepkg_longopts[@]"
|
||||
;;
|
||||
- )
|
||||
_makepkg_action_none
|
||||
;;
|
||||
* )
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
;;
|
||||
esac
|
||||
}
|
||||
_pacman_comp() {
|
||||
case "$service" in
|
||||
makepkg)
|
||||
_makepkg "$@"
|
||||
;;
|
||||
pacman-key)
|
||||
_pacman_key "$@"
|
||||
;;
|
||||
pacman)
|
||||
_pacman_zsh_comp "$@"
|
||||
;;
|
||||
yay)
|
||||
_pacman_zsh_comp "$@"
|
||||
;;
|
||||
*)
|
||||
_message "Error"
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
_pacman_comp "$@"
|
Loading…
Reference in a new issue