utilities/downloadmanager/src/omaddparser.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 "omaddparser.h"
hgs
parents:
diff changeset
    18
#include <QString>
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
const QString nameTag = "name";
hgs
parents:
diff changeset
    21
const QString DDVersionTag = "DDVersion";
hgs
parents:
diff changeset
    22
const QString typeTag = "type";
hgs
parents:
diff changeset
    23
const QString sizeTag = "size";
hgs
parents:
diff changeset
    24
const QString vendorTag = "vendor";
hgs
parents:
diff changeset
    25
const QString descriptionTag = "description";
hgs
parents:
diff changeset
    26
const QString productTag = "product";
hgs
parents:
diff changeset
    27
const QString mediaObjectTag = "mediaObject";
hgs
parents:
diff changeset
    28
const QString progressiveDownloadFlagTag = "progressiveDownloadFlag";
hgs
parents:
diff changeset
    29
const QString serverTag = "server";
hgs
parents:
diff changeset
    30
const QString suppressUserConfirmTag = "suppressUserConfirmation";
hgs
parents:
diff changeset
    31
const QString updatedDDURITag = "updatedDDURI";
hgs
parents:
diff changeset
    32
const QString objectURITag = "objectURI";
hgs
parents:
diff changeset
    33
const QString installNotifyURITag = "installNotifyURI";
hgs
parents:
diff changeset
    34
const QString nextURLTag = "nextURL";
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
// private implementation class
hgs
parents:
diff changeset
    37
class OMADownloadDescParserPrivate {
hgs
parents:
diff changeset
    38
    DM_DECLARE_PUBLIC(OMADownloadDescParser);
hgs
parents:
diff changeset
    39
public:
hgs
parents:
diff changeset
    40
    OMADownloadDescParserPrivate();
hgs
parents:
diff changeset
    41
    ~OMADownloadDescParserPrivate();
hgs
parents:
diff changeset
    42
    OMADownloadDescriptor *m_downloadDesc;
hgs
parents:
diff changeset
    43
    QStack<QString> m_stack;
hgs
parents:
diff changeset
    44
    QString m_characterData;
hgs
parents:
diff changeset
    45
    QString m_errorString;
hgs
parents:
diff changeset
    46
    bool m_isProductTag; // flag to indicate if it is product tag
hgs
parents:
diff changeset
    47
    bool m_isMediaObjTag; // flag to indicate if it is media object tag
hgs
parents:
diff changeset
    48
    OMA2DownloadProduct *m_currProduct;
hgs
parents:
diff changeset
    49
    OMA2DownloadMediaObj *m_currMediaObj;
hgs
parents:
diff changeset
    50
};
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
class OMADownloadDescriptorPrivate {
hgs
parents:
diff changeset
    53
    DM_DECLARE_PUBLIC(OMADownloadDescriptor);
hgs
parents:
diff changeset
    54
public:
hgs
parents:
diff changeset
    55
    OMADownloadDescriptorPrivate();
hgs
parents:
diff changeset
    56
    ~OMADownloadDescriptorPrivate();
hgs
parents:
diff changeset
    57
    QMap<QString, QVariant> m_attrMap;
hgs
parents:
diff changeset
    58
    ProductList m_productList;
hgs
parents:
diff changeset
    59
};
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
class OMA2DownloadProductPrivate {
hgs
parents:
diff changeset
    62
    DM_DECLARE_PUBLIC(OMA2DownloadProduct);
hgs
parents:
diff changeset
    63
public:
hgs
parents:
diff changeset
    64
    OMA2DownloadProductPrivate();
hgs
parents:
diff changeset
    65
    ~OMA2DownloadProductPrivate();
hgs
parents:
diff changeset
    66
    QMap<QString, QVariant> m_productAttrMap;
hgs
parents:
diff changeset
    67
    MediaObjectList m_mediaObjList;
hgs
parents:
diff changeset
    68
};
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
class OMA2DownloadMediaObjPrivate {
hgs
parents:
diff changeset
    71
    DM_DECLARE_PUBLIC(OMA2DownloadMediaObj);
hgs
parents:
diff changeset
    72
public:
hgs
parents:
diff changeset
    73
    QMap<QString, QVariant> m_mediaObjAttrMap;
hgs
parents:
diff changeset
    74
};
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
OMADownloadDescParserPrivate::OMADownloadDescParserPrivate():m_downloadDesc(0)
hgs
parents:
diff changeset
    77
                                                            ,m_isProductTag(false)
