summaryrefslogtreecommitdiff
path: root/browser/errorlogger.cpp
blob: e0c5e8e8f194c3917c342c0c227ce65cdc893962 (plain)
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
/**
 * Copyright (C) 2014, Pelagicore
 *
 * Author: Jonatan PĂ„lsson <jonatan.palsson@pelagicore.com>
 *
 * This file is part of the GENIVI project Browser Proof-Of-Concept
 * For further information, see http://genivi.org/
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 */

#include <QObject>
#include <QDBusContext>
#include <QDebug>
#include <QAbstractNetworkCache>
#include <QNetworkDiskCache>
#include <QDateTime>

#include "errorlogger.h"
#include "../common/browserdefs.h"

errorlogger* errorlogger::m_instance = NULL;

uint errorlogger::getItemsCount(qlonglong timeFrom, qlonglong timeTo)
{
    uint num = 0;
    for (int i = 0; i < m_errors->size(); i++) {
        const conn::brw::ErrorItem *e = &m_errors->at(i);
        if (timeFrom <= e->i64DateTime && timeTo >= e->i64DateTime)
            num++;
    }
    return num;
}
conn::brw::ERROR_IDS errorlogger::getItems(qlonglong timeFrom,
                                           qlonglong timeTo,
                                           conn::brw::ERROR_SORT_TYPE type,
                                           uint startIndex,
                                           uint itemsCount,
                                           conn::brw::ErrorItemList &items)
{
    if (type == conn::brw::EST_DATE_ASCENDING)
        qSort (m_errors->begin(), m_errors->end(), conn::brw::ltError);
    else
        qSort (m_errors->begin(), m_errors->end(), conn::brw::gtError);
    for (int i = 0; i < m_errors->size(); i++){
    }
    for (int i = startIndex; i < m_errors->size(); i++) {
        const conn::brw::ErrorItem e = m_errors->at(i);
        if (timeFrom <= e.i64DateTime && timeTo >= e.i64DateTime) {
            if (items.size() < (int)itemsCount){
                items.append(e);
            }
            else
                break;
        }
    }
    return conn::brw::EID_NO_ERROR;
}


void errorlogger::m_logError(conn::brw::ErrorItem item) {
    m_errors->append(item);
    emit onNewErrorItem(item);
}