mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
gst-launch: handle ERROR messages in the sync handler
Errors causing the pipeline to fail going from NULL to PAUSED were not displayed, and the pipeline was not dumped either in those cases. In addition, dumping the pipeline from the sync handler means the dump matches exactly the state of the pipeline at the moment the error was posted.
This commit is contained in:
parent
b5c19c7426
commit
4f9cac06e4
1 changed files with 19 additions and 19 deletions
|
@ -711,24 +711,6 @@ bus_handler (GstBus * bus, GstMessage * message, gpointer data)
|
||||||
g_free (name);
|
g_free (name);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GST_MESSAGE_ERROR:{
|
|
||||||
/* dump graph on error */
|
|
||||||
GST_DEBUG_BIN_TO_DOT_FILE_WITH_TS (GST_BIN (pipeline),
|
|
||||||
GST_DEBUG_GRAPH_SHOW_ALL, "gst-launch.error");
|
|
||||||
|
|
||||||
print_error_message (message);
|
|
||||||
|
|
||||||
if (target_state == GST_STATE_PAUSED) {
|
|
||||||
gst_printerr (_("ERROR: pipeline doesn't want to preroll.\n"));
|
|
||||||
} else if (interrupting) {
|
|
||||||
PRINT (_("An error happened while waiting for EOS\n"));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* we have an error */
|
|
||||||
last_launch_code = LEC_ERROR;
|
|
||||||
g_main_loop_quit (loop);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case GST_MESSAGE_STATE_CHANGED:{
|
case GST_MESSAGE_STATE_CHANGED:{
|
||||||
GstState old, new, pending;
|
GstState old, new, pending;
|
||||||
|
|
||||||
|
@ -990,6 +972,24 @@ bus_sync_handler (GstBus * bus, GstMessage * message, gpointer data)
|
||||||
g_free (state_transition_name);
|
g_free (state_transition_name);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case GST_MESSAGE_ERROR:{
|
||||||
|
/* dump graph on error */
|
||||||
|
GST_DEBUG_BIN_TO_DOT_FILE_WITH_TS (GST_BIN (pipeline),
|
||||||
|
GST_DEBUG_GRAPH_SHOW_ALL, "gst-launch.error");
|
||||||
|
|
||||||
|
print_error_message (message);
|
||||||
|
|
||||||
|
if (target_state == GST_STATE_PAUSED) {
|
||||||
|
gst_printerr (_("ERROR: pipeline doesn't want to preroll.\n"));
|
||||||
|
} else if (interrupting) {
|
||||||
|
PRINT (_("An error happened while waiting for EOS\n"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* we have an error */
|
||||||
|
last_launch_code = LEC_ERROR;
|
||||||
|
g_main_loop_quit (loop);
|
||||||
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1206,7 +1206,7 @@ main (int argc, char *argv[])
|
||||||
|
|
||||||
switch (ret) {
|
switch (ret) {
|
||||||
case GST_STATE_CHANGE_FAILURE:
|
case GST_STATE_CHANGE_FAILURE:
|
||||||
gst_printerr (_("ERROR: Pipeline doesn't want to pause.\n"));
|
gst_printerr (_("Failed to set pipeline to PAUSED.\n"));
|
||||||
last_launch_code = LEC_STATE_CHANGE_FAILURE;
|
last_launch_code = LEC_STATE_CHANGE_FAILURE;
|
||||||
goto end;
|
goto end;
|
||||||
case GST_STATE_CHANGE_NO_PREROLL:
|
case GST_STATE_CHANGE_NO_PREROLL:
|
||||||
|
|
Loading…
Reference in a new issue