hgs
parents:
diff changeset
    78
                                                            ,m_isMediaObjTag(false)
hgs
parents:
diff changeset
    79
                                                            ,m_currProduct(0)
hgs
parents:
diff changeset
    80
                                                            ,m_currMediaObj(0)
hgs
parents:
diff changeset
    81
{ }
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
OMADownloadDescParserPrivate::~OMADownloadDescParserPrivate()
hgs
parents:
diff changeset
    84
{
hgs
parents:
diff changeset
    85
    if (m_downloadDesc) {
hgs
parents:
diff changeset
    86
        delete m_downloadDesc;
hgs
parents:
diff changeset
    87
        m_downloadDesc = 0;
hgs
parents:
diff changeset
    88
    }
hgs
parents:
diff changeset
    89
}
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
OMADownloadDescParser::OMADownloadDescParser()
hgs
parents:
diff changeset
    92
{
hgs
parents:
diff changeset
    93
    DM_INITIALIZE(OMADownloadDescParser);
hgs
parents:
diff changeset
    94
}
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
OMADownloadDescParser::~OMADownloadDescParser()
hgs
parents:
diff changeset
    97
{
hgs
parents:
diff changeset
    98
    DM_UNINITIALIZE(OMADownloadDescParser);
hgs
parents:
diff changeset
    99
}
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
bool OMADownloadDescParser::startDocument()
hgs
parents:
diff changeset
   102
{
hgs
parents:
diff changeset
   103
    DM_PRIVATE(OMADownloadDescParser);
hgs
parents:
diff changeset
   104
    priv->m_downloadDesc = new OMADownloadDescriptor();
hgs
parents:
diff changeset
   105
    return true;
hgs
parents:
diff changeset
   106
}
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
bool OMADownloadDescParser::startElement(const QString&, const QString&, const QString& qName, const QXmlAttributes&)
hgs
parents:
diff changeset
   109
{
hgs
parents:
diff changeset
   110
    DM_PRIVATE(OMADownloadDescParser);
hgs
parents:
diff changeset
   111
    priv->m_characterData = "";
hgs
parents:
diff changeset
   112
    priv->m_stack.push(qName);
hgs
parents:
diff changeset
   113
    if (qName == productTag) {
hgs
parents:
diff changeset
   114
        priv->m_isProductTag = true;
hgs
parents:
diff changeset
   115
        priv->m_currProduct = new OMA2DownloadProduct();
hgs
parents:
diff changeset
   116
        if (priv->m_currProduct) {
hgs
parents:
diff changeset
   117
            priv->m_downloadDesc->addProduct(priv->m_currProduct);
hgs
parents:
diff changeset
   118
            return true;
hgs
parents:
diff changeset
   119
        }
hgs
parents:
diff changeset
   120
        return false;
hgs
parents:
diff changeset
   121
    }
hgs
parents:
diff changeset
   122
    if (qName == mediaObjectTag) {
hgs
parents:
diff changeset
   123
        priv->m_isMediaObjTag = true;
hgs
parents:
diff changeset
   124
        priv->m_currMediaObj = new OMA2DownloadMediaObj();
hgs
parents:
diff changeset
   125
        if (priv->m_currMediaObj) {
hgs
parents:
diff changeset
   126
            priv->m_currProduct->addMediaObject(priv->m_currMediaObj);
hgs
parents:
diff changeset
   127
            return true;
hgs
parents:
diff changeset
   128
        }
hgs
parents:
diff changeset
   129
        return false;
hgs
parents:
diff changeset
   130
    }
hgs
parents:
diff changeset
   131
    return true;
hgs
parents:
diff changeset
   132
}
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
bool OMADownloadDescParser::endElement(const QString&, const QString&, const QString& qName)
hgs
parents:
diff changeset
   135
{
hgs
parents:
diff changeset
   136
    DM_PRIVATE(OMADownloadDescParser);
hgs
parents:
diff changeset
   137
    QString tagName = priv->m_stack.pop();
hgs
parents:
diff changeset
   138
    if (qName == tagName) {
hgs
parents:
diff changeset
   139
        if (tagName == productTag)
hgs
parents:
diff changeset
   140
            priv->m_isProductTag = false; 
hgs
parents:
diff changeset
   141
        else if (tagName == mediaObjectTag)
hgs
parents:
diff changeset
   142
            priv->m_isMediaObjTag = false;
hgs
parents:
diff changeset
   143
        else {
hgs
parents:
diff changeset
   144
            if ( priv->m_characterData != "") {
hgs
parents:
diff changeset
   145
                if (priv->m_isProductTag) {
hgs
parents:
diff changeset
   146
                    if (priv->m_isMediaObjTag) {
hgs
parents:
diff changeset
   147
                        priv->m_currMediaObj->setAttribute(qName, QVariant(priv->m_characterData));
hgs
parents:
diff changeset
   148
                        priv->m_characterData = "";
hgs
parents:
diff changeset
   149
                    } else {
hgs
parents:
diff changeset
   150
                        priv->m_currProduct->setAttribute(qName, QVariant(priv->m_characterData));
hgs
parents:
diff changeset
   151
                        priv->m_characterData = "";
hgs
parents:
diff changeset
   152
                    }
hgs
parents:
diff changeset
   153
                } else {
hgs
parents:
diff changeset
   154
                    priv->m_downloadDesc->setAttribute(qName, QVariant(priv->m_characterData));
hgs
parents:
diff changeset
   155
                    priv->m_characterData = "";
hgs
parents:
diff changeset
   156
                }
hgs
parents:
diff changeset
   157
            }
hgs
parents:
diff changeset
   158
        }
hgs
parents:
diff changeset
   159
    return true;
hgs
parents:
diff changeset
   160
    } else {
hgs
parents:
diff changeset
   161
        priv->m_errorString = QObject::tr("Tag Mismatch. Check content");
hgs
parents:
diff changeset
   162
        return false;
hgs
parents:
diff changeset
   163
    }
hgs
parents:
diff changeset
   164
}
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
bool OMADownloadDescParser::characters(const QString& ch)
hgs
parents:
diff changeset
   167
{
hgs
parents:
diff changeset
   168
    DM_PRIVATE(OMADownloadDescParser);
hgs
parents:
diff changeset
   169
    QString str = ch.trimmed();
hgs
parents:
diff changeset
   170
    if (str != "")
hgs
parents:
diff changeset
   171
        priv->m_characterData += str;
hgs
parents:
diff changeset
   172
    return true;
hgs
parents:
diff changeset
   173
}
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
QString OMADownloadDescParser::errorString() 
hgs
parents:
diff changeset
   176
{
hgs
parents:
diff changeset
   177
    DM_PRIVATE(OMADownloadDescParser);
hgs
parents:
diff changeset
   178
    return priv->m_errorString;
hgs
parents:
diff changeset
   179
}
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
bool OMADownloadDescParser::fatalError(const QXmlParseException &/*exception*/)
hgs
parents:
diff changeset
   182
{
hgs
parents:
diff changeset
   183
    return false;
hgs
parents:
diff changeset
   184
}
hgs
parents:
diff changeset
   185
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
OMADownloadDescriptorPrivate::OMADownloadDescriptorPrivate()
hgs
parents:
diff changeset
   188
{
hgs
parents:
diff changeset
   189
}
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
OMADownloadDescriptorPrivate::~OMADownloadDescriptorPrivate()
hgs
parents:
diff changeset
   192
{
hgs
parents:
diff changeset
   193
    if (!m_productList.isEmpty()) {
hgs
parents:
diff changeset
   194
        for (int i=0; i<m_productList.count(); i++)
hgs
parents:
diff changeset
   195
            delete m_productList[i];
hgs
parents:
diff changeset
   196
     }
hgs
parents:
diff changeset
   197
}
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
OMADownloadDescriptor* OMADownloadDescParser::downloadDescriptor()
hgs
parents:
diff changeset
   200
{
hgs
parents:
diff changeset
   201
    DM_PRIVATE(OMADownloadDescParser);
hgs
parents:
diff changeset
   202
    return priv->m_downloadDesc;
hgs
parents:
diff changeset
   203
}
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
OMADownloadDescriptor::OMADownloadDescriptor()
hgs
parents:
diff changeset
   206
{
hgs
parents:
diff changeset
   207
    DM_INITIALIZE(OMADownloadDescriptor);
hgs
parents:
diff changeset
   208
}
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
OMADownloadDescriptor::~OMADownloadDescriptor()
hgs
parents:
diff changeset
   211
{
hgs
parents:
diff changeset
   212
    DM_UNINITIALIZE(OMADownloadDescriptor);
hgs
parents:
diff changeset
   213
}
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
QVariant OMADownloadDescriptor::getAttribute(OMADownloadAttribute attr)
hgs
parents:
diff changeset
   216
{
hgs
parents:
diff changeset
   217
    DM_PRIVATE(OMADownloadDescriptor);
hgs
parents:
diff changeset
   218
    switch(attr) {
hgs
parents:
diff changeset
   219
    case OMADownloadDescName:
hgs
parents:
diff changeset
   220
        return QVariant(priv->m_attrMap[nameTag]);
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
    case OMADownloadDescVersion:
hgs
parents:
diff changeset
   223
        return QVariant(priv->m_attrMap[DDVersionTag]);
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
    case OMADownloadDescObjectURI:
hgs
parents:
diff changeset
   226
        return QVariant(priv->m_attrMap[objectURITag]);
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
    case OMADownloadDescType:
hgs
parents:
diff changeset
   229
        return QVariant(priv->m_attrMap[typeTag]);
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
    case OMADownloadDescSize:
hgs
parents:
diff changeset
   232
        return QVariant(priv->m_attrMap[sizeTag]);
hgs
parents:
diff changeset
   233
hgs
parents:
diff changeset
   234
    case OMADownloadDescVendor:
hgs
parents:
diff changeset
   235
        return QVariant(priv->m_attrMap[vendorTag]);
hgs
parents:
diff changeset
   236
hgs
parents:
diff changeset
   237
    case OMADownloadDescDescription:
hgs
parents:
diff changeset
   238
        return QVariant(priv->m_attrMap[descriptionTag]);
hgs
parents:
diff changeset
   239
hgs
parents:
diff changeset
   240
    case OMADownloadDescInstallNotifyURI:
hgs
parents:
diff changeset
   241
        return QVariant(priv->m_attrMap[installNotifyURITag]);
hgs
parents:
diff changeset
   242
hgs
parents:
diff changeset
   243
    case OMA2DownloadDescUpdatedDDURI:
hgs
parents:
diff changeset
   244
        return QVariant(priv->m_attrMap[updatedDDURITag]);
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
    case OMADownloadDescNextURL:
hgs
parents:
diff changeset
   247
        return QVariant(priv->m_attrMap[nextURLTag]);
hgs
parents:
diff changeset
   248
hgs
parents:
diff changeset
   249
    default:
hgs
parents:
diff changeset
   250
        return QVariant();
hgs
parents:
diff changeset
   251
    }
hgs
parents:
diff changeset
   252
}
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
void OMADownloadDescriptor::setAttribute(const QString& attrName, const QVariant& value)
hgs
parents:
diff changeset
   255
{
hgs
parents:
diff changeset
   256
    DM_PRIVATE(OMADownloadDescriptor);
hgs
parents:
diff changeset
   257
    priv->m_attrMap[attrName] = value;
hgs
parents:
diff changeset
   258
}
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
QList<OMA2DownloadProduct*> OMADownloadDescriptor::productList()
hgs
parents:
diff changeset
   261
{
hgs
parents:
diff changeset
   262
    DM_PRIVATE(OMADownloadDescriptor);
hgs
parents:
diff changeset
   263
    return (priv->m_productList); 
hgs
parents:
diff changeset
   264
}
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
int OMADownloadDescriptor::productCount()
hgs
parents:
diff changeset
   267
{
hgs
parents:
diff changeset
   268
    DM_PRIVATE(OMADownloadDescriptor);
hgs
parents:
diff changeset
   269
    return priv->m_productList.count();
hgs
parents:
diff changeset
   270
}
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
void OMADownloadDescriptor::addProduct(OMA2DownloadProduct *Obj)
hgs
parents:
diff changeset
   273
{
hgs
parents:
diff changeset
   274
    DM_PRIVATE(OMADownloadDescriptor);
hgs
parents:
diff changeset
   275
    priv->m_productList.append(Obj);
hgs
parents:
diff changeset
   276
}
hgs
parents:
diff changeset
   277
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
OMA2DownloadProductPrivate::OMA2DownloadProductPrivate()
hgs
parents:
diff changeset
   280
{ }
hgs
parents:
diff changeset
   281
