comparison data/fileio/MatrixFile.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 aa588c391d1a
children
comparison
equal deleted inserted replaced
1136:e94719f941ba 1206:659372323b45
174 openCount --; 174 openCount --;
175 } 175 }
176 176
177 QMutexLocker locker(&m_createMutex); 177 QMutexLocker locker(&m_createMutex);
178 178
179 delete m_setColumns;
180
181 if (m_fileName != "") { 179 if (m_fileName != "") {
182 180
183 if (--m_refcount[m_fileName] == 0) { 181 if (--m_refcount[m_fileName] == 0) {
184 182
185 if (::unlink(m_fileName.toLocal8Bit())) { 183 if (::unlink(m_fileName.toLocal8Bit())) {
206 { 204 {
207 Profiler profiler("MatrixFile::initialise", true); 205 Profiler profiler("MatrixFile::initialise", true);
208 206
209 assert(m_mode == WriteOnly); 207 assert(m_mode == WriteOnly);
210 208
211 m_setColumns = new ResizeableBitset(m_width); 209 m_setColumns.resize(m_width, false);
212 210
213 off_t off = m_headerSize + (m_width * m_height * m_cellSize) + m_width; 211 off_t off = m_headerSize + (m_width * m_height * m_cellSize) + m_width;
214 212
215 #ifdef DEBUG_MATRIX_FILE 213 #ifdef DEBUG_MATRIX_FILE
216 cerr << "MatrixFile[" << m_fd << "]::initialise(" << m_width << ", " << m_height << "): cell size " << m_cellSize << ", header size " << m_headerSize << ", resizing fd " << m_fd << " to " << off << endl; 214 cerr << "MatrixFile[" << m_fd << "]::initialise(" << m_width << ", " << m_height << "): cell size " << m_cellSize << ", header size " << m_headerSize << ", resizing fd " << m_fd << " to " << off << endl;
314 312
315 bool 313 bool
316 MatrixFile::haveSetColumnAt(int x) const 314 MatrixFile::haveSetColumnAt(int x) const
317 { 315 {
318 if (m_mode == WriteOnly) { 316 if (m_mode == WriteOnly) {
319 return m_setColumns->get(x); 317 return m_setColumns[x];
320 } 318 }
321 319
322 if (m_readyToReadColumn >= 0 && 320 if (m_readyToReadColumn >= 0 &&
323 int(m_readyToReadColumn) == x) return true; 321 int(m_readyToReadColumn) == x) return true;
324 322
396 if (w != 1) { 394 if (w != 1) {
397 ::perror("WARNING: MatrixFile::setColumnAt: write failed (3)"); 395 ::perror("WARNING: MatrixFile::setColumnAt: write failed (3)");
398 throw FileOperationFailed(m_fileName, "write"); 396 throw FileOperationFailed(m_fileName, "write");
399 } 397 }
400 398
401 m_setColumns->set(x); 399 m_setColumns[x] = true;
402 if (m_autoClose) { 400 if (m_autoClose) {
403 if (m_setColumns->isAllOn()) { 401 if (std::all_of(m_setColumns.begin(), m_setColumns.end(),
402 [](bool c) { return c; })) {
404 #ifdef DEBUG_MATRIX_FILE 403 #ifdef DEBUG_MATRIX_FILE
405 cerr << "MatrixFile[" << m_fd << "]::setColumnAt(" << x << "): All columns set: auto-closing" << endl; 404 cerr << "MatrixFile[" << m_fd << "]::setColumnAt(" << x << "): All columns set: auto-closing" << endl;
406 #endif 405 #endif
407 close(); 406 close();
408 /* 407 /*