taskswitcher/utils/src/tsidlist.cpp
author hgs
Wed, 06 Oct 2010 16:00:22 +0300
changeset 125 26079c1bb561
parent 119 50e220be30d1
child 127 7b66bc3c6dc9
permissions -rw-r--r--
201039_01
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(const TArray<TInt>& aArray)
hgs
parents:
diff changeset
    72
    {
hgs
parents:
diff changeset
    73
    for( TInt iter(0); iter < aArray.Count(); ++iter )
hgs
parents:
diff changeset
    74
        {
hgs
parents:
diff changeset
    75
        AppendL( aArray[iter] );
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::AppendL(TInt aId)
hgs
parents:
diff changeset
    81
    {
hgs
parents:
diff changeset
    82
    if( !IsPresent( aId ) )
hgs
parents:
diff changeset
    83
        {
hgs
parents:
diff changeset
    84
        iIds.AppendL( aId );
hgs
parents:
diff changeset
    85
        }
hgs
parents:
diff changeset
    86
    }
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    89
void CTsIdList::Reset()
hgs
parents:
diff changeset
    90
    {
hgs
parents:
diff changeset
    91
    iIds.Reset();
hgs
parents:
diff changeset
    92
    }
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
    95
TInt CTsIdList::Size() const
hgs
parents:
diff changeset
    96
    {
hgs
parents:
diff changeset
    97
    return ( iIds.Count() + 1 ) * sizeof( TInt );
hgs
parents:
diff changeset
    98
    }
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
   101
void CTsIdList::ExternalizeL(RWriteStream &aStream) const
hgs
parents:
diff changeset
   102
    {
hgs
parents:
diff changeset
   103
    aStream.WriteInt32L(iIds.Count());
hgs
parents:
diff changeset
   104
    for( TInt iter(0); iter < iIds.Count(); ++iter )
hgs
parents:
diff changeset
   105
        {
hgs
parents:
diff changeset
   106
        aStream.WriteInt32L(iIds[iter]);
hgs
parents:
diff changeset
   107
        }
hgs
parents:
diff changeset
   108
    }
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
//------------------------------------------------------------------------------
hgs
parents:
diff changeset
   111
void CTsIdList::InternalizeL(RReadStream &aStream)
hgs
parents:
diff changeset
   112
    {
hgs
parents:
diff changeset
   113
    Reset();
hgs
parents:
diff changeset
   114
    const TInt count( aStream.ReadInt32L());
hgs
parents:
diff changeset
   115
    for( TInt iter(0); iter < count; ++iter )
hgs
parents:
diff changeset
   116
        {
hgs
parents:
diff changeset
   117
        AppendL( aStream.ReadInt32L() );
hgs
parents:
diff changeset
   118
        }
hgs
parents:
diff changeset
   119
    }
hgs
parents:
diff changeset
   120
125
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   121
//------------------------------------------------------------------------------
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   122
TBool CTsIdList::operator ==( const CTsIdList& aList) const
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   123
    {
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   124
    TBool retVal(aList.iIds.Count() == iIds.Count());
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   125
    for( TInt offset(0); retVal && offset < iIds.Count(); ++offset )
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   126
        {
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   127
        retVal = (KErrNotFound != aList.iIds.Find(iIds[offset]));
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   128
        }
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   129
    return retVal;
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   130
    }
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   131
//------------------------------------------------------------------------------
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   132
TBool CTsIdList::operator !=( const CTsIdList& aList) const
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   133
    {
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   134
    return !(*this ==aList);
26079c1bb561 201039_01
hgs
parents: 119
diff changeset
   135
    }