Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
eepm
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
etersoft
eepm
Commits
d82c4a26
Commit
d82c4a26
authored
Jun 14, 2024
by
Ivan Mazhukin
Committed by
Vitaly Lipatov
Nov 09, 2024
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
zsh_completion/eepm: fix short commands params (eterbug #17426)
parent
302cbbc7
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
173 additions
and
28 deletions
+173
-28
_eepm
zsh_completion/_eepm
+173
-28
No files found.
zsh_completion/_eepm
View file @
d82c4a26
...
@@ -4,11 +4,104 @@ _epm() {
...
@@ -4,11 +4,104 @@ _epm() {
typeset -A opt_args
typeset -A opt_args
local context state line curcontext="$curcontext"
local context state line curcontext="$curcontext"
local ret=1
local ret=1
EEPM_COMMANDS=(
epmp epmi epmI epms epme epmu epmqf epmcl epmsf
query q info packages filelist qp grep query_package ql get-files changelog cl qi show qa list-installed ls li list-available programs
requires deplist depends req depends-on whatdepends rdepends whatrequires wd required-by provides prov whatprovides conflicts policy resolve
qf wp which belongs
install Install reinstall add i it installed simulate prescription recipe
remove rm del remove delete uninstall erase purge e autoorphans remove-orphans
update full-upgrade Upgrade update-repo ur up
search search-file s find sr filesearch sf
status list assure repo autoremove package-cleanup mark tool print
addrepo ar repofix removerepo remove-repo rr
check fix verify dedup release-upgrade upgrade-release upgrade-system release-switch history checkpkg integrity
Downgrade release-downgrade downgrade-release downgrade-system downgrade distro-sync
download fetch fc
remove-old-kernels remove-old-kernel kernel-update kernel-upgrade update-kernel upgrade-kernel stats
clean delete-cache dc restore
audit site url checkpkg integrity
ei ik epminstall epm-install selfinstall
repack play pack -i
)
EEPM_SUBCOMMANDS_ARGS=(epmi epme epmp epmqf epmI epms epmsf epmu epmq epmql epmqa epmqi epmcl epmrl epmwd epmqp)
EEPM_SHORT_ARGS=(
'-h[show help]'
'-v[show version]'
'-y[assume yes]'
'-i[install]'
'-e[remove]'
'-P[remove]'
'-s[search]'
'-qp[query package]'
'-qf[query file]'
'-q[query]'
'-S[search]'
'-sf[search file]'
'-ql[list files]'
'-cl[changelog]'
'-qi[query info]'
'-qa[query all]'
'-V[verify]'
)
EEPM_FULL_ARGS=(
'--help[show help]'
'--version[show version]'
'--verbose[verbose mode]'
'--debug[debug mode]'
'--skip-installed[skip installed]'
'--skip-missed[skip missed]'
'--show-command-only[show command only]'
'--quiet[quiet mode]'
'--silent[silent mode]'
'--nodeps[no dependencies]'
'--force[force action]'
'--noremove[no remove]'
'--no-remove[no remove]'
'--no-stdin[no stdin]'
'--inscript[in script]'
'--dry-run[dry run]'
'--simulate[simulate]'
'--just-print[just print]'
'--no-act[no action]'
'--short[short format]'
'--direct[direct mode]'
'--repack[repack]'
'--norepack[no repack]'
'--install[install]'
'--scripts[show scripts]'
'--noscripts[no scripts]'
'--save-only[save only]'
'--put-to-repo=[put to repo]'
'--download-only[download only]'
'--url[show URL]'
'--sort[sort]'
'--auto[auto]'
'--assumeyes[assume yes]'
'--non-interactive[non-interactive]'
'--disable-interactivity[disable interactivity]'
'--interactive[interactive]'
'--force-yes[force yes]'
'--add-repo[add repo]'
'--orphans[show orphans]'
)
local commands; commands=(
local commands; commands=(
'play:install the application'
'play:install the application'
'add:install packages'
'install:install packages'
'install:install packages'
'i:install packages'
'it:install packages'
'remove:remove packages'
'remove:remove packages'
'uninstall:remove packages'
'rm:remove packages'
'del:remove packages'
'delete:remove packages'
'erase:remove packages'
'purge:remove packages'
'e:remove packages'
'full-upgrade:do full upgrade'
'full-upgrade:do full upgrade'
'update:update remote package repository databases'
'update:update remote package repository databases'
'search:search package by name'
'search:search package by name'
...
@@ -19,21 +112,26 @@ _epm() {
...
@@ -19,21 +112,26 @@ _epm() {
'cl:print changelog for the package'
'cl:print changelog for the package'
)
)
_arguments -C \
'(- 1 *)--help[show usage]' \
'*:command:->args' \
&& ret=0
local cmd
local cmd
for word in "${words[@]}"; do
for word in "${words[@]}"; do
case "$word" in
if [[ " ${EEPM_COMMANDS[@]} " =~ " $word " ]] || [[ " ${EEPM_SHORT_ARGS[@]} " =~ " $word " ]]; then
play|epmp|install|epmi|epmI|epms|remove|epme|full-upgrade|update|epmu|qf|epmqf|cl|epmcl|sf|epmsf|epmq|epmql|epmqi|epmwd|epmqp|epmrl|epmqa)
cmd="$word"
cmd="$word"
break
break
;;
fi
esac
done
done
if [[ ! " ${EEPM_SUBCOMMANDS_ARGS[@]} " =~ " $cmd " ]]; then
_arguments -C \
"${EEPM_SHORT_ARGS[@]}" \
"${EEPM_FULL_ARGS[@]}" \
'*::arg:->args' \
&& ret=0
else
_arguments -C '*:arg:->args'
fi
if [[ -z "$cmd" ]]; then
if [[ -z "$cmd" ]]; then
_describe -t commands 'command' commands && ret=0
_describe -t commands 'command' commands && ret=0
return $ret
return $ret
...
@@ -59,28 +157,63 @@ _epm() {
...
@@ -59,28 +157,63 @@ _epm() {
_epm_play_packages && ret=0
_epm_play_packages && ret=0
fi
fi
;;
;;
install|
epmi|epmI|epms|epmcl|epmwd|epmq|epmqi|epmqp|epmql|cl
)
install|
Install|reinstall|add|i|it|-i|installed|epmi|epmI|epms|epmq|epmql|epmqi|epmcl|epmwd
)
_epm_available_packages && ret=0
_epm_available_packages && ret=0
;;
;;
remove|epme)
_epm_installed_packages && ret=0
;;
full-upgrade)
full-upgrade)
_arguments \
_epm_complete_full-upgrade && ret=0
'-h[help]' \
;;
'--help[help]' \
query|q|-q|info|qp|grep|query_package|-qp|changelog|cl|-cl|show|qi|-qi|search|s|find|sr|-s|-ql|ql|get-files|filelist|requires|deplist|depends|req|depends-on|whatdepends|rdepends|whatrequires|wd|required-by|provides|prov|whatprovides|conflicts|policy|resolve)
'--interactive[ask before every step]' \
_epm_available_packages && ret=0
'--ipfs[use IPFS for epm play]' \
'--no-epm-play[skip epm play during full upgrade]' \
'--no-flatpak[skip flatpak update during full upgrade]'\
'--no-snap[skip snap update during full upgrade]'\
'--no-kernel-update[skip kernel update during full upgrade]'\
'--no-clean[no clean after upgrade]' \
&& ret=0
;;
;;
qf|epmqf)
remove|rm|del|delete|uninstall|erase|purge|e|-e|-P|site|url|epme|epmqp)
_epm_installed_packages && ret=0
;;
qf|wp|which|belongs|-qf|-S|epmqf)
_epm_complete_qf && ret=0
_epm_complete_qf && ret=0
;;
;;
status)
_epm_complete_status && ret=0
;;
list)
_epm_complete_list && ret=0
;;
addrepo|ar|repofix|removerepo|remove-repo|rr)
_epm_complete_repolist && ret=0
;;
repo)
_epm_complete_repo && ret=0
;;
kernel-update|kernel-upgrade|update-kernel|upgrade-kernel)
_epm_complete_kernel_update && ret=0
;;
autoremove|package-cleanup)
_epm_complete_autoremove && ret=0
;;
mark)
_epm_complete_mark && ret=0
;;
history)
_epm_complete_history && ret=0
;;
download|fetch|fc|simulate)
_epm_available_packages && ret=0
;;
prescription|recipe)
_epm_list_available_prescription && ret=0
;;
pack)
_epm_complete_pack && ret=0
;;
repack)
_epm_complete_repack && ret=0
;;
tool)
_epm_complete_tool && ret=0
;;
print)
_epm_complete_print && ret=0
;;
*)
*)
ret=0
ret=0
;;
;;
...
@@ -91,6 +224,20 @@ _epm() {
...
@@ -91,6 +224,20 @@ _epm() {
return $ret
return $ret
}
}
_epm_complete_full-upgrade(){
_arguments \
'-h[help]' \
'--help[help]' \
'--interactive[ask before every step]' \
'--ipfs[use IPFS for epm play]' \
'--no-epm-play[skip epm play during full upgrade]' \
'--no-flatpak[skip flatpak update during full upgrade]'\
'--no-snap[skip snap update during full upgrade]'\
'--no-kernel-update[skip kernel update during full upgrade]'\
'--no-clean[no clean after upgrade]'
}
_epm_complete_qf() {
_epm_complete_qf() {
local current_word="${words[CURRENT]}"
local current_word="${words[CURRENT]}"
if [[ "$current_word" == */* ]]; then
if [[ "$current_word" == */* ]]; then
...
@@ -119,5 +266,3 @@ _epm_installed_packages() {
...
@@ -119,5 +266,3 @@ _epm_installed_packages() {
}
}
compdef _epm epm eepm epmi epme epmp epmqf epmI epms epmsf epmu epmq epmql epmqa epmqi epmcl epmrl epmwd epmqp
compdef _epm epm eepm epmi epme epmp epmqf epmI epms epmsf epmu epmq epmql epmqa epmqi epmcl epmrl epmwd epmqp
\ No newline at end of file
#
#
\ No newline at end of file
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