From d7a29723a143e78c1b607452a4187aefce0f7ed5 Mon Sep 17 00:00:00 2001 From: patrick96 Date: Sun, 2 Apr 2017 20:43:06 +0200 Subject: [PATCH] Add gist completion for read flag Fetches and offers completion for the gists of the currently logged in user (via gist -l) for the '-r' and '--read' arguments The data is cached for one day before expiring --- src/_gist | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 52 insertions(+), 1 deletion(-) diff --git a/src/_gist b/src/_gist index 826c1b7..8366a9b 100644 --- a/src/_gist +++ b/src/_gist @@ -1,6 +1,6 @@ #compdef gist # ------------------------------------------------------------------------------ -# Copyright (c) 2015 Github zsh-users - http://github.com/zsh-users +# Copyright (c) 2017 Github zsh-users - http://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without @@ -35,6 +35,7 @@ # ------- # # * Akira Maeda +# * Patrick Ziegler # # ------------------------------------------------------------------------------ # -*- mode: zsh; sh-indentation: 2; indent-tabs-mode: nil; sh-basic-offset: 2; -*- @@ -61,6 +62,56 @@ _arguments -C \ '(-P --paste)'{-P,--paste}'[Paste from the clipboard to gist]' \ '(-h --help)'{-h,--help}'[print options help]' \ '(-v --version)'{-v,--version}'[print version]' \ + '(-r --read)'{-r,--read}'[Test]:user gists:user_gists' \ '*: :_files' && ret=0 +_user_gists_cache_policy() { + # rebuild if cache is more than a day old + local -a oldp + oldp=( "$1"(mh+1) ) + (( $#oldp )) +} + +user_gists() { + local update_policy ret=1 + zstyle -s ":completion:${curcontext}:" cache-policy update_policy + [[ -z "$update_policy" ]] && zstyle ":completion:${curcontext}:" cache-policy _user_gists_cache_policy + + # Stores the gists of the logged in user in the format ID[Description] + _list=() + _cached_gists="user_gists" + + # Retrieve/Write gists from/to cache + if _cache_invalid $_cached_gists || ! _retrieve_cache $_cached_gists; then + _gists=$(gist -l) + + if [ $? -eq 0 ]; then + _store_cache $_cached_gists _gists + else + # Some error occurred, the user is probably not logged in + # Set _gists to an empty string so that no completion is attempted + _gists="" + fi + else + _retrieve_cache $_cached_gists + fi + + if [ -n "$_gists" ]; then + echo "$_gists" | while read -r line; do + # Splitting the gist -l output + url="$(echo "$line" | cut -d " " -f 1 | cut -d "/" -f 4)" + # Gists w/o descriptions can have only one column in the output, those + # have their description set to an empty string + description="$(echo "$line" | awk '{if(NF > 1){$1=""; print $0}}')" + + _list+=( "${url}[${description}]" ) + done + + _values "gists" $_list + ret=0 + fi + + return ret +} + return ret