telephonyutils/dial/src/DIAL.CPP
changeset 0 3553901f7fa8
child 24 6638e7f4bd8f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/telephonyutils/dial/src/DIAL.CPP	Tue Feb 02 01:41:59 2010 +0200
@@ -0,0 +1,476 @@
+// Copyright (c) 1997-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:
+//
+
+/**
+ @file
+ @publishedAll
+ @deprecated 9.1
+*/
+
+#include "DIALUTIL.H"
+
+/**
+@file
+@internalComponent
+*/
+const TInt KCharacterLength=1;
+
+
+// TelephoneNumber General Parser
+
+/**
+@deprecated 9.1
+*/
+TInt DialUtil::GeneralParse(
+			 TDialString& aDialString,
+			 const TDialLocation & aDialLocation , 
+			 const TChargeCard& aChargeCard ,
+			 const TDesC& aNumberToDial,
+			 TParseMode aParseMode,
+ 			 TCityDialOptions aOption )
+	{
+	
+	TPhoneNumber aPhoneNumToParse(aNumberToDial) ;
+
+//	if ( !DialUtil::PhoneFormatOK (aPhoneNumToParse) )
+//	return (KErrNotSupported) ;
+
+	// analysing dial string
+	TDialNumber dialNumber (aPhoneNumToParse,aDialLocation,aChargeCard) ;
+   
+	aDialString.Zero(); // restart the dial string 
+	if (aDialLocation.IsDisableCallWaitingCode() )
+		{
+		if (!DialUtil::AppendDialString(aDialString,aDialLocation.DisableCallWaitingCode()))
+			return (KErrOverflow) ;
+		}
+	if (aDialLocation.IsWaitForDialingTone() && aParseMode==EForDialing)
+		{
+		if (!DialUtil::AppendDialString(aDialString,KCharW))
+			return (KErrOverflow) ;
+		}
+	if ( aDialLocation.IsDialOutRequired() ) 
+		{
+		if (aParseMode==EForDialing)
+			{
+			if (aDialLocation.IsPbxUsePulseDial())
+				{
+				if (!DialUtil::AppendDialString(aDialString,KCharP))
+					return (KErrOverflow) ;
+				}
+			else
+				{
+				if (!DialUtil::AppendDialString(aDialString,KCharT))
+					return (KErrOverflow) ;
+				}
+			}
+
+		if (dialNumber.CallType() == ELocalCall)
+			{
+			if (!DialUtil::AppendDialString(aDialString,aDialLocation.DialOutLocalCode()))
+				return (KErrOverflow) ;
+			}
+		else
+			{
+			if (!DialUtil::AppendDialString(aDialString,aDialLocation.DialOutLongDistanceCode()))
+				return (KErrOverflow) ;
+			}
+
+		TUint commas = aDialLocation.PauseAfterDialout() ;
+		if (commas > 0)		// we should add a comma if the last character in the string is not already a comma
+			{
+			TBuf<KCharacterLength> lastChar=aDialString.Right(KCharacterLength);
+			if (lastChar.Locate(KCharComma)!=KErrNone)		// if not a comma
+				{
+				if (!DialUtil::AppendDialString(aDialString,KCharComma))
+					return (KErrOverflow) ;
+				}	
+			}
+
+	/*	while (commas--)
+			{
+			if (!DialUtil::AppendDialString(aDialString,KCharComma))
+				return (KErrOverflow) ;
+			}
+	
+	  */}
+
+	if (aDialLocation.IsWaitForProceedTone() && aParseMode==EForDialing)
+		{
+		if (!DialUtil::AppendDialString(aDialString,KCharW))
+			return (KErrOverflow) ;
+		}
+
+	if ( !aDialLocation.IsDialOutRequired() || 
+		 aDialLocation.IsUsePulseDial () != aDialLocation.IsPbxUsePulseDial() )
+		{
+		if (aParseMode==EForDialing)
+			{
+			if (!aDialLocation.IsUsePulseDial ())
+				{
+				if (!DialUtil::AppendDialString(aDialString,KCharT))
+					return (KErrOverflow) ;
+				}
+			else
+				{
+				if (!DialUtil::AppendDialString(aDialString,KCharP))
+					return (KErrOverflow) ;
+				}
+			}
+		}
+	
+	if ( aDialLocation.IsMobile() && aChargeCard.ValidateChargeCardInfo() )
+		return (KErrNotSupported) ;
+		// do not know what to do with this scenario-currently not available !
+    
+	else if ( aDialLocation.IsMobile() && !aChargeCard.ValidateChargeCardInfo() )
+	{
+		aDialString.Zero(); // restart the dial string 
+        if (aDialLocation.IsReturnPhoneNumberWithPlusFormat()) // fix for release 012
+        {
+  			if (!DialUtil::AppendDialString(aDialString,KCharPlus))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.NatCode()))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.AreaCode()))
+				return (KErrOverflow) ;
+        }
+        else
+        {
+		if ( dialNumber.IsNatCode() )  // Nat code supplied
+			{
+			if ( dialNumber.NatCode() != aDialLocation.NatCode() )
+				{// making interNat code 
+				if (!DialUtil::AppendDialString(aDialString,dialNumber.IntlPrefCode()))
+					return (KErrOverflow) ;
+
+				if (!DialUtil::AppendDialString(aDialString,dialNumber.NatCode()))
+					return (KErrOverflow) ;
+				}
+			else // call within the same country
+				{
+				if (!DialUtil::AppendDialString(aDialString,dialNumber.NatPrefCode()))
+					return (KErrOverflow) ;
+				}
+			}
+		else // must dial from the same country
+			{
+			if (!DialUtil::AppendDialString(aDialString,aDialLocation.NatPrefCode()))
+				return (KErrOverflow) ;
+			}
+
+		if ( dialNumber.IsAreaCode() )  // area code supplied
+		{
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.AreaCode()))
+				return (KErrOverflow) ;
+		}
+		else
+		{
+			if (!DialUtil::AppendDialString(aDialString,aDialLocation.AreaCode()))
+				return (KErrOverflow) ;
+		}
+     }
+		if (!DialUtil::AppendDialString(aDialString,dialNumber.PhoneNumber()) )
+			return (KErrOverflow) ;
+		
+	}
+	
+	//----------------------------------------------------
+	// Not a mobile phone and not using chargecard
+	//----------------------------------------------------
+	else if ( !aDialLocation.IsMobile() && !aChargeCard.ValidateChargeCardInfo() ) 
+	{
+        if (aDialLocation.IsReturnPhoneNumberWithPlusFormat()) // fix for release 012
+        {
+  			 if (!DialUtil::AppendDialString(aDialString,KCharPlus))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.NatCode()))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.AreaCode()))
+				return (KErrOverflow) ;
+    		if (!DialUtil::AppendDialString(aDialString,dialNumber.PhoneNumber()) )
+	    		return (KErrOverflow) ;
+        }
+        else
+        {
+
+        if (dialNumber.CallType() == ELocalCall)
+			{
+			// option to allow areacode 
+			if ( aOption==EDialCityAllowDuplicateAreaCode )
+				{
+				if (!DialUtil::AppendDialString(aDialString,dialNumber.NatPrefCode()))
+					return (KErrOverflow) ;
+				if (!DialUtil::AppendDialString(aDialString,dialNumber.AreaCode()))
+					return (KErrOverflow) ;
+				}
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.PhoneNumber()))
+				return (KErrOverflow) ;
+			}
+        if (dialNumber.CallType() == ELongDistanceCall) 
+			{
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.NatPrefCode()))
+				return (KErrOverflow) ;
+
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.AreaCode()))
+				return (KErrOverflow) ;
+
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.PhoneNumber()))
+				return (KErrOverflow) ;
+			}
+        if (dialNumber.CallType() == EInternationalCall) 
+			{
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.IntlPrefCode()))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.NatCode()))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.AreaCode()))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.PhoneNumber()))
+				return (KErrOverflow) ;
+			}
+        }
+	}
+	else if ( !aDialLocation.IsMobile() && aChargeCard.ValidateChargeCardInfo() ) 
+		{
+		TChargeCardRule iRule=dialNumber.RuleToUse() ;
+
+		for ( TInt i=0 ; i < iRule.Length() ; i++) 
+			{ // for each character in rule 
+			switch (iRule[i] ) 
+				{
+			case KCharEUpper: // copy country code into aDialStr 
+			case KCharELower:
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.NatCode()))
+				return (KErrOverflow) ;
+			break;
+			case KCharFUpper: // copy STD code into aDialStr 
+			case KCharFLower:
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.AreaCode()))
+				return (KErrOverflow) ;
+            break;
+			case KCharGUpper: // copy local phone number into aDialStr 
+			case KCharGLower:
+			if (!DialUtil::AppendDialString(aDialString,dialNumber.PhoneNumber()))
+				return (KErrOverflow) ;
+            break;
+
+			case KCharHUpper: // copy chargecard account number & pin into aDialStr 
+			case KCharHLower:
+			if (!DialUtil::AppendDialString(aDialString,aChargeCard.Number()))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,aChargeCard.Pin()))
+				return (KErrOverflow) ;
+			break;
+			case KCharJUpper: // copy chargecard account number into aDialStr 
+			case KCharJLower:
+			if (!DialUtil::AppendDialString(aDialString,aChargeCard.Number()))
+				return (KErrOverflow) ;
+            break;
+        
+			case KCharKUpper: // copy pin into aDialStr 
+			case KCharKLower:
+			if (!DialUtil::AppendDialString(aDialString,aChargeCard.Pin()))
+				return (KErrOverflow) ;
+            break;
+		
+			default:  // copy character into aDialStr 
+			if (!DialUtil::AppendDialString(aDialString,iRule[i]))
+				return (KErrOverflow) ;
+            break;
+				}	
+			}
+		}
+	DialUtil::RemoveSpace (aDialString) ;
+
+	// this is for dtmf dialling string so the string should not have 
+	// any undialable characters
+	if (aParseMode==EForDisplay) 
+		DialUtil::RemoveUndiallableChars (aDialString) ;
+	
+	
+	return(KErrNone) ;
+	}
+
+
+/**
+This parser resolves the phone number for Time/World application.
+
+@param aDialString The results of the telephone parser are stored here.
+@param aFrom Specifies the area code of the dialling location.
+@param aTo Specifies the area code of the city being dialled.
+@param aOption This option applies when the phone number being 
+       dialled is in the same location as the dialler: 
+       It controls whether the area code is included in the final dial string. 
+@param aCodeSeparator Specifies the code separator.
+@param aPlusFormatOption Specifies whether the dial string is in full 
+       or in the ‘+’ char format.
+
+@publishedAll
+@deprecated 9.1
+*/
+EXPORT_C TInt TelephoneNumber::CalculateDialCityPrefix(
+						TDialString& aDialString,
+						const TCityDialCodes& aFrom,
+						const TCityDialCodes& aTo,
+						TCityDialOptions aOption,
+						TChar aCodeSeparator ,
+						TPlusFormatDialOptions aPlusFormatOption )
+	{
+	aDialString.Zero(); // restart the dial string 
+	if (aFrom.iNatCode != aTo.iNatCode) // different country code
+		{
+		if (aPlusFormatOption==EPlusFormatDialNotAllow)
+			{
+			if (!DialUtil::AppendDialString(aDialString,aFrom.iIntlPref))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,aCodeSeparator))
+				return (KErrOverflow) ;
+			} 
+		else
+			{
+			if (!DialUtil::AppendDialString(aDialString,KCharPlus))
+				return (KErrOverflow) ;
+			}
+		if (!DialUtil::AppendDialString(aDialString,aTo.iNatCode))
+			return (KErrOverflow) ;
+		if (!DialUtil::AppendDialString(aDialString,aCodeSeparator))
+			return (KErrOverflow) ;
+		if (!DialUtil::AppendDialString(aDialString,aTo.iAreaCode))
+			return (KErrOverflow) ;
+		return(KErrNone) ;
+		}
+	else if (aFrom.iAreaCode != aTo.iAreaCode) // same country code different area
+		{
+		if (!DialUtil::AppendDialString(aDialString,aFrom.iNatPref))
+			return (KErrOverflow) ;
+		if (!DialUtil::AppendDialString(aDialString,aCodeSeparator))
+			return (KErrOverflow) ;
+		if (!DialUtil::AppendDialString(aDialString,aTo.iAreaCode))
+			return (KErrOverflow) ;
+		return(KErrNone) ;
+		}
+	else if (	(aFrom.iIntlPref == aTo.iIntlPref) && 
+				(aFrom.iNatPref  == aTo.iNatPref) )
+				// must check they are exaclty the same for local call
+		{
+		if (aOption == EDialCityAllowDuplicateAreaCode)
+			{
+			if (!DialUtil::AppendDialString(aDialString,aFrom.iNatPref))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,aCodeSeparator))
+				return (KErrOverflow) ;
+			if (!DialUtil::AppendDialString(aDialString,aTo.iAreaCode))
+				return (KErrOverflow) ;
+			return(KErrNone) ;
+			}
+		else
+			return(KErrNone) ;
+		}
+	else // in valid info in the structure
+		return (KErrOverflow) ;
+	}
+
+
+//
+// for DTMF dialing
+//
+
+/**
+This parser resolves a phone number.  
+It assumes that TCityDialOption is 
+always set to EDialCityStripDuplicateAreaCode
+
+@param aDialString The results of the telephone parser are stored here.
+@param aDialLocation Specifies the dialling location.
+@param aPhoneNumber Telephone number is to be parsed in the form of +44 20...
+
+@publishedAll
+@deprecated 9.1
+*/
+EXPORT_C TInt TelephoneNumber::Parse( TDialString& aDialString ,
+								  const TDialLocation& aDialLocation, 
+								  const TDesC& aPhoneNumber ) 
+	{
+	TChargeCard chargeCard ; // a NULL charge card not used by DTMF
+	return (TelephoneNumber::Parse(
+							aDialString,
+							aDialLocation,
+							chargeCard,
+							aPhoneNumber,
+							EForDisplay	) ); 
+	}
+
+
+// It is for DTMF dialing with option to strip or allow the area code.
+
+/**
+This parser resolves a phone number.
+
+@param aDialString The results of the telephone parser are stored here.
+@param aDialLocation Specifies the dialling location.
+@param aPhoneNumber Telephone number is to be parsed in the form of +44 20 ...
+@param aOption This option applies when the phone number being dialled 
+       is in the same location as the dialler: It controls whether the 
+       area code is included in the final dial string. 
+
+@publishedAll
+@deprecated 9.1
+*/
+EXPORT_C TInt TelephoneNumber::Parse( TDialString& aDialString ,
+								  const TDialLocation& aDialLocation, 
+								  const TDesC& aPhoneNumber , 
+								  TCityDialOptions aOption )
+	{
+	TChargeCard chargeCard ; // a NULL charge card not used by DTMF
+	return DialUtil::GeneralParse(
+							aDialString,
+							aDialLocation,
+							chargeCard,
+							aPhoneNumber,
+							EForDisplay	,
+							aOption ); 
+	}
+
+
+// Parse for dial up network
+
+/**
+This parser resolves a phone number with additional of a TChargeCard.
+
+@param aDialString The results of the telephone parser are stored here.
+@param aDialLocation Specifies the dialling location.
+@param aChargeCard Specifies charge card information. 
+@param aNumberToDial A telephone number is to be parsed in the form of +44 20 ...
+@param aParseMode Indicates whether the resulting string 
+       is for display or for dialling.
+
+@publishedAll
+@deprecated 9.1
+*/
+EXPORT_C TInt TelephoneNumber::Parse(
+			 TDialString& aDialString,
+			 const TDialLocation & aDialLocation , 
+			 const TChargeCard& aChargeCard ,
+			 const TDesC& aNumberToDial,
+			 TParseMode aParseMode )
+	{
+	return DialUtil::GeneralParse (	aDialString,
+							aDialLocation , 
+							aChargeCard ,
+							aNumberToDial,
+							aParseMode,
+							EDialCityStripDuplicateAreaCode ) ;
+	}