hgs
parents:
diff changeset
   282
OMA2DownloadProductPrivate::~OMA2DownloadProductPrivate()
hgs
parents:
diff changeset
   283
{
hgs
parents:
diff changeset
   284
    if (!m_mediaObjList.isEmpty()) {
hgs
parents:
diff changeset
   285
        for (int i=0; i<m_mediaObjList.count(); i++)
hgs
parents:
diff changeset
   286
            delete m_mediaObjList[i];
hgs
parents:
diff changeset
   287
     }
hgs
parents:
diff changeset
   288
}
hgs
parents:
diff changeset
   289
hgs
parents:
diff changeset
   290
OMA2DownloadProduct::OMA2DownloadProduct()
hgs
parents:
diff changeset
   291
{
hgs
parents:
diff changeset
   292
    DM_INITIALIZE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   293
}
hgs
parents:
diff changeset
   294
hgs
parents:
diff changeset
   295
OMA2DownloadProduct::~OMA2DownloadProduct()
hgs
parents:
diff changeset
   296
{
hgs
parents:
diff changeset
   297
    DM_UNINITIALIZE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   298
}
hgs
parents:
diff changeset
   299
hgs
parents:
diff changeset
   300
QVariant OMA2DownloadProduct::getAttribute(OMADownloadAttribute attr)
hgs
parents:
diff changeset
   301
{
hgs
parents:
diff changeset
   302
    DM_PRIVATE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   303
    switch(attr) {
hgs
parents:
diff changeset
   304
    case OMA2DownloadDescProductName:
hgs
parents:
diff changeset
   305
        return QVariant(priv->m_productAttrMap[nameTag]);
hgs
parents:
diff changeset
   306
hgs
parents:
diff changeset
   307
    case OMA2DownloadDescProductInstallNotifyURI:
hgs
parents:
diff changeset
   308
        return QVariant(priv->m_productAttrMap[installNotifyURITag]);
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
    case OMA2DownloadDescProductSuppressConfirmation:
hgs
parents:
diff changeset
   311
        return QVariant(priv->m_productAttrMap[suppressUserConfirmTag]);
hgs
parents:
diff changeset
   312
hgs
parents:
diff changeset
   313
    default:
hgs
parents:
diff changeset
   314
        return QVariant();
hgs
parents:
diff changeset
   315
    }
hgs
parents:
diff changeset
   316
}
hgs
parents:
diff changeset
   317
