Mercurial > hg > svcore
annotate base/Debug.h @ 1268:b7b84ae5f0a7 3.0-integration
Fix fairly obscure mis-canonicalisation in RealTime (leading to non-canonical but still correct values)
author | Chris Cannam |
---|---|
date | Fri, 18 Nov 2016 12:53:21 +0000 |
parents | 8f076d02569a |
children | ad2d3e0a8b7c |
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@1061 | 16 #ifndef SV_DEBUG_H |
Chris@1061 | 17 #define SV_DEBUG_H |
Chris@685 | 18 |
Chris@685 | 19 #include <QDebug> |
Chris@685 | 20 #include <QTextStream> |
Chris@843 | 21 |
Chris@1042 | 22 #include "RealTime.h" |
Chris@871 | 23 |
Chris@685 | 24 #include <string> |
Chris@685 | 25 #include <iostream> |
Chris@1061 | 26 #include <fstream> |
Chris@685 | 27 |
Chris@685 | 28 class QString; |
Chris@685 | 29 class QUrl; |
Chris@685 | 30 |
Chris@685 | 31 QDebug &operator<<(QDebug &, const std::string &); |
Chris@685 | 32 std::ostream &operator<<(std::ostream &, const QString &); |
Chris@685 | 33 std::ostream &operator<<(std::ostream &, const QUrl &); |
Chris@685 | 34 |
Chris@843 | 35 using std::cout; |
Chris@843 | 36 using std::cerr; |
Chris@843 | 37 using std::endl; |
Chris@843 | 38 |
Chris@1061 | 39 class SVDebug { |
Chris@1061 | 40 public: |
Chris@1061 | 41 SVDebug(); |
Chris@1061 | 42 ~SVDebug(); |
Chris@1061 | 43 |
Chris@1061 | 44 template <typename T> |
Chris@1061 | 45 inline SVDebug &operator<<(const T &t) { |
Chris@1061 | 46 if (m_ok) { |
Chris@1061 | 47 if (m_eol) { |
Chris@1061 | 48 m_stream << m_prefix << " "; |
Chris@1061 | 49 } |
Chris@1061 | 50 m_stream << t; |
Chris@1061 | 51 m_eol = false; |
Chris@1061 | 52 } |
Chris@1061 | 53 return *this; |
Chris@1061 | 54 } |
Chris@1061 | 55 |
Chris@1061 | 56 inline SVDebug &operator<<(QTextStreamFunction) { |
Chris@1061 | 57 m_stream << std::endl; |
Chris@1061 | 58 m_eol = true; |
Chris@1061 | 59 return *this; |
Chris@1061 | 60 } |
Chris@1061 | 61 |
Chris@1061 | 62 private: |
Chris@1061 | 63 std::fstream m_stream; |
Chris@1061 | 64 char *m_prefix; |
Chris@1061 | 65 bool m_ok; |
Chris@1061 | 66 bool m_eol; |
Chris@1061 | 67 }; |
Chris@1061 | 68 |
Chris@1061 | 69 extern SVDebug &getSVDebug(); |
Chris@685 | 70 |
Chris@690 | 71 #define SVDEBUG getSVDebug() |
Chris@685 | 72 |
Chris@685 | 73 #endif /* !_DEBUG_H_ */ |
Chris@685 | 74 |