shout: removed shout_data.tag_to_send

When shout_data.tag!=NULL, there is a "tag to send".  The tag_to_send
flag is redundant.
This commit is contained in:
Max Kellermann 2009-02-09 16:35:51 +01:00
parent 044f2561ce
commit cf94008b27
2 changed files with 6 additions and 9 deletions

View File

@ -58,7 +58,6 @@ static struct shout_data *new_shout_data(void)
ret->shout_meta = shout_metadata_new(); ret->shout_meta = shout_metadata_new();
ret->opened = 0; ret->opened = 0;
ret->tag = NULL; ret->tag = NULL;
ret->tag_to_send = 0;
ret->bitrate = -1; ret->bitrate = -1;
ret->quality = -2.0; ret->quality = -2.0;
ret->timeout = DEFAULT_CONN_TIMEOUT; ret->timeout = DEFAULT_CONN_TIMEOUT;
@ -428,7 +427,6 @@ static int open_shout_conn(void *data)
write_page(sd); write_page(sd);
sd->opened = true; sd->opened = true;
sd->tag_to_send = 1;
sd->conn_attempts = 0; sd->conn_attempts = 0;
return 0; return 0;
@ -455,7 +453,9 @@ static void send_metadata(struct shout_data * sd)
static const int size = 1024; static const int size = 1024;
char song[size]; char song[size];
if (!sd->opened || !sd->tag) assert(sd->tag != NULL);
if (!sd->opened)
return; return;
if (sd->encoder->send_metadata_func(sd, song, size)) { if (sd->encoder->send_metadata_func(sd, song, size)) {
@ -463,11 +463,11 @@ static void send_metadata(struct shout_data * sd)
if (SHOUTERR_SUCCESS != shout_set_metadata(sd->shout_conn, if (SHOUTERR_SUCCESS != shout_set_metadata(sd->shout_conn,
sd->shout_meta)) { sd->shout_meta)) {
g_warning("error setting shout metadata\n"); g_warning("error setting shout metadata\n");
return;
} }
} }
sd->tag_to_send = 0; tag_free(sd->tag);
sd->tag = NULL;
} }
static bool static bool
@ -481,7 +481,7 @@ my_shout_play(void *data, const char *chunk, size_t size)
timer_add(sd->timer, size); timer_add(sd->timer, size);
if (sd->opened && sd->tag_to_send) if (sd->opened && sd->tag != NULL)
send_metadata(sd); send_metadata(sd);
if (!sd->opened) { if (!sd->opened) {
@ -519,13 +519,11 @@ static void my_shout_set_tag(void *data,
if (sd->tag) if (sd->tag)
tag_free(sd->tag); tag_free(sd->tag);
sd->tag = NULL; sd->tag = NULL;
sd->tag_to_send = 0;
if (!tag) if (!tag)
return; return;
sd->tag = tag_dup(tag); sd->tag = tag_dup(tag);
sd->tag_to_send = 1;
} }
const struct audio_output_plugin shoutPlugin = { const struct audio_output_plugin shoutPlugin = {

View File

@ -71,7 +71,6 @@ struct shout_data {
bool opened; bool opened;
struct tag *tag; struct tag *tag;
int tag_to_send;
int timeout; int timeout;
int conn_attempts; int conn_attempts;