sl@0: /* sl@0: * Copyright (c) 2001-2009 Nokia Corporation and/or its subsidiary(-ies). sl@0: * All rights reserved. sl@0: * This component and the accompanying materials are made available sl@0: * under the terms of the License "Eclipse Public License v1.0" sl@0: * which accompanies this distribution, and is available sl@0: * at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: * sl@0: * Initial Contributors: sl@0: * Nokia Corporation - initial contribution. sl@0: * sl@0: * Contributors: sl@0: * sl@0: * Description: sl@0: * Code for the sequence-encoding class sl@0: * sl@0: */ sl@0: sl@0: sl@0: #include "panic.h" sl@0: sl@0: #include sl@0: sl@0: const TInt KArrayGranularity = 5; sl@0: sl@0: sl@0: EXPORT_C CASN1EncSequence* CASN1EncSequence::NewLC() sl@0: { sl@0: CASN1EncSequence* self = new (ELeave) CASN1EncSequence(); sl@0: CleanupStack::PushL(self); sl@0: self->ConstructL(); sl@0: return self; sl@0: } sl@0: sl@0: EXPORT_C CASN1EncSequence* CASN1EncSequence::NewL() sl@0: { sl@0: CASN1EncSequence* self = NewLC(); sl@0: CleanupStack::Pop(self); sl@0: return self; sl@0: } sl@0: sl@0: EXPORT_C CASN1EncSequence::~CASN1EncSequence() sl@0: { sl@0: iChildren.ResetAndDestroy(); sl@0: } sl@0: sl@0: sl@0: CASN1EncSequence::CASN1EncSequence() sl@0: : CASN1EncContainer(EASN1Sequence), iChildren(KArrayGranularity) sl@0: { sl@0: } sl@0: sl@0: sl@0: void CASN1EncSequence::AddChildIntL(const CASN1EncBase* aChild) sl@0: { sl@0: User::LeaveIfError(iChildren.Append(aChild)); sl@0: } sl@0: sl@0: sl@0: TUint CASN1EncSequence::NumChildren() const sl@0: { sl@0: return iChildren.Count(); sl@0: } sl@0: sl@0: sl@0: const CASN1EncBase& CASN1EncSequence::Child(const TUint aIndex) const sl@0: { sl@0: return *iChildren[aIndex]; sl@0: } sl@0: sl@0: EXPORT_C CASN1EncSet* CASN1EncSet::NewLC() sl@0: { sl@0: CASN1EncSet* self = new (ELeave) CASN1EncSet(); sl@0: CleanupStack::PushL(self); sl@0: self->ConstructL(); sl@0: return self; sl@0: } sl@0: sl@0: EXPORT_C CASN1EncSet* CASN1EncSet::NewL() sl@0: { sl@0: CASN1EncSet* self = NewLC(); sl@0: CleanupStack::Pop(self); sl@0: return self; sl@0: } sl@0: sl@0: EXPORT_C CASN1EncSet::~CASN1EncSet() sl@0: { sl@0: iChildren.ResetAndDestroy(); sl@0: } sl@0: sl@0: sl@0: CASN1EncSet::CASN1EncSet() sl@0: : CASN1EncContainer(EASN1Set), iChildren(KArrayGranularity) sl@0: { sl@0: } sl@0: sl@0: sl@0: void CASN1EncSet::AddChildIntL(const CASN1EncBase* aChild) sl@0: { sl@0: User::LeaveIfError(iChildren.Append(aChild)); sl@0: } sl@0: sl@0: sl@0: TUint CASN1EncSet::NumChildren() const sl@0: { sl@0: return iChildren.Count(); sl@0: } sl@0: sl@0: sl@0: const CASN1EncBase& CASN1EncSet::Child(const TUint aIndex) const sl@0: { sl@0: return *iChildren[aIndex]; sl@0: }