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 }