在Mac OSX上使用TagLib 1.8和Qt 5.0.1,我正在尝试为AIFF文件创建一组新的ID3标签。该文件没有任何标签可供选择。这是我的代码:
TagLib::Tag *t = concreteTag();
assert(tag);
if (t) {
auto id3Tag = dynamic_cast<TagLib::ID3v2::Tag *>(t);
t -> setTitle(QStringToTagLib(tag -> title()));
t -> setAlbum(QStringToTagLib(tag -> album()));
t -> setComment(QStringToTagLib(tag -> comment()));
t -> setYear(tag -> year());
if (id3Tag)
processID3(id3Tag, tag);
return m_file.save();
}
return false;
tag
变量是我保存元数据的代码中的对象。如果concreteTag()
从FileRef
函数返回TagUnion
,tag()
将返回“正确”的代码对象。我已经确认tag
中的数据是好的。
processID3
将写入不属于TagLib在TagLib::Tag
对象上支持的“基本”字段的元数据:
processID3(TagLib::ID3v2::Tag *dst, TagSP src) const {
addID3Images(dst, src -> albumArt());
addId3TextFrame(dst, "ALBUMARTIST", src -> albumArtist());
addId3TextFrame(dst, "ARTIST", src -> artists());
addId3TextFrame(dst, "GENRE", src -> genres());
addId3TextFrame(dst, "COMPOSER", src -> composers());
if (src -> track() > 0) {
if (src -> totalTracks() > 0)
addId3TextFrame(dst, "TRACKNUMBER", QString(src -> track()) + "/" + src -> totalTracks());
else
addId3TextFrame(dst, "TRACKNUMBER", QString(src -> track()));
}
if (src -> disc() > 0) {
if (src -> totalDiscs() > 0)
addId3TextFrame(dst, "DISCNUMBER", QString(src -> disc()) + "/" + src -> totalDiscs());
else
addId3TextFrame(dst, "DISCNUMBER", QString(src -> disc()));
}
最后,addId3TextFrame看起来像这样(我没有图像所以永远不会调用addID3Images()
):
void addId3TextFrame(TagLib::ID3v2::Tag *tag, const char *type, const QStringList& value) {
if (!value.isEmpty()) {
TagLib::StringList sl;
for (auto it = value.begin(); it != value.end(); it++) {
if (!it -> isEmpty())
sl.append(QStringToTagLibID3(*it));
}
tag -> removeFrames(type);
tag -> addFrame(TagLib::ID3v2::Frame::createTextualFrame(type, sl));
}
}
我的元数据包括(对于我当前的测试文件)相册艺术家,曲目,流派和年份。目前我正在使用ID3v2Frame::createTextualFrame()
,但我尝试使用正确的ID3帧ID(TRCK,TCON等)手动创建文本框架。
这是我的问题。 TagLib正在保存一个只包含1个字段的ID3 v2.4标记 - 我设置的最后一个字段。如果我相应地重新排序我的代码,我可以正确设置Album Artist,Track,Genre或Year中的任何一个,但它只会保存一个字段。
在完整代码中,我有一个函数processMP4,它与processID3非常相似。对于MP4文件,所有标记都已正确保存。这让我相信我的方法是合理的。
任何想法我做错了什么?
答案 0 :(得分:0)
原来这是由于编译设置造成的。默认情况下,OSX上的CMake将链接到标准库的旧GNU libstdc ++ 6实现。我的项目正在使用新的C ++ 11 libc ++实现。
有趣的部分不仅仅是以一种非常明显的方式死亡(崩溃或其他东西),使用libstdc ++ 6的TagLib代码只能读取我的libc ++代码生成的第一个迭代器。此外,libstdc ++ 6中的迭代器上的operator ++没有崩溃,而是返回end()。