Mercurial > hg > svcore
view base/ProgressPrinter.cpp @ 482:f54381e01141
* Fix a deadlock
* Make debug output more suited to datastore rdf implementation
author | Chris Cannam |
---|---|
date | Fri, 14 Nov 2008 12:29:48 +0000 |
parents | beb2948baa77 |
children | 1aefb666ecfc |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Sonic Visualiser An audio file viewer and annotation editor. Centre for Digital Music, Queen Mary, University of London. This file copyright 2007 QMUL. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the file COPYING included with this distribution for more information. */ #include "ProgressPrinter.h" #include <iostream> ProgressPrinter::ProgressPrinter(QString message, QObject *parent) : ProgressReporter(parent), m_prefix(message), m_lastProgress(0), m_definite(true) { } ProgressPrinter::~ProgressPrinter() { if (m_lastProgress > 0 && m_lastProgress != 100) { std::cerr << "\r\n"; } // std::cerr << "(progress printer dtor)" << std::endl; } bool ProgressPrinter::isDefinite() const { return m_definite; } void ProgressPrinter::setDefinite(bool definite) { m_definite = definite; } void ProgressPrinter::setMessage(QString message) { m_prefix = message; } void ProgressPrinter::setProgress(int progress) { if (progress == m_lastProgress) return; if (progress == 100) std::cerr << "\r\n"; else { std::cerr << "\r" << m_prefix.toStdString() << (m_prefix == "" ? "" : " "); if (m_definite) { std::cerr << progress << "%"; } else { std::cerr << "|/-\\"[progress % 4]; } } m_lastProgress = progress; }