Mercurial > hg > svcore
comparison data/fileio/MP3FileReader.cpp @ 1206:659372323b45 tony-2.0-integration
Merge latest SV 3.0 branch code
author | Chris Cannam |
---|---|
date | Fri, 19 Aug 2016 15:58:57 +0100 |
parents | 134ce7667256 |
children | 6b847a59d908 |
comparison
equal
deleted
inserted
replaced
1136:e94719f941ba | 1206:659372323b45 |
---|---|
30 #include <unistd.h> | 30 #include <unistd.h> |
31 | 31 |
32 #ifdef HAVE_ID3TAG | 32 #ifdef HAVE_ID3TAG |
33 #include <id3tag.h> | 33 #include <id3tag.h> |
34 #endif | 34 #endif |
35 | |
35 //#define DEBUG_ID3TAG 1 | 36 //#define DEBUG_ID3TAG 1 |
36 | 37 |
37 #include <QFileInfo> | 38 #include <QFileInfo> |
38 | 39 |
39 MP3FileReader::MP3FileReader(FileSource source, DecodeMode decodeMode, | 40 MP3FileReader::MP3FileReader(FileSource source, DecodeMode decodeMode, |
176 // when we implement support for more than just the one tag! | 177 // when we implement support for more than just the one tag! |
177 | 178 |
178 id3_tag *tag = id3_file_tag(file); | 179 id3_tag *tag = id3_file_tag(file); |
179 if (!tag) { | 180 if (!tag) { |
180 #ifdef DEBUG_ID3TAG | 181 #ifdef DEBUG_ID3TAG |
181 SVDEBUG << "MP3FileReader::loadTags: No ID3 tag found" << endl; | 182 cerr << "MP3FileReader::loadTags: No ID3 tag found" << endl; |
182 #endif | 183 #endif |
183 id3_file_close(file); | 184 id3_file_close(file); |
184 return; | 185 return; |
185 } | 186 } |
186 | 187 |
199 | 200 |
200 id3_file_close(file); | 201 id3_file_close(file); |
201 | 202 |
202 #else | 203 #else |
203 #ifdef DEBUG_ID3TAG | 204 #ifdef DEBUG_ID3TAG |
204 SVDEBUG << "MP3FileReader::loadTags: ID3 tag support not compiled in" | 205 cerr << "MP3FileReader::loadTags: ID3 tag support not compiled in" |
205 << endl; | 206 << endl; |
206 #endif | 207 #endif |
207 #endif | 208 #endif |
208 } | 209 } |
209 | 210 |
214 id3_tag *tag = (id3_tag *)vtag; | 215 id3_tag *tag = (id3_tag *)vtag; |
215 | 216 |
216 id3_frame *frame = id3_tag_findframe(tag, name, 0); | 217 id3_frame *frame = id3_tag_findframe(tag, name, 0); |
217 if (!frame) { | 218 if (!frame) { |
218 #ifdef DEBUG_ID3TAG | 219 #ifdef DEBUG_ID3TAG |
219 SVDEBUG << "MP3FileReader::loadTags: No \"" << name << "\" in ID3 tag" << endl; | 220 cerr << "MP3FileReader::loadTags: No \"" << name << "\" in ID3 tag" << endl; |
220 #endif | 221 #endif |
221 return ""; | 222 return ""; |
222 } | 223 } |
223 | 224 |
224 if (frame->nfields < 2) { | 225 if (frame->nfields < 2) { |
225 SVDEBUG << "MP3FileReader::loadTags: WARNING: Not enough fields (" << frame->nfields << ") for \"" << name << "\" in ID3 tag" << endl; | 226 cerr << "MP3FileReader::loadTags: WARNING: Not enough fields (" << frame->nfields << ") for \"" << name << "\" in ID3 tag" << endl; |
226 return ""; | 227 return ""; |
227 } | 228 } |
228 | 229 |
229 unsigned int nstrings = id3_field_getnstrings(&frame->fields[1]); | 230 unsigned int nstrings = id3_field_getnstrings(&frame->fields[1]); |
230 if (nstrings == 0) { | 231 if (nstrings == 0) { |
231 #ifdef DEBUG_ID3TAG | 232 #ifdef DEBUG_ID3TAG |
232 SVDEBUG << "MP3FileReader::loadTags: No strings for \"" << name << "\" in ID3 tag" << endl; | 233 cerr << "MP3FileReader::loadTags: No strings for \"" << name << "\" in ID3 tag" << endl; |
233 #endif | 234 #endif |
234 return ""; | 235 return ""; |
235 } | 236 } |
236 | 237 |
237 id3_ucs4_t const *ustr = id3_field_getstrings(&frame->fields[1], 0); | 238 id3_ucs4_t const *ustr = id3_field_getstrings(&frame->fields[1], 0); |
238 if (!ustr) { | 239 if (!ustr) { |
239 #ifdef DEBUG_ID3TAG | 240 #ifdef DEBUG_ID3TAG |
240 SVDEBUG << "MP3FileReader::loadTags: Invalid or absent data for \"" << name << "\" in ID3 tag" << endl; | 241 cerr << "MP3FileReader::loadTags: Invalid or absent data for \"" << name << "\" in ID3 tag" << endl; |
241 #endif | 242 #endif |
242 return ""; | 243 return ""; |
243 } | 244 } |
244 | 245 |
245 id3_utf8_t *u8str = id3_ucs4_utf8duplicate(ustr); | 246 id3_utf8_t *u8str = id3_ucs4_utf8duplicate(ustr); |
250 | 251 |
251 QString rv = QString::fromUtf8((const char *)u8str); | 252 QString rv = QString::fromUtf8((const char *)u8str); |
252 free(u8str); | 253 free(u8str); |
253 | 254 |
254 #ifdef DEBUG_ID3TAG | 255 #ifdef DEBUG_ID3TAG |
255 SVDEBUG << "MP3FileReader::loadTags: tag \"" << name << "\" -> \"" | 256 cerr << "MP3FileReader::loadTags: tag \"" << name << "\" -> \"" |
256 << rv << "\"" << endl; | 257 << rv << "\"" << endl; |
257 #endif | 258 #endif |
258 | 259 |
259 | 260 |
260 return rv; | 261 return rv; |