Skip to content

Commit

Permalink
feat: Support shell completion using argcomplete
Browse files Browse the repository at this point in the history
  • Loading branch information
dbarnett committed Aug 24, 2024
1 parent 90e870c commit 90bd3af
Show file tree
Hide file tree
Showing 4 changed files with 27 additions and 2 deletions.
20 changes: 19 additions & 1 deletion docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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 <TAB>
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
Expand Down
7 changes: 6 additions & 1 deletion gcalcli/argparsers.py
Original file line number Diff line number Diff line change
Expand Up @@ -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

Expand Down Expand Up @@ -420,4 +422,7 @@ def get_argument_parser():
'--use_reminders', action=DeprecatedStoreTrue,
help=argparse.SUPPRESS)

# Enrich with argcomplete options.
argcomplete.autocomplete(parser)

return parser
1 change: 1 addition & 0 deletions gcalcli/cli.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#!/usr/bin/env python
# PYTHON_ARGCOMPLETE_OK
#
# ######################################################################### #
# #
Expand Down
1 change: 1 addition & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ dependencies = [
"httplib2",
"google_auth_oauthlib",
"parsedatetime",
"argcomplete",
]

[project.urls]
Expand Down

0 comments on commit 90bd3af

Please sign in to comment.