diff -r 675a964f4eb5 -r 35751d3474b7 contentmgmt/contentaccessfwfordrm/source/f32agent/f32agentdata.cpp --- a/contentmgmt/contentaccessfwfordrm/source/f32agent/f32agentdata.cpp Tue Jul 21 01:04:32 2009 +0100 +++ b/contentmgmt/contentaccessfwfordrm/source/f32agent/f32agentdata.cpp Thu Sep 10 14:01:51 2009 +0300 @@ -1,224 +1,268 @@ -/* -* Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "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: -* -*/ - - -#include -#include "f32agentdata.h" -#include "f32defaultattributes.h" -#include "virtualpath.h" -#include "f32agentui.h" - -using namespace ContentAccess; - -CF32AgentData* CF32AgentData::NewL(const TVirtualPathPtr& aVirtualPath, TContentShareMode aShareMode) - { - CF32AgentData* self = new (ELeave) CF32AgentData; - CleanupStack::PushL(self); - self->ConstructL(aVirtualPath, aShareMode); - CleanupStack::Pop(self); - return self; - } - -CF32AgentData* CF32AgentData::NewL(RFile& aFile, const TDesC& aUniqueId) - { - CF32AgentData* self = new (ELeave) CF32AgentData; - CleanupStack::PushL(self); - self->ConstructL(aFile, aUniqueId); - CleanupStack::Pop(self); - return self; - } - -CF32AgentData::CF32AgentData() - { - } - -CF32AgentData::~CF32AgentData() - { - // Tidy up RFile and RFs - iFile.Close(); - if(iVirtualPath) // opened by name - { - iFs.Close(); - } - - delete iVirtualPath; - } - -void CF32AgentData::ConstructL(const TVirtualPathPtr& aVirtualPath, TContentShareMode aShareMode) - { - iVirtualPath = CVirtualPath::NewL(aVirtualPath); - - // Check that the client hasn't specified some incorrect UniqueId - User::LeaveIfError(TF32DefaultAttributes::CheckUniqueId(aVirtualPath.UniqueId())); - - TUint mode = TF32DefaultAttributes::GetFileMode(aShareMode); - User::LeaveIfError(iFs.Connect()); - - // Make the file session shareable - User::LeaveIfError(iFs.ShareAuto()); - - User::LeaveIfError(iFile.Open(iFs, aVirtualPath.URI(), mode)); - } - -void CF32AgentData::ConstructL(RFile& aFile, const TDesC& aUniqueId) - { - TInt pos = 0; - - // Check that the client hasn't specified some incorrect UniqueId - User::LeaveIfError(TF32DefaultAttributes::CheckUniqueId(aUniqueId)); - - // When creating a CData from a file handle we must duplicate the file handle - // before doing anything - User::LeaveIfError(iFile.Duplicate(aFile)); - User::LeaveIfError(iFile.Seek(ESeekStart, pos)); // reset to start of file - } - -void CF32AgentData::DataSizeL(TInt &aSize) - { - User::LeaveIfError(iFile.Size(aSize)); - } - -TInt CF32AgentData::EvaluateIntent(TIntent /*aIntent*/) - { - return KErrNone; - } - -TInt CF32AgentData::ExecuteIntent(TIntent /*aIntent*/) - { - return KErrNone; - } - -TInt CF32AgentData::Read(TDes8& aDes) - { - return iFile.Read(aDes); - } - -TInt CF32AgentData::Read(TDes8& aDes,TInt aLength) - { - return iFile.Read(aDes,aLength); - } - -void CF32AgentData::Read(TDes8& aDes,TRequestStatus& aStatus) - { - iFile.Read(aDes, aStatus); - } - -void CF32AgentData::Read(TDes8& aDes, - TInt aLength, - TRequestStatus& aStatus) - { - iFile.Read(aDes, aLength, aStatus); - } - -TInt CF32AgentData::Read(TInt aPos, TDes8& aDes, - TInt aLength, - TRequestStatus& aStatus) - { - iFile.Read(aPos, aDes, aLength, aStatus); - return KErrNone; - } - -void CF32AgentData::ReadCancel(TRequestStatus& aStatus) -{ - iFile.ReadCancel(aStatus); -} - -TInt CF32AgentData::Seek(TSeek aMode, TInt& aPos) - { - return iFile.Seek(aMode, aPos); - } - -TInt CF32AgentData::SetProperty(TAgentProperty aProperty, TInt aValue) - { - - if(aProperty==EAgentPropertyAgentUI) - // should only pass type EAgentPropertyAgentUI - { - CF32AgentUi* ui = NULL; - - // get a pointer to the UI - TRAPD(err, ui = &AgentUiL()); - if(err) - { - return err; - } - return ui->SetProperty(aProperty, aValue); - } - else - { - return KErrCANotSupported; - } - } - -TInt CF32AgentData::GetAttribute(TInt aAttribute, TInt& aValue) - { - if(iVirtualPath) - { - return TF32DefaultAttributes::GetAttribute(aAttribute, aValue, iVirtualPath->URI()); - } - else - { - return TF32DefaultAttributes::GetAttribute(aAttribute, aValue, iFile); - } - } - -TInt CF32AgentData::GetAttributeSet(RAttributeSet& aAttributeSet) - { - if(iVirtualPath) - { - return TF32DefaultAttributes::GetAttributeSet(aAttributeSet, iVirtualPath->URI()); - } - else - { - return TF32DefaultAttributes::GetAttributeSet(aAttributeSet, iFile); - } - - } - -TInt CF32AgentData::GetStringAttribute(TInt aAttribute, TDes& aValue) - { - if(iVirtualPath) - { - return TF32DefaultAttributes::GetStringAttribute(aAttribute, aValue, iVirtualPath->URI()); - } - else - { - return TF32DefaultAttributes::GetStringAttribute(aAttribute, aValue, iFile); - } - } - -TInt CF32AgentData::GetStringAttributeSet(RStringAttributeSet& aStringAttributeSet) - { - if(iVirtualPath) - { - return TF32DefaultAttributes::GetStringAttributeSet(aStringAttributeSet, iVirtualPath->URI()); - } - else - { - return TF32DefaultAttributes::GetStringAttributeSet(aStringAttributeSet, iFile); - } - } - -CF32AgentUi& CF32AgentData::AgentUiL() - { - if(!iAgentUi) - { - // load agent UI from f32AgentUi.dll - iAgentUi = TF32AgentUiFactory::CreateF32AgentUiL(); - } - return *iAgentUi; - } +/* +* Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of the License "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: +* +*/ + + +#include +#include "f32agentdata.h" +#include "f32defaultattributes.h" +#include +#include +#include + +using namespace ContentAccess; + +CF32AgentData* CF32AgentData::NewL(const TVirtualPathPtr& aVirtualPath, TContentShareMode aShareMode) + { + CF32AgentData* self = new (ELeave) CF32AgentData; + CleanupStack::PushL(self); + self->ConstructL(aVirtualPath, aShareMode); + CleanupStack::Pop(self); + return self; + } + +CF32AgentData* CF32AgentData::NewL(RFile& aFile, const TDesC& aUniqueId) + { + CF32AgentData* self = new (ELeave) CF32AgentData; + CleanupStack::PushL(self); + self->ConstructL(aFile, aUniqueId); + CleanupStack::Pop(self); + return self; + } + +CF32AgentData::CF32AgentData() + { + } + +CF32AgentData::~CF32AgentData() + { + // Tidy up RFile and RFs + iFile.Close(); + if(iVirtualPath) // opened by name + { + iFs.Close(); + } + + delete iVirtualPath; + } + +void CF32AgentData::ConstructL(const TVirtualPathPtr& aVirtualPath, TContentShareMode aShareMode) + { + iVirtualPath = CVirtualPath::NewL(aVirtualPath); + + // Check that the client hasn't specified some incorrect UniqueId + User::LeaveIfError(TF32DefaultAttributes::CheckUniqueId(aVirtualPath.UniqueId())); + + TUint mode = TF32DefaultAttributes::GetFileMode(aShareMode); + User::LeaveIfError(iFs.Connect()); + + // Make the file session shareable + User::LeaveIfError(iFs.ShareAuto()); + + User::LeaveIfError(iFile.Open(iFs, aVirtualPath.URI(), mode)); + } + +void CF32AgentData::ConstructL(RFile& aFile, const TDesC& aUniqueId) + { +#ifdef SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + TInt64 pos = 0; +#else + TInt pos = 0; +#endif // SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + + // Check that the client hasn't specified some incorrect UniqueId + User::LeaveIfError(TF32DefaultAttributes::CheckUniqueId(aUniqueId)); + + // When creating a CData from a file handle we must duplicate the file handle + // before doing anything + User::LeaveIfError(iFile.Duplicate(aFile)); + User::LeaveIfError(iFile.Seek(ESeekStart, pos)); // reset to start of file + } + +void CF32AgentData::DataSizeL(TInt &aSize) + { +#ifdef SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + TInt64 size; + User::LeaveIfError(iFile.Size(size)); + aSize=size; +#else + User::LeaveIfError(iFile.Size(aSize)); +#endif //SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + } + +#ifdef SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API +void CF32AgentData::DataSize64L(TInt64 &aSize) + { + User::LeaveIfError(iFile.Size(aSize)); + } +#endif //SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + +TInt CF32AgentData::EvaluateIntent(TIntent /*aIntent*/) + { + return KErrNone; + } + +TInt CF32AgentData::ExecuteIntent(TIntent /*aIntent*/) + { + return KErrNone; + } + +TInt CF32AgentData::Read(TDes8& aDes) + { + return iFile.Read(aDes); + } + +TInt CF32AgentData::Read(TDes8& aDes,TInt aLength) + { + return iFile.Read(aDes,aLength); + } + +void CF32AgentData::Read(TDes8& aDes,TRequestStatus& aStatus) + { + iFile.Read(aDes, aStatus); + } + +void CF32AgentData::Read(TDes8& aDes, + TInt aLength, + TRequestStatus& aStatus) + { + iFile.Read(aDes, aLength, aStatus); + } + +TInt CF32AgentData::Read(TInt aPos, TDes8& aDes, + TInt aLength, + TRequestStatus& aStatus) + { + iFile.Read(aPos, aDes, aLength, aStatus); + return KErrNone; + } + +#ifdef SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API +TInt CF32AgentData::Read64(TInt64 aPos, TDes8& aDes, + TInt aLength, + TRequestStatus& aStatus) + { + iFile.Read(aPos, aDes, aLength, aStatus); + return KErrNone; + } +#endif // SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + +void CF32AgentData::ReadCancel(TRequestStatus& aStatus) + { + iFile.ReadCancel(aStatus); + } + +TInt CF32AgentData::Seek(TSeek aMode, TInt& aPos) + { +#ifdef SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + TInt64 pos = aPos; + TInt offset = iFile.Seek(aMode, pos); + aPos = I64INT(pos); +#else + TInt offset = iFile.Seek(aMode, aPos); +#endif // SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + return offset; + } + +#ifdef SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API +TInt CF32AgentData::Seek64(TSeek aMode, TInt64& aPos) + { + return iFile.Seek(aMode, aPos); + } +#endif // SYMBIAN_ENABLE_64_BIT_FILE_SERVER_API + + +TInt CF32AgentData::SetProperty(TAgentProperty aProperty, TInt aValue) + { + + if(aProperty==EAgentPropertyAgentUI) + // should only pass type EAgentPropertyAgentUI + { + CF32AgentUi* ui = NULL; + + // get a pointer to the UI + TRAPD(err, ui = &AgentUiL()); + if(err) + { + return err; + } + return ui->SetProperty(aProperty, aValue); + } + else + { + return KErrCANotSupported; + } + } + +TInt CF32AgentData::GetAttribute(TInt aAttribute, TInt& aValue) + { + if(iVirtualPath) + { + return TF32DefaultAttributes::GetAttribute(aAttribute, aValue, iVirtualPath->URI()); + } + else + { + return TF32DefaultAttributes::GetAttribute(aAttribute, aValue, iFile); + } + } + +TInt CF32AgentData::GetAttributeSet(RAttributeSet& aAttributeSet) + { + if(iVirtualPath) + { + return TF32DefaultAttributes::GetAttributeSet(aAttributeSet, iVirtualPath->URI()); + } + else + { + return TF32DefaultAttributes::GetAttributeSet(aAttributeSet, iFile); + } + + } + +TInt CF32AgentData::GetStringAttribute(TInt aAttribute, TDes& aValue) + { + if(iVirtualPath) + { + return TF32DefaultAttributes::GetStringAttribute(aAttribute, aValue, iVirtualPath->URI()); + } + else + { + return TF32DefaultAttributes::GetStringAttribute(aAttribute, aValue, iFile); + } + } + +TInt CF32AgentData::GetStringAttributeSet(RStringAttributeSet& aStringAttributeSet) + { + if(iVirtualPath) + { + return TF32DefaultAttributes::GetStringAttributeSet(aStringAttributeSet, iVirtualPath->URI()); + } + else + { + return TF32DefaultAttributes::GetStringAttributeSet(aStringAttributeSet, iFile); + } + } + +CF32AgentUi& CF32AgentData::AgentUiL() + { + if(!iAgentUi) + { + // load agent UI from f32AgentUi.dll + iAgentUi = TF32AgentUiFactory::CreateF32AgentUiL(); + } + return *iAgentUi; + } +