diff options
author | Max Kellermann <max@duempel.org> | 2010-01-06 08:28:27 +0100 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2010-01-06 08:50:35 +0100 |
commit | d6d5caae23f5b452a3d2de9f576d0137bbc472e3 (patch) | |
tree | 0a111705bc616f06ab2dcc08456edb8e5600c322 /src/decoder/flac_decoder_plugin.c | |
parent | 382691179f6da54be2b3b1d8bc3146a23b6ea148 (diff) | |
download | mpd-d6d5caae23f5b452a3d2de9f576d0137bbc472e3.tar.gz mpd-d6d5caae23f5b452a3d2de9f576d0137bbc472e3.tar.xz mpd-d6d5caae23f5b452a3d2de9f576d0137bbc472e3.zip |
decoder/flac: moved flac_tag_load() to flac_metadata.c
Make this code is reusable.
Diffstat (limited to '')
-rw-r--r-- | src/decoder/flac_decoder_plugin.c | 53 |
1 files changed, 0 insertions, 53 deletions
diff --git a/src/decoder/flac_decoder_plugin.c b/src/decoder/flac_decoder_plugin.c index df5778e03..db0c077ea 100644 --- a/src/decoder/flac_decoder_plugin.c +++ b/src/decoder/flac_decoder_plugin.c @@ -214,59 +214,6 @@ flac_write_cb(const FLAC__StreamDecoder *dec, const FLAC__Frame *frame, return flac_common_write(data, frame, buf, nbytes); } -static struct tag * -flac_tag_load(const char *file, const char *char_tnum) -{ - struct tag *tag; - FLAC__Metadata_SimpleIterator *it; - FLAC__StreamMetadata *block = NULL; - - it = FLAC__metadata_simple_iterator_new(); - if (!FLAC__metadata_simple_iterator_init(it, file, 1, 0)) { - const char *err; - FLAC_API FLAC__Metadata_SimpleIteratorStatus s; - - s = FLAC__metadata_simple_iterator_status(it); - - switch (s) { /* slightly more human-friendly messages: */ - case FLAC__METADATA_SIMPLE_ITERATOR_STATUS_ILLEGAL_INPUT: - err = "illegal input"; - break; - case FLAC__METADATA_SIMPLE_ITERATOR_STATUS_ERROR_OPENING_FILE: - err = "error opening file"; - break; - case FLAC__METADATA_SIMPLE_ITERATOR_STATUS_NOT_A_FLAC_FILE: - err = "not a FLAC file"; - break; - default: - err = FLAC__Metadata_SimpleIteratorStatusString[s]; - } - g_debug("Reading '%s' metadata gave the following error: %s\n", - file, err); - FLAC__metadata_simple_iterator_delete(it); - return NULL; - } - - tag = tag_new(); - do { - block = FLAC__metadata_simple_iterator_get_block(it); - if (!block) - break; - - flac_tag_apply_metadata(tag, char_tnum, block); - FLAC__metadata_object_delete(block); - } while (FLAC__metadata_simple_iterator_next(it)); - - FLAC__metadata_simple_iterator_delete(it); - - if (!tag_is_defined(tag)) { - tag_free(tag); - tag = NULL; - } - - return tag; -} - #if defined(FLAC_API_VERSION_CURRENT) && FLAC_API_VERSION_CURRENT > 7 static struct tag * |