bash-completion: Add support for new ges-launch commands.

This commit is contained in:
Mathieu Duponchelle 2015-02-26 13:19:25 +01:00 committed by Thibault Saunier
parent d77ad923a6
commit 8e18fd790c
2 changed files with 129 additions and 9 deletions

View file

@ -61,6 +61,58 @@ _ges___videosink () {
COMPREPLY=( $(compgen -W "$($HELPER --klass=Sink --sinkcaps='video/x-raw')" -- $cur) ) COMPREPLY=( $(compgen -W "$($HELPER --klass=Sink --sinkcaps='video/x-raw')" -- $cur) )
} }
_ges_clip () {
if [[ "$prev" == "$command" ]];
then
_mandatory__argument
else
COMPREPLY=( $(compgen -W "duration= inpoint= start= layer= $(ges-launch-1.0 help all | egrep '^ [a-zA-Z0-9]')" -- $cur) )
fi
}
_ges_effect () {
if [[ "$prev" == "$command" ]];
then
_mandatory__argument
else
COMPREPLY=( $(compgen -W "duration= start= layer= $(ges-launch-1.0 help all | egrep '^ [a-zA-Z0-9]')" -- $cur) )
fi
}
_ges_list_options () {
COMPREPLY=( $(compgen -W "$(ges-launch-1.0 --help-all | grep -oh '[[:graph:]]*--[[:graph:]]*' | cut -d'=' -f1)" -- $cur) )
}
_ges_list_commands () {
COMPREPLY=( $(compgen -W "$(ges-launch-1.0 help all | egrep '^ [a-zA-Z0-9]')" -- $cur) )
}
_ges_list_properties () {
local props
if [[ "$real_command" == "" ]]
then
_mandatory__argument
elif [[ "$real_command" == "clip" ]]
then
COMPREPLY=( $(compgen -W "set-alpha set-posx set-posy set-width set-height set-volume set-mute" -- $cur) )
elif [[ "$real_command" == "effect" ]]
then
COMPREPLY=()
effect_bin_description="${effect_bin_description//\"/ }"
array=(${effect_bin_description//!/ })
for i in "${array[@]}"; do
props=("$($HELPER --element-properties $i)")
for j in $props; do
j="${j//=/ }"
COMPREPLY+=( $(compgen -W "set-$j" -- $cur) )
done
done
else
_mandatory__argument
fi
}
_ges___exclude_ () { _mandatory__argument; } _ges___exclude_ () { _mandatory__argument; }
_ges___encoding_profile () { _mandatory__argument; } _ges___encoding_profile () { _mandatory__argument; }
_ges___ges_sample_path () { _mandatory__argument; } _ges___ges_sample_path () { _mandatory__argument; }
@ -69,9 +121,27 @@ _ges___thumbnail () { _mandatory__argument; }
_ges___repeat () { _mandatory__argument; } _ges___repeat () { _mandatory__argument; }
_ges___save () { _mandatory__argument; } _ges___save () { _mandatory__argument; }
containsElement () {
local e
for e in "${@:2}";
do
[[ "$e" == "$1" ]] && return 0;
done
return 1
}
__ges_main () __ges_main ()
{ {
local i=1 c=1 command function_exists completion_func local i=1 c=1 command function_exists completion_func commands real_command effect_bin_description
commands=($(ges-launch-1.0 help all | egrep '^ [a-zA-Z0-9]'))
real_command=""
effect_bin_description=""
if [[ "$cur" == "=" ]]; then
_mandatory__argument
return
fi
while [[ $i -ne $COMP_CWORD ]]; while [[ $i -ne $COMP_CWORD ]];
do do
@ -80,15 +150,18 @@ __ges_main ()
if [[ "$var" == "--"* ]] if [[ "$var" == "--"* ]]
then then
command="$var" command="$var"
elif containsElement "$var" "${commands[@]}";
then
real_command="$var"
command="$var"
if [[ "$var" == "effect" ]]
then
effect_bin_description="${COMP_WORDS[i+1]}"
fi
fi fi
i=$[$i+1] i=$[$i+1]
done done
if [ -z "$command" ]; then
COMPREPLY=( $(compgen -W "$(ges-launch-1.0 --help-all | grep -oh '[[:graph:]]*--[[:graph:]]*' | cut -d'=' -f1)" -- $cur) )
return
fi
if [[ "$command" == "--gst"* ]]; then if [[ "$command" == "--gst"* ]]; then
completion_func="_${command//-/_}" completion_func="_${command//-/_}"
else else
@ -99,13 +172,19 @@ __ges_main ()
function_exists=$? function_exists=$?
if [[ "$cur" == "--"* ]]; then if [[ "$cur" == "-"* ]]; then
COMPREPLY=( $(compgen -W "$(ges-launch-1.0 --help-all | grep -oh '[[:graph:]]*--[[:graph:]]*' | cut -d'=' -f1)" -- $cur) ) _ges_list_options
elif [[ "$cur" == "="* ]]
then
_mandatory__argument
elif [[ "$cur" == "set-"* ]]
then
_ges_list_properties
elif [ $function_exists -eq 0 ] elif [ $function_exists -eq 0 ]
then then
$completion_func $completion_func
else else
COMPREPLY=( $(compgen -W "$(ges-launch-1.0 --help-all | grep -oh '[[:graph:]]*--[[:graph:]]*' | cut -d'=' -f1)" -- $cur) ) _ges_list_commands
fi fi
} }

View file

@ -637,6 +637,46 @@ _parse_timeline (int argc, char **argv)
return string; return string;
} }
static void
_print_all_commands (void)
{
/* Yeah I know very fancy */
g_print ("Available ges-launch-1.0 commands:\n\n");
g_print (" %-9s %-11s %-10s\n\n", "+clip", "+effect", "set-");
g_print ("See ges-launch-1.0 help <command> or ges-launch-1.0 help <guide> "
"to read about a specific command or a given guide\n");
}
static void
_check_command_help (int argc, gchar ** argv)
{
/**
* gchar *page = NULL;
*
* if (argc == 2)
* page = g_strdup ("ges-launch-1.0");
* else if (!g_strcmp0 (argv[2], "all"))
*/
if (!g_strcmp0 (argv[1], "help")) {
_print_all_commands ();
exit (0);
}
/* else
* page = g_strconcat ("ges-launch-1.0", "-", argv[2], NULL);
*
* if (page) {
* execlp ("man", "man", page, NULL);
* g_free (page);
* }
*
* an error is raised by execlp it will be displayed in the terminal
* exit (0);
* }
*/
}
int int
main (int argc, gchar ** argv) main (int argc, gchar ** argv)
{ {
@ -716,6 +756,7 @@ main (int argc, gchar ** argv)
guint signal_watch_id; guint signal_watch_id;
#endif #endif
_check_command_help (argc, argv);
setlocale (LC_ALL, ""); setlocale (LC_ALL, "");
ctx = g_option_context_new ("- plays or renders a timeline."); ctx = g_option_context_new ("- plays or renders a timeline.");