update history to use argparse

This commit is contained in:
Kurtis Rader 2017-07-13 16:21:14 -07:00
parent 5dc78dd858
commit c22df3b823
4 changed files with 59 additions and 95 deletions

View file

@ -2,22 +2,9 @@
# Wrap the builtin history command to provide additional functionality. # Wrap the builtin history command to provide additional functionality.
# #
# This function is meant to mimic the `set_hist_cmd` function in *src/builtin.cpp*.
# In particular the error message should be identical in both locations.
function __fish_set_hist_cmd --no-scope-shadowing
if set -q hist_cmd[1]
set -l msg (printf (_ "you cannot do both '%ls' and '%ls' in the same invocation") \
$hist_cmd $argv[1])
printf (_ "%ls: Invalid combination of options,\n%ls\n") $cmd $msg >&2
return 1
end
set hist_cmd $argv[1]
return 0
end
function __fish_unexpected_hist_args --no-scope-shadowing function __fish_unexpected_hist_args --no-scope-shadowing
if test -n "$search_mode" if test -n "$search_mode"
or test -n "$show_time" or set -q show_time[1]
printf (_ "%ls: you cannot use any options with the %ls command\n") $cmd $hist_cmd >&2 printf (_ "%ls: you cannot use any options with the %ls command\n") $cmd $hist_cmd >&2
return 0 return 0
end end
@ -30,88 +17,66 @@ end
function history --description "display or manipulate interactive command history" function history --description "display or manipulate interactive command history"
set -l cmd history set -l cmd history
set -l options --exclusive 'c,e,p' --exclusive 'S,D,M,V,C' --exclusive 't,T'
set options $options 'h/help' 'c/contains' 'e/exact' 'p/prefix'
set options $options 'C/case-sensitive' 'z/null' 't/show-time=?' 'n/max=' '#-max'
# This long option is deprecated and here solely for legacy compatibility. People should use
# -t or --show-time now.
set options $options 'T-with-time=?'
# The following options are deprecated and will be removed in the next major release.
# Note that they do not have usable short flags.
set options $options 'S-search' 'D-delete' 'M-merge' 'V-save' 'R-clear'
argparse -n $cmd $options -- $argv
or return
if set -q _flag_help
__fish_print_help history
return 0
end
set -l hist_cmd set -l hist_cmd
set -l search_mode
set -l show_time set -l show_time
set -l max_count set -l max_count $_flag_max
set -l case_sensitive
set -l null
# Check for a recognized subcommand as the first argument. set -q _flag_with_time
if set -q argv[1] and set -l _flag_show_time $_flag_with_time
and not string match -q -- '-*' $argv[1] if set -q _flag_show_time[1]
switch $argv[1] set show_time --show-time=$_flag_show_time
case search delete merge save clear else if set -q _flag_show_time
set hist_cmd $argv[1] set show_time --show-time
set -e argv[1]
end
end end
# The "set cmd $cmd xyz" lines are to make it easy to detect if the user specifies more than one set -q _flag_null
# subcommand. and set -l null --null
#
# TODO: Remove the long options that correspond to subcommands (e.g., '--delete') on or after set -q _flag_case_sensitive
# 2017-10 (which will be a full year after these flags have been deprecated). and set -l case_sensitive --case-sensitive
while set -q argv[1]
switch $argv[1] set -q _flag_prefix
case --delete and set -l search_mode --prefix
__fish_set_hist_cmd delete set -q _flag_contains
or return and set -l search_mode --contains
case --save set -q _flag_exact
__fish_set_hist_cmd save and set -l search_mode --exact
or return
case --clear if set -q _flag_delete
__fish_set_hist_cmd clear set hist_cmd delete
or return else if set -q _flag_save
case --search set hist_cmd save
__fish_set_hist_cmd search else if set -q _flag_clear
or return set hist_cmd clear
case --merge else if set -q _flag_search
__fish_set_hist_cmd merge set hist_cmd search
or return else if set -q _flag_merge
case -C --case_sensitive set hist_cmd merge
set case_sensitive --case-sensitive
case -h --help
builtin history --help
return
case -t --show-time '--show-time=*' --with-time '--with-time=*'
set show_time $argv[1]
case -p --prefix
set search_mode --prefix
case -c --contains
set search_mode --contains
case -e --exact
set search_mode --exact
case -z --null
set null --null
case -n --max
if string match -- '-n?*' $argv[1]
or string match -- '--max=*' $argv[1]
set max_count $argv[1]
else
set max_count $argv[1] $argv[2]
set -e argv[1]
end
case --
set -e argv[1]
break
case '*'
if string match -r -- '-\d+' $argv[1]
set max_count $argv[1]
set -e argv[1]
else
break
end
end
set -e argv[1]
end end
# If a history command has not already been specified check the first non-flag argument for a # If a history command has not already been specified check the first non-flag argument for a
# command. This allows the flags to appear before or after the subcommand. # command. This allows the flags to appear before or after the subcommand.
if not set -q hist_cmd[1] if not set -q hist_cmd[1]
and set -q argv[1] and set -q argv[1]
switch $argv[1] if contains $argv[1] search delete merge save clear
case search delete merge save clear
set hist_cmd $argv[1] set hist_cmd $argv[1]
set -e argv[1] set -e argv[1]
end end

View file

@ -42,7 +42,7 @@ struct history_cmd_opts_t {
/// the non-flag subcommand form. While many of these flags are deprecated they must be /// the non-flag subcommand form. While many of these flags are deprecated they must be
/// supported at least until fish 3.0 and possibly longer to avoid breaking everyones /// supported at least until fish 3.0 and possibly longer to avoid breaking everyones
/// config.fish and other scripts. /// config.fish and other scripts.
static const wchar_t *short_options = L":Cmn:epchtz"; static const wchar_t *short_options = L":Cmn:epcht::z";
static const struct woption long_options[] = {{L"prefix", no_argument, NULL, 'p'}, static const struct woption long_options[] = {{L"prefix", no_argument, NULL, 'p'},
{L"contains", no_argument, NULL, 'c'}, {L"contains", no_argument, NULL, 'c'},
{L"help", no_argument, NULL, 'h'}, {L"help", no_argument, NULL, 'h'},

View file

@ -1,5 +1,4 @@
history: Invalid combination of options, history: Mutually exclusive flags 'merge' and `search` seen
you cannot do both 'search' and 'merge' in the same invocation
history: you cannot use any options with the clear command history: you cannot use any options with the clear command
history: you cannot use any options with the merge command history: you cannot use any options with the merge command
history: save expected 0 args, got 1 history: save expected 0 args, got 1

View file

@ -11,7 +11,7 @@ history --save xyz
# Now with the history builtin. # Now with the history builtin.
builtin history --save --prefix builtin history --save --prefix
builtin history --clear --with-time builtin history --clear --show-time
builtin history --merge xyz builtin history --merge xyz
builtin history --clear abc def builtin history --clear abc def
@ -27,13 +27,13 @@ history clear --contains
history merge -t history merge -t
history save xyz history save xyz
history --prefix clear history --prefix clear
history --with-time merge history --show-time merge
echo >&2 echo >&2
# Now with the history builtin. # Now with the history builtin.
builtin history --search --merge builtin history --search --merge
builtin history save --prefix builtin history save --prefix
builtin history clear --with-time builtin history clear --show-time
builtin history merge xyz builtin history merge xyz
builtin history clear abc def builtin history clear abc def
builtin history --contains save builtin history --contains save