From 90bd3af95824df48410a8be4cbe939068138382a Mon Sep 17 00:00:00 2001 From: David Barnett Date: Sat, 24 Aug 2024 12:03:22 -0600 Subject: [PATCH] feat: Support shell completion using argcomplete --- docs/README.md | 20 +++++++++++++++++++- gcalcli/argparsers.py | 7 ++++++- gcalcli/cli.py | 1 + pyproject.toml | 1 + 4 files changed, 27 insertions(+), 2 deletions(-) diff --git a/docs/README.md b/docs/README.md index 5d529bc4..31d9f631 100644 --- a/docs/README.md +++ b/docs/README.md @@ -22,11 +22,12 @@ Requirements * [httplib2](https://github.com/httplib2/httplib2) * [Google OAuth Library](https://github.com/googleapis/google-auth-library-python-oauthlib) * [parsedatetime](https://github.com/bear/parsedatetime) +* [argcomplete](https://kislyuk.github.io/argcomplete) * A love for the command line! ### Optional packages -* [vobject](http://vobject.skyhouseconsulting.com) Python module +* [vobject](https://py-vobject.github.io/) Python module Used for ics/vcal importing. Installation @@ -98,6 +99,7 @@ Features * work against specific calendars (by calendar name w/ regex) * flag file support for specifying option defaults * colored output and unicode character support + * custom shell completion for bash, zsh, fish, etc * super fun hacking with shell scripts, cron, screen, tmux, conky, etc Screenshots @@ -165,6 +167,22 @@ authentication process will proceed. Simply follow the instructions. In most shells, putting a space before the command will keep it, and therefore your secrets, out of history. Check with `history | tail`. 7. This should automatically open the OAuth2 authorization screen in your default browser. +#### Shell completion + +gcalcli provides command completion you can configure in bash, zsh, fish, etc using the [https://kislyuk.github.io/argcomplete/] library. + +To enable it, follow argcomplete's setup instructions to ensure your shell can find the completion hooks. + +```shell +gcalcli +add +agenda +agendaupdate +... +``` + +NOTE: Setup for fish and other shells is currently explained [under "contrib"](https://github.com/kislyuk/argcomplete/tree/develop/contrib) instead of their main docs, and their centralized "global activation" mechanism doesn't seem to be supported yet for those shells. + #### HTTP Proxy Support gcalcli will automatically work with an HTTP Proxy simply by setting up some diff --git a/gcalcli/argparsers.py b/gcalcli/argparsers.py index a91a2e0a..db6e408a 100644 --- a/gcalcli/argparsers.py +++ b/gcalcli/argparsers.py @@ -4,8 +4,10 @@ import copy as _copy import datetime import locale -from shutil import get_terminal_size import sys +from shutil import get_terminal_size + +import argcomplete # type: ignore import gcalcli @@ -420,4 +422,7 @@ def get_argument_parser(): '--use_reminders', action=DeprecatedStoreTrue, help=argparse.SUPPRESS) + # Enrich with argcomplete options. + argcomplete.autocomplete(parser) + return parser diff --git a/gcalcli/cli.py b/gcalcli/cli.py index f36dc4f0..9c62a77e 100755 --- a/gcalcli/cli.py +++ b/gcalcli/cli.py @@ -1,4 +1,5 @@ #!/usr/bin/env python +# PYTHON_ARGCOMPLETE_OK # # ######################################################################### # # # diff --git a/pyproject.toml b/pyproject.toml index c7888154..b25e6a73 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -31,6 +31,7 @@ dependencies = [ "httplib2", "google_auth_oauthlib", "parsedatetime", + "argcomplete", ] [project.urls]