hgs
parents:
diff changeset
   318
void OMA2DownloadProduct::setAttribute(const QString& attrName, const QVariant& value)
hgs
parents:
diff changeset
   319
{
hgs
parents:
diff changeset
   320
    DM_PRIVATE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   321
    priv->m_productAttrMap[attrName] = value;
hgs
parents:
diff changeset
   322
}
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
QList<OMA2DownloadMediaObj*> OMA2DownloadProduct::mediaObjList()
hgs
parents:
diff changeset
   325
{
hgs
parents:
diff changeset
   326
    DM_PRIVATE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   327
    return (priv->m_mediaObjList);
hgs
parents:
diff changeset
   328
}
hgs
parents:
diff changeset
   329
hgs
parents:
diff changeset
   330
int OMA2DownloadProduct::mediaCount()
hgs
parents:
diff changeset
   331
{
hgs
parents:
diff changeset
   332
    DM_PRIVATE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   333
    return priv->m_mediaObjList.count();
hgs
parents:
diff changeset
   334
}
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
void OMA2DownloadProduct::addMediaObject(OMA2DownloadMediaObj *Obj)
hgs
parents:
diff changeset
   337
{
hgs
parents:
diff changeset
   338
    DM_PRIVATE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   339
    priv->m_mediaObjList.append(Obj);
hgs
parents:
diff changeset
   340
}
hgs
parents:
diff changeset
   341
