utilities/downloadmanager/src/downloadevent.cpp
author hgs
Fri, 15 Oct 2010 17:30:59 -0400
changeset 16 3c88a81ff781
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16
hgs
parents:
diff changeset
     1
/**
hgs
parents:
diff changeset
     2
   This file is part of CWRT package **
hgs
parents:
diff changeset
     3
hgs
parents:
diff changeset
     4
   Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). **
hgs
parents:
diff changeset
     5
hgs
parents:
diff changeset
     6
   This program is free software: you can redistribute it and/or modify
hgs
parents:
diff changeset
     7
   it under the terms of the GNU (Lesser) General Public License as 
hgs
parents:
diff changeset
     8
   published by the Free Software Foundation, version 2.1 of the License. 
hgs
parents:
diff changeset
     9
   This program is distributed in the hope that it will be useful, but
hgs
parents:
diff changeset
    10
   WITHOUT ANY WARRANTY; without even the implied warranty of 
hgs
parents:
diff changeset
    11
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 
hgs
parents:
diff changeset
    12
   (Lesser) General Public License for more details. You should have 
hgs
parents:
diff changeset
    13
   received a copy of the GNU (Lesser) General Public License along 
hgs
parents:
diff changeset
    14
   with this program. If not, see <http://www.gnu.org/licenses/>.
hgs
parents:
diff changeset
    15
*/
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
#include "downloadevent.h"
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
// private implementation for DownloadEvent
hgs
parents:
diff changeset
    20
class DownloadEventPrivate
hgs
parents:
diff changeset
    21
{
hgs
parents:
diff changeset
    22
    DM_DECLARE_PUBLIC(DownloadEvent);
hgs
parents:
diff changeset
    23
public:
hgs
parents:
diff changeset
    24
    DownloadEventPrivate();
hgs
parents:
diff changeset
    25
    ~DownloadEventPrivate();
hgs
parents:
diff changeset
    26
    DlEventAttributeMap *m_attrMap; // hold <key, value> pairs
hgs
parents:
diff changeset
    27
    DEventType m_type;
hgs
parents:
diff changeset
    28
    int m_id;
hgs
parents:
diff changeset
    29
};
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
DownloadEventPrivate::DownloadEventPrivate()
hgs
parents:
diff changeset
    32
{
hgs
parents:
diff changeset
    33
    m_attrMap = 0;
hgs
parents:
diff changeset
    34
    m_id = -1;
hgs
parents:
diff changeset
    35
}
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
DownloadEventPrivate::~DownloadEventPrivate()
hgs
parents:
diff changeset
    38
{
hgs
parents:
diff changeset
    39
    if(m_attrMap)
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
        delete m_attrMap;
hgs
parents:
diff changeset
    42
        m_attrMap = 0;
hgs
parents:
diff changeset
    43
    }
hgs
parents:
diff changeset
    44
} 
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
DownloadEvent::DownloadEvent(DEventType type, DlEventAttributeMap* attrMap, int id)
hgs
parents:
diff changeset
    47
    :QEvent((Type)type)
hgs
parents:
diff changeset
    48
{
hgs
parents:
diff changeset
    49
    DM_INITIALIZE(DownloadEvent);
hgs
parents:
diff changeset
    50
    priv->m_type = type;
hgs
parents:
diff changeset
    51
    priv->m_attrMap = attrMap;
hgs
parents:
diff changeset
    52
    priv->m_id = id;
hgs
parents:
diff changeset
    53
}
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
DownloadEvent::~DownloadEvent()
hgs
parents:
diff changeset
    56
{
hgs
parents:
diff changeset
    57
    DM_UNINITIALIZE(DownloadEvent);
hgs
parents:
diff changeset
    58
}
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
Q_DECL_EXPORT QVariant DownloadEvent::getAttribute(DownloadEventAttribute attr)
hgs
parents:
diff changeset
    61
{
hgs
parents:
diff changeset
    62
    DM_PRIVATE(DownloadEvent);
hgs
parents:
diff changeset
    63
    bool exists = (priv->m_attrMap) && (priv->m_attrMap->contains(attr));
hgs
parents:
diff changeset
    64
    if(exists)
hgs
parents:
diff changeset
    65
    {
hgs
parents:
diff changeset
    66
        return priv->m_attrMap->value(attr);
hgs
parents:
diff changeset
    67
    }
hgs
parents:
diff changeset
    68
    else
hgs
parents:
diff changeset
    69
    {
hgs
parents:
diff changeset
    70
        return QVariant();
hgs
parents:
diff changeset
    71
    }
hgs
parents:
diff changeset
    72
}
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
Q_DECL_EXPORT int DownloadEvent::getId()
hgs
parents:
diff changeset
    75
{
hgs
parents:
diff changeset
    76
    DM_PRIVATE(DownloadEvent);
hgs
parents:
diff changeset
    77
    // returns the download id
hgs
parents:
diff changeset
    78
    return priv->m_id;
hgs
parents:
diff changeset
    79
}
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
// private implementation for DownloadManagerEvent   
hgs
parents:
diff changeset
    83
