diff -r 000000000000 -r 094583676ce7 PECengine/AttributeLibrary2/SrcWVAttributes/CPEngWVOnlineStatusConstruct.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/PECengine/AttributeLibrary2/SrcWVAttributes/CPEngWVOnlineStatusConstruct.cpp Thu Dec 17 08:41:52 2009 +0200 @@ -0,0 +1,293 @@ +/* +* Copyright (c) 2004 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: Online Status attribute model implementation. +* +*/ + +// INCLUDE FILES +#include "CPEngWVAttributeConstructBase.h" +#include "CPEngWVAttributeModelBase.h" +#include "CPEngWVOnlineStatusConstruct.h" + +#include "MPEngXMLSerializer.h" +#include "MPEngXMLParser.h" + +#include +#include +#include + + + +// DATA TYPES +/** + * Online status CSP name table. + * + * @since 3.0 + */ +const TWVCspAttributeNameEntry KOnlineStatusCspNameTable[] = + { + { + EWVCspV11, + LIT_AS_DESC8_PTR( KOnlineStatusXMLTag ), + LIT_AS_DESC8_PTR( KPresenceSubListAttributesNS ) + }, + { + EWVCspV12, + LIT_AS_DESC8_PTR( KOnlineStatusXMLTag ), + LIT_AS_DESC8_PTR( KPresenceSubListAttributesNS_CSP12 ) + } + }; + + +const TInt KOnlineStatusCspNameTableCount = sizeof( KOnlineStatusCspNameTable ) / sizeof( TWVCspAttributeNameEntry ); + + + + +// =============== CPEngWVOnlineStatusConstruct MEMBER FUNCTIONS =============== + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusConstruct +// C++ constructor can NOT contain any code, that +// might leave. +// ----------------------------------------------------------------------------- +// +CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusConstruct( TPEngWVCspVersion aCurrentCspVer ) + : CPEngWVAttributeConstructBase( aCurrentCspVer, + KOnlineStatusCspNameTable, + KOnlineStatusCspNameTableCount ) + { + } + + +// Destructor +CPEngWVOnlineStatusConstruct::~CPEngWVOnlineStatusConstruct() + { + } + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::NewAttributeInstanceLC() +// ----------------------------------------------------------------------------- +// +MPEngPresenceAttrModelTypeImp* CPEngWVOnlineStatusConstruct::NewAttributeInstanceLC( + TBool aUserOwnAttribute ) const + { + CPEngWVOnlineStatusModel* model = new ( ELeave ) CPEngWVOnlineStatusModel( + aUserOwnAttribute ); + CleanupStack::PushL( model ); + model->ResetDataL(); + return model; + } + + + + +// ================= CPEngWVOnlineStatusModel MEMBER FUNCTIONS ================= + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel +// C++ constructor can NOT contain any code, that +// might leave. +// ----------------------------------------------------------------------------- +// +CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::CPEngWVOnlineStatusModel( + TBool aUserOwnAttribute ) + : CPEngWVAttributeModelBase( aUserOwnAttribute ) + { + } + + +// Destructor +CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::~CPEngWVOnlineStatusModel() + { + } + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::SetDataL() +// ----------------------------------------------------------------------------- +// +TBool CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::SetDataL( TInt* aIntData, + const TDesC8* /*a8Data*/, + const TDesC16* /*a16Data*/, + TInt aField, + TInt aGroup ) + { + if ( aIntData && + ( aGroup == KPEngDefaultAttrValueGroup ) && + ( aField == EPEngOnlineStatus ) ) + { + //check the data value + switch ( *aIntData ) + { + case EPEngOnlineStatusOffline: + case EPEngOnlineStatusOnline: + { + iOnlineStatus = static_cast ( *aIntData ); + break; + } + + default: + { + __AssertAttrEnumValueOutOfBoundsL(); + break; + } + } + + return ETrue; + } + + return EFalse; + } + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::GetData() +// ----------------------------------------------------------------------------- +// +TBool CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::GetData( TInt* aIntData, + TPtrC8* /*a8Data*/, + TPtrC16* /*a16Data*/, + TInt aField, + TInt aGroup ) const + { + if ( aIntData && + ( aGroup == KPEngDefaultAttrValueGroup ) && + ( aField == EPEngUsrAvailability ) ) + { + *aIntData = iOnlineStatus; + return ETrue; + } + + return EFalse; + } + + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::EncodeDataToXmlL() +// ----------------------------------------------------------------------------- +// +void CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::EncodeDataToXmlL( + MPEngXMLSerializer& aSerializer ) const + { + aSerializer.StartTagL( KPresenceValueXMLTag ); + { + switch ( iOnlineStatus ) + { + case EPEngOnlineStatusOnline: + { + aSerializer.RawValueL( KXMLValueTrue ); + break; + } + case EPEngOnlineStatusOffline: + default: + { + aSerializer.RawValueL( KXMLValueFalse ); + break; + } + } + } + aSerializer.EndTagL( KPresenceValueXMLTag ); + } + + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::DecodeDataFromXmlL() +// ----------------------------------------------------------------------------- +// +void CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::DecodeDataFromXmlL( + MPEngXMLParser& aParser, + const TDesC8& aValueBlock ) + { + if ( aParser.DecodeL( aValueBlock, KPresenceValueXMLTag, EFalse ) ) + { + if ( aParser.ResultL().CompareF( KXMLValueTrue ) == 0 ) + { + iOnlineStatus = EPEngOnlineStatusOnline; + } + else + { + iOnlineStatus = EPEngOnlineStatusOffline; + } + } + } + + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::ResetDataL() +// ----------------------------------------------------------------------------- +// +void CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::ResetDataL() + { + iOnlineStatus = EPEngOnlineStatusOffline; + } + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::DataExternalizeSize() +// ----------------------------------------------------------------------------- +// +TInt CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::DataExternalizeSize() const + { + return 1; //Online Status is stored to 8 bit + } + + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::ExternalizeDataL() +// ----------------------------------------------------------------------------- +// +void CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::ExternalizeDataL( + RWriteStream& aStream ) const + { + aStream.WriteInt8L( iOnlineStatus ); + } + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::InternalizeDataL() +// ----------------------------------------------------------------------------- +// +void CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::InternalizeDataL( + RReadStream& aStream ) + { + iOnlineStatus = static_cast ( aStream.ReadInt8L() ); + } + + +// ----------------------------------------------------------------------------- +// CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::HandleNetworkSessionStateChangeL() +// ----------------------------------------------------------------------------- +// +void CPEngWVOnlineStatusConstruct::CPEngWVOnlineStatusModel::HandleNetworkSessionStateChangeL( + TBool aSessionOpen ) + { + if ( aSessionOpen ) + { + iOnlineStatus = EPEngOnlineStatusOnline; + } + + else + { + iOnlineStatus = EPEngOnlineStatusOffline; + } + } + + +// End of File