File: parser.cpp

package info (click to toggle)
massif-visualizer 0.7.0-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 5,952 kB
  • sloc: cpp: 4,590; xml: 247; sh: 15; makefile: 8
file content (99 lines) | stat: -rw-r--r-- 2,846 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*
   This file is part of Massif Visualizer

   Copyright 2010 Milian Wolff <mail@milianw.de>

   This library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) version 3, or any
   later version accepted by the membership of KDE e.V. (or its
   successor approved by the membership of KDE e.V.), which shall
   act as a proxy defined in Section 6 of version 3 of the license.

   This library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with this library.  If not, see <http://www.gnu.org/licenses/>.
*/

#include "parser.h"

#include "filedata.h"
#include "parserprivate.h"
#include "snapshotitem.h"

#include <QtCore/QIODevice>

using namespace Massif;

Parser::Parser()
    : m_errorLine(-1)
{
}

Parser::~Parser()
{
}

FileData* Parser::parse(QIODevice* file, const QStringList& customAllocators, QAtomicInt* shouldStop)
{
    Q_ASSERT(file->isOpen());
    Q_ASSERT(file->isReadable());

    QScopedPointer<FileData> data(new FileData);

    ParserPrivate p(this, file, data.data(), customAllocators, shouldStop);

    if (p.error()) {
        m_errorLine = p.errorLine();
        m_errorLineString = p.errorLineString();
        return 0;
    } else {
        m_errorLine = -1;
        m_errorLineString.clear();
    }

    // when a massif run gets terminated (^C) the snapshot data might be wrong,
    // hence just always ensure we pick the proper peak ourselves
    if (!data->snapshots().isEmpty()) {
        foreach ( SnapshotItem* snapshot, data->snapshots() ) {
            if (!snapshot->heapTree()) {
                // peak should have detailed info
                continue;
            }
            if (!data->peak() || snapshot->cost() > data->peak()->cost()) {
                data->setPeak(snapshot);
            }
        }
        // still not found? pick any other snapshot
        if (!data->peak()) {
            foreach( SnapshotItem* snapshot, data->snapshots() ) {
                if (!data->peak() || snapshot->cost() > data->peak()->cost()) {
                    data->setPeak(snapshot);
                }
            }
        }
    }
    // peak might still be zero if we have no snapshots, should be handled in the UI then

    return data.take();
}

int Parser::errorLine() const
{
    return m_errorLine;
}

QByteArray Parser::errorLineString() const
{
    return m_errorLineString;
}

void Parser::setProgress(int value)
{
    emit progress(value);
}