class DownloadManagerEventPrivate
hgs
parents:
diff changeset
    84
{
hgs
parents:
diff changeset
    85
    DM_DECLARE_PUBLIC(DownloadManagerEvent);
hgs
parents:
diff changeset
    86
public:
hgs
parents:
diff changeset
    87
    DownloadManagerEventPrivate();
hgs
parents:
diff changeset
    88
    ~DownloadManagerEventPrivate();
hgs
parents:
diff changeset
    89
    DlManagerEventAttributeMap *m_attrMap;
hgs
parents:
diff changeset
    90
    DEventType type;
hgs
parents:
diff changeset
    91
};
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
DownloadManagerEventPrivate::DownloadManagerEventPrivate()
hgs
parents:
diff changeset
    94
{
hgs
parents:
diff changeset
    95
    m_attrMap = 0;
hgs
parents:
diff changeset
    96
}
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
DownloadManagerEventPrivate::~DownloadManagerEventPrivate()
hgs
parents:
diff changeset
    99
{
hgs
parents:
diff changeset
   100
    if(m_attrMap)
hgs
parents:
diff changeset
   101
    {
hgs
parents:
diff changeset
   102
        delete m_attrMap;
hgs
parents:
diff changeset
   103
        m_attrMap = 0;
hgs
parents:
diff changeset
   104
    }
hgs
parents:
diff changeset
   105
} 
hgs
parents:
diff changeset
   106
hgs
parents:
diff changeset
   107
DownloadManagerEvent::DownloadManagerEvent(DEventType type, DlManagerEventAttributeMap* attrMap)
hgs
parents:
diff changeset
   108
    :QEvent((Type)type)
hgs
parents:
diff changeset
   109
{
hgs
parents:
diff changeset
   110
    DM_INITIALIZE(DownloadManagerEvent);
hgs
parents:
diff changeset
   111
    priv->type = type;
hgs
parents:
diff changeset
   112
    priv->m_attrMap = attrMap;
hgs
parents:
diff changeset
   113
}
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
DownloadManagerEvent::~DownloadManagerEvent()
hgs
parents:
diff changeset
   116
{
hgs
parents:
diff changeset
   117
    DM_UNINITIALIZE(DownloadManagerEvent);
hgs
parents:
diff changeset
   118
}
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
QVariant DownloadManagerEvent::getAttribute(DownloadManagerEventAttribute attr)
hgs
parents:
diff changeset
   121
{
hgs
parents:
diff changeset
   122
    DM_PRIVATE(DownloadManagerEvent);
hgs
parents:
diff changeset
   123
    bool exists = priv->m_attrMap->contains(attr);
hgs
parents:
diff changeset
   124
    if(exists)        
hgs
parents:
diff changeset
   125
    {
hgs
parents:
diff changeset
   126
        return priv->m_attrMap->value(attr);
hgs
parents:
diff changeset
   127
    }
hgs
parents:
diff changeset
   128
    else
hgs
parents:
diff changeset
   129
    {
hgs
parents:
diff changeset
   130
        return QVariant();
hgs
parents:
diff changeset
   131
    }
hgs
parents:
diff changeset
   132
}
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135