diff -r bc5a64e5bc3c -r 377c906a8701 phoneengine/phoneservices/src/dialservicedepricated.cpp --- a/phoneengine/phoneservices/src/dialservicedepricated.cpp Tue Jul 06 14:15:47 2010 +0300 +++ b/phoneengine/phoneservices/src/dialservicedepricated.cpp Fri Jul 09 15:40:55 2010 +0300 @@ -18,14 +18,22 @@ #include #include #include +#include +#include +#include #include "dialservicedepricated.h" #include "qtphonelog.h" +// CONSTANTS +const XQSettingsKey dialPrefixMode(XQSettingsKey::TargetCentralRepository, KCRUidTelephonySettings.iUid, KSettingsDialPrefixChangeMode); +const XQSettingsKey dialPrefixString(XQSettingsKey::TargetCentralRepository, KCRUidTelephonySettings.iUid, KSettingsDialPrefixText); DialServiceDepricated::DialServiceDepricated(MPECallControlIF &call, MPECallSettersIF ¶meters, QObject* parent) : - XQServiceProvider(QLatin1String("com.nokia.services.telephony"), parent), m_call (call), m_parameters (parameters) + XQServiceProvider(QLatin1String("com.nokia.symbian.ICallDial"), parent), m_call (call), m_parameters (parameters) { publishAll(); + m_settingsManager = new XQSettingsManager(this); + Q_ASSERT(m_settingsManager != 0); } DialServiceDepricated::~DialServiceDepricated() @@ -35,8 +43,8 @@ int DialServiceDepricated::dial(const QString& number) { PHONE_DEBUG2("DialServiceDepricated::dial number:", number); - QString simplifiedNumber = simplified(number); - TPtrC16 numberPtr(reinterpret_cast(simplifiedNumber.utf16())); + QString phoneNumber = modifyPhoneNumber(number); + TPtrC16 numberPtr(reinterpret_cast(phoneNumber.utf16())); m_parameters.SetPhoneNumber (numberPtr); m_parameters.SetCallTypeCommand (EPECallTypeCSVoice); return m_call.HandleDialServiceCall (); @@ -45,8 +53,8 @@ int DialServiceDepricated::dial(const QString& number, int contactId) { PHONE_DEBUG4("DialServiceDepricated::dial number:", number, "contactId:", contactId); - QString simplifiedNumber = simplified(number); - TPtrC16 numberPtr (reinterpret_cast(simplifiedNumber.utf16())); + QString phoneNumber = modifyPhoneNumber(number); + TPtrC16 numberPtr (reinterpret_cast(phoneNumber.utf16())); m_parameters.SetPhoneNumber (numberPtr); m_parameters.SetCallTypeCommand (EPECallTypeCSVoice); m_parameters.SetContactId2 (contactId); @@ -56,8 +64,8 @@ void DialServiceDepricated::dialVideo(const QString& number) { PHONE_DEBUG2("DialServiceDepricated::dialVideo number:", number); - QString simplifiedNumber = simplified(number); - TPtrC16 numberPtr(reinterpret_cast(simplifiedNumber.utf16())); + QString phoneNumber = modifyPhoneNumber(number); + TPtrC16 numberPtr(reinterpret_cast(phoneNumber.utf16())); m_parameters.SetPhoneNumber (numberPtr); m_parameters.SetCallTypeCommand (EPECallTypeVideo); m_call.HandleDialServiceCall (); @@ -66,8 +74,8 @@ void DialServiceDepricated::dialVideo(const QString& number, int contactId) { PHONE_DEBUG4("DialServiceDepricated::dialVideo number:", number, "contactId:", contactId); - QString simplifiedNumber = simplified(number); - TPtrC16 numberPtr (reinterpret_cast(simplifiedNumber.utf16())); + QString phoneNumber = modifyPhoneNumber(number); + TPtrC16 numberPtr (reinterpret_cast(phoneNumber.utf16())); m_parameters.SetPhoneNumber (numberPtr); m_parameters.SetCallTypeCommand (EPECallTypeVideo); m_parameters.SetContactId2 (contactId); @@ -117,6 +125,15 @@ m_call.HandleDialServiceCall(); } +QString DialServiceDepricated::modifyPhoneNumber(const QString &number) +{ + PHONE_DEBUG2("DialService::modifyPhoneNumber number:", number); + QString modifiedNumber = simplified(number); + modifiedNumber = japanPrefixModifications(modifiedNumber); + + return modifiedNumber; +} + QString DialServiceDepricated::simplified(const QString &number) { QString simplifiedNumber = number; @@ -124,3 +141,34 @@ simplifiedNumber.remove(rx); return simplifiedNumber; } + +QString DialServiceDepricated::japanPrefixModifications(const QString &number) +{ + PHONE_DEBUG2("DialService::japanPrefixModifications number:", number); + bool checkPrefix = FeatureManager::FeatureSupported(KFeatureIdJapanPrefixChange); + if(checkPrefix == false) { + // prefix change setting is off so don't play with the number + return number; + } + + QString modifiedNumber = number; + + int prefixMode = m_settingsManager->readItemValue(dialPrefixMode, XQSettingsManager::TypeInt).toInt(); + PHONE_DEBUG2("DialService::japanPrefixModifications prefixMode:", prefixMode); + + if((m_settingsManager->error() == XQSettingsManager::NoError) && (prefixMode > 0)) { + // No error fetching value and setting is on + QString prefixString = m_settingsManager->readItemValue(dialPrefixString, XQSettingsManager::TypeString).toString(); + PHONE_DEBUG2("DialService::japanPrefixModifications prefixString:", prefixString); + + if(m_settingsManager->error() == XQSettingsManager::NoError) { + if(modifiedNumber.startsWith("+")) { + modifiedNumber = modifiedNumber.remove(0, 1); + modifiedNumber = modifiedNumber.insert(0, prefixString); + } + } + } + + PHONE_DEBUG2("DialService::japanPrefixModifications modifiedNumber:", modifiedNumber); + return modifiedNumber; +}