mirror of
https://github.com/taglib/taglib.git
synced 2025-05-27 21:20:26 -04:00
and make it build. There are still some missing API docs and I'm not sure how I feel about non-opaque types (Item in this case) since they're not used elsewhere in the API, but this will do for now. git-svn-id: svn://anonsvn.kde.org/home/kde/trunk/kdesupport/taglib@333117 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
161 lines
4.4 KiB
C++
161 lines
4.4 KiB
C++
/***************************************************************************
|
|
copyright : (C) 2004 by Allan Sandfeld Jensen
|
|
email : kde@carewolf.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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 *
|
|
* USA *
|
|
***************************************************************************/
|
|
|
|
#ifndef TAGLIB_APETAG_H
|
|
#define TAGLIB_APETAG_H
|
|
|
|
#include "tag.h"
|
|
#include "tbytevector.h"
|
|
#include "tmap.h"
|
|
#include "tstring.h"
|
|
#include "tstringlist.h"
|
|
|
|
namespace TagLib {
|
|
|
|
class File;
|
|
|
|
namespace APE {
|
|
|
|
class Footer;
|
|
|
|
/*!
|
|
* A non-binary APE-item.
|
|
*/
|
|
struct Item
|
|
{
|
|
Item() {};
|
|
explicit Item(const String &);
|
|
explicit Item(const StringList &);
|
|
bool readOnly;
|
|
/*!
|
|
* The value is a URL to external data
|
|
*/
|
|
bool locator;
|
|
StringList value;
|
|
bool isEmpty() const;
|
|
};
|
|
|
|
/*!
|
|
* A mapping between a list of item names, or keys, and the associated item.
|
|
*
|
|
* \see APE::Tag::itemListMap()
|
|
*/
|
|
typedef Map<const String, Item> ItemListMap;
|
|
|
|
|
|
//! An APE tag implementation
|
|
|
|
class Tag : public TagLib::Tag
|
|
{
|
|
public:
|
|
/*!
|
|
* Create an APE tag with default values.
|
|
*/
|
|
Tag();
|
|
|
|
/*!
|
|
* Create an APE tag and parse the data in \a file with APE footer at
|
|
* \a tagOffset.
|
|
*/
|
|
Tag(File *file, long tagOffset);
|
|
|
|
/*!
|
|
* Destroys this Tag instance.
|
|
*/
|
|
virtual ~Tag();
|
|
|
|
/*!
|
|
* Renders the in memory values to a ByteVector suitable for writing to
|
|
* the file.
|
|
*/
|
|
ByteVector render() const;
|
|
|
|
/*!
|
|
* Returns the string "APETAGEX" suitable for usage in locating the tag in a
|
|
* file.
|
|
*/
|
|
static ByteVector fileIdentifier();
|
|
|
|
// Reimplementations.
|
|
|
|
virtual String title() const;
|
|
virtual String artist() const;
|
|
virtual String album() const;
|
|
virtual String comment() const;
|
|
virtual String genre() const;
|
|
virtual uint year() const;
|
|
virtual uint track() const;
|
|
|
|
virtual void setTitle(const String &s);
|
|
virtual void setArtist(const String &s);
|
|
virtual void setAlbum(const String &s);
|
|
virtual void setComment(const String &s);
|
|
virtual void setGenre(const String &s);
|
|
virtual void setYear(uint i);
|
|
virtual void setTrack(uint i);
|
|
|
|
/*!
|
|
* Returns a pointer to the tag's footer.
|
|
*/
|
|
Footer *footer() const;
|
|
|
|
const ItemListMap &itemListMap() const;
|
|
|
|
/*!
|
|
* Removes the \a key comment from the tag
|
|
*/
|
|
void removeItem(const String &key);
|
|
|
|
/*!
|
|
* Adds to the item specified by \a key the data \a value. If \a replace
|
|
* is true, then all of the other values on the same key will be removed
|
|
* first.
|
|
*/
|
|
void addValue(const String &key, const String &value, bool replace = true);
|
|
|
|
/*!
|
|
* Sets the \a key comment to \a item.
|
|
*/
|
|
void setItem(const String &key, const Item &item);
|
|
|
|
protected:
|
|
|
|
/*!
|
|
* Reads from the file specified in the constructor.
|
|
*/
|
|
void read();
|
|
/*!
|
|
* Parses the body of the tag in \a data with \a count items.
|
|
*/
|
|
void parse(const ByteVector &data, uint count);
|
|
|
|
private:
|
|
Tag(const Tag &);
|
|
Tag &operator=(const Tag &);
|
|
|
|
class TagPrivate;
|
|
TagPrivate *d;
|
|
};
|
|
}
|
|
}
|
|
|
|
#endif
|