taskswitcher/utils/src/tsidlist.cpp
author hgs
Mon, 18 Oct 2010 10:44:15 +0300
changeset 127 7b66bc3c6dc9
parent 125 26079c1bb561
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
119
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
*
hgs
parents:
diff changeset
    14
* Description: 
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
#include "tsidlist.h"
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    20
CTsIdList* CTsIdList::NewLC()
hgs
parents:
diff changeset
    21
    {
hgs
parents:
diff changeset
    22
    CTsIdList* self = new(ELeave)CTsIdList();
hgs
parents:
diff changeset
    23
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    24
    return self;
hgs
parents:
diff changeset
    25
    }
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    28
CTsIdList* CTsIdList::NewL()
hgs
parents:
diff changeset
    29
    {
hgs
parents:
diff changeset
    30
    CTsIdList* self = CTsIdList::NewLC();
hgs
parents:
diff changeset
    31
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
    32
    return self;
hgs
parents:
diff changeset
    33
    }
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    36
CTsIdList* CTsIdList::NewLC(RReadStream& aStream)
hgs
parents:
diff changeset
    37
    {
hgs
parents:
diff changeset
    38
    CTsIdList* self = CTsIdList::NewLC();
hgs
parents:
diff changeset
    39
    aStream >> (*self);
hgs
parents:
diff changeset
    40
    return self;
hgs
parents:
diff changeset
    41
    }
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    44
CTsIdList::CTsIdList()
hgs
parents:
diff changeset
    45
    {
hgs
parents:
diff changeset
    46
    //No implementation required
hgs
parents:
diff changeset
    47
    }
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    50
CTsIdList::~CTsIdList()
hgs
parents:
diff changeset
    51
    {
hgs
parents:
diff changeset
    52
    iIds.Reset();
hgs
parents:
diff changeset
    53
    }
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    56
TBool CTsIdList::IsPresent( TInt aId ) const
hgs
parents:
diff changeset
    57
    {
hgs
parents:
diff changeset
    58
    return KErrNotFound != iIds.Find(aId);
hgs
parents:
diff changeset
    59
    }
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    62
void CTsIdList::AppendL(const TInt aArray[], TInt aSize )
hgs
parents:
diff changeset
    63
    {
hgs
parents:
diff changeset
    64
    for( TInt iter(0); iter < aSize; ++iter )
hgs
parents:
diff changeset
    65
        {
hgs
parents:
diff changeset
    66
        AppendL( aArray[iter] );
hgs
parents:
diff changeset
    67
        }
hgs
parents:
diff changeset
    68
    }
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    71
void CTsIdList::AppendL(TInt aId)
hgs
parents:
diff changeset
    72
    {
hgs
parents:
diff changeset
    73
    if( !IsPresent( aId ) )
hgs
parents:
diff changeset
    74
        {
hgs
parents:
diff changeset
    75
        iIds.AppendL( aId );
hgs
parents:
diff changeset
    76
        }
hgs
parents:
diff changeset
    77
    }
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    80
void CTsIdList::Reset()
hgs
parents:
diff changeset
    81
    {
hgs
parents:
diff changeset
    82
    iIds.Reset();
hgs
parents:
diff changeset
    83
    }
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    86
TInt CTsIdList::Size() const
hgs
parents:
diff changeset
    87
    {
hgs
parents:
diff changeset
    88
    return ( iIds.Count() + 1 ) * sizeof( TInt );
hgs
parents:
diff changeset
    89
    }
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    92
void CTsIdList::ExternalizeL(RWriteStream &aStream) const
hgs
parents:
diff changeset
    93
    {
hgs
parents:
diff changeset
    94
    aStream.WriteInt32L(iIds.Count());
hgs
parents:
diff changeset
    95
    for( TInt iter(0); iter < iIds.Count(); ++iter )
hgs
parents:
diff changeset
    96
        {
hgs
parents:
diff changeset
    97
        aStream.WriteInt32L(iIds[iter]);
hgs
parents:
diff changeset
    98
        }
hgs
parents:
diff changeset
    99
    }
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
   102
void CTsIdList::InternalizeL(RReadStream &aStream)
hgs
parents:
diff changeset
   103
    {
hgs
parents:
diff changeset
   104
    Reset();
hgs
parents:
diff changeset
   105
    const TInt count( aStream.ReadInt32L());
hgs
parents:
diff changeset
   106
    for( TInt iter(0); iter < count; ++iter )
hgs
parents:
diff changeset
   107
        {
hgs
parents:
diff changeset
   108
        AppendL( aStream.ReadInt32L() );
hgs
parents:
diff changeset
   109
        }
hgs
parents:
diff changeset
   110
    }
hgs
parents:
diff changeset
   111
125
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   112
//------------------------------------------------------------------------------
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   113
TBool CTsIdList::operator ==( const CTsIdList& aList) const
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   114
    {
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   115
    TBool retVal(aList.iIds.Count() == iIds.Count());
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   116
    for( TInt offset(0); retVal && offset < iIds.Count(); ++offset )
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   117
        {
127
hgs
parents: 125
diff changeset
   118
        retVal = aList.IsPresent(iIds[offset]);
125
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   119
        }
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   120
    return retVal;
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   121
    }
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   122
//------------------------------------------------------------------------------
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   123
TBool CTsIdList::operator !=( const CTsIdList& aList) const
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   124
    {
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   125
    return !(*this ==aList);
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   126
    }