summaryrefslogtreecommitdiff
path: root/scripts/completions/bash
diff options
context:
space:
mode:
author魏曹先生 <1992414357@qq.com>2026-01-05 15:09:57 +0800
committer魏曹先生 <1992414357@qq.com>2026-01-05 15:09:57 +0800
commit4c54c3282b5980551179da5c7f7416359ad2ded9 (patch)
tree8fe05b7ffcd09fa66782d2908829f31eeb044bf7 /scripts/completions/bash
parent5c4e1b0f94fcf61d44b4d0ba86f54dbde98c31fc (diff)
Add share command with subcommands and completion supportMVP
The share command now supports `list`, `see`, and merging operations with conflict resolution modes (--safe, --skip, --overwrite, --reject). Updated help documentation in both English and Chinese locales, and added Bash and PowerShell completion scripts.
Diffstat (limited to 'scripts/completions/bash')
-rw-r--r--scripts/completions/bash/completion_jv.sh36
1 files changed, 35 insertions, 1 deletions
diff --git a/scripts/completions/bash/completion_jv.sh b/scripts/completions/bash/completion_jv.sh
index 4023e42..364df9d 100644
--- a/scripts/completions/bash/completion_jv.sh
+++ b/scripts/completions/bash/completion_jv.sh
@@ -18,7 +18,7 @@ _jv_completion() {
local base_commands="create init direct unstain account update \
sheet status here move mv docs exit use sheets accounts \
as make drop track hold throw login \
- jump align info"
+ jump align info share"
# Subcommands - Account
local account_commands="list as add remove movekey mvkey mvk genpub help"
@@ -157,6 +157,40 @@ _jv_completion() {
return 0
fi
+ # Completion share
+ if [[ "$subcmd" == "share" ]]; then
+ if [[ $cword -eq 2 ]]; then
+ # First parameter: list, see, jv share list --raw results, or files
+ local share_list
+ share_list=$($cmd share list --raw 2>/dev/null)
+ local first_param_options="list see $share_list"
+ COMPREPLY=($(compgen -W "$first_param_options" -f -- "$cur"))
+ elif [[ $cword -eq 3 ]]; then
+ # Second parameter: depends on first parameter
+ local first_param="${words[2]}"
+
+ if [[ "$first_param" == "list" ]]; then
+ # list -> nothing
+ COMPREPLY=()
+ elif [[ "$first_param" == "see" ]]; then
+ # see -> jv share list --raw results
+ local share_list
+ share_list=$($cmd share list --raw 2>/dev/null)
+ COMPREPLY=($(compgen -W "$share_list" -- "$cur"))
+ elif [[ "$first_param" == *"@"* ]]; then
+ # Contains "@" (shareid) -> show options
+ COMPREPLY=($(compgen -W "--safe --overwrite --skip --reject" -- "$cur"))
+ else
+ # File input -> show jv sheet list --all --raw results
+ local all_sheets
+ all_sheets=$($cmd sheet list --all --raw 2>/dev/null)
+ COMPREPLY=($(compgen -W "$all_sheets" -- "$cur"))
+ fi
+ fi
+ # Third parameter: no completion
+ return 0
+ fi
+
# Completion login
if [[ "$subcmd" == "login" ]]; then
if [[ $cword -eq 2 ]]; then