view base/ProgressPrinter.cpp @ 509:6066bde1c126

* Cut back on the locking and general workload in FFTDataServer::getMagnitudes(). This stuff is far too complicated!
author Chris Cannam
date Mon, 08 Dec 2008 11:15:13 +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;
}