2018-05-10 15:29:28 +02:00
|
|
|
/***************************************************************************
|
|
|
|
copyright : (C) 2002 - 2008 by Scott Wheeler
|
|
|
|
email : wheeler@kde.org
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
/***************************************************************************
|
|
|
|
* This library is free software; you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU Lesser General Public License version *
|
|
|
|
* 2.1 as published by the Free Software Foundation. *
|
|
|
|
* *
|
|
|
|
* This library 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 *
|
|
|
|
* Lesser General Public License for more details. *
|
|
|
|
* *
|
|
|
|
* You should have received a copy of the GNU Lesser General Public *
|
|
|
|
* License along with this library; if not, write to the Free Software *
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA *
|
|
|
|
* 02110-1301 USA *
|
|
|
|
* *
|
|
|
|
* Alternatively, this file is available under the Mozilla Public *
|
|
|
|
* License Version 1.1. You may obtain a copy of the License at *
|
|
|
|
* http://www.mozilla.org/MPL/ *
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
#ifndef TAGLIB_TAG_H
|
|
|
|
#define TAGLIB_TAG_H
|
|
|
|
|
|
|
|
#include "taglib_export.h"
|
|
|
|
#include "tstring.h"
|
|
|
|
|
2019-04-26 01:12:42 +02:00
|
|
|
namespace Strawberry_TagLib {
|
|
|
|
namespace TagLib {
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
//! A simple, generic interface to common audio meta data fields
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* This is an attempt to abstract away the difference in the meta data formats of various audio codecs and tagging schemes.
|
|
|
|
* As such it is generally a subset of what is available in the specific formats but should be suitable for most applications.
|
|
|
|
* This is meant to compliment the generic APIs found in TagLib::AudioProperties, TagLib::File and TagLib::FileRef.
|
2018-05-10 15:29:28 +02:00
|
|
|
*/
|
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
class PropertyMap;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
class TAGLIB_EXPORT Tag {
|
|
|
|
public:
|
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Destroys this Tag instance.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual ~Tag();
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Exports the tags of the file as dictionary mapping (human readable) tag names (Strings) to StringLists of tag values.
|
|
|
|
* The default implementation in this class considers only the usual built-in tags (artist, album, ...) and only one value per key.
|
|
|
|
*/
|
2020-06-22 02:32:37 +02:00
|
|
|
virtual PropertyMap properties() const;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Removes unsupported properties, or a subset of them, from the tag.
|
|
|
|
* The parameter \a properties must contain only entries from properties().unsupportedData().
|
|
|
|
*/
|
2020-06-22 02:32:37 +02:00
|
|
|
virtual void removeUnsupportedProperties(const StringList &properties);
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the tags of this File to those specified in \a properties.
|
|
|
|
* This default implementation sets only the tags for which setter methods exist in this class
|
|
|
|
* (artist, album, ...), and only one value per key; the rest will be contained in the returned PropertyMap.
|
|
|
|
*/
|
2020-06-22 02:32:37 +02:00
|
|
|
virtual PropertyMap setProperties(const PropertyMap &origProps);
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns the track name; if no track name is present in the tag String::null will be returned.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual String title() const = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns the artist name; if no artist name is present in the tag String::null will be returned.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual String artist() const = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns the album name; if no album name is present in the tag String::null will be returned.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual String album() const = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns the track comment; if no comment is present in the tag String::null will be returned.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual String comment() const = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns the genre name; if no genre is present in the tag String::null will be returned.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual String genre() const = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns the year; if there is no year set, this will return 0.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual unsigned int year() const = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns the track number; if there is no track number set, this will
|
|
|
|
* return 0.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual unsigned int track() const = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the title to \a s. If \a s is String::null then this value will be cleared.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual void setTitle(const String &s) = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the artist to \a s. If \a s is String::null then this value will be cleared.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual void setArtist(const String &s) = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the album to \a s. If \a s is String::null then this value will be cleared.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual void setAlbum(const String &s) = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the comment to \a s. If \a s is String::null then this value will be cleared.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual void setComment(const String &s) = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the genre to \a s. If \a s is String::null then this value will be cleared.
|
|
|
|
* For tag formats that use a fixed set of genres, the appropriate value will be selected based on a string comparison.
|
|
|
|
* A list of available genres for those formats should be available in that type's implementation.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual void setGenre(const String &s) = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the year to \a i. If \a s is 0 then this value will be cleared.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual void setYear(unsigned int i) = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Sets the track to \a i. If \a s is 0 then this value will be cleared.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual void setTrack(unsigned int i) = 0;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Returns true if the tag does not contain any data.
|
|
|
|
* This should be reimplemented in subclasses that provide more than the basic tagging abilities in this class.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
virtual bool isEmpty() const;
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Copies the generic data from one tag to another.
|
|
|
|
*
|
|
|
|
* \note This will no affect any of the lower level details of the tag.
|
|
|
|
* For instance if any of the tag type specific data (maybe a URL for a band) is set,
|
|
|
|
* this will not modify or copy that.
|
|
|
|
* This just copies using the API in this class.
|
|
|
|
*
|
|
|
|
* If \a overwrite is true then the values will be unconditionally copied.
|
|
|
|
* If false only empty values will be overwritten.
|
|
|
|
*/
|
2020-06-13 19:02:42 +02:00
|
|
|
static void duplicate(const Tag *source, Tag *target, bool overwrite = true);
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
protected:
|
|
|
|
/*!
|
2020-06-14 17:01:05 +02:00
|
|
|
* Construct a Tag. This is protected since tags should only be instantiated through subclasses.
|
|
|
|
*/
|
2020-06-22 02:32:37 +02:00
|
|
|
explicit Tag();
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
private:
|
2020-06-22 02:32:37 +02:00
|
|
|
explicit Tag(const Tag&);
|
|
|
|
Tag &operator=(const Tag&);
|
2018-05-10 15:29:28 +02:00
|
|
|
|
2020-06-13 19:02:42 +02:00
|
|
|
class TagPrivate;
|
|
|
|
TagPrivate *d;
|
|
|
|
};
|
|
|
|
} // namespace TagLib
|
|
|
|
} // namespace Strawberry_TagLib
|
2018-05-10 15:29:28 +02:00
|
|
|
|
|
|
|
#endif
|