engine/src/SettingsEngine.cpp
changeset 2 29cda98b007e
child 44 f6f9647922ba
child 60 4d230e702aa3
child 91 87cb33beeae2
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/engine/src/SettingsEngine.cpp	Thu Feb 25 14:29:19 2010 +0000
@@ -0,0 +1,344 @@
+/*
+* Copyright (c) 2007-2010 Sebastian Brannstrom, Lars Persson, EmbedDev AB
+*
+* 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:
+* EmbedDev AB - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+#include <bautils.h>
+#include <s32file.h>
+#include "SettingsEngine.h"
+#include "SoundEngine.h"
+#include "FeedEngine.h"
+#include "ShowEngine.h"
+
+const TUid KMainSettingsStoreUid = {0x1000};
+const TUid KMainSettingsUid = {0x1002};
+const TUid KExtraSettingsUid = {0x2001};
+const TInt KMaxParseBuffer = 1024;
+
+CSettingsEngine::CSettingsEngine(CPodcastModel& aPodcastModel) : iPodcastModel(aPodcastModel)
+	{
+	}
+
+CSettingsEngine::~CSettingsEngine()
+	{
+	TRAP_IGNORE(SaveSettingsL());	
+	}
+
+CSettingsEngine* CSettingsEngine::NewL(CPodcastModel& aPodcastModel)
+	{
+	CSettingsEngine* self = new (ELeave) CSettingsEngine(aPodcastModel);
+	CleanupStack::PushL(self);
+	self->ConstructL();
+	CleanupStack::Pop();
+	return self;
+	}
+
+void CSettingsEngine::ConstructL()
+	{
+	DP("CSettingsEngine::ConstructL BEGIN");
+	// default values
+	iUpdateFeedInterval = KDefaultUpdateFeedInterval;
+	iDownloadAutomatically = EFalse;
+	iUpdateAutomatically = EAutoUpdateOff;
+	iMaxListItems = KDefaultMaxListItems;
+	iIap = 0;
+	
+	// Check that our basedir exist. Create it otherwise;
+	GetDefaultBaseDirL(iBaseDir);
+	DP1("Base dir: %S", &iBaseDir);
+	
+	// load settings
+	TRAPD(loadErr, LoadSettingsL());
+	if (loadErr != KErrNone)
+		{
+		DP1("CSettingsEngine::ConstructL\tLoadSettingsL returned error=%d", loadErr);
+		DP("CSettingsEngine::ConstructL\tUsing default settings instead");
+	
+		TRAPD(error,SaveSettingsL());
+		if (error != KErrNone) 
+			{
+			DP1("error saving: %d", error);
+			}
+		}
+	DP("CSettingsEngine::ConstructL END");	
+	}
+
+void CSettingsEngine::GetDefaultBaseDirL(TDes & /*aBaseDir*/)
+	{
+	CDesCArray* disks = new(ELeave) CDesCArrayFlat(10);
+	CleanupStack::PushL(disks);
+
+	BaflUtils::GetDiskListL(iPodcastModel.FsSession(), *disks);
+	
+	#ifdef __WINS__
+		iBaseDir.Copy(KPodcastDir3);
+		CleanupStack::PopAndDestroy(disks);
+		return;
+	#endif
+	
+	DP1("Disks count: %u", disks->Count());
+	
+	for (int i=0;i<disks->Count();i++) {
+		TPtrC ptr = disks->operator[](i);
+		DP2("Disk %u: %S", i, &ptr);
+	}
+
+	if (disks->Count() == 1)  // if only one drive, use C:
+		{
+		iBaseDir.Copy(KPodcastDir3);
+		} 
+	else // else we use the flash drive
+		{
+		iBaseDir.Copy(KPodcastDir1);
+		DP1("Trying podcast dir '%S'", &iBaseDir);
+				
+		TRAPD(err, BaflUtils::EnsurePathExistsL(iPodcastModel.FsSession(), iBaseDir));
+		
+		if (err != KErrNone)
+			{
+			DP("Leave in EnsurePathExistsL");
+			iBaseDir.Copy(KPodcastDir2);
+			DP1("Trying podcast dir '%S'", &iBaseDir);
+			TRAPD(err, BaflUtils::EnsurePathExistsL(iPodcastModel.FsSession(), iBaseDir));
+			if (err != KErrNone) 
+				{
+				DP("Leave in EnsurePathExistsL");
+				iBaseDir.Copy(KPodcastDir3);
+				DP1("Trying podcast dir '%S'", &iBaseDir);
+				TRAPD(err, BaflUtils::EnsurePathExistsL(iPodcastModel.FsSession(), iBaseDir));
+				if (err != KErrNone)
+					{
+					DP("Leave in EnsurePathExistsL");
+					}
+				}
+			}
+		}
+	CleanupStack::PopAndDestroy(disks);
+	}
+
+void CSettingsEngine::LoadSettingsL()
+	{
+	DP("CSettingsEngine::LoadSettingsL\t Trying to load settings");
+	
+	// Create path for the config file
+	TFileName configPath;
+	configPath.Copy(PrivatePath());
+	configPath.Append(KConfigFile);
+
+	DP1("Checking settings file: %S", &configPath);
+	
+	CDictionaryFileStore* store = CDictionaryFileStore::OpenLC(iPodcastModel.FsSession(), configPath, KMainSettingsStoreUid);
+
+	if( store->IsPresentL(KMainSettingsUid) )
+	{
+		RDictionaryReadStream stream;
+		stream.OpenLC(*store, KMainSettingsUid);
+		
+		TInt len = stream.ReadInt32L();
+		stream.ReadL(iBaseDir, len);
+		iUpdateFeedInterval = stream.ReadInt32L();
+		iUpdateAutomatically = static_cast<TAutoUpdateSetting>(stream.ReadInt32L());
+		iDownloadAutomatically = stream.ReadInt32L();
+		
+		
+		iDownloadSuspended = stream.ReadInt32L(); // was iMaxSimultaneousDownloads
+		iIap = stream.ReadInt32L();		
+		
+		TInt low = stream.ReadInt32L();
+		TInt high = stream.ReadInt32L();
+		iUpdateFeedTime = MAKE_TINT64(high, low);
+		TInt dummy;		
+		dummy = stream.ReadInt32L(); // was iSelectOnlyUnplayed
+		dummy = stream.ReadInt32L(); // was iSeekStepTime
+				
+		CleanupStack::PopAndDestroy(1); // readStream and iniFile
+		DP("CSettingsEngine::LoadSettingsL\t Settings loaded OK");
+	}
+	CleanupStack::PopAndDestroy();// close store
+}
+
+EXPORT_C void CSettingsEngine::SaveSettingsL()
+	{
+	DP("CSettingsEngine::SaveSettingsL BEGIN");
+
+	TFileName configPath;
+	configPath.Copy(PrivatePath());
+	configPath.Append(KConfigFile);
+
+	CDictionaryFileStore* store = CDictionaryFileStore::OpenLC(iPodcastModel.FsSession(), configPath, KMainSettingsStoreUid);
+
+	RDictionaryWriteStream stream;
+	stream.AssignLC(*store, KMainSettingsUid);
+		
+	stream.WriteInt32L(iBaseDir.Length());
+	stream.WriteL(iBaseDir);
+	stream.WriteInt32L(iUpdateFeedInterval);
+	stream.WriteInt32L(iUpdateAutomatically);
+	stream.WriteInt32L(iDownloadAutomatically);
+	stream.WriteInt32L(iDownloadSuspended);
+	stream.WriteInt32L(iIap);
+	
+	stream.WriteInt32L(I64LOW(iUpdateFeedTime.Int64()));
+	stream.WriteInt32L(I64HIGH(iUpdateFeedTime.Int64()));
+	stream.WriteInt32L(0); // was iSelectOnlyUnplayed
+	stream.WriteInt32L(0); // was iSeekStepTime
+
+	stream.CommitL();
+	store->CommitL();
+	CleanupStack::PopAndDestroy(2); // stream and store
+	DP("CSettingsEngine::SaveSettingsL END");
+	}
+
+TFileName CSettingsEngine::DefaultFeedsFileName()
+	{
+	TFileName defaultFeeds;
+	defaultFeeds.Append(PrivatePath());
+	defaultFeeds.Append(KDefaultFeedsFile);
+	DP1("Default feeds file: %S", &defaultFeeds);
+	return defaultFeeds;
+	}
+
+TFileName CSettingsEngine::ImportFeedsFileName()
+	{
+	TFileName importFeeds;
+	importFeeds.Append(BaseDir());
+	importFeeds.Append(KImportFeedsFile);
+	return importFeeds;
+	}
+
+
+TFileName CSettingsEngine::PrivatePath()
+	{
+	TFileName privatePath;
+	iPodcastModel.FsSession().PrivatePath(privatePath);
+	TRAP_IGNORE(BaflUtils::EnsurePathExistsL(iPodcastModel.FsSession(), privatePath));
+	return privatePath;
+	}
+
+TInt CSettingsEngine::MaxListItems() 
+	{
+	return iMaxListItems;
+	}
+
+EXPORT_C TFileName& CSettingsEngine::BaseDir()
+	{
+	return iBaseDir;
+	}
+
+EXPORT_C void CSettingsEngine::SetBaseDir(TFileName& aFileName)
+	{
+	TInt length = aFileName.Length();
+	if (length > 0) 
+		{
+		if (aFileName[length-1] != '\\') 
+			{
+			aFileName.Append(_L("\\"));
+			}
+		}
+	iBaseDir = aFileName;
+	}
+
+EXPORT_C TInt CSettingsEngine::UpdateFeedInterval() 
+	{
+	return iUpdateFeedInterval;
+	}
+
+EXPORT_C void CSettingsEngine::SetUpdateFeedInterval(TInt aInterval)
+	{
+	iUpdateFeedInterval = aInterval;
+	iPodcastModel.FeedEngine().RunFeedTimer();
+	}
+
+EXPORT_C TAutoUpdateSetting CSettingsEngine::UpdateAutomatically() 
+	{
+	if (iUpdateAutomatically == EAutoUpdateOff || 
+		iUpdateAutomatically == EAutoUpdatePeriod1 ||
+		iUpdateAutomatically == EAutoUpdatePeriod2 ||
+		iUpdateAutomatically == EAutoUpdatePeriod3 ||
+		iUpdateAutomatically == EAutoUpdatePeriod4)
+		return iUpdateAutomatically;
+	else
+		return EAutoUpdateOff;
+	}
+
+EXPORT_C void CSettingsEngine::SetUpdateAutomatically(TAutoUpdateSetting aAutoSetting)
+	{
+	iUpdateAutomatically = aAutoSetting;
+	
+	if (aAutoSetting > 0) {
+		SetUpdateFeedInterval(aAutoSetting);
+	}
+	}
+
+EXPORT_C TBool CSettingsEngine::DownloadAutomatically() 
+	{
+	return iDownloadAutomatically;
+	}
+
+EXPORT_C void CSettingsEngine::SetDownloadAutomatically(TBool aDownloadAuto)
+	{
+	iDownloadAutomatically = aDownloadAuto;
+	}
+
+EXPORT_C TTime CSettingsEngine::UpdateFeedTime()
+	{
+	return iUpdateFeedTime;
+	}
+
+EXPORT_C void CSettingsEngine::SetUpdateFeedTime(TTime aUpdateTime)
+	{
+	iUpdateFeedTime = aUpdateTime;
+	iPodcastModel.FeedEngine().RunFeedTimer();
+	}
+
+EXPORT_C TInt CSettingsEngine::SpecificIAP()
+	{
+	if (iIap == 0 || iIap == -1) {
+		return iIap;
+	}
+	
+	for (int i=0;i<iPodcastModel.IAPIds().Count();i++) {
+		if (((TInt)iPodcastModel.IAPIds()[i].iIapId) == (iIap&KUseIAPMask)) {
+			return iIap;
+		}
+
+	}
+	
+	for (int i=0;i<iPodcastModel.SNAPIds().Count();i++) {
+			if (((TInt)iPodcastModel.SNAPIds()[i].iIapId) == (iIap&KUseIAPMask)) {
+				return iIap;
+			}
+
+		}
+	
+	return iPodcastModel.IAPIds()[0].iIapId;
+	}
+
+EXPORT_C void CSettingsEngine::SetSpecificIAP(TInt aIap)
+	{
+	iIap = aIap;
+	}
+
+EXPORT_C TBool CSettingsEngine::DownloadSuspended()
+	{
+	return iDownloadSuspended;
+	}
+
+EXPORT_C void CSettingsEngine::SetDownloadSuspended(TBool aSuspended)
+	{
+	DP1("CSettingsEngine::SetDownloadSuspended, aSuspended=%d", aSuspended);
+	iDownloadSuspended = aSuspended;
+	}