languageinterworkingfw/servicehandler/src/liwresolver.cpp
changeset 0 99ef825efeca
child 15 947415ec7603
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/languageinterworkingfw/servicehandler/src/liwresolver.cpp	Mon Mar 30 12:51:20 2009 +0300
@@ -0,0 +1,328 @@
+/*
+* Copyright (c) 2003-2005 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:       Implementation of Custom ECom Resolver for LIW.
+*
+*/
+
+
+
+
+
+
+#include "liwresolver.h"
+
+const TInt KMaxDataItemSize = 150;
+_LIT8(KContentTag, "<CONTENT>");
+_LIT8(KOpaqueTag, "<OPAQUE>");
+
+
+CLiwResolver* CLiwResolver::NewL(MPublicRegistry& aRegistry)
+    {
+    return new (ELeave) CLiwResolver(aRegistry);
+    }
+
+
+CLiwResolver::CLiwResolver(MPublicRegistry& aRegistry) : CResolver(aRegistry)
+    {
+    // Nothing to do.
+    }
+
+
+CLiwResolver::~CLiwResolver()
+    {
+    if (iImplementationInfoArray)
+        {
+        iImplementationInfoArray->Reset();  
+        delete iImplementationInfoArray;
+        }
+    }
+
+
+
+TUid CLiwResolver::IdentifyImplementationL(TUid aInterfaceUid, 
+    const TEComResolverParams& aAdditionalParameters) const
+    {
+    RImplInfoArray& implementationsInfo = iRegistry.ListImplementationsL(aInterfaceUid);
+    TUid found = KNullUid;
+
+    if(implementationsInfo.Count())
+        {
+        found = Resolve(implementationsInfo, aAdditionalParameters);
+        }
+
+    return found;
+    }
+
+
+
+RImplInfoArray* CLiwResolver::ListAllL(TUid aInterfaceUid, 
+    const TEComResolverParams& aAdditionalParameters) const
+    {
+    // Use the member var to create the array so that we get proper cleanup behaviour
+    delete iImplementationInfoArray;
+    iImplementationInfoArray = NULL;
+    iImplementationInfoArray = new (ELeave) RImplInfoArray;
+    RImplInfoArray* retList = iImplementationInfoArray;
+
+    RImplInfoArray& fullList = iRegistry.ListImplementationsL(aInterfaceUid);
+
+    const TBool useWildcards = aAdditionalParameters.IsWildcardMatch();
+    TBuf8<KMaxDataItemSize> content;
+    TBuf8<KMaxDataItemSize> opaque;
+
+    ParseInput(aAdditionalParameters.DataType(), content, opaque);
+    const TInt numImps = fullList.Count();
+
+    for (TInt index = 0; index < numImps; ++index)
+        {
+        if (Match(fullList[index]->DataType(), content, useWildcards) &&
+            MatchServiceCmd(fullList[index]->OpaqueData(), opaque))
+            {
+            User::LeaveIfError(retList->Append(fullList[index]));
+            }
+        }
+
+    // Reset the member variable because we are passing ownership back
+    iImplementationInfoArray = NULL;
+
+    return retList;
+    }
+
+
+
+void CLiwResolver::ParseInput(const TDesC8& aParam, TDes8& aContent, TDes8& aOpaque) const
+    {
+    TInt cind = aParam.Find(KContentTag);
+    TInt oind = aParam.Find(KOpaqueTag);
+        
+    if (cind != KErrNotFound)
+        {
+        if (oind != KErrNotFound)
+            {
+            aContent.Copy(aParam.Mid(cind + (&KContentTag)->Length(), 
+                                     oind - (cind + (&KContentTag)->Length())));
+            }
+        else
+            {
+            aContent.Copy(aParam.Mid(cind + (&KContentTag)->Length()));
+            }
+        }
+
+    if (oind != KErrNotFound)
+        {
+        aOpaque.Copy(aParam.Mid(oind + (&KOpaqueTag)->Length()));
+        }
+    }
+
+
+
+TUid CLiwResolver::Resolve(const RImplInfoArray& aImplementationsInfo, 
+    const TEComResolverParams& aAdditionalParameters) const
+    {
+    // Loop through the implementations matching on type
+    const TInt count = aImplementationsInfo.Count();
+
+    for (TInt index = 0; index < count; ++index)
+        {
+        const CImplementationInformation& impData = *aImplementationsInfo[index];
+        // As soon as we get a match on the datatype then return uid of the
+        // implementation found.
+        if (Match(impData.DataType(),                   // The Datatype of this implementation
+            aAdditionalParameters.DataType(),           // The type we are trying to find
+            aAdditionalParameters.IsWildcardMatch()))   // If wildcards should be used
+            {
+            return impData.ImplementationUid();
+            }
+        }
+
+    return KNullUid;
+    }
+
+
+TBool CLiwResolver::Match(const TDesC8& aImplementationType, const TDesC8& aMatchType, 
+    TBool aUseWildcards) const
+    {
+    TInt matchPos = KErrNotFound;
+
+    _LIT8(dataSeparator, "||");
+    const TInt separatorLength = dataSeparator().Length();
+
+    // Look for the section separator marker '||'
+    TInt separatorPos = aImplementationType.Find(dataSeparator);
+
+    if (separatorPos == KErrNotFound)
+        {
+        // Match against the whole string
+        if (aUseWildcards)
+            {
+            matchPos = aImplementationType.Match(aMatchType);
+            }
+        else
+            {
+
+            if (aImplementationType.Compare(aMatchType) == 0)
+                {
+                matchPos = KErrNone;    
+                }
+            }
+        }
+    else
+        {
+        // Find the first section, up to the separator
+        TPtrC8 dataSection = aImplementationType.Left(separatorPos);
+        TPtrC8 remainingData = aImplementationType.Mid(separatorPos + separatorLength);
+
+        // Match against each section in turn
+        while (separatorPos != KErrNotFound)
+            {
+            // Search this section
+            if (aUseWildcards)
+                {          
+                matchPos = dataSection.Match(aMatchType);
+                }
+            else
+                {
+                matchPos = dataSection.Compare(aMatchType);
+                }
+
+            // If we found it then no need to continue, so return
+            if (matchPos != KErrNotFound)
+                {
+                return ETrue;
+                }
+
+            // Move on to the next section
+            separatorPos = remainingData.Find(dataSeparator);
+
+            if (separatorPos != KErrNotFound)
+                {
+                dataSection.Set(remainingData.Left(separatorPos));
+                remainingData.Set(remainingData.Mid(separatorPos + separatorLength));
+                }
+            else
+                {
+                dataSection.Set(remainingData);
+                }   
+            }
+
+        // Check the final part
+        if (aUseWildcards)
+            {
+            matchPos = dataSection.Match(aMatchType);
+            }
+        else
+            {
+            matchPos = dataSection.Compare(aMatchType);
+            }
+
+        }
+
+    return matchPos != KErrNotFound;
+    }
+
+
+
+
+TBool CLiwResolver::MatchServiceCmd(const TDesC8& aOpaqueData, const TDesC8& aServiceCmd) const
+   {
+   _LIT8(KWild,"*");
+   
+   //check for wildcard character *
+   //if yes, return immediatly
+   if(0==aServiceCmd.Compare(KWild))
+   	return ETrue;
+   
+   // Extract List Of service command from OpaQue Data
+    _LIT8(MetadataSeparator, "::");
+    TPtrC8 dataSection;
+    TInt MetadataSeparatorPos = aOpaqueData.Find(MetadataSeparator);
+    if (MetadataSeparatorPos != KErrNotFound)
+    { 
+        dataSection.Set(aOpaqueData.Left(MetadataSeparatorPos));
+    }
+    else
+    {
+        dataSection.Set(aOpaqueData);
+    }
+    
+    _LIT8(dataSeparator, "||");
+    const TInt separatorLength = dataSeparator().Length();
+
+    // Look for the section separator marker '||'
+    TInt separatorPos = dataSection.Find(dataSeparator);
+
+    if (separatorPos == KErrNotFound)
+        {
+         if (aServiceCmd.Compare(dataSection) == 0)
+            {
+            return ETrue;   
+            }
+        }
+    else
+        {
+         // Find the first section, up to the separator
+        TPtrC8 remainingData = dataSection.Mid(separatorPos + separatorLength);
+        dataSection.Set(dataSection.Left(separatorPos));
+
+        // Match against each section in turn
+        while (separatorPos != KErrNotFound)
+            {
+            if (dataSection.Compare(aServiceCmd) == 0)
+                {
+                return ETrue;
+                }
+
+            // Move on to the next section
+            separatorPos = remainingData.Find(dataSeparator);
+
+            if (separatorPos != KErrNotFound)
+                {
+                dataSection.Set(remainingData.Left(separatorPos));
+                remainingData.Set(remainingData.Mid(separatorPos + separatorLength));
+                }
+            else
+                {
+                dataSection.Set(remainingData);
+                }   
+            }
+
+        if (dataSection.Compare(aServiceCmd) == 0)
+            {
+            return ETrue;   
+            }       
+        }
+
+    return EFalse;
+    }
+
+// Map the interface UIDs
+const TImplementationProxy ImplementationTable[] =
+    {
+    IMPLEMENTATION_PROXY_ENTRY(KLiwResolverImplUidValue, CLiwResolver::NewL)
+    };
+
+// Exported proxy for instantiation method resolution
+// ---------------------------------------------------------
+//
+//
+// ---------------------------------------------------------
+//
+EXPORT_C const TImplementationProxy* ImplementationGroupProxy(TInt& aTableCount)
+    {
+    aTableCount = sizeof(ImplementationTable) / sizeof(TImplementationProxy);
+    return ImplementationTable;
+    }
+
+// End of file
+