hgs
parents:
diff changeset
   342
qint64 OMA2DownloadProduct::albumSize()
hgs
parents:
diff changeset
   343
{
hgs
parents:
diff changeset
   344
    DM_PRIVATE(OMA2DownloadProduct);
hgs
parents:
diff changeset
   345
    qint64 albumSize = 0;
hgs
parents:
diff changeset
   346
    for(int i=0; i<priv->m_mediaObjList.count(); i++)
hgs
parents:
diff changeset
   347
        albumSize = albumSize + priv->m_mediaObjList[i]->getAttribute(OMA2DownloadDescMediaObjSize).toInt();
hgs
parents:
diff changeset
   348
    return (albumSize);
hgs
parents:
diff changeset
   349
}
hgs
parents:
diff changeset
   350
hgs
parents:
diff changeset
   351
hgs
parents:
diff changeset
   352
OMA2DownloadMediaObj::OMA2DownloadMediaObj()
hgs
parents:
diff changeset
   353
{
hgs
parents:
diff changeset
   354
    DM_INITIALIZE(OMA2DownloadMediaObj);
hgs
parents:
diff changeset
   355
}
hgs
parents:
diff changeset
   356
hgs
parents:
diff changeset
   357
OMA2DownloadMediaObj::~OMA2DownloadMediaObj()
hgs
parents:
diff changeset
   358
{
hgs
parents:
diff changeset
   359
    DM_UNINITIALIZE(OMA2DownloadMediaObj);
hgs
parents:
diff changeset
   360
}
hgs
parents:
diff changeset
   361
