activityfw/activitydatabase/s60/src/hsserializer.cpp
author hgs
Fri, 16 Apr 2010 14:45:49 +0300
changeset 92 782e3408c2ab
parent 90 0e41c72311af
child 93 82b66994846c
permissions -rw-r--r--
201015
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"
hgs
parents:
diff changeset
    18
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
{
hgs
parents: 90
diff changeset
   109
    QByteArray buffer(QByteArray::fromRawData(reinterpret_cast<const char *>(src.Ptr()),
hgs
parents: 90
diff changeset
   110
                                              src.Length()));
hgs
parents: 90
diff changeset
   111
hgs
parents: 90
diff changeset
   112
    QDataStream stream(&buffer, QIODevice::ReadOnly);
hgs
parents: 90
diff changeset
   113
    QT_TRYCATCH_LEAVING(stream >> dst);
hgs
parents: 90
diff changeset
   114
    return dst;
hgs
parents: 90
diff changeset
   115
}