strawberry-audio-player-win.../3rdparty/taglib/mp4/mp4item.cpp

216 lines
6.1 KiB
C++
Raw Normal View History

2018-05-10 15:29:28 +02:00
/**************************************************************************
copyright : (C) 2007 by Lukáš Lalinský
email : lalinsky@gmail.com
**************************************************************************/
/***************************************************************************
* 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/ *
***************************************************************************/
2020-06-26 23:30:30 +02:00
#include <memory>
#include "taglib.h"
#include "tdebug.h"
2018-05-10 15:29:28 +02:00
#include "mp4item.h"
2020-06-26 23:30:30 +02:00
#include "tutils.h"
2018-05-10 15:29:28 +02:00
using namespace Strawberry_TagLib::TagLib;
2018-05-10 15:29:28 +02:00
2020-06-26 23:30:30 +02:00
namespace {
struct ItemData {
2018-05-10 15:29:28 +02:00
bool valid;
2020-06-26 23:30:30 +02:00
MP4::AtomDataType atomDataType;
MP4::Item::ItemType type;
2018-05-10 15:29:28 +02:00
union {
bool m_bool;
int m_int;
2020-06-26 23:30:30 +02:00
MP4::Item::IntPair m_intPair;
2018-05-10 15:29:28 +02:00
unsigned char m_byte;
unsigned int m_uint;
long long m_longlong;
};
StringList m_stringList;
ByteVectorList m_byteVectorList;
MP4::CoverArtList m_coverArtList;
};
2020-06-26 23:30:30 +02:00
} // namespace
class MP4::Item::ItemPrivate {
public:
explicit ItemPrivate() : data(new ItemData()) {
data->valid = true;
data->atomDataType = MP4::TypeUndefined;
2020-07-13 18:11:57 +02:00
data->type = MP4::Item::TypeUndefined_;
2020-06-26 23:30:30 +02:00
}
std::shared_ptr<ItemData> data;
};
2018-05-10 15:29:28 +02:00
2020-06-13 19:02:42 +02:00
MP4::Item::Item() : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->valid = false;
2018-05-10 15:29:28 +02:00
}
2020-06-26 23:30:30 +02:00
MP4::Item::Item(const Item &item) : d(new ItemPrivate(*item.d)) {}
2018-05-10 15:29:28 +02:00
MP4::Item &MP4::Item::operator=(const Item &item) {
2018-05-10 15:29:28 +02:00
Item(item).swap(*this);
return *this;
}
2020-06-13 19:02:42 +02:00
void MP4::Item::swap(Item &item) {
2018-05-10 15:29:28 +02:00
using std::swap;
swap(d, item.d);
}
2020-06-13 19:02:42 +02:00
MP4::Item::~Item() {
2020-06-26 23:30:30 +02:00
delete d;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(bool value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_bool = value;
d->data->type = TypeBool;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(int value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_int = value;
d->data->type = TypeInt;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(unsigned char value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_byte = value;
d->data->type = TypeByte;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(unsigned int value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_uint = value;
d->data->type = TypeUInt;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(long long value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_longlong = value;
d->data->type = TypeLongLong;
2018-05-10 15:29:28 +02:00
}
2020-06-26 23:30:30 +02:00
MP4::Item::Item(int value1, int value2) : d(new ItemPrivate()) {
d->data->m_intPair.first = value1;
d->data->m_intPair.second = value2;
d->data->type = TypeIntPair;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(const ByteVectorList &value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_byteVectorList = value;
d->data->type = TypeByteVectorList;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(const StringList &value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_stringList = value;
d->data->type = TypeStringList;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::Item::Item(const MP4::CoverArtList &value) : d(new ItemPrivate()) {
2020-06-26 23:30:30 +02:00
d->data->m_coverArtList = value;
d->data->type = TypeCoverArtList;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
void MP4::Item::setAtomDataType(MP4::AtomDataType type) {
2020-06-26 23:30:30 +02:00
d->data->atomDataType = type;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
MP4::AtomDataType MP4::Item::atomDataType() const {
2020-06-26 23:30:30 +02:00
return d->data->atomDataType;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
bool MP4::Item::toBool() const {
2020-06-26 23:30:30 +02:00
return d->data->m_bool;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
int MP4::Item::toInt() const {
2020-06-26 23:30:30 +02:00
return d->data->m_int;
2018-05-10 15:29:28 +02:00
}
unsigned char MP4::Item::toByte() const {
2020-06-26 23:30:30 +02:00
return d->data->m_byte;
2018-05-10 15:29:28 +02:00
}
unsigned int MP4::Item::toUInt() const {
2020-06-26 23:30:30 +02:00
return d->data->m_uint;
2018-05-10 15:29:28 +02:00
}
long long MP4::Item::toLongLong() const {
2020-06-26 23:30:30 +02:00
return d->data->m_longlong;
2018-05-10 15:29:28 +02:00
}
MP4::Item::IntPair MP4::Item::toIntPair() const {
2020-06-26 23:30:30 +02:00
return d->data->m_intPair;
2018-05-10 15:29:28 +02:00
}
StringList MP4::Item::toStringList() const {
2020-06-26 23:30:30 +02:00
return d->data->m_stringList;
2018-05-10 15:29:28 +02:00
}
ByteVectorList MP4::Item::toByteVectorList() const {
2020-06-26 23:30:30 +02:00
return d->data->m_byteVectorList;
2018-05-10 15:29:28 +02:00
}
MP4::CoverArtList MP4::Item::toCoverArtList() const {
2020-06-26 23:30:30 +02:00
return d->data->m_coverArtList;
2018-05-10 15:29:28 +02:00
}
2020-06-13 19:02:42 +02:00
bool MP4::Item::isValid() const {
2020-06-26 23:30:30 +02:00
return d->data->valid;
}
String MP4::Item::toString() const {
StringList desc;
switch (d->data->type) {
case TypeBool:
return d->data->m_bool ? "true" : "false";
case TypeInt:
return Utils::formatString("%d", d->data->m_int);
case TypeIntPair:
return Utils::formatString("%d/%d", d->data->m_intPair.first, d->data->m_intPair.second);
case TypeByte:
return Utils::formatString("%d", d->data->m_byte);
case TypeUInt:
return Utils::formatString("%u", d->data->m_uint);
case TypeLongLong:
return Utils::formatString("%lld", d->data->m_longlong);
case TypeStringList:
return d->data->m_stringList.toString(" / ");
case TypeByteVectorList:
for (size_t i = 0; i < d->data->m_byteVectorList.size(); i++) {
desc.append(Utils::formatString(
"[%d bytes of data]", static_cast<int>(d->data->m_byteVectorList[i].size())));
}
return desc.toString(", ");
case TypeCoverArtList:
for (size_t i = 0; i < d->data->m_coverArtList.size(); i++) {
desc.append(Utils::formatString("[%d bytes of data]", static_cast<int>(d->data->m_coverArtList[i].data().size())));
}
return desc.toString(", ");
2020-07-13 18:11:57 +02:00
case TypeUndefined_:
2020-06-26 23:30:30 +02:00
return "[unknown]";
}
return String();
2018-05-10 15:29:28 +02:00
}