mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-24 01:00:37 +00:00
ges-launch: Better document options.
+ Sort them by topic + remove --sample-paths and --sample-paths-recurse. http://phabricator.freedesktop.org/D58
This commit is contained in:
parent
2c4b92fd98
commit
4a519bcf5c
2 changed files with 142 additions and 89 deletions
|
@ -130,9 +130,9 @@ class GESTest(GstValidateTest):
|
||||||
# We always want paths separator to be cut with '/' for ges-launch
|
# We always want paths separator to be cut with '/' for ges-launch
|
||||||
path = path.replace("\\", "/")
|
path = path.replace("\\", "/")
|
||||||
if not self.options.disable_recurse:
|
if not self.options.disable_recurse:
|
||||||
self.add_arguments("--sample-path-recurse", quote_uri(path))
|
self.add_arguments("--ges-sample-path-recurse", quote_uri(path))
|
||||||
else:
|
else:
|
||||||
self.add_arguments("--sample-path", quote_uri(path))
|
self.add_arguments("--ges-sample-paths", quote_uri(path))
|
||||||
|
|
||||||
def build_arguments(self):
|
def build_arguments(self):
|
||||||
GstValidateTest.build_arguments(self)
|
GstValidateTest.build_arguments(self)
|
||||||
|
|
|
@ -48,6 +48,7 @@ typedef struct
|
||||||
gchar *videosink;
|
gchar *videosink;
|
||||||
gchar *audiosink;
|
gchar *audiosink;
|
||||||
gboolean list_transitions;
|
gboolean list_transitions;
|
||||||
|
gboolean inspect_action_type;
|
||||||
gchar *sanitized_timeline;
|
gchar *sanitized_timeline;
|
||||||
} ParsedOptions;
|
} ParsedOptions;
|
||||||
|
|
||||||
|
@ -65,40 +66,16 @@ struct _GESLauncherPrivate
|
||||||
G_DEFINE_TYPE (GESLauncher, ges_launcher, G_TYPE_APPLICATION);
|
G_DEFINE_TYPE (GESLauncher, ges_launcher, G_TYPE_APPLICATION);
|
||||||
|
|
||||||
static const gchar *HELP_SUMMARY =
|
static const gchar *HELP_SUMMARY =
|
||||||
"ges-launch renders a timeline, which can be specified on the commandline,\n"
|
"ges-launch-1.0 creates a multimedia timeline and plays it back,\n"
|
||||||
"or loaded from a xges file using the -l option.\n\n"
|
" or renders it to the specified format.\n\n"
|
||||||
"A timeline is a list of files, patterns, and transitions to be rendered\n"
|
" It can load a timeline from an existing project, or create one\n"
|
||||||
"one after the other. Files and Patterns provide video and audio as the\n"
|
" from the specified commands.\n\n"
|
||||||
"primary input, and transitions animate between the end of one file/pattern\n"
|
" Updating an existing project can be done through --set-scenario\n"
|
||||||
"and the beginning of a new one. Hence, transitions can only be listed\n"
|
" if ges-launch-1.0 has been compiled with gst-validate, see\n"
|
||||||
"in between patterns or files.\n\n"
|
" ges-launch-1.0 --inspect-action-type for the available commands.\n\n"
|
||||||
"A file is a triplet of filename, inpoint (in seconds) and\n"
|
" You can learn more about individual ges-launch-1.0 commands with\n"
|
||||||
"duration (in seconds). If the duration is 0, the full file length is used.\n\n"
|
" \"ges-launch-1.0 help command\".\n\n"
|
||||||
"Patterns and transitions are triplets that begin with either \"+pattern\"\n"
|
" By default, ges-launch-1.0 is in \"playback-mode\".";
|
||||||
"or \"+transition\", followed by a <type> and duration (in seconds, must be\n"
|
|
||||||
"greater than 0)\n\n"
|
|
||||||
"Durations in all cases can be fractions of a second.\n\n"
|
|
||||||
"========\nExamples\n========\n\n"
|
|
||||||
"Play video1.ogv from inpoint 5 with duration 10 in seconds:\n"
|
|
||||||
"$ ges-launch video1.ogv 5 10\n\n"
|
|
||||||
"Crossfade:\n"
|
|
||||||
"$ ges-launch video1.ogv 0 10 +transition crossfade 3.5 video2.ogv 0 10\n\n"
|
|
||||||
"Render xges to ogv:\n"
|
|
||||||
"$ ges-launch -l project.xges -o rendering.ogv\n\n"
|
|
||||||
"Render xges to an XML encoding-profile called mymkv:\n"
|
|
||||||
"$ ges-launch -l project.xges -o rendering.mkv -e mymkv\n\n"
|
|
||||||
"Render to mp4:\n"
|
|
||||||
"$ ges-launch -l project.xges -o out.mp4 \\\n"
|
|
||||||
" -f \"video/quicktime,variant=iso:video/x-h264:audio/mpeg,mpegversion=1,layer=3\"\n\n"
|
|
||||||
"Render xges to WebM with 1920x1080 resolution:\n"
|
|
||||||
"$ ges-launch -l project.xges -o out.webm \\\n"
|
|
||||||
" -f \"video/webm:video/x-raw,width=1920,height=1080->video/x-vp8:audio/x-vorbis\"\n\n"
|
|
||||||
"A preset name can be used by adding +presetname:\n"
|
|
||||||
"$ ges-launch -l project.xges -o out.webm \\\n"
|
|
||||||
" -f \"video/webm:video/x-vp8+presetname:x-vorbis\"\n\n"
|
|
||||||
"The presence property of the profile can be specified with |<presence>:\n"
|
|
||||||
"$ ges-launch -l project.xges -o out.ogv \\\n"
|
|
||||||
" -f \"application/ogg:video/x-theora|<presence>:audio/x-vorbis\"";
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_parse_track_type (const gchar * option_name, const gchar * value,
|
_parse_track_type (const gchar * option_name, const gchar * value,
|
||||||
|
@ -536,29 +513,122 @@ failure:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
|
||||||
_add_media_path (const gchar * option_name, const gchar * value,
|
|
||||||
gpointer udata, GError ** error)
|
|
||||||
{
|
|
||||||
g_return_val_if_fail (gst_uri_is_valid (value), FALSE);
|
|
||||||
|
|
||||||
if (g_strcmp0 (option_name, "--sample-path-recurse") == 0 ||
|
|
||||||
g_strcmp0 (option_name, "-R") == 0) {
|
|
||||||
ges_add_missing_uri_relocation_uri (value, TRUE);
|
|
||||||
} else {
|
|
||||||
GST_INFO ("Adding folder: %s", value);
|
|
||||||
ges_add_missing_uri_relocation_uri (value, FALSE);
|
|
||||||
}
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_print_transition_list (void)
|
_print_transition_list (void)
|
||||||
{
|
{
|
||||||
print_enum (GES_VIDEO_STANDARD_TRANSITION_TYPE_TYPE);
|
print_enum (GES_VIDEO_STANDARD_TRANSITION_TYPE_TYPE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GOptionGroup *
|
||||||
|
ges_launcher_get_project_option_group (GESLauncher * self)
|
||||||
|
{
|
||||||
|
GOptionGroup *group;
|
||||||
|
ParsedOptions *opts = &self->priv->parsed_options;
|
||||||
|
|
||||||
|
GOptionEntry options[] = {
|
||||||
|
{"load", 'l', 0, G_OPTION_ARG_STRING, &opts->load_path,
|
||||||
|
"Load project from file. The project can be saved "
|
||||||
|
"again with the --save option.",
|
||||||
|
"<path>"},
|
||||||
|
{"save", 's', 0, G_OPTION_ARG_STRING, &opts->save_path,
|
||||||
|
"Save project to file before rendering. "
|
||||||
|
"It can then be loaded with the --load option",
|
||||||
|
"<path>"},
|
||||||
|
{NULL}
|
||||||
|
};
|
||||||
|
group = g_option_group_new ("project", "Project Options",
|
||||||
|
"Show project-related options", NULL, NULL);
|
||||||
|
|
||||||
|
g_option_group_add_entries (group, options);
|
||||||
|
|
||||||
|
return group;
|
||||||
|
}
|
||||||
|
|
||||||
|
static GOptionGroup *
|
||||||
|
ges_launcher_get_info_option_group (GESLauncher * self)
|
||||||
|
{
|
||||||
|
GOptionGroup *group;
|
||||||
|
ParsedOptions *opts = &self->priv->parsed_options;
|
||||||
|
|
||||||
|
GOptionEntry options[] = {
|
||||||
|
#ifdef HAVE_GST_VALIDATE
|
||||||
|
{"inspect-action-type", 0, 0, G_OPTION_ARG_NONE, &opts->inspect_action_type,
|
||||||
|
"Inspect the available action types that can be defined in a scenario "
|
||||||
|
"set with --set-scenario. "
|
||||||
|
"Will list all action-types if action-type is empty.",
|
||||||
|
"<[action-type]>"},
|
||||||
|
#endif
|
||||||
|
{"list-transitions", 0, 0, G_OPTION_ARG_NONE, &opts->list_transitions,
|
||||||
|
"List all valid transition types and exit. "
|
||||||
|
"See ges-launch-1.0 help transition for more information.",
|
||||||
|
NULL},
|
||||||
|
{NULL}
|
||||||
|
};
|
||||||
|
|
||||||
|
group = g_option_group_new ("informative", "Informative Options",
|
||||||
|
"Show informative options", NULL, NULL);
|
||||||
|
|
||||||
|
g_option_group_add_entries (group, options);
|
||||||
|
|
||||||
|
return group;
|
||||||
|
}
|
||||||
|
|
||||||
|
static GOptionGroup *
|
||||||
|
ges_launcher_get_rendering_option_group (GESLauncher * self)
|
||||||
|
{
|
||||||
|
GOptionGroup *group;
|
||||||
|
ParsedOptions *opts = &self->priv->parsed_options;
|
||||||
|
|
||||||
|
GOptionEntry options[] = {
|
||||||
|
{"outputuri", 'o', 0, G_OPTION_ARG_STRING, &opts->outputuri,
|
||||||
|
"If set, ges-launch-1.0 will render the timeline instead of playing "
|
||||||
|
"it back. The default rendering format is ogv, containing theora and vorbis.",
|
||||||
|
"<URI>"},
|
||||||
|
{"format", 'f', 0, G_OPTION_ARG_STRING, &opts->format,
|
||||||
|
"Set an encoding profile on the command line. "
|
||||||
|
"See ges-launch-1.0 help profile for more information. "
|
||||||
|
"This will have no effect if no outputuri has been specified.",
|
||||||
|
"<profile>"},
|
||||||
|
{"encoding-profile", 'e', 0, G_OPTION_ARG_STRING, &opts->encoding_profile,
|
||||||
|
"Set an encoding profile from a preset file. "
|
||||||
|
"See ges-launch-1.0 help profile for more information. "
|
||||||
|
"This will have no effect if no outputuri has been specified.",
|
||||||
|
"<profile-name>"},
|
||||||
|
{NULL}
|
||||||
|
};
|
||||||
|
|
||||||
|
group = g_option_group_new ("rendering", "Rendering Options",
|
||||||
|
"Show rendering options", NULL, NULL);
|
||||||
|
|
||||||
|
g_option_group_add_entries (group, options);
|
||||||
|
|
||||||
|
return group;
|
||||||
|
}
|
||||||
|
|
||||||
|
static GOptionGroup *
|
||||||
|
ges_launcher_get_playback_option_group (GESLauncher * self)
|
||||||
|
{
|
||||||
|
GOptionGroup *group;
|
||||||
|
ParsedOptions *opts = &self->priv->parsed_options;
|
||||||
|
|
||||||
|
GOptionEntry options[] = {
|
||||||
|
{"videosink", 'v', 0, G_OPTION_ARG_STRING, &opts->videosink,
|
||||||
|
"Set the videosink used for playback.", "<videosink>"},
|
||||||
|
{"audiosink", 'a', 0, G_OPTION_ARG_STRING, &opts->audiosink,
|
||||||
|
"Set the audiosink used for playback.", "<audiosink>"},
|
||||||
|
{"mute", 'm', 0, G_OPTION_ARG_NONE, &opts->mute,
|
||||||
|
"Mute playback output. This has no effect when rendering.", NULL},
|
||||||
|
{NULL}
|
||||||
|
};
|
||||||
|
|
||||||
|
group = g_option_group_new ("playback", "Playback Options",
|
||||||
|
"Show playback options", NULL, NULL);
|
||||||
|
|
||||||
|
g_option_group_add_entries (group, options);
|
||||||
|
|
||||||
|
return group;
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_local_command_line (GApplication * application, gchar ** arguments[],
|
_local_command_line (GApplication * application, gchar ** arguments[],
|
||||||
gint * exit_status)
|
gint * exit_status)
|
||||||
|
@ -567,48 +637,24 @@ _local_command_line (GApplication * application, gchar ** arguments[],
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
gchar **argv;
|
gchar **argv;
|
||||||
gint argc;
|
gint argc;
|
||||||
gboolean inspect_action_type = FALSE;
|
|
||||||
GOptionContext *ctx;
|
GOptionContext *ctx;
|
||||||
ParsedOptions *opts = &self->priv->parsed_options;
|
ParsedOptions *opts = &self->priv->parsed_options;
|
||||||
GOptionGroup *main_group;
|
GOptionGroup *main_group;
|
||||||
GOptionEntry options[] = {
|
GOptionEntry options[] = {
|
||||||
{"outputuri", 'o', 0, G_OPTION_ARG_STRING, &opts->outputuri,
|
|
||||||
"URI to encode to", "<protocol>://<location>"},
|
|
||||||
{"format", 'f', 0, G_OPTION_ARG_STRING, &opts->format,
|
|
||||||
"Specify an encoding profile on the command line",
|
|
||||||
"<profile>"},
|
|
||||||
{"encoding-profile", 'e', 0, G_OPTION_ARG_STRING, &opts->encoding_profile,
|
|
||||||
"Use a specific encoding profile from XML", "<profile-name>"},
|
|
||||||
{"list-transitions", 0, 0, G_OPTION_ARG_NONE, &opts->list_transitions,
|
|
||||||
"List valid transition types and exit", NULL},
|
|
||||||
{"save", 's', 0, G_OPTION_ARG_STRING, &opts->save_path,
|
|
||||||
"Save project to file before rendering", "<path>"},
|
|
||||||
{"load", 'l', 0, G_OPTION_ARG_STRING, &opts->load_path,
|
|
||||||
"Load project from file before rendering", "<path>"},
|
|
||||||
{"track-types", 't', 0, G_OPTION_ARG_CALLBACK, &_parse_track_type,
|
|
||||||
"Defines the track types to be created", "<track-types>"},
|
|
||||||
{"mute", 'm', 0, G_OPTION_ARG_NONE, &opts->mute,
|
|
||||||
"Mute playback output by using fakesinks", ""},
|
|
||||||
{"disable-mixing", 0, 0, G_OPTION_ARG_NONE, &opts->disable_mixing,
|
{"disable-mixing", 0, 0, G_OPTION_ARG_NONE, &opts->disable_mixing,
|
||||||
"Do not use mixing element in the tracks", ""},
|
"Do not use mixing elements to mix layers together.", NULL},
|
||||||
{"videosink", 'v', 0, G_OPTION_ARG_STRING, &opts->videosink,
|
{"track-types", 't', 0, G_OPTION_ARG_CALLBACK, &_parse_track_type,
|
||||||
"The video sink used for playing back", "<videosink>"},
|
"Specify the track types to be created. "
|
||||||
{"audiosink", 'a', 0, G_OPTION_ARG_STRING, &opts->audiosink,
|
"When loading a project, only relevant tracks will be added to the timeline.",
|
||||||
"The audio sink used for playing back", "<audiosink>"},
|
"<track-types>"},
|
||||||
{"sample-paths", 'p', 0, G_OPTION_ARG_CALLBACK, &_add_media_path,
|
|
||||||
"List of pathes to look assets in if they were moved", ""},
|
|
||||||
{"sample-path-recurse", 'R', 0, G_OPTION_ARG_CALLBACK,
|
|
||||||
&_add_media_path,
|
|
||||||
"Same as above, but recursing into the folder", ""},
|
|
||||||
#ifdef HAVE_GST_VALIDATE
|
#ifdef HAVE_GST_VALIDATE
|
||||||
{"inspect-action-type", 0, 0, G_OPTION_ARG_NONE, &inspect_action_type,
|
|
||||||
"Inspect the avalaible action types with which to write scenarios"
|
|
||||||
" if no parameter passed, it will list all avalaible action types"
|
|
||||||
" otherwize will print the full description of the wanted types",
|
|
||||||
NULL},
|
|
||||||
{"set-scenario", 0, 0, G_OPTION_ARG_STRING, &opts->scenario,
|
{"set-scenario", 0, 0, G_OPTION_ARG_STRING, &opts->scenario,
|
||||||
"Specify a GstValidate scenario to run, 'none' means load gst-validate"
|
"ges-launch-1.0 exposes gst-validate functionalities, such as scenarios."
|
||||||
" but run no scenario on it", "<scenario_name>"},
|
" Scenarios describe actions to execute, such as seeks or setting of properties. "
|
||||||
|
"GES implements editing-specific actions such as adding or removing clips. "
|
||||||
|
"See gst-validate-1.0 --help for more info about validate and scenarios, "
|
||||||
|
"and --inspect-action-type.",
|
||||||
|
"<scenario_name>"},
|
||||||
#endif
|
#endif
|
||||||
{NULL}
|
{NULL}
|
||||||
};
|
};
|
||||||
|
@ -623,6 +669,13 @@ _local_command_line (GApplication * application, gchar ** arguments[],
|
||||||
g_option_context_set_main_group (ctx, main_group);
|
g_option_context_set_main_group (ctx, main_group);
|
||||||
g_option_context_add_group (ctx, gst_init_get_option_group ());
|
g_option_context_add_group (ctx, gst_init_get_option_group ());
|
||||||
g_option_context_add_group (ctx, ges_init_get_option_group ());
|
g_option_context_add_group (ctx, ges_init_get_option_group ());
|
||||||
|
g_option_context_add_group (ctx,
|
||||||
|
ges_launcher_get_project_option_group (self));
|
||||||
|
g_option_context_add_group (ctx,
|
||||||
|
ges_launcher_get_rendering_option_group (self));
|
||||||
|
g_option_context_add_group (ctx,
|
||||||
|
ges_launcher_get_playback_option_group (self));
|
||||||
|
g_option_context_add_group (ctx, ges_launcher_get_info_option_group (self));
|
||||||
g_option_context_set_ignore_unknown_options (ctx, TRUE);
|
g_option_context_set_ignore_unknown_options (ctx, TRUE);
|
||||||
|
|
||||||
argv = *arguments;
|
argv = *arguments;
|
||||||
|
@ -635,7 +688,7 @@ _local_command_line (GApplication * application, gchar ** arguments[],
|
||||||
*exit_status = 1;
|
*exit_status = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (inspect_action_type) {
|
if (opts->inspect_action_type) {
|
||||||
ges_validate_print_action_types ((const gchar **) argv + 1, argc - 1);
|
ges_validate_print_action_types ((const gchar **) argv + 1, argc - 1);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue