decoder: added assertions on dc.pipe
dc.pipe must be non-NULL while the decoder thread is running. Ensure that with a load of assertions.
This commit is contained in:
parent
d01d1ccad2
commit
ceb00f787e
@ -42,6 +42,7 @@ void decoder_initialized(G_GNUC_UNUSED struct decoder * decoder,
|
|||||||
bool seekable, float total_time)
|
bool seekable, float total_time)
|
||||||
{
|
{
|
||||||
assert(dc.state == DECODE_STATE_START);
|
assert(dc.state == DECODE_STATE_START);
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
assert(decoder != NULL);
|
assert(decoder != NULL);
|
||||||
assert(decoder->stream_tag == NULL);
|
assert(decoder->stream_tag == NULL);
|
||||||
assert(decoder->decoder_tag == NULL);
|
assert(decoder->decoder_tag == NULL);
|
||||||
@ -73,11 +74,15 @@ void decoder_initialized(G_GNUC_UNUSED struct decoder * decoder,
|
|||||||
|
|
||||||
char *decoder_get_uri(G_GNUC_UNUSED struct decoder *decoder)
|
char *decoder_get_uri(G_GNUC_UNUSED struct decoder *decoder)
|
||||||
{
|
{
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
|
|
||||||
return song_get_uri(dc.current_song);
|
return song_get_uri(dc.current_song);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum decoder_command decoder_get_command(G_GNUC_UNUSED struct decoder * decoder)
|
enum decoder_command decoder_get_command(G_GNUC_UNUSED struct decoder * decoder)
|
||||||
{
|
{
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
|
|
||||||
return dc.command;
|
return dc.command;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,6 +91,7 @@ void decoder_command_finished(G_GNUC_UNUSED struct decoder * decoder)
|
|||||||
assert(dc.command != DECODE_COMMAND_NONE);
|
assert(dc.command != DECODE_COMMAND_NONE);
|
||||||
assert(dc.command != DECODE_COMMAND_SEEK ||
|
assert(dc.command != DECODE_COMMAND_SEEK ||
|
||||||
dc.seek_error || decoder->seeking);
|
dc.seek_error || decoder->seeking);
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
|
|
||||||
if (dc.command == DECODE_COMMAND_SEEK) {
|
if (dc.command == DECODE_COMMAND_SEEK) {
|
||||||
/* delete frames from the old song position */
|
/* delete frames from the old song position */
|
||||||
@ -105,6 +111,7 @@ void decoder_command_finished(G_GNUC_UNUSED struct decoder * decoder)
|
|||||||
double decoder_seek_where(G_GNUC_UNUSED struct decoder * decoder)
|
double decoder_seek_where(G_GNUC_UNUSED struct decoder * decoder)
|
||||||
{
|
{
|
||||||
assert(dc.command == DECODE_COMMAND_SEEK);
|
assert(dc.command == DECODE_COMMAND_SEEK);
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
|
|
||||||
decoder->seeking = true;
|
decoder->seeking = true;
|
||||||
|
|
||||||
@ -114,6 +121,7 @@ double decoder_seek_where(G_GNUC_UNUSED struct decoder * decoder)
|
|||||||
void decoder_seek_error(struct decoder * decoder)
|
void decoder_seek_error(struct decoder * decoder)
|
||||||
{
|
{
|
||||||
assert(dc.command == DECODE_COMMAND_SEEK);
|
assert(dc.command == DECODE_COMMAND_SEEK);
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
|
|
||||||
dc.seek_error = true;
|
dc.seek_error = true;
|
||||||
decoder_command_finished(decoder);
|
decoder_command_finished(decoder);
|
||||||
@ -128,6 +136,7 @@ size_t decoder_read(struct decoder *decoder,
|
|||||||
assert(decoder == NULL ||
|
assert(decoder == NULL ||
|
||||||
dc.state == DECODE_STATE_START ||
|
dc.state == DECODE_STATE_START ||
|
||||||
dc.state == DECODE_STATE_DECODE);
|
dc.state == DECODE_STATE_DECODE);
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
assert(is != NULL);
|
assert(is != NULL);
|
||||||
assert(buffer != NULL);
|
assert(buffer != NULL);
|
||||||
|
|
||||||
@ -219,6 +228,7 @@ decoder_data(struct decoder *decoder,
|
|||||||
const char *data = _data;
|
const char *data = _data;
|
||||||
|
|
||||||
assert(dc.state == DECODE_STATE_DECODE);
|
assert(dc.state == DECODE_STATE_DECODE);
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
assert(length % audio_format_frame_size(&dc.in_audio_format) == 0);
|
assert(length % audio_format_frame_size(&dc.in_audio_format) == 0);
|
||||||
|
|
||||||
if (dc.command == DECODE_COMMAND_STOP ||
|
if (dc.command == DECODE_COMMAND_STOP ||
|
||||||
@ -322,6 +332,7 @@ decoder_tag(G_GNUC_UNUSED struct decoder *decoder, struct input_stream *is,
|
|||||||
enum decoder_command cmd;
|
enum decoder_command cmd;
|
||||||
|
|
||||||
assert(dc.state == DECODE_STATE_DECODE);
|
assert(dc.state == DECODE_STATE_DECODE);
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
assert(tag != NULL);
|
assert(tag != NULL);
|
||||||
|
|
||||||
/* save the tag */
|
/* save the tag */
|
||||||
|
@ -60,6 +60,7 @@ static void dc_command_async(enum decoder_command cmd)
|
|||||||
void
|
void
|
||||||
dc_start(struct notify *notify, struct song *song)
|
dc_start(struct notify *notify, struct song *song)
|
||||||
{
|
{
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
assert(song != NULL);
|
assert(song != NULL);
|
||||||
|
|
||||||
dc.next_song = song;
|
dc.next_song = song;
|
||||||
@ -69,6 +70,7 @@ dc_start(struct notify *notify, struct song *song)
|
|||||||
void
|
void
|
||||||
dc_start_async(struct song *song)
|
dc_start_async(struct song *song)
|
||||||
{
|
{
|
||||||
|
assert(dc.pipe != NULL);
|
||||||
assert(song != NULL);
|
assert(song != NULL);
|
||||||
|
|
||||||
dc.next_song = song;
|
dc.next_song = song;
|
||||||
|
Loading…
Reference in New Issue
Block a user