mirror of
https://github.com/onyx-and-iris/slobs-cli.git
synced 2026-04-01 06:39:17 +00:00
add shell completion scripts
add Shell Completion section to README add pdm script completion add pre-commit config
This commit is contained in:
parent
58a8b96603
commit
cab4299b17
7
.pre-commit-config.yaml
Normal file
7
.pre-commit-config.yaml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
repos:
|
||||||
|
- repo: https://github.com/pre-commit/pre-commit-hooks
|
||||||
|
rev: v2.3.0
|
||||||
|
hooks:
|
||||||
|
- id: check-yaml
|
||||||
|
- id: end-of-file-fixer
|
||||||
|
- id: trailing-whitespace
|
||||||
63
README.md
63
README.md
@ -16,6 +16,7 @@ For an outline of past/future changes refer to: [CHANGELOG](CHANGELOG.md)
|
|||||||
- [Configuration](#configuration)
|
- [Configuration](#configuration)
|
||||||
- [Style](#style)
|
- [Style](#style)
|
||||||
- [Commands](#commands)
|
- [Commands](#commands)
|
||||||
|
- [Shell Completion](#shell-completion)
|
||||||
- [License](#license)
|
- [License](#license)
|
||||||
|
|
||||||
## Requirements
|
## Requirements
|
||||||
@ -325,10 +326,70 @@ slobs-cli scenecollection load "ExistingCollection"
|
|||||||
slobs-cli scenecollection rename "ExistingCollection" "NewName"
|
slobs-cli scenecollection rename "ExistingCollection" "NewName"
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Shell Completion
|
||||||
|
|
||||||
|
Shell completion scripts are available for *bash*, *zsh*, and *fish*, you can find them in the [completions directory](./completions/).
|
||||||
|
|
||||||
|
#### Bash
|
||||||
|
|
||||||
|
Save the script in a completion directory of your choice.
|
||||||
|
|
||||||
|
```console
|
||||||
|
cp -v ./completions/_slobs-cli.bash ~/.completions/_slobs-cli
|
||||||
|
```
|
||||||
|
|
||||||
|
Source the file in `~/.bashrc`
|
||||||
|
|
||||||
|
```bash
|
||||||
|
. ~/.completions/_slobs-cli
|
||||||
|
```
|
||||||
|
|
||||||
|
Restart the shell
|
||||||
|
|
||||||
|
```console
|
||||||
|
exec "$SHELL"
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Fish
|
||||||
|
|
||||||
|
Save the script to `~/.config/fish/completions`
|
||||||
|
|
||||||
|
```fish
|
||||||
|
cp -v ./completions/_slobs-cli.fish ~/.config/fish/completions/_slobs-cli
|
||||||
|
```
|
||||||
|
|
||||||
|
Restart the shell
|
||||||
|
|
||||||
|
```console
|
||||||
|
exec "$SHELL"
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Zsh
|
||||||
|
|
||||||
|
Save the script in a completion directory of your choice.
|
||||||
|
|
||||||
|
```console
|
||||||
|
cp -v ./completions/_slobs-cli.zsh ~/.completions/_slobs-cli
|
||||||
|
```
|
||||||
|
|
||||||
|
Source the file in `~/.zshrc`
|
||||||
|
|
||||||
|
```zsh
|
||||||
|
. ~/.completions/_slobs-cli
|
||||||
|
```
|
||||||
|
|
||||||
|
> Note: If you're using a framework like oh-my-zsh you can copy the completion script straight into $ZSH_CUSTOM/completions and skip modifying ~/.zshrc
|
||||||
|
|
||||||
|
Restart the shell
|
||||||
|
|
||||||
|
```console
|
||||||
|
exec "$SHELL"
|
||||||
|
```
|
||||||
|
|
||||||
## Special Thanks
|
## Special Thanks
|
||||||
|
|
||||||
- [Julian-0](https://github.com/Julian-O) For writing the [PySLOBS wrapper](https://github.com/Julian-O/PySLOBS) on which this CLI depends.
|
- [Julian-0](https://github.com/Julian-O) For writing the [PySLOBS wrapper](https://github.com/Julian-O/PySLOBS) on which this CLI depends.
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
`slobs-cli` is distributed under the terms of the [MIT](https://spdx.org/licenses/MIT.html) license.
|
`slobs-cli` is distributed under the terms of the [MIT](https://spdx.org/licenses/MIT.html) license.
|
||||||
|
|||||||
33
Taskfile.yaml
Normal file
33
Taskfile.yaml
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
version: '3'
|
||||||
|
|
||||||
|
tasks:
|
||||||
|
default:
|
||||||
|
desc: Generate completion scripts for supported shells
|
||||||
|
cmds:
|
||||||
|
- task: generate-completion-scripts
|
||||||
|
|
||||||
|
generate-completion-scripts:
|
||||||
|
desc: Generate completion scripts for supported shells
|
||||||
|
cmds:
|
||||||
|
- for:
|
||||||
|
matrix:
|
||||||
|
SHELL: [bash, fish, zsh]
|
||||||
|
task: generate-completion-script-{{.ITEM.SHELL}}
|
||||||
|
|
||||||
|
generate-completion-script-bash:
|
||||||
|
desc: Generate bash completion script
|
||||||
|
cmds:
|
||||||
|
- bash -c '_SLOBS_CLI_COMPLETE=bash_source slobs-cli > ./completions/_slobs-cli.bash'
|
||||||
|
internal: true
|
||||||
|
|
||||||
|
generate-completion-script-fish:
|
||||||
|
desc: Generate fish completion script
|
||||||
|
cmds:
|
||||||
|
- fish -c '_SLOBS_CLI_COMPLETE=fish_source slobs-cli > ./completions/_slobs-cli.fish'
|
||||||
|
internal: true
|
||||||
|
|
||||||
|
generate-completion-script-zsh:
|
||||||
|
desc: Generate zsh completion script
|
||||||
|
cmds:
|
||||||
|
- zsh -c '_SLOBS_CLI_COMPLETE=zsh_source slobs-cli > ./completions/_slobs-cli.zsh'
|
||||||
|
internal: true
|
||||||
28
completions/_slobs-cli.bash
Normal file
28
completions/_slobs-cli.bash
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
_slobs_cli_completion() {
|
||||||
|
local IFS=$'\n'
|
||||||
|
local response
|
||||||
|
|
||||||
|
response=$(env COMP_WORDS="${COMP_WORDS[*]}" COMP_CWORD=$COMP_CWORD _SLOBS_CLI_COMPLETE=bash_complete $1)
|
||||||
|
|
||||||
|
for completion in $response; do
|
||||||
|
IFS=',' read type value <<< "$completion"
|
||||||
|
|
||||||
|
if [[ $type == 'dir' ]]; then
|
||||||
|
COMPREPLY=()
|
||||||
|
compopt -o dirnames
|
||||||
|
elif [[ $type == 'file' ]]; then
|
||||||
|
COMPREPLY=()
|
||||||
|
compopt -o default
|
||||||
|
elif [[ $type == 'plain' ]]; then
|
||||||
|
COMPREPLY+=($value)
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
_slobs_cli_completion_setup() {
|
||||||
|
complete -o nosort -F _slobs_cli_completion slobs-cli
|
||||||
|
}
|
||||||
|
|
||||||
|
_slobs_cli_completion_setup;
|
||||||
17
completions/_slobs-cli.fish
Normal file
17
completions/_slobs-cli.fish
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
function _slobs_cli_completion;
|
||||||
|
set -l response (env _SLOBS_CLI_COMPLETE=fish_complete COMP_WORDS=(commandline -cp) COMP_CWORD=(commandline -t) slobs-cli);
|
||||||
|
|
||||||
|
for completion in $response;
|
||||||
|
set -l metadata (string split "," $completion);
|
||||||
|
|
||||||
|
if test $metadata[1] = "dir";
|
||||||
|
__fish_complete_directories $metadata[2];
|
||||||
|
else if test $metadata[1] = "file";
|
||||||
|
__fish_complete_path $metadata[2];
|
||||||
|
else if test $metadata[1] = "plain";
|
||||||
|
echo $metadata[2];
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
complete --no-files --command slobs-cli --arguments "(_slobs_cli_completion)";
|
||||||
40
completions/_slobs-cli.zsh
Normal file
40
completions/_slobs-cli.zsh
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
#compdef slobs-cli
|
||||||
|
|
||||||
|
_slobs_cli_completion() {
|
||||||
|
local -a completions
|
||||||
|
local -a completions_with_descriptions
|
||||||
|
local -a response
|
||||||
|
(( ! $+commands[slobs-cli] )) && return 1
|
||||||
|
|
||||||
|
response=("${(@f)$(env COMP_WORDS="${words[*]}" COMP_CWORD=$((CURRENT-1)) _SLOBS_CLI_COMPLETE=zsh_complete slobs-cli)}")
|
||||||
|
|
||||||
|
for type key descr in ${response}; do
|
||||||
|
if [[ "$type" == "plain" ]]; then
|
||||||
|
if [[ "$descr" == "_" ]]; then
|
||||||
|
completions+=("$key")
|
||||||
|
else
|
||||||
|
completions_with_descriptions+=("$key":"$descr")
|
||||||
|
fi
|
||||||
|
elif [[ "$type" == "dir" ]]; then
|
||||||
|
_path_files -/
|
||||||
|
elif [[ "$type" == "file" ]]; then
|
||||||
|
_path_files -f
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -n "$completions_with_descriptions" ]; then
|
||||||
|
_describe -V unsorted completions_with_descriptions -U
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$completions" ]; then
|
||||||
|
compadd -U -V unsorted -a completions
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
if [[ $zsh_eval_context[-1] == loadautofunc ]]; then
|
||||||
|
# autoload from fpath, call function directly
|
||||||
|
_slobs_cli_completion "$@"
|
||||||
|
else
|
||||||
|
# eval/source/. command, register function for later
|
||||||
|
compdef _slobs_cli_completion slobs-cli
|
||||||
|
fi
|
||||||
@ -2,7 +2,12 @@
|
|||||||
name = "slobs-cli"
|
name = "slobs-cli"
|
||||||
description = "A command line application for Streamlabs Desktop"
|
description = "A command line application for Streamlabs Desktop"
|
||||||
authors = [{ name = "onyx-and-iris", email = "code@onyxandiris.online" }]
|
authors = [{ name = "onyx-and-iris", email = "code@onyxandiris.online" }]
|
||||||
dependencies = ["pyslobs>=2.0.5", "asyncclick>=8.1.8", "rich>=14.0.0", "anyio>=4.12.0"]
|
dependencies = [
|
||||||
|
"pyslobs>=2.0.5",
|
||||||
|
"asyncclick>=8.1.8",
|
||||||
|
"rich>=14.0.0",
|
||||||
|
"anyio>=4.12.0",
|
||||||
|
]
|
||||||
requires-python = ">=3.11"
|
requires-python = ">=3.11"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
license = { text = "MIT" }
|
license = { text = "MIT" }
|
||||||
@ -36,6 +41,8 @@ test.keep_going = true
|
|||||||
fmt.cmd = "ruff format {args}"
|
fmt.cmd = "ruff format {args}"
|
||||||
post_fmt.cmd = "ruff check {args}"
|
post_fmt.cmd = "ruff check {args}"
|
||||||
|
|
||||||
|
completion.cmd = "task generate-completion-scripts"
|
||||||
|
|
||||||
[dependency-groups]
|
[dependency-groups]
|
||||||
dev = [
|
dev = [
|
||||||
"tox-pdm>=0.7.2",
|
"tox-pdm>=0.7.2",
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user