From 2b676dc5fcd7b3a472d4c14f228ea4b7969b4e9e Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Thu, 5 Sep 2013 18:23:15 +0200 Subject: Tag: move configuration code to TagConfig.cxx Allow using the Tag.cxx library without the Config library. --- src/Main.cxx | 2 ++ src/tag/Tag.cxx | 50 ----------------------------------- src/tag/TagConfig.cxx | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++ src/tag/TagConfig.hxx | 28 ++++++++++++++++++++ 4 files changed, 103 insertions(+), 50 deletions(-) create mode 100644 src/tag/TagConfig.cxx create mode 100644 src/tag/TagConfig.hxx (limited to 'src') diff --git a/src/Main.cxx b/src/Main.cxx index 511e136aa..9ded73be5 100644 --- a/src/Main.cxx +++ b/src/Main.cxx @@ -39,6 +39,7 @@ #include "Volume.hxx" #include "OutputAll.hxx" #include "tag/Tag.hxx" +#include "tag/TagConfig.hxx" #include "replay_gain_config.h" #include "Idle.hxx" #include "SignalHandlers.hxx" @@ -376,6 +377,7 @@ int mpd_main(int argc, char *argv[]) stats_global_init(); tag_lib_init(); + TagLoadConfig(); if (!log_init(options.verbose, options.log_stderr, error)) { g_warning("%s", error.GetMessage()); diff --git a/src/tag/Tag.cxx b/src/tag/Tag.cxx index c960da537..2b1967006 100644 --- a/src/tag/Tag.cxx +++ b/src/tag/Tag.cxx @@ -21,15 +21,9 @@ #include "Tag.hxx" #include "TagInternal.hxx" #include "TagPool.hxx" -#include "ConfigGlobal.hxx" -#include "ConfigOption.hxx" -#include "Song.hxx" -#include "system/FatalError.hxx" #include #include -#include -#include #include /** @@ -85,52 +79,8 @@ items_size(const Tag &tag) void tag_lib_init(void) { - const char *value; - int quit = 0; - char *temp; - char *s; - char *c; - enum tag_type type; - - /* parse the "metadata_to_use" config parameter below */ - /* ignore comments by default */ ignore_tag_items[TAG_COMMENT] = true; - - value = config_get_string(CONF_METADATA_TO_USE, nullptr); - if (value == nullptr) - return; - - memset(ignore_tag_items, true, TAG_NUM_OF_ITEM_TYPES); - - if (0 == g_ascii_strcasecmp(value, "none")) - return; - - temp = c = s = g_strdup(value); - while (!quit) { - if (*s == ',' || *s == '\0') { - if (*s == '\0') - quit = 1; - *s = '\0'; - - c = g_strstrip(c); - if (*c == 0) - continue; - - type = tag_name_parse_i(c); - if (type == TAG_NUM_OF_ITEM_TYPES) - FormatFatalError("error parsing metadata item \"%s\"", - c); - - ignore_tag_items[type] = false; - - s++; - c = s; - } - s++; - } - - g_free(temp); } void diff --git a/src/tag/TagConfig.cxx b/src/tag/TagConfig.cxx new file mode 100644 index 000000000..22f7a64fa --- /dev/null +++ b/src/tag/TagConfig.cxx @@ -0,0 +1,73 @@ +/* + * Copyright (C) 2003-2013 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. + */ + +#include "config.h" +#include "TagConfig.hxx" +#include "TagInternal.hxx" +#include "Tag.hxx" +#include "ConfigGlobal.hxx" +#include "ConfigOption.hxx" +#include "system/FatalError.hxx" + +#include + +#include + +#include + +void +TagLoadConfig() +{ + const char *value = config_get_string(CONF_METADATA_TO_USE, nullptr); + if (value == nullptr) + return; + + std::fill_n(ignore_tag_items, TAG_NUM_OF_ITEM_TYPES, true); + + if (0 == g_ascii_strcasecmp(value, "none")) + return; + + bool quit = false; + char *temp, *c, *s; + temp = c = s = g_strdup(value); + do { + if (*s == ',' || *s == '\0') { + if (*s == '\0') + quit = true; + *s = '\0'; + + c = g_strstrip(c); + if (*c == 0) + continue; + + const auto type = tag_name_parse_i(c); + if (type == TAG_NUM_OF_ITEM_TYPES) + FormatFatalError("error parsing metadata item \"%s\"", + c); + + ignore_tag_items[type] = false; + + s++; + c = s; + } + s++; + } while (!quit); + + g_free(temp); +} diff --git a/src/tag/TagConfig.hxx b/src/tag/TagConfig.hxx new file mode 100644 index 000000000..5ec6766d4 --- /dev/null +++ b/src/tag/TagConfig.hxx @@ -0,0 +1,28 @@ +/* + * Copyright (C) 2003-2013 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_CONFIG_HXX +#define MPD_TAG_CONFIG_HXX + +#include "TagType.h" + +void +TagLoadConfig(); + +#endif -- cgit v1.2.3