hgs
parents:
diff changeset
   362
QVariant OMA2DownloadMediaObj::getAttribute(OMADownloadAttribute attr)
hgs
parents:
diff changeset
   363
{
hgs
parents:
diff changeset
   364
    DM_PRIVATE(OMA2DownloadMediaObj);
hgs
parents:
diff changeset
   365
    switch(attr) {
hgs
parents:
diff changeset
   366
    case OMA2DownloadDescMediaObjName:
hgs
parents:
diff changeset
   367
        return QVariant(priv->m_mediaObjAttrMap[nameTag]);
hgs
parents:
diff changeset
   368
hgs
parents:
diff changeset
   369
    case OMA2DownloadDescMediaObjType:
hgs
parents:
diff changeset
   370
        return QVariant(priv->m_mediaObjAttrMap[typeTag]);
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
    case OMA2DownloadDescMediaObjSize:
hgs
parents:
diff changeset
   373
        return QVariant(priv->m_mediaObjAttrMap[sizeTag]);
hgs
parents:
diff changeset
   374
        
hgs
parents:
diff changeset
   375
    case OMA2DownloadDescMediaObjProgressiveDl:
hgs
parents:
diff changeset
   376
        return QVariant(priv->m_mediaObjAttrMap[progressiveDownloadFlagTag]);
hgs
parents:
diff changeset
   377
hgs
parents:
diff changeset
   378
    case OMA2DownloadDescMediaObjServer:
hgs
parents:
diff changeset
   379
        return QVariant(priv->m_mediaObjAttrMap[serverTag]);
hgs
parents:
diff changeset
   380
hgs
parents:
diff changeset
   381
    case OMA2DownloadDescMediaObjInstallNotifyURI:
hgs
parents:
diff changeset
   382
        return QVariant(priv->m_mediaObjAttrMap[installNotifyURITag]); // need to add the rest of private attributes like license, text, order when implemented in future.
hgs
parents:
diff changeset
   383
hgs
parents:
diff changeset
   384
    case OMA2DownloadDescMediaObjSuppressConfirmation:
hgs
parents:
diff changeset
   385
        return QVariant(priv->m_mediaObjAttrMap[suppressUserConfirmTag]);
hgs
parents:
diff changeset
   386
hgs
parents:
diff changeset
   387
    default:
hgs
parents:
diff changeset
   388
        return QVariant();
hgs
parents:
diff changeset
   389
    }   
hgs
parents:
diff changeset
   390
}
hgs
parents:
diff changeset
   391
hgs
parents:
diff changeset
   392
void OMA2DownloadMediaObj::setAttribute(const QString& attrName, const QVariant& value)
hgs
parents:
diff changeset
   393
{
hgs
parents:
diff changeset
   394
    DM_PRIVATE(OMA2DownloadMediaObj);
hgs
parents:
diff changeset
   395
    priv->m_mediaObjAttrMap[attrName] = value;
hgs
parents:
diff changeset
   396
}