mmlibs/mmfw/src/ControllerFramework/RecMmfUtil.cpp
changeset 0 b8ed18f6c07b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mmlibs/mmfw/src/ControllerFramework/RecMmfUtil.cpp	Thu Oct 07 22:34:12 2010 +0100
@@ -0,0 +1,97 @@
+// Copyright (c) 2003-2009 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:
+//
+
+#include "RecMmfUtilBody.h"
+
+
+/**
+ * @internalAll
+ *
+ * constructor for MMF Recognizer utility class
+ */
+CMmfRecognizerUtil::CMmfRecognizerUtil()
+	{
+	}
+
+CMmfRecognizerUtil::~CMmfRecognizerUtil()
+	{
+	delete iBody;
+	}
+
+void CMmfRecognizerUtil::ConstructL()
+	{
+	iBody = CMmfRecognizerUtil::CBody::NewL();
+	}
+
+/**
+ * @internalAll
+ *
+ * Determine whether the supplied data header on its own is recognized,
+ * or the data header plus the file suffix together are recognized,
+ * and if so return the associated MIME type.
+ *
+ * @param	aFileName
+ *			The name of the file
+ * @param	aImageData
+ *          A descriptor containing the header
+ * @param   aMimeType
+ *          A user-supplied descriptor in which the MIME type is returned
+ * @leave   KErrUnderflow 
+ *			Not enough data in descriptor to identify whether it is supported
+ *          by any plugin.
+ * @leave	This method may also leave with one of the system-wide error codes.
+ * @return  EMatchNone if a match was not found.
+ *			EMatchData if a data match was found.
+ *			EMatchName if a data and file suffix match was found.
+ * @post    If recognized, the caller's descriptor is filled with the MIME types
+ */
+EXPORT_C CMmfRecognizerUtil::TMatchLevel CMmfRecognizerUtil::GetMimeTypeL(const TDesC& aFileName, const TDesC8& aImageData, TDes8& aMimeType)
+	{
+	return iBody->GetMimeTypeL(aFileName, aImageData, aMimeType);
+	}
+
+/**
+ * @internalAll
+ *
+ * Static factory constructor. Uses two phase
+ * construction and leaves nothing on the cleanup stack
+ *
+ * @leave KErrNoMemory
+ * @return A pointer to the newly created CMmfRecognizerUtil object
+ *
+ */
+EXPORT_C CMmfRecognizerUtil* CMmfRecognizerUtil::NewL()
+	{
+	CMmfRecognizerUtil* self=new (ELeave) CMmfRecognizerUtil();   
+	CleanupStack::PushL(self);
+	self->ConstructL();
+	CleanupStack::Pop(self);
+	return self;
+	}
+
+/**
+ * @internalAll
+ *
+ * Get all the mime types supported by MMF
+ * @param	aMimeTypes
+ *          A caller-supplied array of descriptors.
+ * @leave	This method may leave with one of the system-wide error codes.
+ * @post    The caller's array is filled with the supported MIME types
+ */
+EXPORT_C void CMmfRecognizerUtil::GetMimeTypesL(CDesC8Array* aMimeTypes)
+	{
+	CMmfRecognizerUtil::CBody::GetMimeTypesL(aMimeTypes);
+	}
+