activityfw/activitydatabase/s60/src/hsserializer.cpp
author hgs
Fri, 30 Apr 2010 15:22:08 +0300
changeset 93 82b66994846c
parent 92 782e3408c2ab
child 94 dbb8300717f7
permissions -rw-r--r--
201017
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
89
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
92
hgs
parents: 90
diff changeset
    14
* Description:
89
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
#include "hsserializer.h"
93
hgs
parents: 92
diff changeset
    18
#include <s32mem.h>
89
hgs
parents:
diff changeset
    19
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    20
//
hgs
parents:
diff changeset
    21
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    22
//
92
hgs
parents: 90
diff changeset
    23
RBuf8 &operator <<(RBuf8 &dst, const QPixmap &src)
89
hgs
parents:
diff changeset
    24
{
hgs
parents:
diff changeset
    25
    QByteArray buffer;
hgs
parents:
diff changeset
    26
    QDataStream stream(&buffer, QIODevice::WriteOnly);
92
hgs
parents: 90
diff changeset
    27
89
hgs
parents:
diff changeset
    28
    QT_TRYCATCH_LEAVING(stream << src);
hgs
parents:
diff changeset
    29
    const int dataLength(buffer.length());
92
hgs
parents: 90
diff changeset
    30
    const unsigned char *dataPtr(reinterpret_cast<const unsigned char *>(buffer.constData()));
hgs
parents: 90
diff changeset
    31
    if (dst.MaxLength() < dataLength) {
89
hgs
parents:
diff changeset
    32
        dst.ReAllocL(dataLength);
hgs
parents:
diff changeset
    33
    }
hgs
parents:
diff changeset
    34
    dst.Copy(dataPtr, dataLength);
hgs
parents:
diff changeset
    35
    return dst;
hgs
parents:
diff changeset
    36
}
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    39
//
hgs
parents:
diff changeset
    40
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    41
//
92
hgs
parents: 90
diff changeset
    42
QPixmap &operator <<(QPixmap &dst, const TDesC8 &src)
89
hgs
parents:
diff changeset
    43
{
92
hgs
parents: 90
diff changeset
    44
    QByteArray buffer(QByteArray::fromRawData(reinterpret_cast<const char *>(src.Ptr()),
hgs
parents: 90
diff changeset
    45
                                              src.Length()) );
hgs
parents: 90
diff changeset
    46
89
hgs
parents:
diff changeset
    47
    QDataStream stream(&buffer, QIODevice::ReadOnly);
hgs
parents:
diff changeset
    48
    QT_TRYCATCH_LEAVING(stream >> dst);
hgs
parents:
diff changeset
    49
    return dst;
hgs
parents:
diff changeset
    50
}
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    53
//
hgs
parents:
diff changeset
    54
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    55
//
92
hgs
parents: 90
diff changeset
    56
RBuf8 &operator <<(RBuf8 &dst, const QVariantHash &src)
89
hgs
parents:
diff changeset
    57
{
hgs
parents:
diff changeset
    58
    QByteArray buffer;
hgs
parents:
diff changeset
    59
    QDataStream stream(&buffer, QIODevice::WriteOnly);
92
hgs
parents: 90
diff changeset
    60
89
hgs
parents:
diff changeset
    61
    QT_TRYCATCH_LEAVING(stream << src);
92
hgs
parents: 90
diff changeset
    62
    const int dataLength(buffer.length());
hgs
parents: 90
diff changeset
    63
    const unsigned char *dataPtr(reinterpret_cast<const unsigned char *>(buffer.constData()));
hgs
parents: 90
diff changeset
    64
    if (dst.MaxLength() < dataLength) {
hgs
parents: 90
diff changeset
    65
        dst.ReAllocL(dataLength);
89
hgs
parents:
diff changeset
    66
    }
92
hgs
parents: 90
diff changeset
    67
    dst.Copy(dataPtr, dataLength);
89
hgs
parents:
diff changeset
    68
    return dst;
hgs
parents:
diff changeset
    69
}
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    72
//
hgs
parents:
diff changeset
    73
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    74
//
92
hgs
parents: 90
diff changeset
    75
