File indexing completed on 2024-04-28 17:02:21
0001 /* 0002 This file is part of Massif Visualizer 0003 0004 Copyright 2012 Milian Wolff <mail@milianw.de> 0005 0006 This program is free software; you can redistribute it and/or 0007 modify it under the terms of the GNU General Public License as 0008 published by the Free Software Foundation; either version 2 of 0009 the License or (at your option) version 3 or any later version 0010 accepted by the membership of KDE e.V. (or its successor approved 0011 by the membership of KDE e.V.), which shall act as a proxy 0012 defined in Section 14 of version 3 of the license. 0013 0014 This program is distributed in the hope that it will be useful, 0015 but WITHOUT ANY WARRANTY; without even the implied warranty of 0016 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 0017 GNU General Public License for more details. 0018 0019 You should have received a copy of the GNU General Public License 0020 along with this program. If not, see <http://www.gnu.org/licenses/>. 0021 */ 0022 0023 0024 #include <KFilterDev> 0025 0026 #include <QCoreApplication> 0027 #include <QElapsedTimer> 0028 #include <QDebug> 0029 0030 #include "massifdata/parser.h" 0031 #include "massifdata/filedata.h" 0032 0033 int main(int argc, char** argv) { 0034 QCoreApplication app(argc, argv); 0035 0036 if (app.arguments().size() != 2) { 0037 qWarning() << "usage: massifparser MASSIF_FILE"; 0038 return 1; 0039 } 0040 0041 const QString file = app.arguments().at(1); 0042 KFilterDev device(file); 0043 if (!device.open(QIODevice::ReadOnly)) { 0044 qWarning() << "could not open file:" << file; 0045 return 2; 0046 } 0047 0048 qDebug() << "parsing file:" << file; 0049 0050 QElapsedTimer t; 0051 t.start(); 0052 0053 Massif::Parser parser; 0054 QScopedPointer<Massif::FileData> data(parser.parse(&device)); 0055 if (!data) { 0056 qWarning() << "failed to parse file:" << file; 0057 qWarning() << parser.errorLineString() << "in line" << parser.errorLine(); 0058 return 3; 0059 } 0060 0061 qDebug() << "finished parsing in" << t.elapsed() << "ms"; 0062 0063 return 0; 0064 }