The main class in the ID3v2 implementation. More...
#include <id3v2tag.h>
Public Member Functions | |
Tag () | |
Tag (File *file, offset_t tagOffset, const FrameFactory *factory=FrameFactory::instance()) | |
~Tag () override | |
Tag (const Tag &)=delete | |
Tag & | operator= (const Tag &)=delete |
String | title () const override |
String | artist () const override |
String | album () const override |
String | comment () const override |
String | genre () const override |
unsigned int | year () const override |
unsigned int | track () const override |
void | setTitle (const String &s) override |
void | setArtist (const String &s) override |
void | setAlbum (const String &s) override |
void | setComment (const String &s) override |
void | setGenre (const String &s) override |
void | setYear (unsigned int i) override |
void | setTrack (unsigned int i) override |
bool | isEmpty () const override |
Header * | header () const |
ExtendedHeader * | extendedHeader () const |
const FrameListMap & | frameListMap () const |
const FrameList & | frameList () const |
const FrameList & | frameList (const ByteVector &frameID) const |
void | addFrame (Frame *frame) |
void | removeFrame (Frame *frame, bool del=true) |
void | removeFrames (const ByteVector &id) |
PropertyMap | properties () const override |
void | removeUnsupportedProperties (const StringList &properties) override |
PropertyMap | setProperties (const PropertyMap &) override |
StringList | complexPropertyKeys () const override |
List< VariantMap > | complexProperties (const String &key) const override |
bool | setComplexProperties (const String &key, const List< VariantMap > &value) override |
ByteVector | render () const |
ByteVector | render (Version version) const |
Public Member Functions inherited from TagLib::Tag | |
virtual | ~Tag () |
Tag (const Tag &)=delete | |
Tag & | operator= (const Tag &)=delete |
virtual PropertyMap | properties () const |
virtual void | removeUnsupportedProperties (const StringList &properties) |
virtual PropertyMap | setProperties (const PropertyMap &origProps) |
virtual StringList | complexPropertyKeys () const |
virtual List< VariantMap > | complexProperties (const String &key) const |
virtual bool | setComplexProperties (const String &key, const List< VariantMap > &value) |
virtual String | title () const =0 |
virtual String | artist () const =0 |
virtual String | album () const =0 |
virtual String | comment () const =0 |
virtual String | genre () const =0 |
virtual unsigned int | year () const =0 |
virtual unsigned int | track () const =0 |
virtual void | setTitle (const String &s)=0 |
virtual void | setArtist (const String &s)=0 |
virtual void | setAlbum (const String &s)=0 |
virtual void | setComment (const String &s)=0 |
virtual void | setGenre (const String &s)=0 |
virtual void | setYear (unsigned int i)=0 |
virtual void | setTrack (unsigned int i)=0 |
virtual bool | isEmpty () const |
Static Public Member Functions | |
static Latin1StringHandler const * | latin1StringHandler () |
static void | setLatin1StringHandler (const Latin1StringHandler *handler) |
Static Public Member Functions inherited from TagLib::Tag | |
static void | duplicate (const Tag *source, Tag *target, bool overwrite=true) |
static String | joinTagValues (const StringList &values) |
Protected Member Functions | |
void | read () |
void | parse (const ByteVector &origData) |
void | setTextFrame (const ByteVector &id, const String &value) |
void | downgradeFrames (FrameList *frames, FrameList *newFrames) const |
Protected Member Functions inherited from TagLib::Tag | |
Tag () | |
The main class in the ID3v2 implementation.
This is the main class in the ID3v2 implementation. It serves two functions. The first, as is obvious from the public API, is to provide a container for the other ID3v2 related classes. In addition, through the read() and parse() protected methods, it provides the most basic level of parsing. In these methods the ID3v2 tag is extracted from the file and split into data components.
ID3v2 tags have several parts, TagLib attempts to provide an interface for them all. header() and extendedHeader() correspond to those data structures in the ID3v2 standard and the APIs for the classes that they return attempt to reflect this.
Also ID3v2 tags are built up from a list of frames, which have a header and a list of fields. TagLib provides two ways of accessing the list of frames that are in a given ID3v2 tag. The first is simply via the frameList() method. This is just a list of pointers to the frames. The second is a map from the frame type – i.e. "COMM" for comments – and a list of frames of that type. (In some cases ID3v2 allows for multiple frames of the same type, hence this being a map to a list rather than just a map to an individual frame.)
More information on the structure of frames can be found in the ID3v2::Frame class.
read() and parse() pass binary data to the other ID3v2 class structures, they do not handle parsing of flags or fields, for instance. Those are handled by similar functions within those classes.
TagLib::ID3v2::Tag::Tag | ( | ) |
Constructs an empty ID3v2 tag.
TagLib::ID3v2::Tag::Tag | ( | File * | file, |
offset_t | tagOffset, | ||
const FrameFactory * | factory = FrameFactory::instance() |
||
) |
Constructs an ID3v2 tag read from file starting at tagOffset. factory specifies which FrameFactory will be used for the construction of new frames.
|
overridevirtual |
Destroys this Tag instance.
Reimplemented from TagLib::Tag.
|
delete |
void TagLib::ID3v2::Tag::addFrame | ( | Frame * | frame | ) |
Add a frame to the tag. At this point the tag takes ownership of the frame and will handle freeing its memory.
|
overridevirtual |
Returns the album name; if no album name is present in the tag an empty string will be returned.
Implements TagLib::Tag.
|
overridevirtual |
Returns the artist name; if no artist name is present in the tag an empty string will be returned.
Implements TagLib::Tag.
|
overridevirtual |
Returns the track comment; if no comment is present in the tag an empty string will be returned.
Implements TagLib::Tag.
|
overridevirtual |
Get the complex properties for a given key. In order to be flexible for different metadata formats, the properties are represented as variant maps. Despite this dynamic nature, some degree of standardization should be achieved between formats:
Reimplemented from TagLib::Tag.
|
overridevirtual |
Get the keys of complex properties, i.e. properties which cannot be represented simply by a string. Because such properties might be expensive to fetch, there are separate operations to get the available keys - which is expected to be cheap - and getting and setting the property values. The default implementation returns only an empty list. Reimplementations should provide "PICTURE" if embedded cover art is present, and optionally support other properties.
Reimplemented from TagLib::Tag.
|
protected |
Downgrade frames from ID3v2.4 (used internally and by default) to ID3v2.3.
ExtendedHeader * TagLib::ID3v2::Tag::extendedHeader | ( | ) | const |
Returns a pointer to the tag's extended header or null if there is no extended header.
const FrameList & TagLib::ID3v2::Tag::frameList | ( | ) | const |
Returns a reference to the frame list. This is a FrameList of all of the frames in the tag in the order that they were parsed.
This can be useful if for example you want to iterate over the tag's frames in the order that they occur in the tag.
const FrameList & TagLib::ID3v2::Tag::frameList | ( | const ByteVector & | frameID | ) | const |
Returns the frame list for frames with the id frameID or an empty list if there are no frames of that type. This is just a convenience and is equivalent to:
const FrameListMap & TagLib::ID3v2::Tag::frameListMap | ( | ) | const |
Returns a reference to the frame list map. This is a FrameListMap of all of the frames in the tag.
This is the most convenient structure for accessing the tag's frames. Many frame types allow multiple instances of the same frame type so this is a map of lists. In most cases however there will only be a single frame of a certain type.
Let's say for instance that you wanted to access the frame for total beats per minute – the TBPM frame.
|
overridevirtual |
Returns the genre name; if no genre is present in the tag an empty string will be returned.
Implements TagLib::Tag.
Header * TagLib::ID3v2::Tag::header | ( | ) | const |
Returns a pointer to the tag's header.
|
overridevirtual |
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.
Reimplemented from TagLib::Tag.
|
static |
Gets the current string handler that decides how the "Latin-1" data will be converted to and from binary data.
|
protected |
This is called by read to parse the body of the tag. It determines if an extended header exists and adds frames to the FrameListMap.
|
overridevirtual |
Implements the unified property interface – export function. This function does some work to translate the hard-specified ID3v2 frame types into a free-form string-to-stringlist PropertyMap:
Reimplemented from TagLib::Tag.
|
protected |
Reads data from the file specified in the constructor. It does basic parsing of the data in the largest chunks. It partitions the tag into the Header, the body of the tag (which contains the ExtendedHeader and frames) and Footer.
void TagLib::ID3v2::Tag::removeFrame | ( | Frame * | frame, |
bool | del = true |
||
) |
Remove a frame from the tag. If del is true
the frame's memory will be freed; if it is false
, it must be deleted by the user.
void TagLib::ID3v2::Tag::removeFrames | ( | const ByteVector & | id | ) |
Remove all frames of type id from the tag and free their memory.
|
overridevirtual |
Removes unsupported frames given by properties. The elements of properties must be taken from properties().unsupportedData(); they are of one of the following forms:
Reimplemented from TagLib::Tag.
ByteVector TagLib::ID3v2::Tag::render | ( | ) | const |
Render the tag back to binary data, suitable to be written to disk.
ByteVector TagLib::ID3v2::Tag::render | ( | Version | version | ) | const |
Render the tag back to binary data, suitable to be written to disk.
The version parameter specifies whether ID3v2.4 (default) or ID3v2.3 should be used.
|
overridevirtual |
Sets the album to s. If s is an empty string then this value will be cleared.
Implements TagLib::Tag.
|
overridevirtual |
Sets the artist to s. If s is an empty string then this value will be cleared.
Implements TagLib::Tag.
|
overridevirtual |
Sets the comment to s. If s is an empty string then this value will be cleared.
Implements TagLib::Tag.
|
overridevirtual |
Set all complex properties for a given key using variant maps as value with the same format as returned by complexProperties(). An empty list as value removes all complex properties for key.
Reimplemented from TagLib::Tag.
|
overridevirtual |
Sets the genre to s. If s is an empty string 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.
Implements TagLib::Tag.
|
static |
Sets the string handler that decides how the "Latin-1" data will be converted to and from binary data. If the parameter handler is null, the previous handler is released and default ISO-8859-1 handler is restored.
|
overridevirtual |
Implements the unified property interface – import function. See the comments in properties().
Reimplemented from TagLib::Tag.
|
protected |
Sets the value of the text frame with the Frame ID id to value. If the frame does not exist, it is created.
|
overridevirtual |
Sets the title to s. If s is an empty string then this value will be cleared.
Implements TagLib::Tag.
|
overridevirtual |
Sets the track to i. If s is 0 then this value will be cleared.
Implements TagLib::Tag.
|
overridevirtual |
Sets the year to i. If s is 0 then this value will be cleared.
Implements TagLib::Tag.
|
overridevirtual |
Returns the track name; if no track name is present in the tag an empty string will be returned.
Implements TagLib::Tag.
|
overridevirtual |
Returns the track number; if there is no track number set, this will return 0.
Implements TagLib::Tag.
|
overridevirtual |
Returns the year; if there is no year set, this will return 0.
Implements TagLib::Tag.