QVariantHash &operator <<(QVariantHash &dst, const TDesC8 &src)
89
hgs
parents:
diff changeset
    76
{
92
hgs
parents: 90
diff changeset
    77
    QByteArray buffer(QByteArray::fromRawData(reinterpret_cast<const char *>(src.Ptr()),
hgs
parents: 90
diff changeset
    78
                                               src.Length()) );
hgs
parents: 90
diff changeset
    79
89
hgs
parents:
diff changeset
    80
    QDataStream stream(&buffer, QIODevice::ReadOnly);
hgs
parents:
diff changeset
    81
    QT_TRYCATCH_LEAVING(stream >> dst);
hgs
parents:
diff changeset
    82
    return dst;
hgs
parents:
diff changeset
    83
}
92
hgs
parents: 90
diff changeset
    84
hgs
parents: 90
diff changeset
    85
// -----------------------------------------------------------------------------
hgs
parents: 90
diff changeset
    86
//
hgs
parents: 90
diff changeset
    87
// -----------------------------------------------------------------------------
hgs
parents: 90
diff changeset
    88
//
hgs
parents: 90
diff changeset
    89
RBuf8 &operator <<(RBuf8 &dst, const QList<QVariantHash>& src)
hgs
parents: 90
diff changeset
    90
{
hgs
parents: 90
diff changeset
    91
    QByteArray buffer;
hgs
parents: 90
diff changeset
    92
    QDataStream stream(&buffer, QIODevice::WriteOnly);
hgs
parents: 90
diff changeset
    93
hgs
parents: 90
diff changeset
    94
    QT_TRYCATCH_LEAVING(stream << src);
hgs
parents: 90
diff changeset
    95
hgs
parents: 90
diff changeset
    96
    if (dst.MaxLength() < buffer.length()) {
hgs
parents: 90
diff changeset
    97
        dst.ReAllocL(buffer.length());
hgs
parents: 90
diff changeset
    98
    }
hgs
parents: 90
diff changeset
    99
    dst.Copy(reinterpret_cast<const TUint8 *>(buffer.data()), buffer.length());
hgs
parents: 90
diff changeset
   100
    return dst;
hgs
parents: 90
diff changeset
   101
}
hgs
parents: 90
diff changeset
   102
hgs
parents: 90
diff changeset
   103
// -----------------------------------------------------------------------------
hgs
parents: 90
diff changeset
   104
//
hgs
parents: 90
diff changeset
   105
// -----------------------------------------------------------------------------
hgs
parents: 90
diff changeset
   106
//
hgs
parents: 90
diff changeset
   107
QList<QVariantHash>& operator <<(QList<QVariantHash>& dst, const TDesC8 &src)
hgs
parents: 90
diff changeset
   108
{
93
hgs
parents: 92
diff changeset
   109
    dst.clear();
hgs
parents: 92
diff changeset
   110
    
hgs
parents: 92
diff changeset
   111
    QVariantHash item;
hgs
parents: 92
diff changeset
   112
    TRAP_IGNORE(
hgs
parents: 92
diff changeset
   113
    RDesReadStream srcStream(src);
hgs
parents: 92
diff changeset
   114
    int numOfItems(srcStream.ReadInt32L());
hgs
parents: 92
diff changeset
   115
    int bufferSize;
hgs
parents: 92
diff changeset
   116
    
hgs
parents: 92
diff changeset
   117
    RBuf8 tmpBuff;
hgs
parents: 92
diff changeset
   118
    CleanupClosePushL(tmpBuff);
hgs
parents: 92
diff changeset
   119
    for (int iter(0); iter < numOfItems; ++iter) {
hgs
parents: 92
diff changeset
   120
        bufferSize = srcStream.ReadInt32L();
hgs
parents: 92
diff changeset
   121
        if (tmpBuff.MaxLength() < bufferSize) {
hgs
parents: 92
diff changeset
   122
            tmpBuff.ReAllocL(bufferSize);
hgs
parents: 92
diff changeset
   123
        }
hgs
parents: 92
diff changeset
   124
        item.clear();
hgs
parents: 92
diff changeset
   125
        if (0 < bufferSize) {
hgs
parents: 92
diff changeset
   126
            srcStream.ReadL(tmpBuff, bufferSize);
hgs
parents: 92
diff changeset
   127
            item << tmpBuff;
hgs
parents: 92
diff changeset
   128
        }
hgs
parents: 92
diff changeset
   129
        dst.append(item);
hgs
parents: 92
diff changeset
   130
    }
hgs
parents: 92
diff changeset
   131
    CleanupStack::PopAndDestroy(&tmpBuff));
92
hgs
parents: 90
diff changeset
   132
    return dst;
hgs
parents: 90
diff changeset
   133
}