cryptomgmtlibs/securityutils/source/sectcbutil/miscutil.cpp
changeset 8 35751d3474b7
parent 0 2c201484c85f
child 19 ece3df019add
--- a/cryptomgmtlibs/securityutils/source/sectcbutil/miscutil.cpp	Tue Jul 21 01:04:32 2009 +0100
+++ b/cryptomgmtlibs/securityutils/source/sectcbutil/miscutil.cpp	Thu Sep 10 14:01:51 2009 +0300
@@ -1,84 +1,102 @@
-/*
-* Copyright (c) 2008-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: 
-* Contains miscellaneous utility functions that can be used by any code in security component
-*
-*/
-
-
-
-
-/**
- @file
-*/
-
-#include "miscutil.h"
-
-namespace MiscUtil
-{
-/*
- * Function used to extract lines of text from a buffer. Note that this only works for non-unicode text. It skips
- * over blank lines and the characters '\n' or '\r' are treated as end-of-line markers.
- *
- * @param aBuffer		Input buffer
- * @param aPos		Starting index into aBuffer
- * @return			ETrue if a line was successfully extracted from the buffer, EFalse if end of buffer reached
- */
-
-EXPORT_C TBool ReadNonEmptyLineL(const TDesC8& aBuffer, TInt& aPos, TPtrC8& aLine)
-	{
-	TBool lineIdentified = ETrue;
-	aLine.Set(NULL, 0);
-
-	TInt bufferLength = aBuffer.Length();
-	__ASSERT_ALWAYS(aPos >=0 && aPos <= bufferLength, User::Leave(KErrArgument));
-
-	// Skip blank lines
-	while (aPos < bufferLength)
-		{
-		TChar  c = aBuffer[aPos];
-		if (c != '\r' && c != '\n')
-			{
-			break;
-			}
-		aPos++;
-		}
-
-	// Find the position of the next delimter
-	TInt endPos = aPos;
-	while (endPos < bufferLength)
-		{
-		TChar c = aBuffer[endPos];
-		if (c == '\n' || c == '\r') 	// Find end of line
-			{
-			break;
-			}
-		endPos++;
-		}
-
-	if (endPos != aPos)
-		{
-		TInt tokenLen = endPos - aPos;
-		aLine.Set(&aBuffer[aPos], tokenLen);
-		}
-	else
-		{
-		lineIdentified = EFalse; // End of buffer
-		}
-
-	aPos = endPos;
-	return lineIdentified;
-	}
-
-}	// namespace MiscUtil
+/*
+* Copyright (c) 2008-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: 
+* Contains miscellaneous utility functions that can be used by any code in security component
+*
+*/
+
+
+/**
+ @file
+*/
+
+#include "miscutil.h"
+
+namespace MiscUtil
+{
+/*
+ * Function used to extract lines of text from a buffer. Note that this only works for non-unicode text. It skips
+ * over blank lines and the characters '\n' or '\r' are treated as end-of-line markers.
+ *
+ * @param aBuffer		Input buffer
+ * @param aPos		Starting index into aBuffer
+ * @return			ETrue if a line was successfully extracted from the buffer, EFalse if end of buffer reached
+ */
+
+EXPORT_C TBool ReadNonEmptyLineL(const TDesC8& aBuffer, TInt& aPos, TPtrC8& aLine)
+	{
+	TBool lineIdentified = ETrue;
+	aLine.Set(NULL, 0);
+
+	TInt bufferLength = aBuffer.Length();
+	__ASSERT_ALWAYS(aPos >=0 && aPos <= bufferLength, User::Leave(KErrArgument));
+
+	// Skip blank lines
+	while (aPos < bufferLength)
+		{
+		TChar  c = aBuffer[aPos];
+		if (c != '\r' && c != '\n')
+			{
+			break;
+			}
+		aPos++;
+		}
+
+	// Find the position of the next delimter
+	TInt endPos = aPos;
+	while (endPos < bufferLength)
+		{
+		TChar c = aBuffer[endPos];
+		if (c == '\n' || c == '\r') 	// Find end of line
+			{
+			break;
+			}
+		endPos++;
+		}
+
+	if (endPos != aPos)
+		{
+		TInt tokenLen = endPos - aPos;
+		aLine.Set(&aBuffer[aPos], tokenLen);
+		}
+	else
+		{
+		lineIdentified = EFalse; // End of buffer
+		}
+
+	aPos = endPos;
+	return lineIdentified;
+	}
+
+/*
+ * Recursively deletes all folders in the path (as long as they are empty)
+ *
+ * @param aFs		Connected  filesystem session
+ * @param aPath		Fully qualified path to start the recursive delete
+ */
+EXPORT_C void DeletePathIfEmpty(RFs& aFs, const TDesC& aPath)
+	{
+	HBufC* pathBuf = aPath.AllocLC();
+	TPtr pathPtr(pathBuf->Des());
+	TParsePtr path(pathPtr);
+
+	if (path.PathPresent())
+		{
+		while ((aFs.RmDir(path.DriveAndPath()) == KErrNone) && (path.PopDir() == KErrNone))
+			;
+		}
+	CleanupStack::PopAndDestroy(pathBuf);
+	}
+
+}	// namespace MiscUtil