/* * Copyright 2003-2016 The Music Player Daemon Project * http://www.musicpd.org * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #ifndef MPD_TAG_HANDLER_HXX #define MPD_TAG_HANDLER_HXX #include "check.h" #include "TagType.h" #include "Chrono.hxx" #include /** * A callback table for receiving metadata of a song. */ struct TagHandler { /** * Declare the duration of a song. Do not call * this when the duration could not be determined, because * there is no magic value for "unknown duration". */ void (*duration)(SongTime duration, void *ctx); /** * A tag has been read. * * @param the value of the tag; the pointer will become * invalid after returning */ void (*tag)(TagType type, const char *value, void *ctx); /** * A name-value pair has been read. It is the codec specific * representation of tags. */ void (*pair)(const char *key, const char *value, void *ctx); }; static inline void tag_handler_invoke_duration(const TagHandler &handler, void *ctx, SongTime duration) { if (handler.duration != nullptr) handler.duration(duration, ctx); } static inline void tag_handler_invoke_tag(const TagHandler &handler, void *ctx, TagType type, const char *value) { assert((unsigned)type < TAG_NUM_OF_ITEM_TYPES); assert(value != nullptr); if (handler.tag != nullptr) handler.tag(type, value, ctx); } static inline void tag_handler_invoke_pair(const TagHandler &handler, void *ctx, const char *name, const char *value) { assert(name != nullptr); assert(value != nullptr); if (handler.pair != nullptr) handler.pair(name, value, ctx); } /** * This #TagHandler implementation adds tag values to a #TagBuilder object * (casted from the context pointer). */ extern const TagHandler add_tag_handler; /** * This #TagHandler implementation adds tag values to a #TagBuilder object * (casted from the context pointer), and supports the has_playlist * attribute. */ extern const TagHandler full_tag_handler; #endif