annotate base/Debug.h @ 862:786ee8d1f30e

Fix handling of negative frame times in returned features from plugin -- we don't handle them, so don't insert them into the model (instead of blowing up)
author Chris Cannam
date Wed, 11 Dec 2013 21:40:27 +0000
parents e802e550a1f2
children 0b15c9328003
rev   line source
Chris@685 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@685 2
Chris@685 3 /*
Chris@685 4 Sonic Visualiser
Chris@685 5 An audio file viewer and annotation editor.
Chris@685 6 Centre for Digital Music, Queen Mary, University of London.
Chris@685 7 This file copyright 2010-2011 Chris Cannam and QMUL.
Chris@685 8
Chris@685 9 This program is free software; you can redistribute it and/or
Chris@685 10 modify it under the terms of the GNU General Public License as
Chris@685 11 published by the Free Software Foundation; either version 2 of the
Chris@685 12 License, or (at your option) any later version. See the file
Chris@685 13 COPYING included with this distribution for more information.
Chris@685 14 */
Chris@685 15
Chris@685 16 #ifndef _DEBUG_H_
Chris@685 17 #define _DEBUG_H_
Chris@685 18
Chris@685 19 #include <QDebug>
Chris@685 20 #include <QTextStream>
Chris@843 21
Chris@685 22 #include <string>
Chris@685 23 #include <iostream>
Chris@685 24
Chris@685 25 class QString;
Chris@685 26 class QUrl;
Chris@685 27
Chris@685 28 QDebug &operator<<(QDebug &, const std::string &);
Chris@685 29 std::ostream &operator<<(std::ostream &, const QString &);
Chris@685 30 std::ostream &operator<<(std::ostream &, const QUrl &);
Chris@685 31
Chris@843 32 using std::cout;
Chris@843 33 using std::cerr;
Chris@843 34 using std::endl;
Chris@843 35
Chris@685 36 #ifndef NDEBUG
Chris@685 37
Chris@685 38 extern QDebug &getSVDebug();
Chris@685 39
Chris@690 40 #define SVDEBUG getSVDebug()
Chris@685 41
Chris@685 42 template <typename T>
Chris@685 43 inline QDebug &operator<<(QDebug &d, const T &t) {
Chris@685 44 QString s;
Chris@685 45 QTextStream ts(&s);
Chris@685 46 ts << t;
Chris@685 47 d << s;
Chris@685 48 return d;
Chris@685 49 }
Chris@685 50
Chris@685 51 #else
Chris@685 52
Chris@685 53 class NoDebug
Chris@685 54 {
Chris@685 55 public:
Chris@685 56 inline NoDebug() {}
Chris@685 57 inline ~NoDebug(){}
Chris@685 58
Chris@685 59 template <typename T>
Chris@685 60 inline NoDebug &operator<<(const T &) { return *this; }
Chris@685 61
Chris@685 62 inline NoDebug &operator<<(QTextStreamFunction) { return *this; }
Chris@685 63 };
Chris@685 64
Chris@690 65 #define SVDEBUG NoDebug()
Chris@685 66
Chris@685 67 #endif /* !NDEBUG */
Chris@685 68
Chris@685 69 #endif /* !_DEBUG_H_ */
Chris@685 70