comparison data/fileio/FileSource.cpp @ 1036:682d64f05e72

Merge
author Chris Cannam
date Mon, 02 Mar 2015 17:21:34 +0000
parents 3a48b22fed48
children 24c48323c662
comparison
equal deleted inserted replaced
1035:d74ebd2d2c49 1036:682d64f05e72
30 #include <iostream> 30 #include <iostream>
31 #include <cstdlib> 31 #include <cstdlib>
32 32
33 #include <unistd.h> 33 #include <unistd.h>
34 34
35 //#define DEBUG_FILE_SOURCE 1 35 #define DEBUG_FILE_SOURCE 1
36 36
37 int 37 int
38 FileSource::m_count = 0; 38 FileSource::m_count = 0;
39 39
40 QMutex 40 QMutex
49 QMutex 49 QMutex
50 FileSource::m_mapMutex; 50 FileSource::m_mapMutex;
51 51
52 #ifdef DEBUG_FILE_SOURCE 52 #ifdef DEBUG_FILE_SOURCE
53 static int extantCount = 0; 53 static int extantCount = 0;
54 static int threadCount = 0;
54 static std::map<QString, int> urlExtantCountMap; 55 static std::map<QString, int> urlExtantCountMap;
56 static QMutex countMutex;
55 static void incCount(QString url) { 57 static void incCount(QString url) {
58 QMutexLocker locker(&countMutex);
56 ++extantCount; 59 ++extantCount;
57 if (urlExtantCountMap.find(url) == urlExtantCountMap.end()) { 60 if (urlExtantCountMap.find(url) == urlExtantCountMap.end()) {
58 urlExtantCountMap[url] = 1; 61 urlExtantCountMap[url] = 1;
59 } else { 62 } else {
60 ++urlExtantCountMap[url]; 63 ++urlExtantCountMap[url];
61 } 64 }
62 cerr << "FileSource: Now " << urlExtantCountMap[url] << " for this url, " << extantCount << " total" << endl; 65 cerr << "FileSource: Now " << urlExtantCountMap[url] << " for this url, " << extantCount << " total" << endl;
63 } 66 }
64 static void decCount(QString url) { 67 static void decCount(QString url) {
68 QMutexLocker locker(&countMutex);
65 --extantCount; 69 --extantCount;
66 --urlExtantCountMap[url]; 70 --urlExtantCountMap[url];
67 cerr << "FileSource: Now " << urlExtantCountMap[url] << " for this url, " << extantCount << " total" << endl; 71 cerr << "FileSource: Now " << urlExtantCountMap[url] << " for this url, " << extantCount << " total" << endl;
68 } 72 }
73 void
74 FileSource::debugReport()
75 {
76 QMutexLocker locker(&countMutex);
77 cerr << "\nFileSource::debugReport: Have " << extantCount << " FileSource object(s) extant across " << threadCount << " thread(s)" << endl;
78 cerr << "URLs by extant count:" << endl;
79 cerr << "Count | URL" << endl;
80 for (std::map<QString, int>::const_iterator i = urlExtantCountMap.begin();
81 i != urlExtantCountMap.end(); ++i) {
82 cerr << i->second << " | " << i->first << endl;
83 }
84 cerr << "FileSource::debugReport done\n" << endl;
85 }
86 #else
87 void FileSource::debugReport() { }
69 #endif 88 #endif
70 89
71 static QThreadStorage<QNetworkAccessManager *> nms; 90 static QThreadStorage<QNetworkAccessManager *> nms;
72 91
73 FileSource::FileSource(QString fileOrUrl, ProgressReporter *reporter, 92 FileSource::FileSource(QString fileOrUrl, ProgressReporter *reporter,
266 } 285 }
267 286
268 void 287 void
269 FileSource::init() 288 FileSource::init()
270 { 289 {
271 { // check we have a QNetworkAccessManager
272 QMutexLocker locker(&m_mapMutex);
273 if (!nms.hasLocalData()) {
274 nms.setLocalData(new QNetworkAccessManager());
275 }
276 }
277
278 if (isResource()) { 290 if (isResource()) {
279 #ifdef DEBUG_FILE_SOURCE 291 #ifdef DEBUG_FILE_SOURCE
280 cerr << "FileSource::init: Is a resource" << endl; 292 cerr << "FileSource::init: Is a resource" << endl;
281 #endif 293 #endif
282 QString resourceFile = m_url.toString(); 294 QString resourceFile = m_url.toString();
459 << m_preferredContentType << "\"" << endl; 471 << m_preferredContentType << "\"" << endl;
460 #endif 472 #endif
461 req.setRawHeader 473 req.setRawHeader
462 ("Accept", 474 ("Accept",
463 QString("%1, */*").arg(m_preferredContentType).toLatin1()); 475 QString("%1, */*").arg(m_preferredContentType).toLatin1());
476 }
477
478 { // check we have a QNetworkAccessManager
479 QMutexLocker locker(&m_mapMutex);
480 if (!nms.hasLocalData()) {
481 #ifdef DEBUG_FILE_SOURCE
482 ++threadCount;
483 #endif
484 nms.setLocalData(new QNetworkAccessManager());
485 }
464 } 486 }
465 487
466 m_reply = nms.localData()->get(req); 488 m_reply = nms.localData()->get(req);
467 489
468 connect(m_reply, SIGNAL(readyRead()), 490 connect(m_reply, SIGNAL(readyRead()),