FreeCalypso > hg > fc-tourmaline
diff src/ui/bmi/mmiCall.c @ 82:2e93bc63ba71
mmiCall.c: white space initial preen
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 26 Oct 2020 06:13:01 +0000 |
parents | 67bfe9f274f6 |
children | 7160f0d005d2 |
line wrap: on
line diff
--- a/src/ui/bmi/mmiCall.c Mon Oct 26 05:29:36 2020 +0000 +++ b/src/ui/bmi/mmiCall.c Mon Oct 26 06:13:01 2020 +0000 @@ -28,232 +28,232 @@ ******************************************************************************** $History: MmiCall.c - August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) - Description: COMBO PLUS: Voice can not be heard in a call when MP3 tone was set - Have an MP3 tone set as Ringer. Make a call to the target. - Accept the same, no voice can be heard from the calling - device or from the board that received - Issue: Timing Synchronization Issue between BMI-ACI-L1. - BMI calls sAT_A to accept the call. ACI then sends the RING_OFF signal - to BMI, wherein BMI does a Ringer Stop. After this, ACI calls Vocoder - Enable. However, the Ringer Stop goes to L1 much later after Vocoder - Enable reaches L1 due to which the Vocoder eventually gets disabled. - Solution: The Vocoder Enable Implementation is removed from ACI and - shall be called by BMI on receipt of AS_STOP_IND - (AS_STOP_IND is the message sent by AS to BMI when BMI invokes - as_stop for ringer_stop). This way, it is assured that the Vocoder - Enable Request reaches L1 only after Ringer Stop is completely done - - July 06, 2007 DR: OMAPS00137334 x0062172(Syed Sirajudeen) - Description:[MPY]Wrong indication when add party if conference full - Solution: Pop up the "Conference Full" string if user tries to add (MAX_CALLS+1)th user - to the conference. - - - - May 28, 2007 DR: OMAPS00123948 x0066692 - Description: MMI doesn't display specific dialogs for enabling TTY_VCO and TTY_HCO - Solution : In call_tty_statuswin() Dialog data is initialized specific to TTY_VCO and - TTY_HCO and TTY_ALL. Also conditions CALL_TTY_ALWAYSON and CALL_TTY_ONNEXTCALL - are applied while displaying hte dialog. - - Mar 21, 2007 DR: OMAPS00121645 x0066814 - Description: Bip ringer are always heard during calling and even during the voice call - Solution : In E_CM_CONNECT_ACK event, the code to stop the ringer is added. - - - May 16, 2007 DR: OMAPS00117598 x0066692 - Description: Ringer instabilities during incoming call when headset is plugged. - Solution : Function mfw_hook_register() is called after starting the ringer during - incoming call. - - May 10 2007 DR:OMAPS00127983 x066814 - Description: PSTN caller name not displayed on MS - Solution: In incomingCall() funtion, added a case to check whether - the name is updated by rAT_PercentCNAP. - - Apr 03, 2007 ER: OMAPS00122561 x0pleela - Description: [ACI] Phone lock feature has to be supported by ACI - Solution: Phone Lock ER implementation - - Mar 22, 2007,DR: OMAPS00121671 x0066814(Geetha) - Description: Bip ringer are always heard during calling and even during the voice call - Solution: In E_CM_CONNECT_ACK event, the code to stop the ringer is added - - Feb 16, 2007 DR: OMAPS00114834 x0pleela - Description: When accepting the call through AT commands with MP3 ringer, the corrupted - MP3 play continues - Solution: Made changes in the function: - 1) call_incoming_cb(): In KCD_RIGHT and KCD_LEFT keypad events, the code to - stop the ringer is commented as MMI should stop the ringer when it recieves - the RING_OFF event from ACI rather than stopping the ringer when user - accepts or rejects the call using keypad - 2) callcmevent(): In E_CM_CONNECT_ACK event, the code to stop the ringer is - commented as this code is moved and handled in call event E_CM_RING_OFF - - Jan 10, 2007 DR: OMAPS00110568 x0039928 - Description: Remove duplication of FFS.Flashdata from GDI - Solution: Added a new function get_call_data_tty(). - - Dec 22, 2006 REF:OMAPS00107042 x0039928 + August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) + Description: COMBO PLUS: Voice can not be heard in a call when MP3 tone was set + Have an MP3 tone set as Ringer. Make a call to the target. + Accept the same, no voice can be heard from the calling + device or from the board that received + Issue: Timing Synchronization Issue between BMI-ACI-L1. + BMI calls sAT_A to accept the call. ACI then sends the RING_OFF signal + to BMI, wherein BMI does a Ringer Stop. After this, ACI calls Vocoder + Enable. However, the Ringer Stop goes to L1 much later after Vocoder + Enable reaches L1 due to which the Vocoder eventually gets disabled. + Solution: The Vocoder Enable Implementation is removed from ACI and + shall be called by BMI on receipt of AS_STOP_IND + (AS_STOP_IND is the message sent by AS to BMI when BMI invokes + as_stop for ringer_stop). This way, it is assured that the Vocoder + Enable Request reaches L1 only after Ringer Stop is completely done + + July 06, 2007 DR: OMAPS00137334 x0062172(Syed Sirajudeen) + Description:[MPY]Wrong indication when add party if conference full + Solution: Pop up the "Conference Full" string if user tries to add (MAX_CALLS+1)th user + to the conference. + + + + May 28, 2007 DR: OMAPS00123948 x0066692 + Description: MMI doesn't display specific dialogs for enabling TTY_VCO and TTY_HCO + Solution : In call_tty_statuswin() Dialog data is initialized specific to TTY_VCO and + TTY_HCO and TTY_ALL. Also conditions CALL_TTY_ALWAYSON and CALL_TTY_ONNEXTCALL + are applied while displaying hte dialog. + + Mar 21, 2007 DR: OMAPS00121645 x0066814 + Description: Bip ringer are always heard during calling and even during the voice call + Solution : In E_CM_CONNECT_ACK event, the code to stop the ringer is added. + + + May 16, 2007 DR: OMAPS00117598 x0066692 + Description: Ringer instabilities during incoming call when headset is plugged. + Solution : Function mfw_hook_register() is called after starting the ringer during + incoming call. + + May 10 2007 DR:OMAPS00127983 x066814 + Description: PSTN caller name not displayed on MS + Solution: In incomingCall() funtion, added a case to check whether + the name is updated by rAT_PercentCNAP. + + Apr 03, 2007 ER: OMAPS00122561 x0pleela + Description: [ACI] Phone lock feature has to be supported by ACI + Solution: Phone Lock ER implementation + + Mar 22, 2007,DR: OMAPS00121671 x0066814(Geetha) + Description: Bip ringer are always heard during calling and even during the voice call + Solution: In E_CM_CONNECT_ACK event, the code to stop the ringer is added + + Feb 16, 2007 DR: OMAPS00114834 x0pleela + Description: When accepting the call through AT commands with MP3 ringer, the corrupted + MP3 play continues + Solution: Made changes in the function: + 1) call_incoming_cb(): In KCD_RIGHT and KCD_LEFT keypad events, the code to + stop the ringer is commented as MMI should stop the ringer when it recieves + the RING_OFF event from ACI rather than stopping the ringer when user + accepts or rejects the call using keypad + 2) callcmevent(): In E_CM_CONNECT_ACK event, the code to stop the ringer is + commented as this code is moved and handled in call event E_CM_RING_OFF + + Jan 10, 2007 DR: OMAPS00110568 x0039928 + Description: Remove duplication of FFS.Flashdata from GDI + Solution: Added a new function get_call_data_tty(). + + Dec 22, 2006 REF:OMAPS00107042 x0039928 Description : Tagrget hangs or crashes when making MO call with Agilent Solution : cm status variable is otpimized to get memory from heap to avoid stack overflow. - - - Dec 13, 2006 DR:OMAPS00107103 a0393213(R.Prabakar) - Description : No DTMF tones for simultanous keypress - Solution : Once there was some problem in sending DTMF tones, the problem persisted till the next reset. - This was because the queue was not getting flushed once the call was ended. - Now the queue is flushed once the call is ended. - - Nov 03, 2006 DR: OMAPS000101158 x0pleela + + + Dec 13, 2006 DR:OMAPS00107103 a0393213(R.Prabakar) + Description : No DTMF tones for simultanous keypress + Solution : Once there was some problem in sending DTMF tones, the problem persisted till the next reset. + This was because the queue was not getting flushed once the call was ended. + Now the queue is flushed once the call is ended. + + Nov 03, 2006 DR: OMAPS000101158 x0pleela Description : Board crashes after sending atd command through HyperTerminal Solution : Avoid peforming phonebook search operation if the source id is not LOCAL - callCmEvent: Check for the value of uOthersrc and if set donot perform phonebook - search operation. Else perform phonebook search operation + callCmEvent: Check for the value of uOthersrc and if set donot perform phonebook + search operation. Else perform phonebook search operation Oct 8 2006 OMAPS00097714 x0039928(sumanth) TTY HCO/VCO options in MMI - Sep 01, 2006 REF:OMAPS00090555 x0039928 + Sep 01, 2006 REF:OMAPS00090555 x0039928 Description : When make a MO call,MFW can not get call number from ACI. - Solution : The called number is extracted from the parameter of callCmEvent() - for event E_CM_MO_RES and is displayed. Also stack memory optimization is done to + Solution : The called number is extracted from the parameter of callCmEvent() + for event E_CM_MO_RES and is displayed. Also stack memory optimization is done to resolve MMI stack overflow problem. - xrashmic 21 Aug, 2005 OMAPS00090198 - The mmeSetVolume is skipped when in a TTY call, as TTY has it own profile - and when this profile is loaded, the volume would also be set. - - Aug 17, 2006 REF:OMAPS00090196 x0039928 + xrashmic 21 Aug, 2005 OMAPS00090198 + The mmeSetVolume is skipped when in a TTY call, as TTY has it own profile + and when this profile is loaded, the volume would also be set. + + Aug 17, 2006 REF:OMAPS00090196 x0039928 Description : HOOk Register / Unregister shall not be called when TTY is ON Solution : TTY ON condition is checked before registering / unregistering for the hook. - - Aug 31, 2006 DR: OMAPS00083503 x0pleela - Description: Result of ss_check_ss_string may be ignored - Solution: - Removed the new code added in callnumber() : MFW_SS_USSD - switch case to send the USSD string through at+cusd command. Instead sending through ATDn command - - Aug 30, 2006 DR: OMAPS00083503 x0pleela - Description: Result of ss_check_ss_string may be ignored - Solution: - Calling function GLOBAL USHORT get_nm_status(void) as per the review - comments to avoid the usage of the global variable gnm_status - - Aug 28, 2006 DR: OMAPS00083503 x0pleela - Description: Result of ss_check_ss_string may be ignored - Solution: callnumber(): MFW_SS_USSD is handled separately where send_ss_ussd() is called to - initaite USSD transaction - - Aug 03, 2006 REF:OMAPS00088329 x0039928 + + Aug 31, 2006 DR: OMAPS00083503 x0pleela + Description: Result of ss_check_ss_string may be ignored + Solution: - Removed the new code added in callnumber() : MFW_SS_USSD + switch case to send the USSD string through at+cusd command. Instead sending through ATDn command + + Aug 30, 2006 DR: OMAPS00083503 x0pleela + Description: Result of ss_check_ss_string may be ignored + Solution: - Calling function GLOBAL USHORT get_nm_status(void) as per the review + comments to avoid the usage of the global variable gnm_status + + Aug 28, 2006 DR: OMAPS00083503 x0pleela + Description: Result of ss_check_ss_string may be ignored + Solution: callnumber(): MFW_SS_USSD is handled separately where send_ss_ussd() is called to + initaite USSD transaction + + Aug 03, 2006 REF:OMAPS00088329 x0039928 Description : TTY> When TTY is ON Headset insertion detection / profile download should not happen Solution : TTY ON condition is checked before downloading the headset profile. - May 30, 2006 DR: OMAPS00070657 x0pleela - Description: CPHS feature on Locosto-Lite - Solution: For ALS feature, - a) Added new enum "CALL_ACTIVE_LINE", to display current active line along - with the called/calling number - b) Modified function "inCall_displayData", "call_win_cb" to display current active - line along with the called/calling number - - Jun 02, 2006 DRT OMAPS00079213 x0039928(sumanth) - Description: Triton PG2.2 impacts on Locosto program - Solution: Software workaround is done to register headset-hook dynamically - during/before call is established and unregister it after the call is ended/disconnected. - - May 18, 2006 REF: DRT OMAPS00076438 xdeepadh - Description: Scrolling not implemented in Imageviewer - Solution: The support for scrolling has been provided. - - - May 15, 2006 DR: OMAPS00075901 x0021334 - Descripton: Call Waiting - Release and Accept - incompatible usage of MMI and AT interpreter - Solution: The call waiting tone is stopped on receipt of E_CM_RING_OFF event. - - May 9, 2006 REF:DR OMAPS00074884 xrashmic - Description: Pressing Red key in scratch pad does not release calls but deletes the characters - Solution: Pressing Red key in scratch pad releses all calls. If there are no calls, it would destroy - the scratch pad. + May 30, 2006 DR: OMAPS00070657 x0pleela + Description: CPHS feature on Locosto-Lite + Solution: For ALS feature, + a) Added new enum "CALL_ACTIVE_LINE", to display current active line along + with the called/calling number + b) Modified function "inCall_displayData", "call_win_cb" to display current active + line along with the called/calling number + + Jun 02, 2006 DRT OMAPS00079213 x0039928(sumanth) + Description: Triton PG2.2 impacts on Locosto program + Solution: Software workaround is done to register headset-hook dynamically + during/before call is established and unregister it after the call is ended/disconnected. + + May 18, 2006 REF: DRT OMAPS00076438 xdeepadh + Description: Scrolling not implemented in Imageviewer + Solution: The support for scrolling has been provided. + + + May 15, 2006 DR: OMAPS00075901 x0021334 + Descripton: Call Waiting - Release and Accept - incompatible usage of MMI and AT interpreter + Solution: The call waiting tone is stopped on receipt of E_CM_RING_OFF event. + + May 9, 2006 REF:DR OMAPS00074884 xrashmic + Description: Pressing Red key in scratch pad does not release calls but deletes the characters + Solution: Pressing Red key in scratch pad releses all calls. If there are no calls, it would destroy + the scratch pad. Apr 26, 2006 OMAPS00074886 a0393213 (Prabakar R) - Description : No option in MMI to release the held call. + Description : No option in MMI to release the held call. Solution : No option was available. Added a menu option. - - Mar 31, 2006 ER: OMAPS00067709 x0pleela - Description: Voice Buffering implementation on C+ for PTT via PCM API - Solution: Added prototype for voice_buffering_stop_recording - Added check before calling play/record stop - - Mar 15, 2006 ER: OMAPS00067709 x0pleela - Description: Voice Buffering implementation on C+ for PTT via PCM API - Solution: Function: callCmEvent - Changes: 1. E_CM_DISCONNECT: Added code for voice buffering to stop playing - and recording if PTT call is disconnected. - 2. E_CM_CONNECT_ACK: Added code for voice buffering to start playing - if PTT call is connected. - - Function: call_kbd_cb - Changes: Added code to update voice_buffering_data when END key is pressed - while in PTT call - - Function: incomingCall - Changes: Added code to reject incoming call while in buffering phase - - Function: call_calling_cb - Changes: Added code to update voice_buffering_data when END key is pressed - before PTT call setup - - Mar 28, 2006 REF:DR OMAPS00072407 x0039928 - Description: Phone hangs when tried to make an outgoing call - Solution: Reverting back the changes of issue OMAPS00048894 to stop from stack overflow. - - Mar 11, 2006 REF:DR:OMAPS00061467 x0035544 - Description: 27.22.4.13.3 SET UP CALL (display of icons) fails. - Solution: During an event CALL_OUTGOING_SAT in the function Call() Copied sim icon data in to the - structure call_data inorder to display it on the dialog screen. - - Feb 13, 2006 REF:DR OMAPS00067943 x0039928 - Description: MMI gives access to Application during active call in Plus but not in Lite - Solution: The Menu function M_exeViewfinder is renamed to M_exeApplication and moved out of - FF_MMI_TEST_CAMERA flag. - - Jan 27, 2006 REF:DR OMAPS00048894 x0039928 - Description: Outgoing Call: The called number is not displayed while an outgoing call is made - Solution: The called number is extracted from the parameter of callCmEvent() for event E_CM_MO_RES and is displayed. - - Jan 05, 2006 REF:DR OMAPS00050454 x0039928 - Description: Phone power cycles while deflecting a call to another number - Solution: The calling window dialog is destroyed if there are no more calls. - - Nov 09, 2005 REF: OMAPS00043190 - x0018858 - Description: PTCRB - 27.22.4.1.4 (DISPLAY TEXT (Sustained text) Fails in 1900 DISPLAY TEXT - (Sustained text) - Solution: Have added a new global variable to store the handle of the window and then release - it when a higher priority call event comes in. - - Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh - Description: Mp3 Ringer Implementation - Solution: The Midi Ringer application has been enhanced to support mp3 as ringer. - The interface function names have been modified. - - Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg - Description: Locosto: MIgration to New LCD APIs - Solution: Migrated to New APIs by replacing the old driver APIs with - corresponding New LCD APIs - - Aug 22 2005, xpradipg - LOCOSTO-ENH-31154 - Description: Application to test camera - Solution: Implemented the camera application with following functionalities - preview, snapshot and image saving. - - xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 - Description: Support for various audio profiles - Solution: The support for audio device's carkit/headset/loudspeaker/handheld. - The audio device is enabled as per the user actions. - - Apr 06, 2005 REF: ENH 30011 xdeepadh - Description: Replacing the Test Application compilation flags with new flags. - Solution: The existing flags for Camera and MP3 test application have beeen replaced with the + + Mar 31, 2006 ER: OMAPS00067709 x0pleela + Description: Voice Buffering implementation on C+ for PTT via PCM API + Solution: Added prototype for voice_buffering_stop_recording + Added check before calling play/record stop + + Mar 15, 2006 ER: OMAPS00067709 x0pleela + Description: Voice Buffering implementation on C+ for PTT via PCM API + Solution: Function: callCmEvent + Changes: 1. E_CM_DISCONNECT: Added code for voice buffering to stop playing + and recording if PTT call is disconnected. + 2. E_CM_CONNECT_ACK: Added code for voice buffering to start playing + if PTT call is connected. + + Function: call_kbd_cb + Changes: Added code to update voice_buffering_data when END key is pressed + while in PTT call + + Function: incomingCall + Changes: Added code to reject incoming call while in buffering phase + + Function: call_calling_cb + Changes: Added code to update voice_buffering_data when END key is pressed + before PTT call setup + + Mar 28, 2006 REF:DR OMAPS00072407 x0039928 + Description: Phone hangs when tried to make an outgoing call + Solution: Reverting back the changes of issue OMAPS00048894 to stop from stack overflow. + + Mar 11, 2006 REF:DR:OMAPS00061467 x0035544 + Description: 27.22.4.13.3 SET UP CALL (display of icons) fails. + Solution: During an event CALL_OUTGOING_SAT in the function Call() Copied sim icon data in to the + structure call_data inorder to display it on the dialog screen. + + Feb 13, 2006 REF:DR OMAPS00067943 x0039928 + Description: MMI gives access to Application during active call in Plus but not in Lite + Solution: The Menu function M_exeViewfinder is renamed to M_exeApplication and moved out of + FF_MMI_TEST_CAMERA flag. + + Jan 27, 2006 REF:DR OMAPS00048894 x0039928 + Description: Outgoing Call: The called number is not displayed while an outgoing call is made + Solution: The called number is extracted from the parameter of callCmEvent() for event E_CM_MO_RES and is displayed. + + Jan 05, 2006 REF:DR OMAPS00050454 x0039928 + Description: Phone power cycles while deflecting a call to another number + Solution: The calling window dialog is destroyed if there are no more calls. + + Nov 09, 2005 REF: OMAPS00043190 - x0018858 + Description: PTCRB - 27.22.4.1.4 (DISPLAY TEXT (Sustained text) Fails in 1900 DISPLAY TEXT + (Sustained text) + Solution: Have added a new global variable to store the handle of the window and then release + it when a higher priority call event comes in. + + Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh + Description: Mp3 Ringer Implementation + Solution: The Midi Ringer application has been enhanced to support mp3 as ringer. + The interface function names have been modified. + + Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg + Description: Locosto: MIgration to New LCD APIs + Solution: Migrated to New APIs by replacing the old driver APIs with + corresponding New LCD APIs + + Aug 22 2005, xpradipg - LOCOSTO-ENH-31154 + Description: Application to test camera + Solution: Implemented the camera application with following functionalities + preview, snapshot and image saving. + + xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 + Description: Support for various audio profiles + Solution: The support for audio device's carkit/headset/loudspeaker/handheld. + The audio device is enabled as per the user actions. + + Apr 06, 2005 REF: ENH 30011 xdeepadh + Description: Replacing the Test Application compilation flags with new flags. + Solution: The existing flags for Camera and MP3 test application have beeen replaced with the new compilation flags,FF_MMI_TEST_CAMERA and FF_MMI_TEST_MP3 respectively. April 25, 200 REF: MMI-FIX-30125 x0018858 @@ -264,7 +264,7 @@ Apr 05, 2005 REF: ENH 29994 xdeepadh Description: Implementation of Generic Midi Ringer and Modification of existing Midi Test Application Solution: Generic Midi Ringer and Midi Test Application were implemented. - + Feb 03, 200 REF: CRR 25960 x0012850 Description: Call Hold: While one call in Active and other in Held by swapping either of phone is not audible @@ -272,88 +272,88 @@ Jan 19, 2005 REF: CRR MMI-SPR-27455 xnkulkar Description: TC 29.3.2.6.7 failed on 900 on R&S - Solution: function "mfw_aud_l1_enable_vocoder ()" should be called only when the + Solution: function "mfw_aud_l1_enable_vocoder ()" should be called only when the call mode is not DATA or FAX Nov 29, 2004 REF: CRR 25051 xkundadu Description: INCALL SCREEN ?ADJUSTING THE VOLUME - Fix: Added volume level list linked to up/down keys. + Fix: Added volume level list linked to up/down keys. User can select the speaker volume among those levels. Nov 16, 2004 REF: CRR MMI-SPR-26120 xnkulkar - Description: After disconnecting MOC cannot return to STK menu - Solution: When the user ends a call, check if it is a STK call and send SAT_RETURN event to - return the control to STK menu. + Description: After disconnecting MOC cannot return to STK menu + Solution: When the user ends a call, check if it is a STK call and send SAT_RETURN event to + return the control to STK menu. Oct 27, 2004 REF: CRR MMI-SPR-15632 xnkulkar Description: SMS : class 2 and 3 SMSMT : icon not displayed when 2 active calls - Solution: In callCmEvent() under case case E_CM_TIMER_EVERY_SECOND, - condition "call_data.calls.mode == CallSingle" is removed to make the sms icon visible - even if there are more than one calls present. + Solution: In callCmEvent() under case case E_CM_TIMER_EVERY_SECOND, + condition "call_data.calls.mode == CallSingle" is removed to make the sms icon visible + even if there are more than one calls present. October 07, 2004 REF: CRR MMI-FIX-24440 xnkulkar Description: Bug in mmicall.c callID related Error - Solution: In holdExec() function "callIndex()" function is used instead of directly - using status[call_data.calls.selected] - - Bug Id 14 & 21 : 12 Aug, 2004 - xrashmic - Description: Presing up/Down scroll key displays alert mode optins, - which overlaps with incoming call screen - Solution: Up and down scroll keys have been disabled for incoming call screen - - Sep 2, 2004 REF: CRR 21370 xkundadu - Description: Giving wrong expected result by long press on "#" key - Fix: When user presses long on '#' key it will display 'p'. - Changed the long press of '*' key to display 'w' + Solution: In holdExec() function "callIndex()" function is used instead of directly + using status[call_data.calls.selected] + + Bug Id 14 & 21 : 12 Aug, 2004 - xrashmic + Description: Presing up/Down scroll key displays alert mode optins, + which overlaps with incoming call screen + Solution: Up and down scroll keys have been disabled for incoming call screen + + Sep 2, 2004 REF: CRR 21370 xkundadu + Description: Giving wrong expected result by long press on "#" key + Fix: When user presses long on '#' key it will display 'p'. + Changed the long press of '*' key to display 'w' // Jul 2, 2004 REF: CRR 21421 xvilliva -// Bug: ALS:Action on the other line when change is locked. -// Fix: The error code returned by ACI is processed and an alert -// is flashed to the user. - - Jul 14, 2004 REF=CRR 13847 xkundadu - Description: Have one active call and one held call. - If you end the active call using MMI, the Held call is still on - hold and UNHOLD has to be selected to retrieve the call - If you end the active call using BPM then the held call - automatically beocmes an active call, shouldn't there be - consistency between the two? - Solution: After all the disconnection, if there is only one call and - that call is HELD, retrieve that call to make it as ACTIVE. - Added the boolean variable bhostDisconnection to test - whether the disconnection process started from host side or not - If disconenction is from remote side, after the - disconnection if there is only one call and that is HELD, dont - change its status to ACTIVE. - +// Bug: ALS:Action on the other line when change is locked. +// Fix: The error code returned by ACI is processed and an alert +// is flashed to the user. + + Jul 14, 2004 REF=CRR 13847 xkundadu + Description: Have one active call and one held call. + If you end the active call using MMI, the Held call is still on + hold and UNHOLD has to be selected to retrieve the call + If you end the active call using BPM then the held call + automatically beocmes an active call, shouldn't there be + consistency between the two? + Solution: After all the disconnection, if there is only one call and + that call is HELD, retrieve that call to make it as ACTIVE. + Added the boolean variable bhostDisconnection to test + whether the disconnection process started from host side or not + If disconenction is from remote side, after the + disconnection if there is only one call and that is HELD, dont + change its status to ACTIVE. + // Jun 30, 2004 REF: CRR 13698 xvilliva -// Bug: No possibility to make an emergency call when active call and held -// call are existing. -// Fix: If the call being attempted is an emergency call in the presence -// of a held call and an active call, we release all current calls by -// calling cm_end_all() and initate the emergency call on receiving the -// E_CM_DISCONNECT_ALL event. - -// Jun 10, 2004 REF=CRR 13602 Sasken/xreddymn -// Added * and # key handling, to allow the input of -// * and # characters in the scratchpad screen +// Bug: No possibility to make an emergency call when active call and held +// call are existing. +// Fix: If the call being attempted is an emergency call in the presence +// of a held call and an active call, we release all current calls by +// calling cm_end_all() and initate the emergency call on receiving the +// E_CM_DISCONNECT_ALL event. + +// Jun 10, 2004 REF=CRR 13602 Sasken/xreddymn +// Added * and # key handling, to allow the input of +// * and # characters in the scratchpad screen // June 08, 2004 REF: CRR MMI-SPR-13876 xkundadu(Sasken) // Issue description: CHW : AUDIO : No difference between CW and incoming call -// If there is one Active call and one wiating call and if the Active call is disconnected +// If there is one Active call and one wiating call and if the Active call is disconnected // from the remote side/network side, the waiting tone should change to ringing tone. Jun 30, 2004 REF: CRR 15685 xkundadu(Sasken) - Description: FT - TC5.3 MOC - No busy tone upon MOC to busy - subscriber/GOLite. - Solution: Added code to play beep sound when the called party is busy. - When the remote party is busy, earlier there was only dialog - box indication that 'Number busy' - - Fix : "Setting" menu has been provided to set the SMS settings, during the active call - - 25/10/00 Original Condat(UK) BMI version. + Description: FT - TC5.3 MOC - No busy tone upon MOC to busy + subscriber/GOLite. + Solution: Added code to play beep sound when the called party is busy. + When the remote party is busy, earlier there was only dialog + box indication that 'Number busy' + + Fix : "Setting" menu has been provided to set the SMS settings, during the active call + + 25/10/00 Original Condat(UK) BMI version. @@ -417,11 +417,11 @@ #include "mfw_sms.h" #include "mfw_cm.h" // Apr 05, 2005 REF: ENH 29994 xdeepadh -#ifdef FF_MIDI_RINGER +#ifdef FF_MIDI_RINGER #include "mfw_midi.h" -#endif //FF_MIDI_RINGER - -//Apr 06, 2005 REF: ENH 30011 xdeepadh +#endif //FF_MIDI_RINGER + +//Apr 06, 2005 REF: ENH 30011 xdeepadh #ifdef FF_MMI_TEST_CAMERA //e-armanetsaid 19/08/04 #include "mfw_cam.h" @@ -462,7 +462,7 @@ #include "MmiNetwork.h" #include "mmiSat_i.h" #include "MmiAoc.h" -#include "MmiResources.h" /* sbh */ +#include "MmiResources.h" /* sbh */ #include "MmiCPHS.h" #include "gdi.h" @@ -477,13 +477,13 @@ #include "mmiColours.h" -// xpradipg - LOCOSTO-ENH-31154 : 22 Aug 2005 +// xpradipg - LOCOSTO-ENH-31154 : 22 Aug 2005 #ifdef FF_MMI_TEST_CAMERA #include "r2d/r2d.h" #endif //x0pleela 09 Mar, 2006 ER:OMAPS00067709 -#ifdef FF_PCM_VM_VB +#ifdef FF_PCM_VM_VB #include "Mfw_aud.h" #endif // June 08, 2004 REF: CRR MMI-SPR-13877 Ajith K P @@ -496,7 +496,7 @@ // June 08, 2004 REF: CRR MMI-SPR-13876 xkundadu(Sasken) // Issue description: CHW : AUDIO : No difference between CW and incoming call -// If there is one Active call and one wiating call and if the Active call is disconnected +// If there is one Active call and one wiating call and if the Active call is disconnected // from the remote side/network side, the waiting tone should change to ringing tone. @@ -513,7 +513,7 @@ //x0pleela 23 Aug, 2006 DR: OMAPS00083503 -//EXTERN USHORT get_nm_status(void); +//EXTERN USHORT get_nm_status(void); /* Marcus: Issue 1057: 21/01/2003: Added the following two external prototypes */ extern T_MFW_HND sat_get_setup_menu_win (void); @@ -521,7 +521,7 @@ USHORT item_flag_hold( struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi ); USHORT item_flag_swap( struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi ); -// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. +// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. // prototype of the function which determines whether the menu option is to be displayed or not. USHORT item_flag_endheld( struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi ); @@ -532,11 +532,11 @@ *******************************************************************************/ extern T_MFW_HND satDisplayTextWin; // Nov 09, 2005 REF: OMAPS00043190 - x0018858 - // Externed this sat display text handle to make it accessible here. - + // Externed this sat display text handle to make it accessible here. + extern UBYTE getCurrentRingerSettings(void ); extern int M_exeSendNew(MfwMnu* m, MfwMnuItem* i); // MZ -extern MfwMnuAttr *settingMenuAttributes(void);//May 27, 2004 REF: CRR 19186 Deepa M.D +extern MfwMnuAttr *settingMenuAttributes(void);//May 27, 2004 REF: CRR 19186 Deepa M.D extern MfwMnuAttr *applicationsMenuAttributes(void);//August 24, 2004 e-armanetsaid void deflect_destroy(BOOL delete_call_windows); //GW /******************************************************************************* @@ -568,7 +568,7 @@ #define MMI_OUTGOING_CALL_DIALOG_NORMAL (1) #define MMI_OUTGOING_CALL_DIALOG_SAT (2) -#define NUMERIC_KEYS 0x8FF /*MC for setting up dialogue key events*/ +#define NUMERIC_KEYS 0x8FF /*MC for setting up dialogue key events*/ #define MAX_SOUND 255 @@ -631,10 +631,10 @@ (U8)-1, /* use default font */ NULL, /* with these items */ 0, /* number of items */ - COLOUR_LIST_NETWORK, TxtNull, NULL, MNUATTRSPARE + COLOUR_LIST_NETWORK, TxtNull, NULL, MNUATTRSPARE }; -#if 0 /* FreeCalypso */ +#if 0 /* FreeCalypso */ //Daisy tang added for Real Resume feature 20071107 BOOL IsRealPaused=FALSE; extern BOOL IsMP3Playing; @@ -675,7 +675,7 @@ static UBYTE InCallTimer = TRUE; //This ought to be stored in ffs // Default "dialogDisp" should be TRUE! This has been added so that removeAllCalls doesn't display a dialog for each call -// May 9, 2006 REF:DR OMAPS00074884 xrashmic +// May 9, 2006 REF:DR OMAPS00074884 xrashmic // When removing calls one by one from removeAllCalls, rebuild calls should not be called // Added a new paramter to the removeCall function to indicate the same int removeCall (SHORT cid, BOOL dialogDisp,BOOL allCallsEnded); @@ -685,7 +685,7 @@ static int InformationTimerEvent(MfwEvt e, MfwTim *t); -/* x0039928 - Commented for lint warning removal +/* x0039928 - Commented for lint warning removal static int callWaitingAnswerKeyEvent (MfwEvt e, MfwKbd *k); */ void callAutoRedialKeyEvent(T_MFW_HND win, USHORT identifier, USHORT reason); @@ -693,7 +693,7 @@ static void callSetMode(int mode, BOOL dialogDisp); static int contactsExec(MfwMnu* m, MfwMnuItem* i); -static int M_exeSetting(MfwMnu* m, MfwMnuItem* i);//May 27, 2004 REF: CRR 19186 Deepa M.D +static int M_exeSetting(MfwMnu* m, MfwMnuItem* i);//May 27, 2004 REF: CRR 19186 Deepa M.D // Feb 13, 2006 REF:DR OMAPS00067943 x0039928 // Fix : The Menu function M_exeViewfinder is renamed to M_exeApplication static int M_exeApplication(MfwMnu* m, MfwMnuItem* i);//August 24 e-armanetsaid @@ -704,9 +704,9 @@ static int startConferenceExec(MfwMnu* m, MfwMnuItem* i); static int swapExec(MfwMnu* m, MfwMnuItem* i); static int endAllExec(MfwMnu* m, MfwMnuItem* i); -// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. +// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. // Prototype of the handler for "End held" menu option -static int endHeldExec(MfwMnu* m, MfwMnuItem* i); +static int endHeldExec(MfwMnu* m, MfwMnuItem* i); static int endConferenceExec(MfwMnu* m, MfwMnuItem* i); /* x0039928 - Commented for lint warning removal static int transferExec(MfwMnu* m, MfwMnuItem* i);*/ @@ -716,7 +716,7 @@ static int callExeNameEnter(MfwMnu* m, MfwMnuItem* i); static void showCCNotify (T_MFW_HND win, T_MFW_CM_NOTIFY * cc_notify); -/* x0039928 - Commented for lint warning removal +/* x0039928 - Commented for lint warning removal static int call_incoming_animation_cb(MfwEvt e, MfwTim *t); */ @@ -734,7 +734,7 @@ static void callFailureCause(UBYTE cause); static void sendDTMFString(void); -/* x0039928 - Commented for lint warning removal +/* x0039928 - Commented for lint warning removal static void callCalcCost(char* line); */ @@ -742,10 +742,10 @@ char* callInformation; -//xvilliva SPR13698, strECC used to store the emergency number. +//xvilliva SPR13698, strECC used to store the emergency number. static char strECC[EDITOR_SIZE]; //xvilliva SPR13698, "makeECC" indicating the need to intiate emergency call. -static BOOL makeECC = false; +static BOOL makeECC = false; int callIndex(SHORT cid); char line[MAX_LINE]; @@ -754,7 +754,7 @@ int idwithheld; -// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 +// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 #ifdef FF_MMI_AUDIO_PROFILE extern UBYTE carkitInserted; extern UBYTE headsetInserted; @@ -773,24 +773,24 @@ static T_MFW_MNU_ITEM menuCallSingleItems[] = { {0,0,0, (char*) TxtSoftContacts, 0,(MenuFunc)contactsExec, item_flag_none}, - {0,0,0, (char*) TxtHold, 0,(MenuFunc)holdExec, item_flag_none}, + {0,0,0, (char*) TxtHold, 0,(MenuFunc)holdExec, item_flag_none}, {0,0,0, (char*) TxtMute, 0,(MenuFunc)muteExec, item_flag_none}, -// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 -// new menu items added for all the four different profiles, only one of the -// menu item will be available at any given point fo time +// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 +// new menu items added for all the four different profiles, only one of the +// menu item will be available at any given point fo time #ifdef FF_MMI_AUDIO_PROFILE - {0,0,0, (char*) TxtLoudspeaker, 0, (MenuFunc)M_exeLoudspeaker, item_loudspeaker_status }, - {0,0,0, (char*) TxtHandheld, 0, (MenuFunc)M_exeHandheld, item_handheld_status }, - {0,0,0, (char*) TxtHeadset, 0, (MenuFunc)M_exeHeadset, item_headset_status}, - {0,0,0,(char*) TxtCarkit, 0, (MenuFunc)M_exeCarkit, item_carkit_status}, -#endif - {0,0,0, (char*) TxtSendMessage, 0, (MenuFunc)M_exeSendNew, item_flag_none }, - {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ - {0,0,0, (char*) TxtSettings, 0, (MenuFunc)M_exeSetting, item_flag_none }, //May 27, 2004 REF: CRR 19186 Deepa M.D .//Added Menu item for SMS Setting + {0,0,0, (char*) TxtLoudspeaker, 0, (MenuFunc)M_exeLoudspeaker, item_loudspeaker_status }, + {0,0,0, (char*) TxtHandheld, 0, (MenuFunc)M_exeHandheld, item_handheld_status }, + {0,0,0, (char*) TxtHeadset, 0, (MenuFunc)M_exeHeadset, item_headset_status}, + {0,0,0,(char*) TxtCarkit, 0, (MenuFunc)M_exeCarkit, item_carkit_status}, +#endif + {0,0,0, (char*) TxtSendMessage, 0, (MenuFunc)M_exeSendNew, item_flag_none }, + {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ + {0,0,0, (char*) TxtSettings, 0, (MenuFunc)M_exeSetting, item_flag_none }, //May 27, 2004 REF: CRR 19186 Deepa M.D .//Added Menu item for SMS Setting // Feb 13, 2006 REF:DR OMAPS00067943 x0039928 - // Fix : The Menu function M_exeViewfinder is renamed to M_exeApplication + // Fix : The Menu function M_exeViewfinder is renamed to M_exeApplication // and moved out of FF_MMI_TEST_CAMERA flag. - {0,0,0, (char*) TxtApplications, 0, (MenuFunc)M_exeApplication, item_flag_none }//August 23, 2004 e-armanetsaid.//Added Menu item for Camera test purposes while call ongoing + {0,0,0, (char*) TxtApplications, 0, (MenuFunc)M_exeApplication, item_flag_none }//August 23, 2004 e-armanetsaid.//Added Menu item for Camera test purposes while call ongoing }; static const MfwMnuAttr menuCallSingle = @@ -800,35 +800,35 @@ (U8)-1, /* use default font */ (T_MFW_MNU_ITEM*)menuCallSingleItems, /* with these items */ sizeof(menuCallSingleItems)/sizeof(T_MFW_MNU_ITEM), /* number of items */ - COLOUR_LIST_XX, TxtNull, NULL, MNUATTRSPARE + COLOUR_LIST_XX, TxtNull, NULL, MNUATTRSPARE }; //18/12/2001 MC added sms message option static T_MFW_MNU_ITEM menuCallTwoItems[] = { - {0,0,0, (char*) TxtMultiparty, 0,(MenuFunc)startConferenceExec, item_flag_none}, + {0,0,0, (char*) TxtMultiparty, 0,(MenuFunc)startConferenceExec, item_flag_none}, {0,0,0, (char*) TxtContacts, 0,(MenuFunc)contactsExec, item_flag_none}, {0,0,0, (char*) TxtSwap, 0,(MenuFunc)swapExec, item_flag_swap}, {0,0,0, (char*) TxtEndAll, 0,(MenuFunc)endAllExec, item_flag_none}, - // Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. + // Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. // Code which adds "End held" to the menu which appears when user presses Option soft key when there are atleast two calls // This menu item is displayed only when some call is in hold state - {0,0,0, (char*) TxtEndHeld, 0,(MenuFunc)endHeldExec, item_flag_endheld}, + {0,0,0, (char*) TxtEndHeld, 0,(MenuFunc)endHeldExec, item_flag_endheld}, {0,0,0, (char*) TxtMute, 0,(MenuFunc)muteExec, item_flag_none}, {0,0,0, (char*) TxtHold, 0,(MenuFunc)holdExec, item_flag_hold},//MC -// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 -// new menu items added for all the four different profiles, only one of the -// menu item will be available at any given point fo time +// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 +// new menu items added for all the four different profiles, only one of the +// menu item will be available at any given point fo time #ifdef FF_MMI_AUDIO_PROFILE - {0,0,0, (char*) TxtLoudspeaker, 0, (MenuFunc)M_exeLoudspeaker, item_loudspeaker_status }, - {0,0,0, (char*) TxtHandheld, 0, (MenuFunc)M_exeHandheld, item_handheld_status }, - {0,0,0, (char*) TxtHeadset, 0, (MenuFunc)M_exeHeadset, item_headset_status}, - {0,0,0,(char*) TxtCarkit, 0, (MenuFunc)M_exeCarkit, item_carkit_status}, -#endif - {0,0,0, (char*) TxtSendMessage, 0, (MenuFunc)M_exeSendNew, item_flag_none }, - {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ - {0,0,0, (char*) TxtSettings, 0, (MenuFunc)M_exeSetting, item_flag_none }//May 27, 2004 REF: CRR 19186 Deepa M.D //Added Menu item for SMS Setting + {0,0,0, (char*) TxtLoudspeaker, 0, (MenuFunc)M_exeLoudspeaker, item_loudspeaker_status }, + {0,0,0, (char*) TxtHandheld, 0, (MenuFunc)M_exeHandheld, item_handheld_status }, + {0,0,0, (char*) TxtHeadset, 0, (MenuFunc)M_exeHeadset, item_headset_status}, + {0,0,0,(char*) TxtCarkit, 0, (MenuFunc)M_exeCarkit, item_carkit_status}, +#endif + {0,0,0, (char*) TxtSendMessage, 0, (MenuFunc)M_exeSendNew, item_flag_none }, + {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ + {0,0,0, (char*) TxtSettings, 0, (MenuFunc)M_exeSetting, item_flag_none }//May 27, 2004 REF: CRR 19186 Deepa M.D //Added Menu item for SMS Setting }; static const MfwMnuAttr menuCallTwo = @@ -838,7 +838,7 @@ (U8)-1, /* use default font */ menuCallTwoItems, /* with these items */ sizeof(menuCallTwoItems)/sizeof(T_MFW_MNU_ITEM), /* number of items */ - COLOUR_LIST_XX, TxtNull, NULL, MNUATTRSPARE + COLOUR_LIST_XX, TxtNull, NULL, MNUATTRSPARE }; @@ -852,21 +852,21 @@ {0,0,0, (char*) TxtContacts, 0,(MenuFunc)contactsExec, item_flag_none}, {0,0,0, (char*) TxtHold, 0,(MenuFunc)holdExec, item_flag_hold}, {0,0,0, (char*) TxtMute, 0,(MenuFunc)muteExec, item_flag_none}, -// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 -// new menu items added for all the four different profiles, only one of the -// menu item will be available at any given point fo time +// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 +// new menu items added for all the four different profiles, only one of the +// menu item will be available at any given point fo time #ifdef FF_MMI_AUDIO_PROFILE - {0,0,0, (char*) TxtLoudspeaker, 0, (MenuFunc)M_exeLoudspeaker, item_loudspeaker_status }, - {0,0,0, (char*) TxtHandheld, 0, (MenuFunc)M_exeHandheld, item_handheld_status }, - {0,0,0, (char*) TxtHeadset, 0, (MenuFunc)M_exeHeadset, item_headset_status}, - {0,0,0,(char*) TxtCarkit, 0, (MenuFunc)M_exeCarkit, item_carkit_status}, + {0,0,0, (char*) TxtLoudspeaker, 0, (MenuFunc)M_exeLoudspeaker, item_loudspeaker_status }, + {0,0,0, (char*) TxtHandheld, 0, (MenuFunc)M_exeHandheld, item_handheld_status }, + {0,0,0, (char*) TxtHeadset, 0, (MenuFunc)M_exeHeadset, item_headset_status}, + {0,0,0,(char*) TxtCarkit, 0, (MenuFunc)M_exeCarkit, item_carkit_status}, #endif {0,0,0, (char*) TxtScratchPad, 0,(MenuFunc)scratchPadExec, item_flag_none}, {0,0,0, (char*) TxtMainMenu, 0,(MenuFunc)mainMenuExec, item_flag_none}, - {0,0,0, (char*) TxtSendMessage, 0, (MenuFunc)M_exeSendNew, item_flag_none }, - {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ - {0,0,0, (char*) TxtSettings, 0, (MenuFunc)M_exeSetting, item_flag_none }//May 27, 2004 REF: CRR 19186 Deepa M.D //Added Menu item for SMS Setting + {0,0,0, (char*) TxtSendMessage, 0, (MenuFunc)M_exeSendNew, item_flag_none }, + {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ + {0,0,0, (char*) TxtSettings, 0, (MenuFunc)M_exeSetting, item_flag_none }//May 27, 2004 REF: CRR 19186 Deepa M.D //Added Menu item for SMS Setting }; static const MfwMnuAttr menuCallConference = @@ -876,7 +876,7 @@ (U8)-1, /* use default font */ (T_MFW_MNU_ITEM *)menuCallConferenceItems, /* with these items */ sizeof(menuCallConferenceItems)/sizeof(T_MFW_MNU_ITEM), /* number of items */ - COLOUR_LIST_XX, TxtNull, NULL, MNUATTRSPARE + COLOUR_LIST_XX, TxtNull, NULL, MNUATTRSPARE }; @@ -884,7 +884,7 @@ static const T_MFW_MNU_ITEM menuDTMFItems [] = { {0,0,0, (char*) TxtSendMessage, 0,(MenuFunc)exeSendMessage, item_flag_none}, - {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ + {0,0,0, (char*) TxtMessages, 0, (MenuFunc)M_exeRead, item_flag_none },/*SPR2132*/ {0,0,0, (char*) TxtAddNew, 0,(MenuFunc)callExeNameEnter, item_flag_none} }; @@ -895,16 +895,16 @@ (U8)-1, /* use default font */ (T_MFW_MNU_ITEM *)menuDTMFItems, /* with these items */ sizeof(menuDTMFItems)/sizeof(T_MFW_MNU_ITEM), /* number of items */ - COLOUR_LIST_XX, TxtNull,NULL, MNUATTRSPARE + COLOUR_LIST_XX, TxtNull,NULL, MNUATTRSPARE }; #endif enum { - CALL_STATUS_CALL, - CALL_TIMER_CALL, - CALL_ID_NAME_CALL, - CALL_ID_NUM_CALL + CALL_STATUS_CALL, + CALL_TIMER_CALL, + CALL_ID_NAME_CALL, + CALL_ID_NUM_CALL //x0pleela 23 May, 2006 DR: OMAPS00070657 #ifdef FF_CPHS , @@ -921,9 +921,9 @@ **********************************************************************/ //x0pleela 27 Mar, 2007 ER: OMAPS00122561 #ifdef FF_PHONE_LOCK -extern T_MFW_HND phlock_win_handle; /* to hold the win handle of phone unlock editor window */ -extern T_MFW_HND phlock_kbd_handle; /* to hold the kbd handle of phone unlock editor window */ -extern T_MFW_HND phlock_mtc_win_handle; /* to hold the win handle of MT call window */ +extern T_MFW_HND phlock_win_handle; /* to hold the win handle of phone unlock editor window */ +extern T_MFW_HND phlock_kbd_handle; /* to hold the kbd handle of phone unlock editor window */ +extern T_MFW_HND phlock_mtc_win_handle; /* to hold the win handle of MT call window */ #endif //FF_PHONE_LOCK T_call call_data; @@ -1030,17 +1030,17 @@ typedef struct { - T_MMI_CONTROL mmi_control; - T_MFW_HND win; // window handle - T_MFW_HND kbd; - T_MFW_HND kbd_long; + T_MMI_CONTROL mmi_control; + T_MFW_HND win; // window handle + T_MFW_HND kbd; + T_MFW_HND kbd_long; #ifdef NEW_EDITOR - T_ED_DATA *editor; /* SPR#1428 - SH - New Editor changes */ + T_ED_DATA *editor; /* SPR#1428 - SH - New Editor changes */ #else - T_MFW_HND edt; -#endif - UBYTE mode; - UBYTE callstatus; + T_MFW_HND edt; +#endif + UBYTE mode; + UBYTE callstatus; } T_call_scratchpad; @@ -1058,7 +1058,7 @@ #ifdef NEPTUNE_BOARD #ifdef MMI_POWER_MANAGEMENT_TEST int iIncomingCall = 0; /* Variable for Incoming Call */ -#endif +#endif #endif //x0pleela 03 Nov, 2006 DR: OMAPS000101158 @@ -1077,13 +1077,13 @@ Private Methods *******************************************************************************/ -#if 0 /* FreeCalypso */ -//Daisy tang added for Real Resume feature 20071107 +#if 0 /* FreeCalypso */ +//Daisy tang added for Real Resume feature 20071107 static void mp3_test_real_resume(void) { - IsRealPaused = FALSE; - IsMP3Playing = TRUE; - mfw_fm_audRealResume(); + IsRealPaused = FALSE; + IsMP3Playing = TRUE; + mfw_fm_audRealResume(); } @@ -1113,7 +1113,6 @@ void callInit (MfwHnd parent) { - TRACE_FUNCTION("callInit"); cm_init(); @@ -1140,8 +1139,7 @@ void callExit (void) { - - TRACE_FUNCTION("callExit"); + TRACE_FUNCTION("callExit"); cm_delete(call_data.win); timDelete(call_data.timer); cm_exit(); @@ -1168,17 +1166,17 @@ TRACE_FUNCTION("callAutoRedialKeyEvent"); - call_data.win_redial = 0; - switch (reason) - { - case INFO_KCD_LEFT: - /* - callSetMode(ViewAutoRedial); - cm_redial(); - */ - break; - case INFO_KCD_HUP: - case INFO_KCD_RIGHT: + call_data.win_redial = 0; + switch (reason) + { + case INFO_KCD_LEFT: + /* + callSetMode(ViewAutoRedial); + cm_redial(); + */ + break; + case INFO_KCD_HUP: + case INFO_KCD_RIGHT: case INFO_KCD_CLEAR: cm_redial_abort(); callSetMode(ViewConnect, TRUE); @@ -1220,7 +1218,7 @@ T_MFW_CM_CPI *cmCpi; /* SPR#1352 - SH - TTY */ #ifdef MMI_TTY_ENABLED - T_MFW_CM_CTYI *cmCTYI; + T_MFW_CM_CTYI *cmCTYI; #endif /* end SH */ @@ -1232,21 +1230,21 @@ // heldCall_Id gets the index of a HELD call. SHORT heldCall_Id; -// Aug 24, 2004 REF: CRR MMI-SPR-15750 xkundadu -// activeCall_Id gets the index of a ACTIVE call. +// Aug 24, 2004 REF: CRR MMI-SPR-15750 xkundadu +// activeCall_Id gets the index of a ACTIVE call. SHORT activeCall_Id; //x0pleela 09 Feb, 2007 DR: OMAPS00114834 //This definition is required to get the current ringer settings -#ifndef FF_MIDI_RINGER +#ifndef FF_MIDI_RINGER UBYTE currentRinger; #endif -#ifndef FF_MIDI_RINGER +#ifndef FF_MIDI_RINGER currentRinger = getCurrentRingerSettings(); #endif - TRACE_EVENT_P2("%s %d","callCmEvent ",e); + TRACE_EVENT_P2("%s %d","callCmEvent ",e); switch(e) { @@ -1255,29 +1253,29 @@ * Handle call notifications */ case E_CM_NOTIFY: - TRACE_EVENT("E_CM_NOTIFY"); + TRACE_EVENT("E_CM_NOTIFY"); SEND_EVENT (call_data.win, E_CM_NOTIFY, 0, para); break; - case E_CM_COLP: - TRACE_EVENT("E_CM_COLP"); - SEND_EVENT (call_data.win, E_CM_COLP,0, para); + case E_CM_COLP: + TRACE_EVENT("E_CM_COLP"); + SEND_EVENT (call_data.win, E_CM_COLP,0, para); break; case E_CM_CW: -//Apr 06, 2005 REF: ENH 30011 xdeepadh +//Apr 06, 2005 REF: ENH 30011 xdeepadh #ifdef FF_MMI_TEST_CAMERA #ifdef RVM_CAMA_SWE #ifdef RVM_CAMD_SWE //e-armanetsaid 18/08/04 -enable R2D back when incoming call -might have been disabled by camera test module //Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg //replaced the flag with the function call, to migrate to the new Lcd APIs - if(dspl_control(DSPL_ACCESS_QUERY) == DSPL_ACCESS_DISABLE) + if(dspl_control(DSPL_ACCESS_QUERY) == DSPL_ACCESS_DISABLE) { //Sept 15, 2005 REF: LOCOSTO-ENH-34257 - xpradipg -//replaced the flag with the function call, to migrate to the new Lcd APIs - dspl_control(DSPL_ACCESS_ENABLE); - mfw_cam_disable_sensor(); +//replaced the flag with the function call, to migrate to the new Lcd APIs + dspl_control(DSPL_ACCESS_ENABLE); + mfw_cam_disable_sensor(); } //e-armanetsaid 18/08/04 -enable R2D back when incoming call -might have been disabled by camera test module #endif @@ -1293,34 +1291,34 @@ if(para) incomingCall((T_MFW_CM_CW_INFO*)para); -// Apr 05, 2005 REF: ENH 29994 xdeepadh -//Commented mmesetvolume.since the speaker volume will be set, +// Apr 05, 2005 REF: ENH 29994 xdeepadh +//Commented mmesetvolume.since the speaker volume will be set, //once the call is acknowledged. // mmeSetVolume (1, FFS_flashData.output_volume); break; case E_CM_RING_OFF: - TRACE_EVENT("E_CM_RING_OFF"); + TRACE_EVENT("E_CM_RING_OFF"); //Below original code is commented by x0pleela 09 Feb, 2007 DR: OMAPS00114834 // x0021334 15 May, 2006 DR: OMAPS00075901 // This event comes before incoming call is accepted . Stop call waiting tone. // audio_StopSoundbyID (AUDIO_MICROPHONE, TONES_CW); //x0pleela 15 Feb, 2007 DR: OMAPS00114834 -/* Above original code is commented and the following condition is added to stop - the ringer when MMI recieves the RING_OFF event from ACI rather than stopping - the ringer when user accepts or rejects the call using keypad +/* Above original code is commented and the following condition is added to stop + the ringer when MMI recieves the RING_OFF event from ACI rather than stopping + the ringer when user accepts or rejects the call using keypad */ - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ - - /* Set the Incoming Call Ringer Status as "Stopped" */ - bmi_incomingcall_set_ringer_status(BMI_INCOMING_CALL_NONE); - - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ - - if (LocalRing) + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ + + /* Set the Incoming Call Ringer Status as "Stopped" */ + bmi_incomingcall_set_ringer_status(BMI_INCOMING_CALL_NONE); + + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ + + if (LocalRing) { #ifdef FF_MMI_RINGTONE /* Stop MSL */ audio_StopSoundbyID(AUDIO_MICROPHONE , CALLTONE_SELECT); @@ -1329,69 +1327,69 @@ #endif LocalRing = FALSE; - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ - - /* Vocoder Enable */ - mfw_aud_l1_enable_vocoder(); - - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ + + /* Vocoder Enable */ + mfw_aud_l1_enable_vocoder(); + + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ } - else - { - // Checking whether call is present or not - if(call_data.calls.numCalls) - { - // Checking whether the call is mobile terminated. - if(call_data.call_direction EQ MFW_CM_MTC) - { - // The call is incoming call, So stop the call waiting tone. - audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); - - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ - - /* Vocoder Enable */ - mfw_aud_l1_enable_vocoder(); - - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ - - } - - } - else - { + else + { + // Checking whether call is present or not + if(call_data.calls.numCalls) + { + // Checking whether the call is mobile terminated. + if(call_data.call_direction EQ MFW_CM_MTC) + { + // The call is incoming call, So stop the call waiting tone. + audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); + + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ + + /* Vocoder Enable */ + mfw_aud_l1_enable_vocoder(); + + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ + + } + + } + else + { // stop this ringing tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); - - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ - - /* Set the Incoming Call Ringer Status as "Stopped" */ - bmi_incomingcall_set_ringer_status(BMI_INCOMING_CALL_RINGERSTOPPED); - - /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); + + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- Start */ + + /* Set the Incoming Call Ringer Status as "Stopped" */ + bmi_incomingcall_set_ringer_status(BMI_INCOMING_CALL_RINGERSTOPPED); + + /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */ #else #ifdef FF_MMI_RINGTONE /* Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); #else - // This is to stop the buzzer - audio_StopSoundbyID( AUDIO_BUZZER, getCurrentRingerSettings() ); -#endif -#endif - } - } + // This is to stop the buzzer + audio_StopSoundbyID( AUDIO_BUZZER, getCurrentRingerSettings() ); +#endif +#endif + } + } break; case E_CM_DISCONNECT_ALL: - TRACE_EVENT(" E_CM_DISCONNECT_ALL : Call ended remove All Calls!"); - - call_show_ending_all(); - - removeAllCalls(); - - if (call_data.win) - call_destroy(call_data.win); - + TRACE_EVENT(" E_CM_DISCONNECT_ALL : Call ended remove All Calls!"); + + call_show_ending_all(); + + removeAllCalls(); + + if (call_data.win) + call_destroy(call_data.win); + // Jun 02, 2006 DRT OMAPS00079213 x0039928(sumanth) // Fix: Hook is unregistered if the calls are disconnected. #ifdef FF_MMI_AUDIO_PROFILE @@ -1402,95 +1400,95 @@ #endif - mfw_hook_unregister(); - - -#endif - - //xvilliva SPR13698, After receiving the "E_CM_DISCONNECT_ALL" - //we initiate the MO ECC. We reset the flag and then initiate the call. - if(makeECC == TRUE && strlen(strECC)>0) - { - makeECC = FALSE; - cm_mo_call((UBYTE *)strECC, VOICE_CALL); - } + mfw_hook_unregister(); + + +#endif + + //xvilliva SPR13698, After receiving the "E_CM_DISCONNECT_ALL" + //we initiate the MO ECC. We reset the flag and then initiate the call. + if(makeECC == TRUE && strlen(strECC)>0) + { + makeECC = FALSE; + cm_mo_call((UBYTE *)strECC, VOICE_CALL); + } //x0pleela 24 Mar, 2006 ER:OMAPS00067709 -//stop voice recording +//stop voice recording #ifdef FF_PCM_VM_VB - if( (get_voice_memo_type() EQ VOICE_BUFFERING) AND - (!voice_buffering_data.incoming_call_discon) ) - { - if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) - voice_buffering_stop_playing(); - if( !voice_buffering_data.recording_possible) - voice_buffering_stop_recording(); - } -#endif - -#if 0 /* FreeCalypso */ - //Daisy tang added for Real Resume feature 20071107 - if(IsRealPaused) - timStart( mp3playTimer ); -#endif - break; + if( (get_voice_memo_type() EQ VOICE_BUFFERING) AND + (!voice_buffering_data.incoming_call_discon) ) + { + if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) + voice_buffering_stop_playing(); + if( !voice_buffering_data.recording_possible) + voice_buffering_stop_recording(); + } +#endif + +#if 0 /* FreeCalypso */ + //Daisy tang added for Real Resume feature 20071107 + if(IsRealPaused) + timStart( mp3playTimer ); +#endif + break; case E_CM_DISCONNECT: TRACE_EVENT("E_CM_DISCONNECT"); -//EF assign dc now 29/01/2003 +//EF assign dc now 29/01/2003 dc = (T_MFW_CM_DISCONNECT *)para; if (strlen((char*)call_data.colp_number) > 0) - memset(call_data.colp_number,'\0',sizeof(call_data.colp_number)); - - /* SPR 1392, work out whether we need to remove the call deflection windows*/ - /*if the call to be disconnected is the current incoming call*/ - if ((dc->call_number==call_data.incCall)) - { /*if the deflection editor exists*/ - if (call_data.win_deflectEdit) - { - // Jan 05, 2006 REF:DR OMAPS00050454 x0039928 - // Delete the calling window also - deflect_destroy(TRUE); - } - } + memset(call_data.colp_number,'\0',sizeof(call_data.colp_number)); + + /* SPR 1392, work out whether we need to remove the call deflection windows*/ + /*if the call to be disconnected is the current incoming call*/ + if ((dc->call_number==call_data.incCall)) + { /*if the deflection editor exists*/ + if (call_data.win_deflectEdit) + { + // Jan 05, 2006 REF:DR OMAPS00050454 x0039928 + // Delete the calling window also + deflect_destroy(TRUE); + } + } #ifdef FF_WAP - /* SPR#1983 - SH - Inform WAP of a disconnection */ - AUI_wap_call_disconnect(dc->call_number); -#endif - - /* MZ cq11080 25-07-03 Check to see if call is muted then Unmute.*/ - if (call_data.calls.muted) - { - if (audio_SetMute(AUDIO_MICROPHONE, AUDIO_MUTING_OFF) == DRV_OK) - { - call_data.calls.muted = false; - menuCallSingleItems[2].str = (char*)TxtMute; - } - } + /* SPR#1983 - SH - Inform WAP of a disconnection */ + AUI_wap_call_disconnect(dc->call_number); +#endif + + /* MZ cq11080 25-07-03 Check to see if call is muted then Unmute.*/ + if (call_data.calls.muted) + { + if (audio_SetMute(AUDIO_MICROPHONE, AUDIO_MUTING_OFF) == DRV_OK) + { + call_data.calls.muted = false; + menuCallSingleItems[2].str = (char*)TxtMute; + } + } if (call_data.ignore_disconnect) - { - //x0pleela 15 Mar, 2006 ER:OMAPS00067709 - //stop voice recording + { + //x0pleela 15 Mar, 2006 ER:OMAPS00067709 + //stop voice recording #ifdef FF_PCM_VM_VB - if( get_voice_memo_type() EQ VOICE_BUFFERING ) - { - if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) - voice_buffering_stop_playing(); - if( !voice_buffering_data.recording_possible) - voice_buffering_stop_recording(); - } -#endif -#if 0 /* FreeCalypso */ - //Daisy tang added for Real Resume feature 20071107 - if(IsRealPaused) - timStart( mp3playTimer ); -#endif - - return 1; - } + if( get_voice_memo_type() EQ VOICE_BUFFERING ) + { + if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) + voice_buffering_stop_playing(); + if( !voice_buffering_data.recording_possible) + voice_buffering_stop_recording(); + } +#endif +#if 0 /* FreeCalypso */ + //Daisy tang added for Real Resume feature 20071107 + if(IsRealPaused) + timStart( mp3playTimer ); +#endif + + return 1; + } if (LocalRing) @@ -1502,9 +1500,9 @@ #endif LocalRing = FALSE; } - - - + + + TRACE_EVENT("Disconnect Event"); cm_get_aoc_value(CM_AOC_CCM,&call_data.aocInfo); @@ -1512,110 +1510,110 @@ if (!dc->call_number) // Delete multiparty { -// Oct 6, 2004 REF: CRR 23948 xkundadu -// Description: FT-Brazil-TC 9.2 multiparty using BPM -After multiparty -// 'call ended', mmi doesnot return to idle,but indicates that a call is still.. -// Fix: Call the removeCall() function for all the calls in the multiparty -// in the case of multiparty disconnection. - - // Temporary variable to store the call table entries. -/* Dec 22, 2006 REF:OMAPS00107042 x0039928 */ +// Oct 6, 2004 REF: CRR 23948 xkundadu +// Description: FT-Brazil-TC 9.2 multiparty using BPM -After multiparty +// 'call ended', mmi doesnot return to idle,but indicates that a call is still.. +// Fix: Call the removeCall() function for all the calls in the multiparty +// in the case of multiparty disconnection. + + // Temporary variable to store the call table entries. +/* Dec 22, 2006 REF:OMAPS00107042 x0039928 */ #ifdef FF_MMI_PB_OPTIM T_MFW_CM_STATUS *currentstatus = NULL; #else - T_MFW_CM_STATUS currentstatus[MAX_CALLS] = {-1}; -#endif - UBYTE noOfCalls = 0;//Number of calls - int j; - BOOL bCallEndedShown = FALSE;//To check 'Call ended' screen displayed or not - + T_MFW_CM_STATUS currentstatus[MAX_CALLS] = {-1}; +#endif + UBYTE noOfCalls = 0;//Number of calls + int j; + BOOL bCallEndedShown = FALSE;//To check 'Call ended' screen displayed or not + #ifdef FF_MMI_PB_OPTIM currentstatus = (T_MFW_CM_STATUS *)ALLOC_MEMORY(MAX_CALLS * sizeof(T_MFW_CM_STATUS)); #endif - noOfCalls = call_data.calls.numCalls; - - // Storing the call table to a temperory table. - for( j=0;j<call_data.calls.numCalls;j++) - { - currentstatus[j].call_number = call_data.calls.status[j].call_number; - currentstatus[j].stat = call_data.calls.status[j].stat; - currentstatus[j].mtpy = call_data.calls.status[j].mtpy; - } - - // Check whether the call in the call table is multiparty member or not. - // If it is multiparty member, remove the call table entry for that. - for( j=0;j<noOfCalls;j++) - { - if(currentstatus[j].mtpy == MFW_MTPY_MEMBER) - { - call_data.accessEnd = TRUE; - // Avoid display of 'Call ended' screen multiple times. - if(bCallEndedShown == FALSE) - { - bCallEndedShown = TRUE; - // May 9, 2006 REF:DR OMAPS00074884 xrashmic - removeCall(currentstatus[j].call_number, TRUE,FALSE); - } - else - { - // May 9, 2006 REF:DR OMAPS00074884 xrashmic - removeCall(currentstatus[j].call_number, FALSE,FALSE); - } - - } - } -/* Dec 22, 2006 REF:OMAPS00107042 x0039928 */ + noOfCalls = call_data.calls.numCalls; + + // Storing the call table to a temperory table. + for( j=0;j<call_data.calls.numCalls;j++) + { + currentstatus[j].call_number = call_data.calls.status[j].call_number; + currentstatus[j].stat = call_data.calls.status[j].stat; + currentstatus[j].mtpy = call_data.calls.status[j].mtpy; + } + + // Check whether the call in the call table is multiparty member or not. + // If it is multiparty member, remove the call table entry for that. + for( j=0;j<noOfCalls;j++) + { + if(currentstatus[j].mtpy == MFW_MTPY_MEMBER) + { + call_data.accessEnd = TRUE; + // Avoid display of 'Call ended' screen multiple times. + if(bCallEndedShown == FALSE) + { + bCallEndedShown = TRUE; + // May 9, 2006 REF:DR OMAPS00074884 xrashmic + removeCall(currentstatus[j].call_number, TRUE,FALSE); + } + else + { + // May 9, 2006 REF:DR OMAPS00074884 xrashmic + removeCall(currentstatus[j].call_number, FALSE,FALSE); + } + + } + } +/* Dec 22, 2006 REF:OMAPS00107042 x0039928 */ #ifdef FF_MMI_PB_OPTIM if(currentstatus != NULL) - { FREE_MEMORY((UBYTE*)currentstatus, MAX_CALLS * sizeof(T_MFW_CM_STATUS)); - currentstatus = NULL; - } + { FREE_MEMORY((UBYTE*)currentstatus, MAX_CALLS * sizeof(T_MFW_CM_STATUS)); + currentstatus = NULL; + } #endif } else { if (callIndex(dc->call_number)<MAX_CALLS) - { - // May 9, 2006 REF:DR OMAPS00074884 xrashmic - removeCall(dc->call_number, TRUE,FALSE); // Delete active call + { + // May 9, 2006 REF:DR OMAPS00074884 xrashmic + removeCall(dc->call_number, TRUE,FALSE); // Delete active call // June 08, 2004 REF: CRR MMI-SPR-13876 xkundadu(Sasken) // Issue description: CHW : AUDIO : No difference between CW and incoming call -// If there is one Active call and one wiating call and if the Active call is -// disconnected from the remote side/network side, the waiting tone should +// If there is one Active call and one wiating call and if the Active call is +// disconnected from the remote side/network side, the waiting tone should // change to ringing tone. // Solution: If there is a waiting call and all other calls has been disconnected, -// change the waiting tone to ringing tone. - - // Check whether a waiting call is exisiting - if (cm_search_callId(CAL_STAT_Wait, &waiting_callnumber) EQ CM_OK) - { - // Checking whether there is no other calls - if(!call_data.calls.numCalls) - { - // If there is no other calls, stop the waiting tone and start ringing tone. - audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// change the waiting tone to ringing tone. + + // Check whether a waiting call is exisiting + if (cm_search_callId(CAL_STAT_Wait, &waiting_callnumber) EQ CM_OK) + { + // Checking whether there is no other calls + if(!call_data.calls.numCalls) + { + // If there is no other calls, stop the waiting tone and start ringing tone. + audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh -#ifdef FF_MIDI_RINGER - mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); #else #ifdef NEPTUNE_BOARD #ifdef FF_MMI_RINGTONE /* MSL Ring Tone */ audio_PlaySoundID( AUDIO_BUZZER, CALLTONE_SELECT, 0 , AUDIO_PLAY_INFINITE); #else - audio_PlaySoundID( AUDIO_BUZZER, getCurrentRingerSettings(), + audio_PlaySoundID( AUDIO_BUZZER, getCurrentRingerSettings(), getCurrentVoulmeSettings(), AUDIO_PLAY_INFINITE); #endif #else - audio_PlaySoundID( AUDIO_BUZZER, getCurrentRingerSettings(), 0 , AUDIO_PLAY_INFINITE); + audio_PlaySoundID( AUDIO_BUZZER, getCurrentRingerSettings(), 0 , AUDIO_PLAY_INFINITE); #endif /* END RAVI */ #endif - } - } - } + } + } + } else // Delete not executed call { if ((dc->call_number==call_data.incCall)) @@ -1623,63 +1621,63 @@ if (call_data.win_incoming) { - // Jun 21, 2004 REF: CRR MMI-SPR-17981 xkundadu - // Issue description: RE: S60/Symbian: ACI reports RING messages after an - // incoming call was closed using at+CHLD=1x or ATH - // Solution: If E_CM_DISCONNECT event comes and if incoming call alert is there - // stop the ringing tone. - -// Apr 05, 2005 REF: ENH 29994 xdeepadh + // Jun 21, 2004 REF: CRR MMI-SPR-17981 xkundadu + // Issue description: RE: S60/Symbian: ACI reports RING messages after an + // incoming call was closed using at+CHLD=1x or ATH + // Solution: If E_CM_DISCONNECT event comes and if incoming call alert is there + // stop the ringing tone. + +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /* Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); #else - audio_StopSoundbyID( AUDIO_BUZZER, getCurrentRingerSettings()); + audio_StopSoundbyID( AUDIO_BUZZER, getCurrentRingerSettings()); #endif #endif TRACE_EVENT("Dialog Destroy No 1"); if(idwithheld == TRUE) - idCounter = idCounter + 1; + idCounter = idCounter + 1; SEND_EVENT(call_data.win_incoming,DIALOG_DESTROY,0,0); call_data.win_incoming = 0; } TRACE_EVENT_P2("GET_CAUSE_VALUE(dc->cause %x) EQ %x", dc->cause, GET_CAUSE_VALUE(dc->cause)); - + if (GET_CAUSE_VALUE (dc->cause)!=NOT_PRESENT_8BIT) { //Calling side has terminated the call, turn of ringer MZ. - if(call_data.calls.numCalls) - { - TRACE_EVENT("NDH >>> Stopping TONES_CW in the Microphone"); - audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); - } - else - { - TRACE_EVENT("NDH >>> Stopping current Rigner on the Buzzer"); -// Apr 05, 2005 REF: ENH 29994 xdeepadh + if(call_data.calls.numCalls) + { + TRACE_EVENT("NDH >>> Stopping TONES_CW in the Microphone"); + audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); + } + else + { + TRACE_EVENT("NDH >>> Stopping current Rigner on the Buzzer"); +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh -#ifdef FF_MIDI_RINGER - // Stopping the current ring tone. - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + // Stopping the current ring tone. + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else - /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ - /* currentRinger = getCurrentRingerSettings(); */ + /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ + /* currentRinger = getCurrentRingerSettings(); */ #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); #else - /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ - currentRinger = getCurrentRingerSettings(); - - audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); -#endif -#endif - } + /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ + currentRinger = getCurrentRingerSettings(); + + audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); +#endif +#endif + } //Check if incoming call has been rejected by user, call is not regarded as a missed call. MZ #ifdef FF_2TO1_PS if(dc->cause != M_CC_CAUSE_USER_BUSY ) /*SPR#2217 - DS - Changed MNCC_CAUSE_USER_BUSY to CAUSE_USER_BUSY */ @@ -1700,32 +1698,32 @@ { call_destroy(call_data.win); /* SPR#1985 - SH - Revert to initial TTY setting - * Do not access dc-> after this call, as it will generate - * an event here which will overwrite the previous data */ + * Do not access dc-> after this call, as it will generate + * an event here which will overwrite the previous data */ #ifdef MMI_TTY_ENABLED - call_tty_revert(); + call_tty_revert(); #endif //x0pleela 09 Mar, 2006 ER:OMAPS00067709 -//stop voice recording +//stop voice recording #ifdef FF_PCM_VM_VB - if( (get_voice_memo_type() EQ VOICE_BUFFERING) AND - (!voice_buffering_data.incoming_call_discon) ) - { - if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) - voice_buffering_stop_playing(); - if( !voice_buffering_data.recording_possible) - voice_buffering_stop_recording(); - voice_buffering_data.call_active = FALSE; - vocoder_mute_ul(0); - } - -#endif - -#if 0 /* FreeCalypso */ - //Daisy tang added for Real Resume feature 20071107 - if(IsRealPaused) - timStart( mp3playTimer ); + if( (get_voice_memo_type() EQ VOICE_BUFFERING) AND + (!voice_buffering_data.incoming_call_discon) ) + { + if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) + voice_buffering_stop_playing(); + if( !voice_buffering_data.recording_possible) + voice_buffering_stop_recording(); + voice_buffering_data.call_active = FALSE; + vocoder_mute_ul(0); + } + +#endif + +#if 0 /* FreeCalypso */ + //Daisy tang added for Real Resume feature 20071107 + if(IsRealPaused) + timStart( mp3playTimer ); #endif return 1; } @@ -1748,63 +1746,63 @@ cm_disconnect(call_data.calls.status[0].call_number); } - /* SPR#1985 - SH - Revert to initial TTY setting - * Do not access dc-> after this call, as it will generate - * an event here which will overwrite the previous data */ + /* SPR#1985 - SH - Revert to initial TTY setting + * Do not access dc-> after this call, as it will generate + * an event here which will overwrite the previous data */ #ifdef MMI_TTY_ENABLED - call_tty_revert(); -#endif - - //GW-SPR#1035 - Added SAT changed - /*NM, 110702 - in case that the SAT initiate the setup call (open a new editor); - so we want to make sure that the editor disappear after disconnect - */ - sat_release_the_editor (); - /*NM, 110702 END*/ - - rebuildCalls(); // Marcus: Issue 1795: 12/03/2003 - - // MMI-SPR 13847 xkundadu - // Solution: If there is only one call and if that call is HELD, - // change its status to ACTIVE. - - // Checking whether the disconnection indication is initiated from host - if(bhostDisconnection == TRUE) - { - bhostDisconnection = FALSE; - - // Aug 24, 2004 REF: CRR MMI-SPR-15750 xkundadu - // Bug:"END" function is not implemented for mutiple call - // Solution: In the case of multiparty HELD call or single HELD call - // change its state to ACTIVE. - - if(call_data.calls.numCalls) - { - //If HELD call is there and no ACTIVE call, change the HELD - //call to ACTIVE. - if((cm_search_callId(CAL_STAT_Held, &heldCall_Id) == CM_OK) AND - (cm_search_callId(CAL_STAT_Active, &activeCall_Id) != CM_OK)) - { - // Change the HELD call to ACTIVE call - cm_command(heldCall_Id, CM_RETRIEVE, '\0'); - call_data.current_command = CM_RETRIEVE; - } - } - } + call_tty_revert(); +#endif + + //GW-SPR#1035 - Added SAT changed + /*NM, 110702 + in case that the SAT initiate the setup call (open a new editor); + so we want to make sure that the editor disappear after disconnect + */ + sat_release_the_editor (); + /*NM, 110702 END*/ + + rebuildCalls(); // Marcus: Issue 1795: 12/03/2003 + + // MMI-SPR 13847 xkundadu + // Solution: If there is only one call and if that call is HELD, + // change its status to ACTIVE. + + // Checking whether the disconnection indication is initiated from host + if(bhostDisconnection == TRUE) + { + bhostDisconnection = FALSE; + + // Aug 24, 2004 REF: CRR MMI-SPR-15750 xkundadu + // Bug:"END" function is not implemented for mutiple call + // Solution: In the case of multiparty HELD call or single HELD call + // change its state to ACTIVE. + + if(call_data.calls.numCalls) + { + //If HELD call is there and no ACTIVE call, change the HELD + //call to ACTIVE. + if((cm_search_callId(CAL_STAT_Held, &heldCall_Id) == CM_OK) AND + (cm_search_callId(CAL_STAT_Active, &activeCall_Id) != CM_OK)) + { + // Change the HELD call to ACTIVE call + cm_command(heldCall_Id, CM_RETRIEVE, '\0'); + call_data.current_command = CM_RETRIEVE; + } + } + } //x0pleela 09 Mar, 2006 ER:OMAPS00067709 -//stop voice recording +//stop voice recording #ifdef FF_PCM_VM_VB - if( (get_voice_memo_type() EQ VOICE_BUFFERING) AND - (!voice_buffering_data.incoming_call_discon) ) - { - if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) - voice_buffering_stop_playing(); - if( !voice_buffering_data.recording_possible) - voice_buffering_stop_recording(); - voice_buffering_data.call_active = FALSE; - vocoder_mute_ul(0); - } + if( (get_voice_memo_type() EQ VOICE_BUFFERING) AND + (!voice_buffering_data.incoming_call_discon) ) + { + if(voice_buffering_data.call_active AND (!voice_buffering_data.play_stopped )) + voice_buffering_stop_playing(); + if( !voice_buffering_data.recording_possible) + voice_buffering_stop_recording(); + voice_buffering_data.call_active = FALSE; + vocoder_mute_ul(0); + } #endif @@ -1818,13 +1816,13 @@ if(FFS_flashData.ttyAlwaysOn == FALSE && call_data.tty == CALL_TTY_OFF) #endif - if(call_data.calls.numCalls == 0) - mfw_hook_unregister(); -#endif -#if 0 /* FreeCalypso */ - //Daisy tang added for Real Resume feature 20071107 - if(IsRealPaused) - timStart( mp3playTimer ); + if(call_data.calls.numCalls == 0) + mfw_hook_unregister(); +#endif +#if 0 /* FreeCalypso */ + //Daisy tang added for Real Resume feature 20071107 + if(IsRealPaused) + timStart( mp3playTimer ); #endif break; @@ -1837,25 +1835,25 @@ // Jan 19, 2005 REF: CRR MMI-SPR-27455 xnkulkar // Description: TC 29.3.2.6.7 failed on 900 on R&S -// Solution: function "mfw_aud_l1_enable_vocoder ()" should be called only when the -// call mode is not DATA or FAX - if (cm_search_callMode(*cid) != CAL_MODE_Data AND cm_search_callMode(*cid) != CAL_MODE_Fax) - { - if (call_data.vocoderState == CALL_VOCODER_DISABLED) - { - /* - ** If the Vocoder is disabled, now is the time to re-enable it. - */ - TRACE_EVENT("BMI E_CM_CONNECT_ACK: enable vocoder"); - mfw_aud_l1_enable_vocoder (); - } - - call_data.vocoderState = CALL_VOCODER_INCALL; - } - else - { - TRACE_EVENT("BMI E_CM_CONNECT_ACK: not voice call"); - } +// Solution: function "mfw_aud_l1_enable_vocoder ()" should be called only when the +// call mode is not DATA or FAX + if (cm_search_callMode(*cid) != CAL_MODE_Data AND cm_search_callMode(*cid) != CAL_MODE_Fax) + { + if (call_data.vocoderState == CALL_VOCODER_DISABLED) + { + /* + ** If the Vocoder is disabled, now is the time to re-enable it. + */ + TRACE_EVENT("BMI E_CM_CONNECT_ACK: enable vocoder"); + mfw_aud_l1_enable_vocoder (); + } + + call_data.vocoderState = CALL_VOCODER_INCALL; + } + else + { + TRACE_EVENT("BMI E_CM_CONNECT_ACK: not voice call"); + } if (LocalRing) { @@ -1866,95 +1864,95 @@ #endif LocalRing = FALSE; } - else - { - + else + { + // Jun 08 2004 REF: CRR MMI-SPR-13877 Ajith K P // Issue description: CHW : AUDIO : CW tone not stopped // Solution: When MMI receives the event E_CM_CONNECT_ACK, if number of // calls is greater than 1 and if the call is MTC, Stop the waiting call beep, otherwise stop the, // normal ringing tone. - // Checking whether call is present or not - if(call_data.calls.numCalls) - { - - // Checking whether the call is mobile terminated. - if(call_data.call_direction EQ MFW_CM_MTC) - { - // The call is incoming call, So stop the call waiting tone. - audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); - } - - } - else - { -// Apr 05, 2005 REF: ENH 29994 xdeepadh + // Checking whether call is present or not + if(call_data.calls.numCalls) + { + + // Checking whether the call is mobile terminated. + if(call_data.call_direction EQ MFW_CM_MTC) + { + // The call is incoming call, So stop the call waiting tone. + audio_StopSoundbyID( AUDIO_MICROPHONE, TONES_CW); + } + + } + else + { +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Since there is no other call the ringing tone will be Buzzer, // So stop this ringing tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /* Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); #else - // This is to stop the buzzer - audio_StopSoundbyID( AUDIO_BUZZER, getCurrentRingerSettings() ); -#endif -#endif - } - } - - - - if ((*cid==call_data.incCall)&&(call_data.win_incoming)) - { - SEND_EVENT(call_data.win_incoming,DIALOG_DESTROY,0,0); - call_data.win_incoming = 0; - } - - if ((*cid==call_data.outCall)&&(call_data.win_calling)){ - SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); - call_data.win_calling = 0; - } - // Aug 17, 2004 REF: CRR 6401 xvilliva - // Recitified 'for' loop, Changed from MAX_CALL_NR to MAX_CALLS - // as it is going out of bounds of call_data.calls.status[i] - // which is of size MAX_CALLS only. - //Quick check to see if we're duplicating call table - for (i =0; i<MAX_CALLS; i++) - { - if (*cid == call_data.calls.status[i].call_number) - { - return 1; /*a0393213 lint warning removal - 1 returned*/ - } - } - - call_data.outCall = 0; - call_data.incCall = 0; + // This is to stop the buzzer + audio_StopSoundbyID( AUDIO_BUZZER, getCurrentRingerSettings() ); +#endif +#endif + } + } + + + + if ((*cid==call_data.incCall)&&(call_data.win_incoming)) + { + SEND_EVENT(call_data.win_incoming,DIALOG_DESTROY,0,0); + call_data.win_incoming = 0; + } + + if ((*cid==call_data.outCall)&&(call_data.win_calling)){ + SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); + call_data.win_calling = 0; + } + // Aug 17, 2004 REF: CRR 6401 xvilliva + // Recitified 'for' loop, Changed from MAX_CALL_NR to MAX_CALLS + // as it is going out of bounds of call_data.calls.status[i] + // which is of size MAX_CALLS only. + //Quick check to see if we're duplicating call table + for (i =0; i<MAX_CALLS; i++) + { + if (*cid == call_data.calls.status[i].call_number) + { + return 1; /*a0393213 lint warning removal - 1 returned*/ + } + } + + call_data.outCall = 0; + call_data.incCall = 0; callConnect(*cid); - //xrashmic 21 Aug, 2005 OMAPS00090198 - //The mmeSetVolume is skippen when in a TTY call - #ifdef MMI_TTY_ENABLED - if( call_data.tty == CALL_TTY_OFF ) - #endif - { - mmeSetVolume (1, FFS_flashData.output_volume); - } + //xrashmic 21 Aug, 2005 OMAPS00090198 + //The mmeSetVolume is skippen when in a TTY call + #ifdef MMI_TTY_ENABLED + if( call_data.tty == CALL_TTY_OFF ) + #endif + { + mmeSetVolume (1, FFS_flashData.output_volume); + } #ifdef MMI_TTY_ENABLED - else - { - audio_set_tty(3); - } - #endif + else + { + audio_set_tty(3); + } + #endif //x0pleela 09 Mar, 2006 ER:OMAPS00067709 //Playing the recorded voice for PTT #ifdef FF_PCM_VM_VB if( get_voice_memo_type() EQ VOICE_BUFFERING ) { voice_buffering_data.call_active = TRUE; - voice_buffering_playback_start(); + voice_buffering_playback_start(); } #endif break; @@ -1983,14 +1981,14 @@ call_data.outCall = 0; call_data.incCall = 0; callConnect(*cid); - //xrashmic 21 Aug, 2005 OMAPS00090198 - //The mmeSetVolume is skippen when in a TTY call - #ifdef MMI_TTY_ENABLED - if( call_data.tty == CALL_TTY_OFF ) - #endif - { - mmeSetVolume (1, FFS_flashData.output_volume); - } + //xrashmic 21 Aug, 2005 OMAPS00090198 + //The mmeSetVolume is skippen when in a TTY call + #ifdef MMI_TTY_ENABLED + if( call_data.tty == CALL_TTY_OFF ) + #endif + { + mmeSetVolume (1, FFS_flashData.output_volume); + } break; case E_CM_WAP_CALL_CONNECTED: @@ -2019,30 +2017,30 @@ break; case CM_HOLD_MULTIPARTY: TRACE_EVENT("call CM_HOLD_MULTIPARTY received"); - //Mar 26,2008, OMAPS00164785, x0091220(Daniel) - if(call_data.calls.numCalls>1) - { - call_data.calls.mode = CallConference; - } - else - { - call_data.calls.mode = CallSingle; - } + //Mar 26,2008, OMAPS00164785, x0091220(Daniel) + if(call_data.calls.numCalls>1) + { + call_data.calls.mode = CallConference; + } + else + { + call_data.calls.mode = CallSingle; + } break; case CM_RETRIEVE_MULTIPARTY: TRACE_EVENT("call CM_RETRIEVE_MULTIPARTY received"); - - // Aug 24, 2004 REF: CRR MMI-SPR-15750 xkundadu - // If number of calls greater than one, set the mode to CallConference. - + + // Aug 24, 2004 REF: CRR MMI-SPR-15750 xkundadu + // If number of calls greater than one, set the mode to CallConference. + if(call_data.calls.numCalls >1) - { - call_data.calls.mode = CallConference; - - } - - + { + call_data.calls.mode = CallConference; + + } + + break; case CM_SWAP: TRACE_EVENT("call CM_SWAP received"); @@ -2061,7 +2059,7 @@ { if (call_data.calls.status[i].call_number!=singleCall) { - // May 9, 2006 REF:DR OMAPS00074884 xrashmic + // May 9, 2006 REF:DR OMAPS00074884 xrashmic if (!removeCall(call_data.calls.status[i].call_number, TRUE,FALSE)) i++; } @@ -2076,59 +2074,59 @@ } rebuildCalls(); - if (call_data.win_waiting) - { - SEND_EVENT(call_data.win_waiting,DIALOG_DESTROY,0,0); - call_data.win_waiting = 0; - // Feb 03, 200 REF: CRR 25960 x0012850 + if (call_data.win_waiting) + { + SEND_EVENT(call_data.win_waiting,DIALOG_DESTROY,0,0); + call_data.win_waiting = 0; + // Feb 03, 200 REF: CRR 25960 x0012850 // Description: Call Hold: While one call in Active and other in Held by swapping either of phone is not audible // Solution: Call cm_setSpeechMode() to attach user connection again. - cm_setSpeechMode(); - TRACE_EVENT("destroy call win h"); - } - if (call_data.win_calling) - { - SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); - call_data.win_calling = 0; - TRACE_EVENT("destroy call win i"); - } - - } - if (call_data.accessEnd) - { + cm_setSpeechMode(); + TRACE_EVENT("destroy call win h"); + } + if (call_data.win_calling) + { + SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); + call_data.win_calling = 0; + TRACE_EVENT("destroy call win i"); + } + + } + if (call_data.accessEnd) + { callSetMode(ViewConnect, TRUE); } - /* indicates if a command has failed e.g. ECT MC 12/04/02*/ - if (comm->result == NotPresent) - { - //06 July, 2007 DR: OMAPS00137334 x0062172 Syed - if(call_data.calls.numCalls >= MAX_CALLS) - { - bookShowInformation(call_data.win, TxtConferenceFull,NULL, NULL); - } - else - { - bookShowInformation(call_data.win, TxtFailed,NULL, NULL); /*a0393213 lint warning removal*/ - } - - if (call_data.win_waiting) /*If we're waiting for current command*/ - { /*Get rid of waiting window*/ - SEND_EVENT(call_data.win_waiting,DIALOG_DESTROY,0,0); - call_data.win_waiting = 0; - TRACE_FUNCTION("destroy call win h"); - } + /* indicates if a command has failed e.g. ECT MC 12/04/02*/ + if (comm->result == NotPresent) + { + //06 July, 2007 DR: OMAPS00137334 x0062172 Syed + if(call_data.calls.numCalls >= MAX_CALLS) + { + bookShowInformation(call_data.win, TxtConferenceFull,NULL, NULL); + } + else + { + bookShowInformation(call_data.win, TxtFailed,NULL, NULL); /*a0393213 lint warning removal*/ + } + + if (call_data.win_waiting) /*If we're waiting for current command*/ + { /*Get rid of waiting window*/ + SEND_EVENT(call_data.win_waiting,DIALOG_DESTROY,0,0); + call_data.win_waiting = 0; + TRACE_FUNCTION("destroy call win h"); + } //TISH, patch for OMAPS00129157 //start - if (call_data.win_calling && comm->command==CM_HOLD) - { - SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); - call_data.win_calling = 0; - TRACE_EVENT("destroy call win i"); - } + if (call_data.win_calling && comm->command==CM_HOLD) + { + SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); + call_data.win_calling = 0; + TRACE_EVENT("destroy call win i"); + } //end - } + } break; case E_CM_DTMF: if (call_data.sendingDTMF) @@ -2142,103 +2140,103 @@ pRedial = (T_MFW_CM_REDIAL*)para; if(pRedial == NULL) /*a0393213 lint warnings removal - check for null added*/ { - TRACE_ERROR("callCmEvent():E_CM_REDIAL null parameter"); + TRACE_ERROR("callCmEvent():E_CM_REDIAL null parameter"); } else - { - switch(pRedial->redial_mode) - { - - case CM_REDIAL_BLACKLIST: - TRACE_EVENT("CM_REDIAL_BLACKLIST"); - TRACE_EVENT("the blacklist is now full"); - /* - GSM 2.07 - when the blacklist is full the MT - shall prohibit further automatic call - attempts to any one number until - the blacklist is manually cleared at the MT - - The blacklist is cleared after switch off/on ?! - */ - break; - case CM_REDIAL_NO_SERVICE: - TRACE_EVENT("CM_REDIAL_NO_SERVICE"); - break; - case CM_REDIAL_OUTGOING: - TRACE_EVENT("CM_REDIAL_OUTGOING"); - case CM_REDIAL_INCOMING: - TRACE_EVENT("CM_REDIAL_INCOMING"); - case CM_REDIAL_ABORTED: - TRACE_EVENT("CM_REDIAL_ABORTED"); - case CM_REDIAL_BLACKLISTED : - TRACE_EVENT("CM_REDIAL_BLACKLISTED"); - - if (call_data.win_redial) - { - SEND_EVENT(call_data.win_redial,DIALOG_DESTROY,0,0); - call_data.win_redial = 0; - TRACE_EVENT("destroy redial win "); - } - - break; - case CM_REDIAL_SUCCESS: - TRACE_EVENT("CM_REDIAL_SUCCESS"); - - if (call_data.win_redial) - { - SEND_EVENT(call_data.win_redial,DIALOG_DESTROY,0,0); - call_data.win_redial = 0; - TRACE_EVENT("destroy redial win "); - } - rebuildCalls(); - break; - - case CM_REDIAL_STARTED: - TRACE_EVENT("CM_REDIAL_STARTED"); - /* */ - - - - - if (call_data.win_calling) - { - SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); - call_data.win_calling = 0; - TRACE_EVENT("destroy call call_win"); - } - - if (pRedial->left_attempts EQ 0 ) // Not yet started redial attempts - { - /* start the 1st repeat attempt */ - cm_autoredial_start(); - } - callSetMode(ViewAutoRedial, TRUE); - break; - - case CM_REDIAL_STOP: - TRACE_EVENT("E_CM_REDIAL_STOP"); - if (call_data.win_redial) - { - SEND_EVENT(call_data.win_redial,DIALOG_DESTROY,0,0); - call_data.win_redial = 0; - } - rebuildCalls(); - break; - case CM_REDIAL_ATTEMPT: - TRACE_EVENT("E_CM_REDIAL ATTEMPT"); - break; - default: - break; - } - } + { + switch(pRedial->redial_mode) + { + + case CM_REDIAL_BLACKLIST: + TRACE_EVENT("CM_REDIAL_BLACKLIST"); + TRACE_EVENT("the blacklist is now full"); + /* + GSM 2.07 + when the blacklist is full the MT + shall prohibit further automatic call + attempts to any one number until + the blacklist is manually cleared at the MT + + The blacklist is cleared after switch off/on ?! + */ + break; + case CM_REDIAL_NO_SERVICE: + TRACE_EVENT("CM_REDIAL_NO_SERVICE"); + break; + case CM_REDIAL_OUTGOING: + TRACE_EVENT("CM_REDIAL_OUTGOING"); + case CM_REDIAL_INCOMING: + TRACE_EVENT("CM_REDIAL_INCOMING"); + case CM_REDIAL_ABORTED: + TRACE_EVENT("CM_REDIAL_ABORTED"); + case CM_REDIAL_BLACKLISTED : + TRACE_EVENT("CM_REDIAL_BLACKLISTED"); + + if (call_data.win_redial) + { + SEND_EVENT(call_data.win_redial,DIALOG_DESTROY,0,0); + call_data.win_redial = 0; + TRACE_EVENT("destroy redial win "); + } + + break; + case CM_REDIAL_SUCCESS: + TRACE_EVENT("CM_REDIAL_SUCCESS"); + + if (call_data.win_redial) + { + SEND_EVENT(call_data.win_redial,DIALOG_DESTROY,0,0); + call_data.win_redial = 0; + TRACE_EVENT("destroy redial win "); + } + rebuildCalls(); + break; + + case CM_REDIAL_STARTED: + TRACE_EVENT("CM_REDIAL_STARTED"); + /* */ + + + + + if (call_data.win_calling) + { + SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); + call_data.win_calling = 0; + TRACE_EVENT("destroy call call_win"); + } + + if (pRedial->left_attempts EQ 0 ) // Not yet started redial attempts + { + /* start the 1st repeat attempt */ + cm_autoredial_start(); + } + callSetMode(ViewAutoRedial, TRUE); + break; + + case CM_REDIAL_STOP: + TRACE_EVENT("E_CM_REDIAL_STOP"); + if (call_data.win_redial) + { + SEND_EVENT(call_data.win_redial,DIALOG_DESTROY,0,0); + call_data.win_redial = 0; + } + rebuildCalls(); + break; + case CM_REDIAL_ATTEMPT: + TRACE_EVENT("E_CM_REDIAL ATTEMPT"); + break; + default: + break; + } + } break; case E_CM_MO_RES: { T_MFW_PHB_ENTRY phb_entry; // Sep 01, 2006 REF:OMAPS00090555 x0039928 // Fix : Get the outgoing call data/number from the parameter passed to callCmEvent - T_MFW_CM_MO_INFO *outgoing_call_data = (T_MFW_CM_MO_INFO*) para; + T_MFW_CM_MO_INFO *outgoing_call_data = (T_MFW_CM_MO_INFO*) para; T_MFW_CM_AOC_INFO aoc_info; char * v_Number = NULL; cid = &(outgoing_call_data->call_id); @@ -2273,24 +2271,24 @@ #else audio_StopSoundbyID(AUDIO_MICROPHONE ,TONES_RINGING_TONE); #endif - LocalRing = FALSE; + LocalRing = FALSE; } /* SPR#1983 - SH - Notify WAP if a data call is set up */ #ifdef FF_WAP - { - T_MFW_CM_CALL_STAT stat; - UBYTE ton; - UBYTE mode; - - cm_search_callStat(*cid, &stat, &ton, &mode); - - if (mode == DATA_CALL) - { - AUI_wap_call_connect(*cid); - } - } + { + T_MFW_CM_CALL_STAT stat; + UBYTE ton; + UBYTE mode; + + cm_search_callStat(*cid, &stat, &ton, &mode); + + if (mode == DATA_CALL) + { + AUI_wap_call_connect(*cid); + } + } #endif /* set the outcall ID */ @@ -2298,7 +2296,7 @@ call_data.call_direction = MFW_CM_MOC; /* set local pointer to number from outgoing call data */ -// Sep 01, 2006 REF:OMAPS00090555 x0039928 +// Sep 01, 2006 REF:OMAPS00090555 x0039928 v_Number = (char*)(outgoing_call_data->number); TRACE_EVENT_P1("(char*)outgoing_call_data.number: %s", outgoing_call_data->number); @@ -2319,16 +2317,16 @@ //Ensure calling string is NULL terminated call_data.phbNameNumber[sizeof(call_data.phbNameNumber)-1] = 0; } - //x0pleela 03 Nov, 2006 DR: OMAPS000101158 - //check the value of uOthersrc - //If the value is not set then do the phone book search operation - //Else do not perform phone book search operation - //this is to avoid stack overflow probelm when the source id is not LOCAL - if(!mfw_get_OtherSrc_Value()) - { + //x0pleela 03 Nov, 2006 DR: OMAPS000101158 + //check the value of uOthersrc + //If the value is not set then do the phone book search operation + //Else do not perform phone book search operation + //this is to avoid stack overflow probelm when the source id is not LOCAL + if(!mfw_get_OtherSrc_Value()) + { #ifdef NO_ASCIIZ - // else //x0pleela 03 Nov, 2006 DR: OMAPS000101158 - if ((bookFindNameInSDNPhonebook(v_Number, &phb_entry) == 1) && (phb_entry.name.len != 0) ) + // else //x0pleela 03 Nov, 2006 DR: OMAPS000101158 + if ((bookFindNameInSDNPhonebook(v_Number, &phb_entry) == 1) && (phb_entry.name.len != 0) ) { memcpy(call_data.phbNameNumber, (char*)phb_entry.name.data, sizeof(call_data.phbNameNumber)-1); call_data.phbNameNumber[sizeof(call_data.phbNameNumber)-1] = 0; @@ -2357,11 +2355,11 @@ /* Marcus: Issue 987: 18/09/2002: Ensured call_data.phbNameNumber null terminated */ call_data.phbNameNumber[sizeof(call_data.phbNameNumber)-1] = 0; /*MC end*/ -// Sep 01, 2006 REF:OMAPS00090555 x0039928 +// Sep 01, 2006 REF:OMAPS00090555 x0039928 if ( (outgoing_call_data->ton == MFW_TON_INTERNATIONAL) && ( outgoing_call_data->number[0] != '+') ) { - char InterNat_Plus[EDITOR_SIZE]; /* NDH : This should NOT be static!& the size is determined by calldata.phbNameNumber */ + char InterNat_Plus[EDITOR_SIZE]; /* NDH : This should NOT be static!& the size is determined by calldata.phbNameNumber */ TRACE_EVENT("International Call Required!"); // API - 826 - Create a buffer and a plus to the start of the buffer then add the out going number @@ -2373,11 +2371,11 @@ } } - //x0pleela 03 Nov, 2006 DR: OMAPS000101158 - //check the value of uOthersrc - //If the value is set then reset it to FALSE - if(mfw_get_OtherSrc_Value()) - mfw_set_OtherSrc_Value(FALSE); + //x0pleela 03 Nov, 2006 DR: OMAPS000101158 + //check the value of uOthersrc + //If the value is set then reset it to FALSE + if(mfw_get_OtherSrc_Value()) + mfw_set_OtherSrc_Value(FALSE); if (call_SATCall == TRUE) { @@ -2395,58 +2393,58 @@ /* create the outgoing call dialog */ call_calling_show(MMI_OUTGOING_CALL_DIALOG_NORMAL); } - } + } break; case E_CM_TIMER_EVERY_SECOND: TRACE_EVENT("EVERY_SECOND"); refreshCallTimer(); cm_get_aoc_value(CM_AOC_CCM,&call_data.aocInfo); - TRACE_EVENT_P1("winIsFocussed(call_data.win) %d",winIsFocussed(call_data.win)); - - /* SPR#1602 - SH - Uncomment check to see if window is focussed */ - // Oct 27, 2004 REF: CRR MMI-SPR-15632 xnkulkar - // Description: SMS : class 2 and 3 SMSMT : icon not displayed when 2 active calls - // Fix: condition "call_data.calls.mode == CallSingle" is removed to make the sms icon visible - // even if there are more than one calls present. - if (winIsFocussed(call_data.win) - //x0pleela 27 Mar, 2007 ER: OMAPS00122561 + TRACE_EVENT_P1("winIsFocussed(call_data.win) %d",winIsFocussed(call_data.win)); + + /* SPR#1602 - SH - Uncomment check to see if window is focussed */ + // Oct 27, 2004 REF: CRR MMI-SPR-15632 xnkulkar + // Description: SMS : class 2 and 3 SMSMT : icon not displayed when 2 active calls + // Fix: condition "call_data.calls.mode == CallSingle" is removed to make the sms icon visible + // even if there are more than one calls present. + if (winIsFocussed(call_data.win) + //x0pleela 27 Mar, 2007 ER: OMAPS00122561 #ifdef FF_PHONE_LOCK - || ((!phlock_win_handle) || (mmiPinsEmergencyCall())) + || ((!phlock_win_handle) || (mmiPinsEmergencyCall())) #endif //FF_PHONE_LOCK - ) - winShow(call_data.win); + ) + winShow(call_data.win); break; case E_CM_CPI: - { - T_DISPLAY_DATA display_info; /* cq11676: User Busy indication for E plus. 10-02-04 MZ */ - cmCpi = (T_MFW_CM_CPI*)para; - TRACE_EVENT_P5("callCmEvent - CPI : Call No %d, type %d, InBand %d, TCh %d, Cause 0x%4x ", - cmCpi->call_number, - cmCpi->type, - cmCpi->inband, - cmCpi->tch, - cmCpi ->cause); - - if (cmCpi->type == CPI_TYPE_ALERT)/*a0393213 lint warnings removal - CPI_MSG_Alert changed to CPI_TYPE_ALERT*/ + { + T_DISPLAY_DATA display_info; /* cq11676: User Busy indication for E plus. 10-02-04 MZ */ + cmCpi = (T_MFW_CM_CPI*)para; + TRACE_EVENT_P5("callCmEvent - CPI : Call No %d, type %d, InBand %d, TCh %d, Cause 0x%4x ", + cmCpi->call_number, + cmCpi->type, + cmCpi->inband, + cmCpi->tch, + cmCpi ->cause); + + if (cmCpi->type == CPI_TYPE_ALERT)/*a0393213 lint warnings removal - CPI_MSG_Alert changed to CPI_TYPE_ALERT*/ { if (!cmCpi->inband) { -/* RAVI - 20-1-2006 */ -/* Silent Implementation */ +/* RAVI - 20-1-2006 */ +/* Silent Implementation */ #ifdef NEPTUNE_BOARD #ifdef FF_MMI_RINGTONE audio_PlaySoundID(AUDIO_MICROPHONE, CALLTONE_SELECT, 0, AUDIO_PLAY_INFINITE); #else - audio_PlaySoundID( AUDIO_MICROPHONE, TONES_RINGING_TONE, + audio_PlaySoundID( AUDIO_MICROPHONE, TONES_RINGING_TONE, getCurrentVoulmeSettings(), AUDIO_PLAY_INFINITE); #endif #else - /* Testcase 26.8.x - generated internal alert */ - audio_PlaySoundID(AUDIO_MICROPHONE, TONES_RINGING_TONE, 0, AUDIO_PLAY_INFINITE); -#endif - LocalRing = TRUE; + /* Testcase 26.8.x - generated internal alert */ + audio_PlaySoundID(AUDIO_MICROPHONE, TONES_RINGING_TONE, 0, AUDIO_PLAY_INFINITE); +#endif + LocalRing = TRUE; } else if (LocalRing) { @@ -2461,65 +2459,65 @@ } else if ((cmCpi->type == CPI_TYPE_SYNC) && (cmCpi->tch)) /*a0393213 lint warnings removal - CPI_MSG_Sync changed to CPI_TYPE_SYNC*/ { - /* - ** check whether this is an incoming call from Idle, as the Vocoder should not be disabled if - ** we are already in a call, or if Late Traffic Channel assignment has caused the channel to be - ** assigned after the call has been accepted. - */ - if (call_data.vocoderState == CALL_VOCODER_IDLE) - { - /* - ** A the Traffic Channel is assigned the Vocoder will have been turned on by Layer1. - ** Disable the Vocoder, so that an E2 Melody can be played - */ - mfw_aud_l1_disable_vocoder(); - - call_data.vocoderState = CALL_VOCODER_DISABLED; - } - + /* + ** check whether this is an incoming call from Idle, as the Vocoder should not be disabled if + ** we are already in a call, or if Late Traffic Channel assignment has caused the channel to be + ** assigned after the call has been accepted. + */ + if (call_data.vocoderState == CALL_VOCODER_IDLE) + { + /* + ** A the Traffic Channel is assigned the Vocoder will have been turned on by Layer1. + ** Disable the Vocoder, so that an E2 Melody can be played + */ + mfw_aud_l1_disable_vocoder(); + + call_data.vocoderState = CALL_VOCODER_DISABLED; + } + } else if((cmCpi->type == CPI_TYPE_DISC) && (cmCpi->inband)) /*a0393213 lint warnings removal - CPI_MSG_Disc changed to CPI_TYPE_DISC*/ - { - /* cq11676: Display the Number busy indication on receiving the Disconnect cause and allow user to stay in calling screen - untill the final Traffic channel Release indication has been received. Specific for E+ network. 17-02-04 MZ */ - + { + /* cq11676: Display the Number busy indication on receiving the Disconnect cause and allow user to stay in calling screen + untill the final Traffic channel Release indication has been received. Specific for E+ network. 17-02-04 MZ */ + #ifdef FF_2TO1_PS - if ( cmCpi->cause == CAUSE_NWCC_USER_BUSY) + if ( cmCpi->cause == CAUSE_NWCC_USER_BUSY) #else - if ( cmCpi->cause == M_CC_CAUSE_USER_BUSY) + if ( cmCpi->cause == M_CC_CAUSE_USER_BUSY) #endif { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNumberBusy, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); - info_dialog(idle_get_window(), &display_info); - } - - } + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNumberBusy, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); + info_dialog(idle_get_window(), &display_info); + } + + } } break; /*MC SPR 1392, call deflection status*/ - case E_CM_CALL_DEFLECT_STATUS: - { BOOL* result = para; - T_DISPLAY_DATA display_info; - - - if (*result == TRUE)/*If call deflection was successful*/ - { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtDone, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); - } - else/*if call deflection failed*/ - { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtFailed, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); - } - /*Show dialog*/ - info_dialog(idle_get_window(), &display_info); - /*destroy the call deflection windows and the call windows if no active call*/ - deflect_destroy(TRUE); - - } - break; + case E_CM_CALL_DEFLECT_STATUS: + { BOOL* result = para; + T_DISPLAY_DATA display_info; + + + if (*result == TRUE)/*If call deflection was successful*/ + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtDone, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); + } + else/*if call deflection failed*/ + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtFailed, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); + } + /*Show dialog*/ + info_dialog(idle_get_window(), &display_info); + /*destroy the call deflection windows and the call windows if no active call*/ + deflect_destroy(TRUE); + + } + break; /* Marcus: CCBS: 14/11/2002: Start */ case E_CM_CCBS: TRACE_EVENT("E_CM_CCBS"); @@ -2533,26 +2531,26 @@ cmCTYI = (T_MFW_CM_CTYI*)para; switch (cmCTYI->neg) { - case CTYI_REJECT: - TRACE_EVENT("CTYI REJECT"); - /* TTY rejected, switch it off */ - - call_tty_set(CALL_TTY_OFF); - call_tty_statuswin(); - break; - case CTYI_GRANT: - TRACE_EVENT("CTYI GRANT"); - /* If user has set "always on", then set that status. - * Otherwise, we're just switching on TTY for the next - * call */ - - if (FFS_flashData.ttyAlwaysOn) - call_tty_set(CALL_TTY_ALWAYSON); - else - call_tty_set(CALL_TTY_ONNEXTCALL); - - call_tty_statuswin(); - break; + case CTYI_REJECT: + TRACE_EVENT("CTYI REJECT"); + /* TTY rejected, switch it off */ + + call_tty_set(CALL_TTY_OFF); + call_tty_statuswin(); + break; + case CTYI_GRANT: + TRACE_EVENT("CTYI GRANT"); + /* If user has set "always on", then set that status. + * Otherwise, we're just switching on TTY for the next + * call */ + + if (FFS_flashData.ttyAlwaysOn) + call_tty_set(CALL_TTY_ALWAYSON); + else + call_tty_set(CALL_TTY_ONNEXTCALL); + + call_tty_statuswin(); + break; } break; #endif @@ -2616,23 +2614,23 @@ { dspl_ClearAll(); GlobalIconStatus = GlobalSignalIconFlag | GlobalBatteryIconFlag - | GlobalSMSIconFlag| GlobalVoiceMailIconFlag - | GlobalCallForwardingIconFlag| GlobalKeyplockIconFlag - | GlobalRingerIconFlag | GlobalRingVibrIconFlag - | GlobalVibratorIconFlag | GlobalAlarmIconFlag - | GlobalSilentRingerIconFlag|GlobalCipheringActivIconFlag - | GlobalCipheringDeactivIconFlag + | GlobalSMSIconFlag| GlobalVoiceMailIconFlag + | GlobalCallForwardingIconFlag| GlobalKeyplockIconFlag + | GlobalRingerIconFlag | GlobalRingVibrIconFlag + | GlobalVibratorIconFlag | GlobalAlarmIconFlag + | GlobalSilentRingerIconFlag|GlobalCipheringActivIconFlag + | GlobalCipheringDeactivIconFlag /* SH 18/01/02. Flag for GPRS On icon. Note: Homezone icon not displayed during call. */ - #ifdef MMI_GPRS_ENABLED - | GlobalGPRSOnIconFlag - #endif - /* SPR#1352 - SH - Flag for TTY icon */ - #ifdef MMI_TTY_ENABLED - | GlobalTTYIconFlag - #endif - /* SH end */ - ; + #ifdef MMI_GPRS_ENABLED + | GlobalGPRSOnIconFlag + #endif + /* SPR#1352 - SH - Flag for TTY icon */ + #ifdef MMI_TTY_ENABLED + | GlobalTTYIconFlag + #endif + /* SH end */ + ; iconsShow(); } @@ -2673,50 +2671,50 @@ showDefault(); memset(tag,'\0',sizeof(tag)); if (call_data.calls.numCalls<MAX_CALLS) - topLine = Mmi_layout_line(2); + topLine = Mmi_layout_line(2); else - topLine = Mmi_layout_line(1); + topLine = Mmi_layout_line(1); for (i=0;i<call_data.calls.numCalls;i++) { memset(line,'\0',sizeof(line)); memset(tag,'\0',sizeof(tag)); sprintf(line,"%d",i+1); if (call_data.calls.status[i].stat == CALL_ACTIVE) - stat = 'A'; + stat = 'A'; else - stat = 'H'; - sprintf(line,"%d.%c.",i+1,stat); + stat = 'H'; + sprintf(line,"%d.%c.",i+1,stat); if (i==callIndex(call_data.calls.selected)) - dspl_TextOut(CALLINFO_X_AH, (USHORT)(topLine+Mmi_layout_line_height()*i), DSPL_TXTATTR_INVERS, line); + dspl_TextOut(CALLINFO_X_AH, (USHORT)(topLine+Mmi_layout_line_height()*i), DSPL_TXTATTR_INVERS, line); else - dspl_TextOut(CALLINFO_X_AH, (USHORT)(topLine+Mmi_layout_line_height()*i), 0, line); + dspl_TextOut(CALLINFO_X_AH, (USHORT)(topLine+Mmi_layout_line_height()*i), 0, line); #ifdef NO_ASCIIZ /*MC, SPR 1257, merge from 3.3.3*/ if (call_data.calls.status[i].name.len > 0) { - resources_truncate_to_screen_width((char*)call_data.calls.status[i].name.data,call_data.calls.status[i].name.len ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,FALSE); + resources_truncate_to_screen_width((char*)call_data.calls.status[i].name.data,call_data.calls.status[i].name.len ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,FALSE); } /*MC end*/ #else if (strlen((char*)call_data.calls.status[i].name) > 0) { - resources_truncate_to_screen_width(call_data.calls.status[i].name,0 ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,FALSE); - } -#endif - else + resources_truncate_to_screen_width(call_data.calls.status[i].name,0 ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,FALSE); + } +#endif + else if (strlen((char*)call_data.calls.status[i].number) > 0) { - resources_truncate_to_screen_width((char*)call_data.calls.status[i].number,0 ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,FALSE); + resources_truncate_to_screen_width((char*)call_data.calls.status[i].number,0 ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,FALSE); } else { - resources_truncate_to_screen_width(GET_TEXT(TxtSoftCall),0 ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,TRUE); + resources_truncate_to_screen_width(GET_TEXT(TxtSoftCall),0 ,(char*)tag,MAX_CHAR-2, SCREEN_SIZE_X,TRUE); } if (i==callIndex(call_data.calls.selected)) - dspl_TextOut(CALLINFO_X_TAGPOS,(USHORT)(topLine+Mmi_layout_line_height()*i), DSPL_TXTATTR_INVERS, tag); + dspl_TextOut(CALLINFO_X_TAGPOS,(USHORT)(topLine+Mmi_layout_line_height()*i), DSPL_TXTATTR_INVERS, tag); else - dspl_TextOut(CALLINFO_X_TAGPOS,(USHORT)(topLine+Mmi_layout_line_height()*i), 0, tag); + dspl_TextOut(CALLINFO_X_TAGPOS,(USHORT)(topLine+Mmi_layout_line_height()*i), 0, tag); } displaySoftKeys(TxtSoftSelect,TxtEnd); } @@ -2741,7 +2739,7 @@ TRACE_FUNCTION("showWaitingAnswer"); showDefault(); - PROMPT(TXTMESSAGE_X, Mmi_layout_line(2), 0, TxtPleaseWait); + PROMPT(TXTMESSAGE_X, Mmi_layout_line(2), 0, TxtPleaseWait); displaySoftKeys(TxtCancel,'\0'); } @@ -2765,7 +2763,7 @@ TRACE_FUNCTION("showSendingDTMF"); showDefault(); - PROMPT(TXTMESSAGE_X, Mmi_layout_line(2), 0, TxtSendingDTMF); + PROMPT(TXTMESSAGE_X, Mmi_layout_line(2), 0, TxtSendingDTMF); displaySoftKeys(TxtCancel,'\0'); } @@ -2827,7 +2825,7 @@ { /*SPR 1392, check for valid incoming call ID rather than existence of incoming call window. During the setting up of call deflection, the incoming call screen doesn't exist*/ if ((!call_data.incCall) && (!call_data.win_calling)&&(call_data.win)) - call_destroy(call_data.win); + call_destroy(call_data.win); return; } break; @@ -2859,78 +2857,78 @@ getTimeString(call_data.timeEnded,(char*)line); setLastCallDuration(call_data.timeEnded, call_data.call_direction); - if (dialogDisp) - { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallEnded, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_ending_cb, THREE_SECS, KEY_CLEAR ); - - /* - * Call Info Screen - */ - call_data.win_ending = info_dialog (call_data.win, &display_info); - } + if (dialogDisp) + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallEnded, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_ending_cb, THREE_SECS, KEY_CLEAR ); + + /* + * Call Info Screen + */ + call_data.win_ending = info_dialog (call_data.win, &display_info); + } } break; case ViewAutoRedial: - memset(line,'\0',sizeof(line)); - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtCancel, TxtAutoredial, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)callAutoRedialKeyEvent, FOREVER, KEY_RIGHT|KEY_CLEAR|KEY_HUP ); - display_info.TextString2 = (char*)call_data.phbNameNumber; - - call_data.win_redial = info_dialog (call_data.win, &display_info); + memset(line,'\0',sizeof(line)); + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtCancel, TxtAutoredial, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)callAutoRedialKeyEvent, FOREVER, KEY_RIGHT|KEY_CLEAR|KEY_HUP ); + display_info.TextString2 = (char*)call_data.phbNameNumber; + + call_data.win_redial = info_dialog (call_data.win, &display_info); break; default: break; } - switch (mode) - { - case ViewDTMF: - call_data.calls.view = ViewDTMF; - /* SPR#1428 - SH - New Editor changes */ + switch (mode) + { + case ViewDTMF: + call_data.calls.view = ViewDTMF; + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - call_data.editorAttrDTMF.cursor = ED_CURSOR_BAR; + call_data.editorAttrDTMF.cursor = ED_CURSOR_BAR; #else /* NEW_EDITOR */ - call_data.edtAttrDTMF.mode = edtCurBar1; + call_data.edtAttrDTMF.mode = edtCurBar1; #endif /* NEW_EDITOR */ - break; - - case ViewScratchPad: - call_data.calls.view = ViewScratchPad; - /* SPR#1428 - SH - New Editor changes */ + break; + + case ViewScratchPad: + call_data.calls.view = ViewScratchPad; + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - call_data.editorAttrDTMF.cursor = ED_CURSOR_BAR; + call_data.editorAttrDTMF.cursor = ED_CURSOR_BAR; #else /* NEW_EDITOR */ - call_data.edtAttrDTMF.mode = edtCurBar1; + call_data.edtAttrDTMF.mode = edtCurBar1; #endif /* NEW_EDITOR */ break; case ViewSelectPrivateCall: - call_data.calls.view = ViewSelectPrivateCall; + call_data.calls.view = ViewSelectPrivateCall; break; //GW Added - case ViewShortWait: - dlg_initDisplayData_TextId( &display_info, TxtCancel, TxtNull, TxtPleaseWait, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_waiting_answer_cb, ONE_SECS, KEY_LEFT ); - display_info.TextString2 = (char*)line; - call_data.win_waiting = info_dialog (call_data.win, &display_info); + case ViewShortWait: + dlg_initDisplayData_TextId( &display_info, TxtCancel, TxtNull, TxtPleaseWait, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_waiting_answer_cb, ONE_SECS, KEY_LEFT ); + display_info.TextString2 = (char*)line; + call_data.win_waiting = info_dialog (call_data.win, &display_info); break; - case ViewWaitingAnswer: - dlg_initDisplayData_TextId( &display_info, TxtCancel, TxtNull, TxtPleaseWait, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_waiting_answer_cb, FOREVER, KEY_LEFT ); - display_info.TextString2 = NULL; - call_data.win_waiting = info_dialog (call_data.win, &display_info); + case ViewWaitingAnswer: + dlg_initDisplayData_TextId( &display_info, TxtCancel, TxtNull, TxtPleaseWait, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_waiting_answer_cb, FOREVER, KEY_LEFT ); + display_info.TextString2 = NULL; + call_data.win_waiting = info_dialog (call_data.win, &display_info); break; case ViewSendingDTMF: - dlg_initDisplayData_TextId( &display_info, TxtCancel, TxtNull, TxtSendingDTMF, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_sending_dtmf_cb, FOREVER, KEY_LEFT ); - display_info.TextString2 = (char*)line; - call_data.win_sending_dtmf = info_dialog (call_data.win, &display_info); + dlg_initDisplayData_TextId( &display_info, TxtCancel, TxtNull, TxtSendingDTMF, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_sending_dtmf_cb, FOREVER, KEY_LEFT ); + display_info.TextString2 = (char*)line; + call_data.win_sending_dtmf = info_dialog (call_data.win, &display_info); break; default: break; @@ -2968,67 +2966,67 @@ } -//May 27, 2004 REF: CRR 19186 Deepa M.D -/******************************************************************************* - - $Function: M_exeSetting - - $Description: This function is called when the user press "Settings" in the - Active call "options" screen.This function creates and displays the - SMS Settings menu in an active call screen. - - $Returns: Execution status - - $Arguments: m - menu handler - i - Menu item selected - +//May 27, 2004 REF: CRR 19186 Deepa M.D +/******************************************************************************* + + $Function: M_exeSetting + + $Description: This function is called when the user press "Settings" in the + Active call "options" screen.This function creates and displays the + SMS Settings menu in an active call screen. + + $Returns: Execution status + + $Arguments: m - menu handler + i - Menu item selected + *******************************************************************************/ static int M_exeSetting(MfwMnu* m, MfwMnuItem* i) { - + // T_MFW_HND win = mfwParent(mfw_header()); // RAVI // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // RAVI // T_call_menu * data = (T_call_menu *)win_data->user; // RAVI - TRACE_FUNCTION("M_exeSetting"); - - /* Create the SMS Setting menu*/ - bookMenuStart(call_data.win, settingMenuAttributes(),0); - - return 1; + TRACE_FUNCTION("M_exeSetting"); + + /* Create the SMS Setting menu*/ + bookMenuStart(call_data.win, settingMenuAttributes(),0); + + return 1; } //August 24 2004 e-armanetsaid added for camera driver test purposes // Feb 13, 2006 REF:DR OMAPS00067943 x0039928 -// Fix : The Menu function M_exeViewfinder is renamed to M_exeApplication -/******************************************************************************* - - $Function: M_exeApplication - - $Description: This function is called when the user press "Application" in the - Active call "options" screen.This function creates and displays the - Application menu in an active call screen. - - $Returns: Execution status - - $Arguments: m - menu handler - i - Menu item selected - +// Fix : The Menu function M_exeViewfinder is renamed to M_exeApplication +/******************************************************************************* + + $Function: M_exeApplication + + $Description: This function is called when the user press "Application" in the + Active call "options" screen.This function creates and displays the + Application menu in an active call screen. + + $Returns: Execution status + + $Arguments: m - menu handler + i - Menu item selected + *******************************************************************************/ static int M_exeApplication(MfwMnu* m, MfwMnuItem* i) { - + // T_MFW_HND win = mfwParent(mfw_header()); // RAVI // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // RAVI // T_call_menu * data = (T_call_menu *)win_data->user; // RAVI - TRACE_FUNCTION("M_exeSetting"); - - /* Create the Application menu*/ - bookMenuStart(call_data.win, applicationsMenuAttributes(),0); - - return 1; + TRACE_FUNCTION("M_exeSetting"); + + /* Create the Application menu*/ + bookMenuStart(call_data.win, applicationsMenuAttributes(),0); + + return 1; } /******************************************************************************* @@ -3049,8 +3047,8 @@ switch (call_data.calls.mode){ case CallSingle: case CallTwo: - // Oct 07, 2004 REF: CRR MMI-FIX-24440 xnkulkar - // callIndex function is used instead of directly using status[call_data.calls.selected] + // Oct 07, 2004 REF: CRR MMI-FIX-24440 xnkulkar + // callIndex function is used instead of directly using status[call_data.calls.selected] if (call_data.calls.status[callIndex(call_data.calls.selected)].stat == CALL_HELD) { cm_command(call_data.calls.selected, CM_RETRIEVE, '\0'); @@ -3064,8 +3062,8 @@ callSetMode(ViewWaitingAnswer, TRUE); break; case CallConference: - // Oct 07, 2004 REF: CRR MMI-FIX-24440 xnkulkar - // callIndex function is used instead of directly using status[call_data.calls.selected] + // Oct 07, 2004 REF: CRR MMI-FIX-24440 xnkulkar + // callIndex function is used instead of directly using status[call_data.calls.selected] if (call_data.calls.status[callIndex(call_data.calls.selected)].stat == CALL_HELD) { cm_command(call_data.calls.selected, CM_RETRIEVE_MULTIPARTY, '\0'); @@ -3103,7 +3101,7 @@ T_MFW_HND win = mfwParent(mfw_header()); // T_MFW_WIN *win_data = ((T_MFW_HDR *)win)->data; //RAVI // T_call_menu *data = (T_call_menu *)win_data->user; // RAVI - + if (call_data.calls.muted) { if (audio_SetMute(AUDIO_MICROPHONE, AUDIO_MUTING_OFF) == DRV_OK) @@ -3144,11 +3142,11 @@ // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // T_call_menu * data = (T_call_menu *)win_data->user; - /* SPR#1428 - SH - New Editor changes */ + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - call_scratchpad_start(win,ctrlBack,ViewScratchPad, 0); + call_scratchpad_start(win,ctrlBack,ViewScratchPad, 0); #else - call_scratchpad_start(win,ecBack,ViewScratchPad, 0); + call_scratchpad_start(win,ecBack,ViewScratchPad, 0); #endif return 1; } @@ -3208,14 +3206,14 @@ static int privateStartAddConferenceExec(MfwMnu* m, MfwMnuItem* i){ switch(call_data.calls.mode){ - case CallConference: - cm_command(call_data.calls.selected,CM_SPLIT_MULTIPARTY,'\0'); - callSetMode(ViewShortWait, TRUE); - break; - case CallMultipartySingle : - case CallSingleMultiparty : - case CallTwo: - TRACE_EVENT("call to BUILD_MULTIPARTY------------------------------------"); + case CallConference: + cm_command(call_data.calls.selected,CM_SPLIT_MULTIPARTY,'\0'); + callSetMode(ViewShortWait, TRUE); + break; + case CallMultipartySingle : + case CallSingleMultiparty : + case CallTwo: + TRACE_EVENT("call to BUILD_MULTIPARTY------------------------------------"); cm_command(0,CM_BUILD_MULTIPARTY,'\0'); call_data.current_command = CM_BUILD_MULTIPARTY; callSetMode(ViewWaitingAnswer, TRUE); @@ -3246,9 +3244,9 @@ switch(call_data.calls.mode){ case CallSingleMultiparty : - case CallMultipartySingle : - - cm_command(0,CM_SWAP_MULTIPARTY, '\0'); + case CallMultipartySingle : + + cm_command(0,CM_SWAP_MULTIPARTY, '\0'); call_data.current_command = CM_SWAP_MULTIPARTY; callSetMode(ViewWaitingAnswer, TRUE); break; @@ -3283,7 +3281,7 @@ } -// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. +// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. // Handler for "End held" menu item added /******************************************************************************* @@ -3350,7 +3348,7 @@ return 1; } -*/ +*/ @@ -3368,7 +3366,7 @@ -// May 9, 2006 REF:DR OMAPS00074884 xrashmic +// May 9, 2006 REF:DR OMAPS00074884 xrashmic int removeCall(SHORT cid, BOOL dialogDisp, BOOL allCallsEnded) { int i; @@ -3397,7 +3395,7 @@ call_data.call_direction = call_data.calls.status[callIndex(cid)].call_direction; call_data.calls.status[callIndex(cid)].call_direction = MFW_CM_INV_DIR; - + for (i = 0; i < MAX_CALLS; i++) { if (call_data.calls.status[i].call_number == cid) @@ -3415,33 +3413,33 @@ } } - if (call_data.calls.numCalls > 0) - call_data.calls.numCalls--; - - if (call_data.calls.selected == cid) - call_data.calls.selected = 0; - - if (call_data.calls.numCalls ==1) - call_data.calls.mode = CallSingle; - - if (call_data.calls.mode == CallSingleMultiparty) - //Mar 26,2008, OMAPS00164785, x0091220(Daniel) - call_data.calls.mode = CallSingle; - - if (call_data.singleCall == cid) - call_data.singleCall = 0; - // May 9, 2006 REF:DR OMAPS00074884 xrashmic - // When removing calls one by one from removeAllCalls, rebuild calls should not be called - if (call_data.calls.numCalls && (allCallsEnded==FALSE)) - rebuildCalls(); - else - { - resetDTMFQueue(); /*OMAPS00107103 a0393213(R.Prabakar) - The DTMF queue is flushed once the call is ended*/ - call_data.vocoderState = CALL_VOCODER_IDLE; - } - - callSetMode(ViewEnd, dialogDisp); - return 1; + if (call_data.calls.numCalls > 0) + call_data.calls.numCalls--; + + if (call_data.calls.selected == cid) + call_data.calls.selected = 0; + + if (call_data.calls.numCalls ==1) + call_data.calls.mode = CallSingle; + + if (call_data.calls.mode == CallSingleMultiparty) + //Mar 26,2008, OMAPS00164785, x0091220(Daniel) + call_data.calls.mode = CallSingle; + + if (call_data.singleCall == cid) + call_data.singleCall = 0; + // May 9, 2006 REF:DR OMAPS00074884 xrashmic + // When removing calls one by one from removeAllCalls, rebuild calls should not be called + if (call_data.calls.numCalls && (allCallsEnded==FALSE)) + rebuildCalls(); + else + { + resetDTMFQueue(); /*OMAPS00107103 a0393213(R.Prabakar) - The DTMF queue is flushed once the call is ended*/ + call_data.vocoderState = CALL_VOCODER_IDLE; + } + + callSetMode(ViewEnd, dialogDisp); + return 1; } @@ -3462,29 +3460,29 @@ int removeAllCalls(void) { - int i; - int j = 0; - - TRACE_FUNCTION("removeAllCalls()"); - - for (i=0; i<MAX_CALLS; i++) - { - /* - ** Because removecall() shifts the data down each time a call is removed, the index to use should remain as 0 - */ - if (call_data.calls.status[j].call_direction != MFW_CM_INV_DIR) - { - call_data.accessEnd = TRUE; - // May 9, 2006 REF:DR OMAPS00074884 xrashmic - // When removing calls one by one from removeAllCalls, rebuild calls should not be called - // Added a new paramter to the removeCall function to indicate the same - removeCall(call_data.calls.status[j].call_number, FALSE,TRUE); - } - else - j++; - } - - return 1; + int i; + int j = 0; + + TRACE_FUNCTION("removeAllCalls()"); + + for (i=0; i<MAX_CALLS; i++) + { + /* + ** Because removecall() shifts the data down each time a call is removed, the index to use should remain as 0 + */ + if (call_data.calls.status[j].call_direction != MFW_CM_INV_DIR) + { + call_data.accessEnd = TRUE; + // May 9, 2006 REF:DR OMAPS00074884 xrashmic + // When removing calls one by one from removeAllCalls, rebuild calls should not be called + // Added a new paramter to the removeCall function to indicate the same + removeCall(call_data.calls.status[j].call_number, FALSE,TRUE); + } + else + j++; + } + + return 1; } /******************************************************************************* @@ -3613,10 +3611,10 @@ void callNumber(UBYTE *number) { - T_MFW res; -// T_MFW_PHB_ENTRY phb_entry; // RAVI - T_MFW_SS_RETURN ssRes; - char edt_buf_prov[EDITOR_SIZE]; + T_MFW res; +// T_MFW_PHB_ENTRY phb_entry; // RAVI + T_MFW_SS_RETURN ssRes; + char edt_buf_prov[EDITOR_SIZE]; TRACE_FUNCTION("callnumber()"); // Jun 02, 2006 DRT OMAPS00079213 x0039928(sumanth) @@ -3625,15 +3623,15 @@ // Aug 17, 2006 REF:OMAPS00090196 x0039928 #ifdef MMI_TTY_ENABLED if(FFS_flashData.ttyAlwaysOn == FALSE && call_data.tty == CALL_TTY_OFF) -#endif - mfw_hook_register(); -#endif - +#endif + mfw_hook_register(); +#endif + call_data.emergencyCall = FALSE; mfwStrncpy((char*)edt_buf_prov,(char*)number, EDITOR_SIZE); ssRes = ss_check_ss_string((UBYTE*)edt_buf_prov); - + switch (ssRes) { case MFW_SS_USSD: @@ -3651,24 +3649,24 @@ case MFW_SS_SIM_REG_PW: case MFW_SS_SIM_UNBLCK_PIN: case MFW_SS_MMI: - res = cm_mo_call((UBYTE*)number, VOICE_CALL); - switch(res) - { - //xvilliva 21421 - We flash an alert "Invalid Request" to user as Line1 - //is locked and CF interrogation is done for line2. - case CM_ALS_ERR: - info_screen(0, TxtNotImplemented, TxtNull, NULL); - break; - } + res = cm_mo_call((UBYTE*)number, VOICE_CALL); + switch(res) + { + //xvilliva 21421 - We flash an alert "Invalid Request" to user as Line1 + //is locked and CF interrogation is done for line2. + case CM_ALS_ERR: + info_screen(0, TxtNotImplemented, TxtNull, NULL); + break; + } return; /* Handled on # */ /*MC 12/04/02*/ case MFW_SS_ECT: - TRACE_EVENT("Recognised ECT string"); - cm_mo_call((UBYTE*)number, VOICE_CALL); + TRACE_EVENT("Recognised ECT string"); + cm_mo_call((UBYTE*)number, VOICE_CALL); return; /* Handled on # */ case MFW_SS_CCBS: - TRACE_EVENT("Recognised CCBS string"); - cm_mo_call((UBYTE*)number, VOICE_CALL); + TRACE_EVENT("Recognised CCBS string"); + cm_mo_call((UBYTE*)number, VOICE_CALL); return; case MFW_SS_DIAL: case MFW_SS_DIAL_IDX: @@ -3686,95 +3684,95 @@ case CM_EC: call_data.emergencyCall = TRUE; break; - case CM_BLACKLIST: - TRACE_EVENT("number blacklisted now"); - /*NM, p018*/ - if (call_data.win) - bookShowInformation(call_data.win,Txtblacklisted,NULL,(T_VOID_FUNC)call_failure_cb); - break; + case CM_BLACKLIST: + TRACE_EVENT("number blacklisted now"); + /*NM, p018*/ + if (call_data.win) + bookShowInformation(call_data.win,Txtblacklisted,NULL,(T_VOID_FUNC)call_failure_cb); + break; case CM_SIM: case CM_SS : case CM_MMI: case CM_USSD: return; // break; //RAVI - //GW-SPR#1035 - Added from SAT changes baseline - case CM_CFDN_ERR: - case CM_CBDN_ERR: - TRACE_EVENT("MO-Call blocked by FDN or BDN"); - info_screen(0, TxtCallBlocked, TxtNull, NULL); - break; + //GW-SPR#1035 - Added from SAT changes baseline + case CM_CFDN_ERR: + case CM_CBDN_ERR: + TRACE_EVENT("MO-Call blocked by FDN or BDN"); + info_screen(0, TxtCallBlocked, TxtNull, NULL); + break; default: - TRACE_FUNCTION("call not OK"); - //check if call ended because ACM>=ACMMAX - { + TRACE_FUNCTION("call not OK"); + //check if call ended because ACM>=ACMMAX + { // Sep 01, 2006 REF:OMAPS00090555 x0039928 // Fix: Memory for aocInfo is allocated fron heap instead of stack if flag FF_MMI_PB_OPTIM is defined - #ifdef FF_MMI_PB_OPTIM - T_MFW_CM_AOC_INFO* aocInfo; - aocInfo = (T_MFW_CM_AOC_INFO*)ALLOC_MEMORY(sizeof(T_MFW_CM_AOC_INFO)); - #else - T_MFW_CM_AOC_INFO aocInfo; - #endif - - #ifdef FF_MMI_PB_OPTIM - cm_get_aoc_value(CM_AOC_ACMMAX,aocInfo); - cm_get_aoc_value(CM_AOC_ACM,aocInfo); - if((aocInfo->acm >= aocInfo->acm_max) && - ( aocInfo->acm_max > 0)) - #else - cm_get_aoc_value(CM_AOC_ACMMAX,&aocInfo); - - //Get ACM and ACMMAX - cm_get_aoc_value(CM_AOC_ACM,&aocInfo); - - //display "No Credit" to user - if((aocInfo.acm >= aocInfo.acm_max) && - ( aocInfo.acm_max > 0)) - #endif - { T_DISPLAY_DATA display_info; - /* SPR2500, initialise info dialogue correctly*/ - dlg_initDisplayData_TextId(&display_info, TxtSoftOK, NULL, TxtNo, TxtCredit, COLOUR_STATUS); - dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT | KEY_RIGHT); - - TRACE_EVENT("acm_max exceeded"); - info_dialog (call_data.win, &display_info); + #ifdef FF_MMI_PB_OPTIM + T_MFW_CM_AOC_INFO* aocInfo; + aocInfo = (T_MFW_CM_AOC_INFO*)ALLOC_MEMORY(sizeof(T_MFW_CM_AOC_INFO)); + #else + T_MFW_CM_AOC_INFO aocInfo; + #endif + + #ifdef FF_MMI_PB_OPTIM + cm_get_aoc_value(CM_AOC_ACMMAX,aocInfo); + cm_get_aoc_value(CM_AOC_ACM,aocInfo); + if((aocInfo->acm >= aocInfo->acm_max) && + ( aocInfo->acm_max > 0)) + #else + cm_get_aoc_value(CM_AOC_ACMMAX,&aocInfo); + + //Get ACM and ACMMAX + cm_get_aoc_value(CM_AOC_ACM,&aocInfo); + + //display "No Credit" to user + if((aocInfo.acm >= aocInfo.acm_max) && + ( aocInfo.acm_max > 0)) + #endif + { T_DISPLAY_DATA display_info; + /* SPR2500, initialise info dialogue correctly*/ + dlg_initDisplayData_TextId(&display_info, TxtSoftOK, NULL, TxtNo, TxtCredit, COLOUR_STATUS); + dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT | KEY_RIGHT); + + TRACE_EVENT("acm_max exceeded"); + info_dialog (call_data.win, &display_info); // Sep 01, 2006 REF:OMAPS00090555 x0039928 // Fix: if flag FF_MMI_PB_OPTIM is defined then free the allocated memory from heap for aocInfo - #ifdef FF_MMI_PB_OPTIM - if(aocInfo) - FREE_MEMORY((UBYTE*)aocInfo,sizeof(T_MFW_CM_AOC_INFO)); - #endif - - return; - - } - else - { - TRACE_FUNCTION("call not OK to show error"); - /*API - 917 - Added code so that when trying to generate an MO call when FDN is - activated an entry is not in the FDN phonebook this screen should be displayed - */ - /*NM, p018*/ - if (call_data.win) - { - bookShowInformation(call_data.win,TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); - } - else - { - /* to show any notification even in the case "call_data.win == 0" */ - info_screen(0, TxtOperationNotAvail, TxtNull, NULL); - } - } + #ifdef FF_MMI_PB_OPTIM + if(aocInfo) + FREE_MEMORY((UBYTE*)aocInfo,sizeof(T_MFW_CM_AOC_INFO)); + #endif + + return; + + } + else + { + TRACE_FUNCTION("call not OK to show error"); + /*API - 917 - Added code so that when trying to generate an MO call when FDN is + activated an entry is not in the FDN phonebook this screen should be displayed + */ + /*NM, p018*/ + if (call_data.win) + { + bookShowInformation(call_data.win,TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); + } + else + { + /* to show any notification even in the case "call_data.win == 0" */ + info_screen(0, TxtOperationNotAvail, TxtNull, NULL); + } + } // Sep 01, 2006 REF:OMAPS00090555 x0039928 -// Fix: if flag FF_MMI_PB_OPTIM is defined then free the allocated memory from heap for aocInfo - #ifdef FF_MMI_PB_OPTIM - if(aocInfo) - FREE_MEMORY((UBYTE*)aocInfo,sizeof(T_MFW_CM_AOC_INFO)); - #endif - } - return; - } +// Fix: if flag FF_MMI_PB_OPTIM is defined then free the allocated memory from heap for aocInfo + #ifdef FF_MMI_PB_OPTIM + if(aocInfo) + FREE_MEMORY((UBYTE*)aocInfo,sizeof(T_MFW_CM_AOC_INFO)); + #endif + } + return; + } } @@ -3870,17 +3868,17 @@ TRACE_FUNCTION("Ending call"); call_data.accessEnd = TRUE; - + // Nov 16, 2004 REF: CRR MMI-SPR-26120 xnkulkar -// Description: After disconnecting MOC cannot return to STK menu -// Solution: When the user ends a call, check if it is a STK call and send SAT_RETURN event to -// return the control to STK menu. +// Description: After disconnecting MOC cannot return to STK menu +// Solution: When the user ends a call, check if it is a STK call and send SAT_RETURN event to +// return the control to STK menu. if (call_SATCall == TRUE) { - SEND_EVENT(sat_get_setup_menu_win(), SAT_RETURN, 0, NULL); - } + SEND_EVENT(sat_get_setup_menu_win(), SAT_RETURN, 0, NULL); + } if (call_data.endQueue){ - // May 9, 2006 REF:DR OMAPS00074884 xrashmic + // May 9, 2006 REF:DR OMAPS00074884 xrashmic removeCall(call_data.endQueue->call_number, TRUE,FALSE); return; } @@ -3922,7 +3920,7 @@ call_data.calls.selected = call_data.calls.status[0].call_number; if (call_data.calls.mode != CallConference){ for (i=0;i < call_data.calls.numCalls;i++){ - TRACE_EVENT_P1("Getting call number %d", i); + TRACE_EVENT_P1("Getting call number %d", i); getCallStatus(call_data.calls.status[i].call_number, &call_data.calls.status[i]); if (call_data.calls.status[i].stat == CALL_ACTIVE) call_data.calls.selected = call_data.calls.status[i].call_number; @@ -3966,23 +3964,23 @@ i=0; while ((i <call->name.len) && (call->number[i]==prov[i])) { - i++; + i++; } if (i == call->name.len) - { - memset(call->name.data,'\0',PHB_MAX_LEN); - /*a0393213 lint warning:access beyond array soln:memcpy changed to mfwStrncpy*/ - mfwStrncpy((char*)call->name.data, (char*)prov, PHB_MAX_LEN); - } + { + memset(call->name.data,'\0',PHB_MAX_LEN); + /*a0393213 lint warning:access beyond array soln:memcpy changed to mfwStrncpy*/ + mfwStrncpy((char*)call->name.data, (char*)prov, PHB_MAX_LEN); + } #else - //copy current name to temp var + //copy current name to temp var mfwStrncpy((char*)prov,(char*)call->name, MFW_TAG_LEN); - //read status from MFW + //read status from MFW p = cm_status(call_number,call, 1); TRACE_EVENT_P4("CID:%d,orig name:%s new name: %s, Call number: %s", prov, call->name, prov, call->number); - //if number alphabetically ahead of orig name + //if number alphabetically ahead of orig name if (strcmp((char*)call->number,(char*)prov)) - mfwStrncpy((char*)call->name,(char*)prov, MFW_TAG_LEN); //copy orig name to structure + mfwStrncpy((char*)call->name,(char*)prov, MFW_TAG_LEN); //copy orig name to structure #endif return p; @@ -4050,22 +4048,22 @@ case M_CC_CAUSE_NUM_FORMAT: case M_CC_CAUSE_BARRED_IN_CUG: case M_CC_CAUSE_USER_NOT_IN_CUG: -/* RAVI - 20-1-2006 */ -/* Silent Implementation */ +/* RAVI - 20-1-2006 */ +/* Silent Implementation */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), - AUDIO_PLAY_ONCE); -#else - /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ - /* Play the Error tone if the call failure is due to above causes. */ - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), + AUDIO_PLAY_ONCE); +#else + /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ + /* Play the Error tone if the call failure is due to above causes. */ + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); #endif /* END RAVI */ - bookShowInformation(idle_get_window(),TxtCheckNumber,NULL,(T_VOID_FUNC)call_failure_cb); + bookShowInformation(idle_get_window(),TxtCheckNumber,NULL,(T_VOID_FUNC)call_failure_cb); break; case M_CC_CAUSE_USER_BUSY: -/* RAVI - 20-1-2006 */ -/* Silent Implementation */ +/* RAVI - 20-1-2006 */ +/* Silent Implementation */ #ifdef NEPTUNE_BOARD audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_THRICE); @@ -4095,23 +4093,23 @@ case M_CC_CAUSE_ACM_MAX: case M_CC_CAUSE_FACILITY_NOT_IMPLEM: case M_CC_CAUSE_SERVICE_NOT_IMPLEM: -/* RAVI - 20-1-2006 */ +/* RAVI - 20-1-2006 */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE); -#else - /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ - /* Play the Error tone if the call failure is due to above causes. */ - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE); +#else + /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ + /* Play the Error tone if the call failure is due to above causes. */ + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); #endif /* END RAVI */ - bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); - + bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); + break; case M_CC_CAUSE_NO_CHAN_AVAIL: case M_CC_CAUSE_TEMP_FAIL: case M_CC_CAUSE_SWITCH_CONGEST: case M_CC_CAUSE_REQ_CHAN_UNAVAIL: - + bookShowInformation(idle_get_window(),TxtNetworkBusy,NULL,(T_VOID_FUNC)call_failure_cb); break; case M_CC_CAUSE_FACILITY_UNSUBSCRIB: @@ -4119,26 +4117,26 @@ bookShowInformation(idle_get_window(),TxtNotSubscribed,NULL,(T_VOID_FUNC)call_failure_cb); break; - //GW-SPR#1035 - Added SAT changed - /*NM, 110702 - the "202" stands for timer 303 expired; - unfortunately there is no define for that in the SAP/MNCC */ - case 202: - bookShowInformation(idle_get_window(),TxtCallTimeout,NULL,(T_VOID_FUNC)call_failure_cb); - break; - /*NM, 110702 END*/ + //GW-SPR#1035 - Added SAT changed + /*NM, 110702 + the "202" stands for timer 303 expired; + unfortunately there is no define for that in the SAP/MNCC */ + case 202: + bookShowInformation(idle_get_window(),TxtCallTimeout,NULL,(T_VOID_FUNC)call_failure_cb); + break; + /*NM, 110702 END*/ default: /* RAVI - 20-1-2006 */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE); #else - /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ - /* Play the Error tone if the call failure is due to any other reason. */ - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); + /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ + /* Play the Error tone if the call failure is due to any other reason. */ + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); #endif /* END RAVI */ - bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); + bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); break; } return; @@ -4157,22 +4155,22 @@ case M_CC_CAUSE_NUM_FORMAT: case M_CC_CAUSE_BARRED_IN_CUG: case M_CC_CAUSE_USER_NOT_IN_CUG: -/* RAVI - 20-1-2006 */ +/* RAVI - 20-1-2006 */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE); #else - /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ - /* Play the Error tone if the call failure is due to above causes. */ - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); + /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ + /* Play the Error tone if the call failure is due to above causes. */ + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); #endif /* END RAVI */ - bookShowInformation(idle_get_window(),TxtCheckNumber,NULL,(T_VOID_FUNC)call_failure_cb); + bookShowInformation(idle_get_window(),TxtCheckNumber,NULL,(T_VOID_FUNC)call_failure_cb); break; case M_CC_CAUSE_USER_BUSY: -/* RAVI - 20-1-2006 */ +/* RAVI - 20-1-2006 */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_THRICE); + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_THRICE); #else /* Jun 30, 2004 REF: CRR 15685 xkundadu(Sasken) */ /* Play the beep sound if the called party is busy. */ @@ -4199,18 +4197,18 @@ case M_CC_CAUSE_ACM_MAX: case M_CC_CAUSE_FACILITY_NOT_IMPLEM: case M_CC_CAUSE_SERVICE_NOT_IMPLEM: -/* RAVI - 20-1-2006 */ -/* Silent Implementation */ +/* RAVI - 20-1-2006 */ +/* Silent Implementation */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE); #else - /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ - /* Play the Error tone if the call failure is due to above causes. */ - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); + /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ + /* Play the Error tone if the call failure is due to above causes. */ + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); #endif /* END RAVI */ - bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); + bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); break; case M_CC_CAUSE_NO_CHAN_AVAIL: case M_CC_CAUSE_TEMP_FAIL: @@ -4223,27 +4221,27 @@ bookShowInformation(idle_get_window(),TxtNotSubscribed,NULL,(T_VOID_FUNC)call_failure_cb); break; - //GW-SPR#1035 - Added SAT changed - /*NM, 110702 - the "202" stands for timer 303 expired; - unfortunately there is no define for that in the SAP/MNCC */ - case 202: - bookShowInformation(idle_get_window(),TxtCallTimeout,NULL,(T_VOID_FUNC)call_failure_cb); - break; - /*NM, 110702 END*/ + //GW-SPR#1035 - Added SAT changed + /*NM, 110702 + the "202" stands for timer 303 expired; + unfortunately there is no define for that in the SAP/MNCC */ + case 202: + bookShowInformation(idle_get_window(),TxtCallTimeout,NULL,(T_VOID_FUNC)call_failure_cb); + break; + /*NM, 110702 END*/ default: /* RAVI - 20-1-2006 */ /* Silent Implementation */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE); #else - /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ - /* Play the Error tone if the call failure is due to any other reason. */ - audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); + /* Oct 07, 2004 REF: CRR 23873 xnkulkar(Sasken) */ + /* Play the Error tone if the call failure is due to any other reason. */ + audio_PlaySoundID( AUDIO_SPEAKER, TONES_BUSY, 0 , AUDIO_PLAY_ONCE); #endif /* END RAVI */ - bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); + bookShowInformation(idle_get_window(),TxtOperationNotAvail,NULL,(T_VOID_FUNC)call_failure_cb); break; } return; @@ -4416,37 +4414,37 @@ //x0pleela 07 Apr, 2007 ER: OMAPS00122561 #ifdef FF_PHONE_LOCK - if( phlock_win_handle && ( call_data.call_direction == MFW_CM_MTC ) ) - { - phlock_mtc_win_handle = data->win; - - kbd_delete(data->kbd); - data->kbd = phlock_kbd_handle; //set the kbd handle of unlock screen - } + if( phlock_win_handle && ( call_data.call_direction == MFW_CM_MTC ) ) + { + phlock_mtc_win_handle = data->win; + + kbd_delete(data->kbd); + data->kbd = phlock_kbd_handle; //set the kbd handle of unlock screen + } #endif //FF_PHONE_LOCK data->cm = cm_create(data->win, E_CM_ALL_SERVICES, (MfwCb)callCmEvent); /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - AUI_edit_SetAttr(&data->editorAttrCall,CALL_EDITOR,COLOUR_EDITOR_XX,EDITOR_FONT, ED_MODE_ALPHA, ED_CURSOR_BAR,ATB_DCS_ASCII, (UBYTE*)data->phbNameNumber,EDITOR_SIZE); + AUI_edit_SetAttr(&data->editorAttrCall,CALL_EDITOR,COLOUR_EDITOR_XX,EDITOR_FONT, ED_MODE_ALPHA, ED_CURSOR_BAR,ATB_DCS_ASCII, (UBYTE*)data->phbNameNumber,EDITOR_SIZE); data->editorCall = ATB_edit_Create(&data->editorAttrCall,0); #else /*NEW_EDITOR*/ - bookSetEditAttributes(CALL_EDITOR,COLOUR_EDITOR_XX,0,edtCurBar1,0,(char*)data->phbNameNumber,EDITOR_SIZE,&data->edtAttrCall); + bookSetEditAttributes(CALL_EDITOR,COLOUR_EDITOR_XX,0,edtCurBar1,0,(char*)data->phbNameNumber,EDITOR_SIZE,&data->edtAttrCall); data->editCall = edtCreate(data->win,&data->edtAttrCall,0,0); #endif /* NEW_EDITOR */ SEND_EVENT(data->win,CALL_INIT,0,0); //x0pleela 27 Mar, 2007 ER: OMAPS00122561 #ifdef FF_PHONE_LOCK if( ( !phlock_win_handle) || (mmiPinsEmergencyCall()) ) -#endif //FF_PHONE_LOCK - winShow(data->win); +#endif //FF_PHONE_LOCK + winShow(data->win); //x0pleela 27 Mar, 2007 ER: OMAPS00122561 #ifdef FF_PHONE_LOCK else { - //show phone unlock window - winShow(phlock_win_handle ); + //show phone unlock window + winShow(phlock_win_handle ); } #endif //FF_PHONE_LOCK @@ -4495,12 +4493,12 @@ */ #ifdef FF_MMI_AUDIO_PROFILE - if( mfw_get_current_audioDevice() == MFW_AUD_LOUDSPEAKER) - { - mfw_audio_set_device(MFW_AUD_HANDHELD); - } -#endif - + if( mfw_get_current_audioDevice() == MFW_AUD_LOUDSPEAKER) + { + mfw_audio_set_device(MFW_AUD_HANDHELD); + } +#endif + if (call_data.win_calling){ SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); call_data.win_calling = 0; @@ -4522,57 +4520,57 @@ call_data.win_sending_dtmf = 0; } - if (call_data.win_incoming) - { - return; - } + if (call_data.win_incoming) + { + return; + } /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - /* New editor not destroyed automatically by win_delete, - * so do so here */ - if (call_data.editorCall) - { - ATB_edit_Destroy(call_data.editorCall); - call_data.editorCall = 0; - } + /* New editor not destroyed automatically by win_delete, + * so do so here */ + if (call_data.editorCall) + { + ATB_edit_Destroy(call_data.editorCall); + call_data.editorCall = 0; + } #endif /* NEW_EDITOR */ /*mc, spr 1392, destroy all call deflection windows*/ - if (call_data.win_deflectSearch) - { - bookPhonebookDestroy(call_data.win_deflectSearch); - call_data.win_deflectSearch = 0; - } - - if (call_data.win_deflectEdit) - { - /* SPR#1428 - SH - New editor */ - #ifdef NEW_EDITOR - AUI_edit_Destroy(call_data.win_deflectEdit); - #else /* NEW_EDITOR */ - editor_destroy(call_data.win_deflectEdit); - #endif /* NEW_EDITOR */ - - call_data.win_deflectEdit = 0; - } - - if (call_data.win_deflecting) - { - SEND_EVENT(call_data.win_deflecting, DIALOG_DESTROY, NULL, NULL); - call_data.win_deflecting = 0; - } + if (call_data.win_deflectSearch) + { + bookPhonebookDestroy(call_data.win_deflectSearch); + call_data.win_deflectSearch = 0; + } + + if (call_data.win_deflectEdit) + { + /* SPR#1428 - SH - New editor */ + #ifdef NEW_EDITOR + AUI_edit_Destroy(call_data.win_deflectEdit); + #else /* NEW_EDITOR */ + editor_destroy(call_data.win_deflectEdit); + #endif /* NEW_EDITOR */ + + call_data.win_deflectEdit = 0; + } + + if (call_data.win_deflecting) + { + SEND_EVENT(call_data.win_deflecting, DIALOG_DESTROY, NULL, NULL); + call_data.win_deflecting = 0; + } win_delete (data->win); data->win=0; - //x0pleela 07 Apr, 2007 ER: OMAPS00122561 + //x0pleela 07 Apr, 2007 ER: OMAPS00122561 #ifdef FF_PHONE_LOCK - if(( call_data.call_direction == MFW_CM_MTC )&& phlock_mtc_win_handle ) - { - phlock_mtc_win_handle = NULL; - } + if(( call_data.call_direction == MFW_CM_MTC )&& phlock_mtc_win_handle ) + { + phlock_mtc_win_handle = NULL; + } #endif //FF_PHONE_LOCK } @@ -4588,51 +4586,51 @@ /******************************************************************************* - $Function: deflect_destroy - - $Description: destroys call deflection windows and, depending upon the value of the - parameter delete_call_windows, deletes the call windows if there is no - currently active call. - - $Returns: nothing - - $Arguments: Boolean delete_call_windows, should be set to TRUE if call winodws - ought to be deleted too. + $Function: deflect_destroy + + $Description: destroys call deflection windows and, depending upon the value of the + parameter delete_call_windows, deletes the call windows if there is no + currently active call. + + $Returns: nothing + + $Arguments: Boolean delete_call_windows, should be set to TRUE if call winodws + ought to be deleted too. *******************************************************************************/ void deflect_destroy(BOOL delete_call_windows) { /*destroy all call deflection windows*/ - if (call_data.win_deflectSearch) - { - bookPhonebookDestroy(call_data.win_deflectSearch); - call_data.win_deflectSearch = 0; - } - - if (call_data.win_deflectEdit) - { - /* SPR#1428 - SH - New editor */ - #ifdef NEW_EDITOR - AUI_edit_Destroy(call_data.win_deflectEdit); - #else /* NEW_EDITOR */ - editor_destroy(call_data.win_deflectEdit); - #endif /* NEW_EDITOR */ - - call_data.win_deflectEdit = 0; - } - - if (call_data.win_deflecting) - { - SEND_EVENT(call_data.win_deflecting, DIALOG_DESTROY, NULL, NULL); - call_data.win_deflecting = 0; - } - - /*set incoming call number to 0, as call deflection has either failed or succeeded*/ - call_data.incCall = 0; + if (call_data.win_deflectSearch) + { + bookPhonebookDestroy(call_data.win_deflectSearch); + call_data.win_deflectSearch = 0; + } + + if (call_data.win_deflectEdit) + { + /* SPR#1428 - SH - New editor */ + #ifdef NEW_EDITOR + AUI_edit_Destroy(call_data.win_deflectEdit); + #else /* NEW_EDITOR */ + editor_destroy(call_data.win_deflectEdit); + #endif /* NEW_EDITOR */ + + call_data.win_deflectEdit = 0; + } + + if (call_data.win_deflecting) + { + SEND_EVENT(call_data.win_deflecting, DIALOG_DESTROY, NULL, NULL); + call_data.win_deflecting = 0; + } + + /*set incoming call number to 0, as call deflection has either failed or succeeded*/ + call_data.incCall = 0; /*destroy call window if no active call and flag TRUE*/ if (!call_data.calls.numCalls && delete_call_windows == TRUE) - { if (call_data.win) + { if (call_data.win) { call_destroy(call_data.win); } @@ -4669,7 +4667,7 @@ memset(&data->calls,0,sizeof(data->calls)); - memset(call_data.colp_number,'\0',sizeof(call_data.colp_number)); + memset(call_data.colp_number,'\0',sizeof(call_data.colp_number)); phb_set_auto_off(PHB_AUTO_ON); data->win_incoming=0; data->win_calling=0; @@ -4693,15 +4691,15 @@ data->sendingDTMF=FALSE; data->ignore_disconnect = FALSE; - for (i=0; i<MAX_CALLS; i++) call_data.calls.status[i].call_direction = MFW_CM_INV_DIR; - - //GW Ensure a valid (non-zero) number for currentVolume - /*if (FFS_flashData.output_volume > MAX_SOUND) - FFS_flashData.output_volume = MAX_SOUND; - else if (FFS_flashData.output_volume <= 0) - FFS_flashData.output_volume = MAX_SOUND;*//*a0393213 lint warning removal - commented as the statement as no effect*/ -// Apr 05, 2005 REF: ENH 29994 xdeepadh -//Commented mmesetvolume.since the speaker volume will be set, + for (i=0; i<MAX_CALLS; i++) call_data.calls.status[i].call_direction = MFW_CM_INV_DIR; + + //GW Ensure a valid (non-zero) number for currentVolume + /*if (FFS_flashData.output_volume > MAX_SOUND) + FFS_flashData.output_volume = MAX_SOUND; + else if (FFS_flashData.output_volume <= 0) + FFS_flashData.output_volume = MAX_SOUND;*//*a0393213 lint warning removal - commented as the statement as no effect*/ +// Apr 05, 2005 REF: ENH 29994 xdeepadh +//Commented mmesetvolume.since the speaker volume will be set, //once the call is acknowledged. //mmeSetVolume (1, FFS_flashData.output_volume); //x0pleela 27 Mar, 2007 ER: OMAPS00122561 @@ -4721,31 +4719,31 @@ } break; case CALL_DESTROY_CALLING_WINDOW: - /* SPR#1983 - SH - This is a special WAP event. - * It destroys the "Calling" dialog if WAP connection - * is cancelled. */ - - TRACE_EVENT("CALL_DESTROY_CALLING_WINDOW"); - - if (call_data.win_calling) - { - SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); - call_data.win_calling = 0; - } - - if (call_data.outCall) - { - cm_disconnect(call_data.outCall); - call_data.outCall = 0; - if (!call_data.calls.numCalls) - { - call_data.ignore_disconnect = TRUE; - call_destroy(call_data.win); - return; - } - endingCall(); - } - break; + /* SPR#1983 - SH - This is a special WAP event. + * It destroys the "Calling" dialog if WAP connection + * is cancelled. */ + + TRACE_EVENT("CALL_DESTROY_CALLING_WINDOW"); + + if (call_data.win_calling) + { + SEND_EVENT(call_data.win_calling,DIALOG_DESTROY,0,0); + call_data.win_calling = 0; + } + + if (call_data.outCall) + { + cm_disconnect(call_data.outCall); + call_data.outCall = 0; + if (!call_data.calls.numCalls) + { + call_data.ignore_disconnect = TRUE; + call_destroy(call_data.win); + return; + } + endingCall(); + } + break; case E_CM_NOTIFY: /* @@ -4753,24 +4751,24 @@ */ showCCNotify( win, (T_MFW_CM_NOTIFY*) parameter ); break; - case E_CM_COLP: - { - /* NM 056, FTA Testcase 31.1.3.1 - * add COLP only for the singlecall and have - * to be done for multicall as well ! - */ - - T_MFW_CM_MO_INFO *colp = (T_MFW_CM_MO_INFO*) parameter ; - - TRACE_EVENT ("E_CM_COLP"); - - if (strlen((char*)colp->number) > 0) - { - memset(call_data.colp_number,'\0',sizeof(call_data.colp_number)); - strncpy ((char*)call_data.colp_number , (char*)colp->number, sizeof(call_data.colp_number)-1); - } - } - break; + case E_CM_COLP: + { + /* NM 056, FTA Testcase 31.1.3.1 + * add COLP only for the singlecall and have + * to be done for multicall as well ! + */ + + T_MFW_CM_MO_INFO *colp = (T_MFW_CM_MO_INFO*) parameter ; + + TRACE_EVENT ("E_CM_COLP"); + + if (strlen((char*)colp->number) > 0) + { + memset(call_data.colp_number,'\0',sizeof(call_data.colp_number)); + strncpy ((char*)call_data.colp_number , (char*)colp->number, sizeof(call_data.colp_number)-1); + } + } + break; case CALL_OUTGOING_SAT: { /* this means the SIM toolkit is about to start a call - this means we will @@ -4805,47 +4803,47 @@ tempString = call_setup_parameter->TextString2; //x0035544 Mar 11, 2006, DR:OMAPS00061467 #ifdef FF_MMI_SAT_ICON - if(call_setup_parameter->IconInfo2.dst != NULL) - { - //Copy the icon data for the second alpah ID - call_data.IconData.width = call_setup_parameter->IconInfo2.width; - call_data.IconData.height = call_setup_parameter->IconInfo2.height; - call_data.IconData.dst = call_setup_parameter->IconInfo2.dst; - call_data.IconData.selfExplanatory = call_setup_parameter->IconInfo2.selfExplanatory; - TRACE_EVENT_P2("icon width=%d, icon height= %d---sudha",call_data.IconData.width,call_data.IconData.height); - } - else - { - call_data.IconData.dst = NULL; - call_data.IconData.width = 0; - call_data.IconData.height = 0; - call_data.IconData.selfExplanatory = FALSE; - } - #endif + if(call_setup_parameter->IconInfo2.dst != NULL) + { + //Copy the icon data for the second alpah ID + call_data.IconData.width = call_setup_parameter->IconInfo2.width; + call_data.IconData.height = call_setup_parameter->IconInfo2.height; + call_data.IconData.dst = call_setup_parameter->IconInfo2.dst; + call_data.IconData.selfExplanatory = call_setup_parameter->IconInfo2.selfExplanatory; + TRACE_EVENT_P2("icon width=%d, icon height= %d---sudha",call_data.IconData.width,call_data.IconData.height); + } + else + { + call_data.IconData.dst = NULL; + call_data.IconData.width = 0; + call_data.IconData.height = 0; + call_data.IconData.selfExplanatory = FALSE; + } + #endif } else /* Second alpha id not set therefore use first alpha id */ { TRACE_EVENT("Use first alpha id: TextString"); tempString = call_setup_parameter->TextString; //x0035544 Mar 11, 2006, DR:OMAPS00061467 - #ifdef FF_MMI_SAT_ICON - if(call_setup_parameter->IconInfo.dst != NULL) - { - //copy the icon data of first alpha ID - call_data.IconData.width = call_setup_parameter->IconInfo.width; - call_data.IconData.height = call_setup_parameter->IconInfo.height; - call_data.IconData.dst = call_setup_parameter->IconInfo.dst; - call_data.IconData.selfExplanatory = call_setup_parameter->IconInfo.selfExplanatory; - } - else - { - call_data.IconData.dst = NULL; - call_data.IconData.width = 0; - call_data.IconData.height = 0; - call_data.IconData.selfExplanatory = FALSE; - } - #endif - } + #ifdef FF_MMI_SAT_ICON + if(call_setup_parameter->IconInfo.dst != NULL) + { + //copy the icon data of first alpha ID + call_data.IconData.width = call_setup_parameter->IconInfo.width; + call_data.IconData.height = call_setup_parameter->IconInfo.height; + call_data.IconData.dst = call_setup_parameter->IconInfo.dst; + call_data.IconData.selfExplanatory = call_setup_parameter->IconInfo.selfExplanatory; + } + else + { + call_data.IconData.dst = NULL; + call_data.IconData.width = 0; + call_data.IconData.height = 0; + call_data.IconData.selfExplanatory = FALSE; + } + #endif + } if (tempString NEQ NULL) { @@ -4886,8 +4884,8 @@ TRACE_EVENT_P1("Ascii SAT label is %d bytes", len); strncpy(call_data.phbNameNumber, tempString, len-1);/*a0393213 lint warnings removal - changed len to len-1*/ - call_data.phbNameNumber[len-1]=0x00;/*a0393213 lint warnings removal - added this statement*/ - } + call_data.phbNameNumber[len-1]=0x00;/*a0393213 lint warnings removal - added this statement*/ + } } else { @@ -4898,31 +4896,31 @@ call_SATCall = TRUE; } - break; + break; /* SPR#1428 - SH - Insert phone number into new editor */ - /*MC, SPR 1392, phone number selected for call deflection*/ - case DEFLECT_PHBK_NUMBER: - #ifdef NEW_EDITOR - { - T_ATB_TEXT text; - text.dcs = ATB_DCS_ASCII; - - /*API - 25/08/03 - SPR2144 - Remove the call to pass call_data.editor_buffer, instead pass down parameter*/ - text.data = (UBYTE *)parameter; - /*API - 25/08/03 - SPR 2144 - END*/ - - text.len = ATB_string_Length(&text); - SEND_EVENT(call_data.win_deflectEdit, E_ED_INSERT, 0, (void *)&text); - } - #else /* NEW_EDITOR */ - /*copy number to editor*/ - memcpy (call_data.editor_buffer , (char *)parameter, sizeof(call_data.editor_buffer)); - SEND_EVENT(call_data.win_deflectEdit, E_EDITOR_CURSOR_END, NULL, NULL); - #endif /* NEW_EDITOR */ - - /*Set search window pointer to NULL as we've just exited that window*/ - call_data.win_deflectSearch = 0; - break; + /*MC, SPR 1392, phone number selected for call deflection*/ + case DEFLECT_PHBK_NUMBER: + #ifdef NEW_EDITOR + { + T_ATB_TEXT text; + text.dcs = ATB_DCS_ASCII; + + /*API - 25/08/03 - SPR2144 - Remove the call to pass call_data.editor_buffer, instead pass down parameter*/ + text.data = (UBYTE *)parameter; + /*API - 25/08/03 - SPR 2144 - END*/ + + text.len = ATB_string_Length(&text); + SEND_EVENT(call_data.win_deflectEdit, E_ED_INSERT, 0, (void *)&text); + } + #else /* NEW_EDITOR */ + /*copy number to editor*/ + memcpy (call_data.editor_buffer , (char *)parameter, sizeof(call_data.editor_buffer)); + SEND_EVENT(call_data.win_deflectEdit, E_EDITOR_CURSOR_END, NULL, NULL); + #endif /* NEW_EDITOR */ + + /*Set search window pointer to NULL as we've just exited that window*/ + call_data.win_deflectSearch = 0; + break; default: break; @@ -4932,312 +4930,312 @@ int lines_inBetween_Display(int noCalls, int callNo) { - switch(noCalls) - { - case 1: - case 2: - return (1+(callNo*5)); - // break; // RAVI - - case 3: - return (0+(callNo*4)); - // break; // RAVI - - case 4: - return (0+(callNo*3)); - // break; // RAVI - - case 5: - case 6: - return (0+(callNo*2)); - // break; // RAVI - - default: - /* x0045876, 14-Aug-2006 (WR - missing return statement at end of non-void function) */ - /* break; */ - return 0; - } + switch(noCalls) + { + case 1: + case 2: + return (1+(callNo*5)); + // break; // RAVI + + case 3: + return (0+(callNo*4)); + // break; // RAVI + + case 4: + return (0+(callNo*3)); + // break; // RAVI + + case 5: + case 6: + return (0+(callNo*2)); + // break; // RAVI + + default: + /* x0045876, 14-Aug-2006 (WR - missing return statement at end of non-void function) */ + /* break; */ + return 0; + } } // API - SPR 1775 - Conference call, added to place a arrow next to the call looking at! int multiCall_ActiveCall (int bitmap_pos, int CurrentCallNo) { - t_font_bitmap multicall_pointer = { 0, BMP_FORMAT_BW_UNPACKED, 8, 8, 0, (char*)multi_pointer}; - int xPos, yPos; - int noActCalls, nLines; - - noActCalls = call_data.calls.numCalls; - - TRACE_EVENT("multiCall_ActiveCall"); - TRACE_EVENT_P2("CurrentCallNo = %d, noActCalls = %d", CurrentCallNo, noActCalls); - - xPos = 5; - nLines = lines_inBetween_Display(noActCalls, CurrentCallNo); - - TRACE_EVENT_P1("nLines = %d", nLines); - - switch(bitmap_pos) - { - case CALL_STATUS_CALL : - if(noActCalls <= 2) - nLines = nLines; - else if(noActCalls == 3) - nLines = nLines; - else if(noActCalls >= 4) - nLines = nLines; - break; - - default: - xPos = 5; - yPos = nLines; - break; - } - yPos = Mmi_layout_IconHeight() + (nLines * Mmi_layout_line_height()); - - TRACE_EVENT_P2("xPos = %d, yPos = %d", xPos, yPos); - - dspl_show_bitmap(xPos, yPos, &multicall_pointer, 0 ); - - /* x0045876, 14-Aug-2006 (WR - missing return statement at end of non-void function) */ - return TRUE; + t_font_bitmap multicall_pointer = { 0, BMP_FORMAT_BW_UNPACKED, 8, 8, 0, (char*)multi_pointer}; + int xPos, yPos; + int noActCalls, nLines; + + noActCalls = call_data.calls.numCalls; + + TRACE_EVENT("multiCall_ActiveCall"); + TRACE_EVENT_P2("CurrentCallNo = %d, noActCalls = %d", CurrentCallNo, noActCalls); + + xPos = 5; + nLines = lines_inBetween_Display(noActCalls, CurrentCallNo); + + TRACE_EVENT_P1("nLines = %d", nLines); + + switch(bitmap_pos) + { + case CALL_STATUS_CALL : + if(noActCalls <= 2) + nLines = nLines; + else if(noActCalls == 3) + nLines = nLines; + else if(noActCalls >= 4) + nLines = nLines; + break; + + default: + xPos = 5; + yPos = nLines; + break; + } + yPos = Mmi_layout_IconHeight() + (nLines * Mmi_layout_line_height()); + + TRACE_EVENT_P2("xPos = %d, yPos = %d", xPos, yPos); + + dspl_show_bitmap(xPos, yPos, &multicall_pointer, 0 ); + + /* x0045876, 14-Aug-2006 (WR - missing return statement at end of non-void function) */ + return TRUE; } /*MC, please note: it is assumed that txtStr will have a unicode tag at the beginning if it ought to be displayed in Unicode, otherwise, it *will* be displayed in ASCII*/ int inCall_displayData( int dataId , int txtId, char* txtStr, int CurrentCallNo) { - int xPos, yPos; - int txtFormat; - int lenStr, lenId, txtWidth, nLines; - int noActCalls; // statusWidth; // RAVI - char idStr[PHB_MAX_LEN]; - /*MC, SPR 1319*/ - UBYTE unicode_string =0;/*Unicode flag*/ - UBYTE current_display_type = dspl_get_char_type();/*store current char type*/ - noActCalls = call_data.calls.numCalls; - //noActCalls = 4; + int xPos, yPos; + int txtFormat; + int lenStr, lenId, txtWidth, nLines; + int noActCalls; // statusWidth; // RAVI + char idStr[PHB_MAX_LEN]; + /*MC, SPR 1319*/ + UBYTE unicode_string =0;/*Unicode flag*/ + UBYTE current_display_type = dspl_get_char_type();/*store current char type*/ + noActCalls = call_data.calls.numCalls; + //noActCalls = 4; TRACE_EVENT_P4("inCall_displayData %d %d %s %d",dataId,txtId,txtStr,CurrentCallNo); - if (txtStr != NULL) - { + if (txtStr != NULL) + { /*MC SPR 1319*/ #ifdef NO_ASCIIZ - /*set char type so correct text extent calculated*/ - if (txtStr[0] ==(char)0x80)/*if unicode tag*//*a0393213 lint warnings removal - typecasting done*/ - { - dspl_set_char_type(DSPL_TYPE_UNICODE); - } - else - { - dspl_set_char_type(DSPL_TYPE_ASCII); - } + /*set char type so correct text extent calculated*/ + if (txtStr[0] ==(char)0x80)/*if unicode tag*//*a0393213 lint warnings removal - typecasting done*/ + { + dspl_set_char_type(DSPL_TYPE_UNICODE); + } + else + { + dspl_set_char_type(DSPL_TYPE_ASCII); + } #endif /*mc end*/ - lenStr = dspl_GetTextExtent( txtStr, 0); - } - else - lenStr = 0; - - if(txtId != TxtNull) - { - memcpy(idStr, MmiRsrcGetText(txtId), PHB_MAX_LEN); - lenId = dspl_GetTextExtent( idStr, 0); - /*MC, unicode string if in chinese*/ - if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE) - unicode_string = 1; - } - else - { - lenId = 0; + lenStr = dspl_GetTextExtent( txtStr, 0); + } + else + lenStr = 0; + + if(txtId != TxtNull) + { + memcpy(idStr, MmiRsrcGetText(txtId), PHB_MAX_LEN); + lenId = dspl_GetTextExtent( idStr, 0); + /*MC, unicode string if in chinese*/ + if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE) + unicode_string = 1; + } + else + { + lenId = 0; /*MC SPR 1319*/ - #ifdef NO_ASCIIZ - /*MC*/ - if ((txtStr != NULL) && (txtStr[0] ==(char)0x80))/*if unicode tag*//*a0393213 lint warnings removal - typecasting done*/ - { char debug[25]; - int i; - - dspl_set_char_type(DSPL_TYPE_UNICODE); - //idStr = txtStr; - resources_truncate_to_screen_width(txtStr,0, idStr, PHB_MAX_LEN, - SCREEN_SIZE_X, TRUE); - unicode_string = 1;/*set unicode flag*/ - - for(i=0; i< 25;i++) - { if (txtStr[i] == NULL) - debug[i] = '0'; - else - debug[i] = txtStr[i]; - } - - - TRACE_EVENT_P1("Call Name string:%s", debug); - } - else + #ifdef NO_ASCIIZ + /*MC*/ + if ((txtStr != NULL) && (txtStr[0] ==(char)0x80))/*if unicode tag*//*a0393213 lint warnings removal - typecasting done*/ + { char debug[25]; + int i; + + dspl_set_char_type(DSPL_TYPE_UNICODE); + //idStr = txtStr; + resources_truncate_to_screen_width(txtStr,0, idStr, PHB_MAX_LEN, + SCREEN_SIZE_X, TRUE); + unicode_string = 1;/*set unicode flag*/ + + for(i=0; i< 25;i++) + { if (txtStr[i] == NULL) + debug[i] = '0'; + else + debug[i] = txtStr[i]; + } + + + TRACE_EVENT_P1("Call Name string:%s", debug); + } + else #endif /*MC end*/ - { //idStr = txtStr; - resources_truncate_to_screen_width(txtStr,0, idStr, PHB_MAX_LEN, - SCREEN_SIZE_X, FALSE); - dspl_set_char_type(DSPL_TYPE_ASCII); - } - } - - txtWidth = lenStr+lenId; + { //idStr = txtStr; + resources_truncate_to_screen_width(txtStr,0, idStr, PHB_MAX_LEN, + SCREEN_SIZE_X, FALSE); + dspl_set_char_type(DSPL_TYPE_ASCII); + } + } + + txtWidth = lenStr+lenId; #ifndef LSCREEN - xPos = 0; - yPos = 0; - txtFormat = 0; - - switch (dataId) - { - case CALL_STATUS_CALL : - xPos = 8; - if (CurrentCallNo == 0) - yPos = Mmi_layout_line(1); - else - yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); - break; - - case CALL_TIMER_CALL : - xPos = INCALLTIMER_X; - if (CurrentCallNo == 0) - yPos = Mmi_layout_line(2); - else - yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); - break; - - case CALL_ID_NAME_CALL : - xPos = CALLID_NUM_XPOS; - if (CurrentCallNo == 0) - yPos = Mmi_layout_line(1); - else - yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); - break; - - case CALL_ID_NUM_CALL : - xPos = CALLID_NUM_XPOS; - if (CurrentCallNo == 0) - yPos = Mmi_layout_line(1); - else - yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); - break; - - default: - break; - } + xPos = 0; + yPos = 0; + txtFormat = 0; + + switch (dataId) + { + case CALL_STATUS_CALL : + xPos = 8; + if (CurrentCallNo == 0) + yPos = Mmi_layout_line(1); + else + yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); + break; + + case CALL_TIMER_CALL : + xPos = INCALLTIMER_X; + if (CurrentCallNo == 0) + yPos = Mmi_layout_line(2); + else + yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); + break; + + case CALL_ID_NAME_CALL : + xPos = CALLID_NUM_XPOS; + if (CurrentCallNo == 0) + yPos = Mmi_layout_line(1); + else + yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); + break; + + case CALL_ID_NUM_CALL : + xPos = CALLID_NUM_XPOS; + if (CurrentCallNo == 0) + yPos = Mmi_layout_line(1); + else + yPos = (Mmi_layout_line(1) + LINE_HEIGHT*CurrentCallNo); + break; + + default: + break; + } #else - txtFormat = 0; - xPos = ((SCREEN_SIZE_X - txtWidth)/2); - nLines = lines_inBetween_Display(noActCalls, CurrentCallNo); - - switch (dataId) - { - case CALL_STATUS_CALL : - if(noActCalls <= 2) - nLines = nLines; - else if(noActCalls == 3) - nLines = nLines; - else if(noActCalls >= 4) - { - xPos = 5; - nLines = nLines; - } - break; - - case CALL_ID_NAME_CALL : - if(noActCalls <= 2) - { - #ifdef FF_CPHS - nLines=nLines+2; - #else - nLines = nLines + 1; - #endif - } - else if(noActCalls == 3) - { - #ifdef FF_CPHS - nLines=nLines+1; - #else - nLines = nLines; - #endif - } - else if(noActCalls >= 4) - { - #ifdef FF_CPHS - nLines= nLines+2; - #else - nLines = nLines + 1; - #endif - } - break; - - case CALL_ID_NUM_CALL : - if(noActCalls <= 2) - { - #ifdef FF_CPHS - nLines = nLines + 3; - #else - nLines = nLines + 2; - #endif - } - else if(noActCalls == 3) - { - #ifdef FF_CPHS - nLines = nLines + 2; - #else - nLines = nLines + 1; - #endif - } - else if(noActCalls >= 4) - { - #ifdef FF_CPHS - nLines = nLines + 2; - #else - nLines = nLines + 1; - #endif - } - break; - - case CALL_TIMER_CALL : - if(noActCalls <= 2) - { - #ifdef FF_CPHS - nLines = nLines + 4; - #else - nLines = nLines + 3; - #endif - } - else if(noActCalls == 3) - { - #ifdef FF_CPHS - nLines = nLines + 3; - #else - nLines = nLines + 2; - #endif - } - else if(noActCalls >= 4) - { - xPos = (SCREEN_SIZE_X - 5) - dspl_GetTextExtent( idStr, 0); - #ifdef FF_CPHS - nLines = nLines + 1; - #else - nLines = nLines; - #endif - } - break; + txtFormat = 0; + xPos = ((SCREEN_SIZE_X - txtWidth)/2); + nLines = lines_inBetween_Display(noActCalls, CurrentCallNo); + + switch (dataId) + { + case CALL_STATUS_CALL : + if(noActCalls <= 2) + nLines = nLines; + else if(noActCalls == 3) + nLines = nLines; + else if(noActCalls >= 4) + { + xPos = 5; + nLines = nLines; + } + break; + + case CALL_ID_NAME_CALL : + if(noActCalls <= 2) + { + #ifdef FF_CPHS + nLines=nLines+2; + #else + nLines = nLines + 1; + #endif + } + else if(noActCalls == 3) + { + #ifdef FF_CPHS + nLines=nLines+1; + #else + nLines = nLines; + #endif + } + else if(noActCalls >= 4) + { + #ifdef FF_CPHS + nLines= nLines+2; + #else + nLines = nLines + 1; + #endif + } + break; + + case CALL_ID_NUM_CALL : + if(noActCalls <= 2) + { + #ifdef FF_CPHS + nLines = nLines + 3; + #else + nLines = nLines + 2; + #endif + } + else if(noActCalls == 3) + { + #ifdef FF_CPHS + nLines = nLines + 2; + #else + nLines = nLines + 1; + #endif + } + else if(noActCalls >= 4) + { + #ifdef FF_CPHS + nLines = nLines + 2; + #else + nLines = nLines + 1; + #endif + } + break; + + case CALL_TIMER_CALL : + if(noActCalls <= 2) + { + #ifdef FF_CPHS + nLines = nLines + 4; + #else + nLines = nLines + 3; + #endif + } + else if(noActCalls == 3) + { + #ifdef FF_CPHS + nLines = nLines + 3; + #else + nLines = nLines + 2; + #endif + } + else if(noActCalls >= 4) + { + xPos = (SCREEN_SIZE_X - 5) - dspl_GetTextExtent( idStr, 0); + #ifdef FF_CPHS + nLines = nLines + 1; + #else + nLines = nLines; + #endif + } + break; #ifdef FF_CPHS - case CALL_ACTIVE_LINE: - nLines = nLines + 1; - break; -#endif - default: - break; - } + case CALL_ACTIVE_LINE: + nLines = nLines + 1; + break; +#endif + default: + break; + } yPos = Mmi_layout_IconHeight() + (nLines * Mmi_layout_line_height()); #endif @@ -5245,10 +5243,10 @@ #ifdef NO_ASCIIZ if (unicode_string==1) - dspl_TextOut(xPos, yPos, DSPL_TXTATTR_UNICODE, idStr); + dspl_TextOut(xPos, yPos, DSPL_TXTATTR_UNICODE, idStr); else #endif - dspl_ScrText(xPos, yPos, idStr, txtFormat); + dspl_ScrText(xPos, yPos, idStr, txtFormat); /*MC SPR 1319, restore original char type*/ dspl_set_char_type(current_display_type); @@ -5269,417 +5267,417 @@ //GW-SPR#???-Truncate phone numbers at the beginning (lose first x chars) static int call_win_cb(MfwEvt e, MfwWin *w){ -// int j; // RAVI +// int j; // RAVI int i = 0; char line[/*MAX_LINE*/PHB_MAX_LEN]; - char tag[MAX_CHAR]; - char name[MAX_CHAR]; - int topLine; - int alphaUsed=0; /*a0393213 lint warnings removal - initialization done*/ - /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ - char len; - TRACE_FUNCTION("call_win_cb"); - - switch (e) - { - case MfwWinVisible: - memset(tag,'\0',sizeof(tag)); - memset(name,'\0',sizeof(name)); - TRACE_EVENT_P1("icon SMS is = %d", iconsGetState(iconIdSMS)); - // Jun 11, 2004 REF: CRR 15634 Deepa M.D - //Check for unread SMS here and display the SMS icon accordingly. - if (smsidle_get_unread_sms_available()) - iconsSetState(iconIdSMS);//Make the SMS Icon visible. - else - iconsDeleteState(iconIdSMS);//Make the SMS Icon invisible. - /*iconsShow();*/ /* SPR#1699 - SH - Undo this change for now */ - showDefault(); - - if (!call_data.calls.numCalls){ - displaySoftKeys('\0',TxtEnd); - return 1; - } - -#ifdef FF_PHONE_LOCK - if( ( call_data.call_direction == MFW_CM_MTC ) && ( phlock_mtc_win_handle ) ) - { - TRACE_EVENT("dialog_info_win_resize_cb: creating mtc kbd handler"); - call_data.kbd= kbd_create (phlock_mtc_win_handle, KEY_ALL, (T_MFW_CB)call_kbd_cb); - } -#endif //FF_PHONE_LOCK - - switch(call_data.calls.mode){ - case CallSingle : - if (call_data.calls.muted) - { - inCall_displayData( CALL_STATUS_CALL ,TxtMuted, NULL, 0); + char tag[MAX_CHAR]; + char name[MAX_CHAR]; + int topLine; + int alphaUsed=0; /*a0393213 lint warnings removal - initialization done*/ + /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ + char len; + TRACE_FUNCTION("call_win_cb"); + + switch (e) + { + case MfwWinVisible: + memset(tag,'\0',sizeof(tag)); + memset(name,'\0',sizeof(name)); + TRACE_EVENT_P1("icon SMS is = %d", iconsGetState(iconIdSMS)); + // Jun 11, 2004 REF: CRR 15634 Deepa M.D + //Check for unread SMS here and display the SMS icon accordingly. + if (smsidle_get_unread_sms_available()) + iconsSetState(iconIdSMS);//Make the SMS Icon visible. + else + iconsDeleteState(iconIdSMS);//Make the SMS Icon invisible. + /*iconsShow();*/ /* SPR#1699 - SH - Undo this change for now */ + showDefault(); + + if (!call_data.calls.numCalls){ + displaySoftKeys('\0',TxtEnd); + return 1; + } + +#ifdef FF_PHONE_LOCK + if( ( call_data.call_direction == MFW_CM_MTC ) && ( phlock_mtc_win_handle ) ) + { + TRACE_EVENT("dialog_info_win_resize_cb: creating mtc kbd handler"); + call_data.kbd= kbd_create (phlock_mtc_win_handle, KEY_ALL, (T_MFW_CB)call_kbd_cb); + } +#endif //FF_PHONE_LOCK + + switch(call_data.calls.mode){ + case CallSingle : + if (call_data.calls.muted) + { + inCall_displayData( CALL_STATUS_CALL ,TxtMuted, NULL, 0); #ifndef LSCREEN - TRACE_EVENT("Call is Muted!"); + TRACE_EVENT("Call is Muted!"); #else - inCall_displayData(CALL_ID_NAME_CALL, 0, name, 0); - inCall_displayData(CALL_ID_NUM_CALL, 0, tag, 0); + inCall_displayData(CALL_ID_NAME_CALL, 0, name, 0); + inCall_displayData(CALL_ID_NUM_CALL, 0, tag, 0); //x0pleela 23 May, 2006 DR: OMAPS00070657 #ifdef FF_CPHS - if(call_data.call_direction==MFW_CM_MOC) - { - if(mmi_get_als_selectedLine()==MFW_SERV_LINE1) - { - inCall_displayData(CALL_ACTIVE_LINE,TxtLine1,NULL, 0); - } - else if(mmi_get_als_selectedLine()==MFW_SERV_LINE2) - { - inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, 0); - } - } + if(call_data.call_direction==MFW_CM_MOC) + { + if(mmi_get_als_selectedLine()==MFW_SERV_LINE1) + { + inCall_displayData(CALL_ACTIVE_LINE,TxtLine1,NULL, 0); + } + else if(mmi_get_als_selectedLine()==MFW_SERV_LINE2) + { + inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, 0); + } + } #endif /* FF_CPHS*/ -#endif - } - else - { - i = callIndex(call_data.calls.selected); - /*a0393213 lint warnings removal - check for callIndex done*/ - if(i<0 || i>=MAX_CALLS) - { - TRACE_ERROR("call_win_cb(): Call index out of bounds"); - break; - } - alphaUsed = 0; - - if (call_data.calls.status[i].stat == CALL_ACTIVE) - { +#endif + } + else + { + i = callIndex(call_data.calls.selected); + /*a0393213 lint warnings removal - check for callIndex done*/ + if(i<0 || i>=MAX_CALLS) + { + TRACE_ERROR("call_win_cb(): Call index out of bounds"); + break; + } + alphaUsed = 0; + + if (call_data.calls.status[i].stat == CALL_ACTIVE) + { #ifndef LSCREEN #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - inCall_displayData( CALL_STATUS_CALL, 0, "1TTY", 0); - else -#endif - inCall_displayData( CALL_STATUS_CALL ,0, "1.A.", 0); + if (call_tty_get()) + inCall_displayData( CALL_STATUS_CALL, 0, "1TTY", 0); + else +#endif + inCall_displayData( CALL_STATUS_CALL ,0, "1.A.", 0); #else - /* SPR#1352 - SH - Make this a text ID, and check for TTY*/ + /* SPR#1352 - SH - Make this a text ID, and check for TTY*/ #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - inCall_displayData( CALL_STATUS_CALL, TxtActiveTTYCall, 0, 0); - else -#endif - inCall_displayData( CALL_STATUS_CALL, TxtActiveCall, 0, 0); -#endif - } - else - { + if (call_tty_get()) + inCall_displayData( CALL_STATUS_CALL, TxtActiveTTYCall, 0, 0); + else +#endif + inCall_displayData( CALL_STATUS_CALL, TxtActiveCall, 0, 0); +#endif + } + else + { #ifndef LSCREEN - inCall_displayData( CALL_STATUS_CALL ,0, "1.H.", 0); + inCall_displayData( CALL_STATUS_CALL ,0, "1.H.", 0); #else - /* SPR#1352 - SH - Make this a text ID, and check for TTY*/ + /* SPR#1352 - SH - Make this a text ID, and check for TTY*/ #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - inCall_displayData( CALL_STATUS_CALL, TxtHeldTTYCall, 0, 0); - else -#endif - inCall_displayData( CALL_STATUS_CALL, TxtHeldCall, 0, 0); -#endif - } - /*mc SPR 1319*/ + if (call_tty_get()) + inCall_displayData( CALL_STATUS_CALL, TxtHeldTTYCall, 0, 0); + else +#endif + inCall_displayData( CALL_STATUS_CALL, TxtHeldCall, 0, 0); +#endif + } + /*mc SPR 1319*/ #ifdef NO_ASCIIZ - if (call_data.calls.status[i].name.len > 0) - { - alphaUsed = TRUE; - if (call_data.calls.status[i].name.data[0] == 0x80) - { /*convert string from on-sim unicode to display format*/ - memset(name, 0, MAX_CHAR); - /*make sure we don't go over the end of the name string*/ - if (call_data.calls.status[i].name.len-1 > (MAX_CHAR -2)) - len = MAX_CHAR-2; - else - len = call_data.calls.status[i].name.len-1; - memcpy(&name[2], &call_data.calls.status[i].name.data[1], len); - name[0] = (char)0x80;/*a0393213 lint warnings removal - char* removed*/ - name[1] = 0x7f; - } - else - strncpy(name, (char*)call_data.calls.status[i].name.data,MAX_CHAR-1); - } + if (call_data.calls.status[i].name.len > 0) + { + alphaUsed = TRUE; + if (call_data.calls.status[i].name.data[0] == 0x80) + { /*convert string from on-sim unicode to display format*/ + memset(name, 0, MAX_CHAR); + /*make sure we don't go over the end of the name string*/ + if (call_data.calls.status[i].name.len-1 > (MAX_CHAR -2)) + len = MAX_CHAR-2; + else + len = call_data.calls.status[i].name.len-1; + memcpy(&name[2], &call_data.calls.status[i].name.data[1], len); + name[0] = (char)0x80;/*a0393213 lint warnings removal - char* removed*/ + name[1] = 0x7f; + } + else + strncpy(name, (char*)call_data.calls.status[i].name.data,MAX_CHAR-1); + } #else - if (strlen((char*)call_data.calls.status[i].name) > 0) - { - alphaUsed = TRUE; - strncpy(name, &call_data.calls.status[i].name,MAX_CHAR-1 ); - } - -#endif - if (strlen((char*)call_data.calls.status[i].number) > 0) - { - - TRACE_EVENT("output COLP number"); - /* NM, Testcase 31.1.3.1 COLP, - show the real connected number, - for single call - */ - if (strlen((char*)call_data.colp_number) > 0) - { - strncpy(tag, (char*)call_data.colp_number, MAX_CHAR-1); - } - else - { - strncpy(tag, (char*)call_data.calls.status[i].number, MAX_CHAR-1); - } - } - else - {/*MC SPR 1319*/ + if (strlen((char*)call_data.calls.status[i].name) > 0) + { + alphaUsed = TRUE; + strncpy(name, &call_data.calls.status[i].name,MAX_CHAR-1 ); + } + +#endif + if (strlen((char*)call_data.calls.status[i].number) > 0) + { + + TRACE_EVENT("output COLP number"); + /* NM, Testcase 31.1.3.1 COLP, + show the real connected number, + for single call + */ + if (strlen((char*)call_data.colp_number) > 0) + { + strncpy(tag, (char*)call_data.colp_number, MAX_CHAR-1); + } + else + { + strncpy(tag, (char*)call_data.calls.status[i].number, MAX_CHAR-1); + } + } + else + {/*MC SPR 1319*/ #ifdef NO_ASCIIZ - if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE) - { /*prepend string with unicode tag so that we know to display it as unicode*/ - memset(tag, 0, MAX_CHAR); - tag[0] = (char)0x80;/*a0393213 lint warnings removal - typecasting done*/ - tag[1] = 0x7f; + if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE) + { /*prepend string with unicode tag so that we know to display it as unicode*/ + memset(tag, 0, MAX_CHAR); + tag[0] = (char)0x80;/*a0393213 lint warnings removal - typecasting done*/ + tag[1] = 0x7f; #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes - new function to calculate length of unicode string */ - memcpy(&tag[2], GET_TEXT(TxtSoftCall), ATB_string_UCLength((USHORT*)GET_TEXT(TxtSoftCall))*sizeof(USHORT)); + memcpy(&tag[2], GET_TEXT(TxtSoftCall), ATB_string_UCLength((USHORT*)GET_TEXT(TxtSoftCall))*sizeof(USHORT)); #else /* NEW_EDITOR */ - memcpy(&tag[2], GET_TEXT(TxtSoftCall), strlenUnicode((U16*)GET_TEXT(TxtSoftCall))-2); + memcpy(&tag[2], GET_TEXT(TxtSoftCall), strlenUnicode((U16*)GET_TEXT(TxtSoftCall))-2); #endif /* NEW_EDITOR */ - TRACE_EVENT_P1("TxtSoftCall: %s", tag); - } - else -#endif - /*mc end*/ { - memcpy(tag, GET_TEXT(TxtSoftCall), MAX_CHAR); - } - } - } - - if(alphaUsed == TRUE) - { - alphaUsed = FALSE; - inCall_displayData(CALL_ID_NAME_CALL, 0, name, 0); + TRACE_EVENT_P1("TxtSoftCall: %s", tag); + } + else +#endif + /*mc end*/ { + memcpy(tag, GET_TEXT(TxtSoftCall), MAX_CHAR); + } + } + } + + if(alphaUsed == TRUE) + { + alphaUsed = FALSE; + inCall_displayData(CALL_ID_NAME_CALL, 0, name, 0); #ifdef LSCREEN - inCall_displayData(CALL_ID_NUM_CALL, 0, tag, 0); -#endif - } - else - inCall_displayData(CALL_ID_NUM_CALL, 0, tag, 0); + inCall_displayData(CALL_ID_NUM_CALL, 0, tag, 0); +#endif + } + else + inCall_displayData(CALL_ID_NUM_CALL, 0, tag, 0); //x0pleela 23 May, 2006 DR: OMAPS00070657 #ifdef FF_CPHS - if(CphsPresent() && mmi_cphs_get_als_value()) - { - - TRACE_FUNCTION_P1("call_data.call_direction: %d", call_data.call_direction); - if(call_data.call_direction==MFW_CM_MOC) - { - if(mmi_get_als_selectedLine()==MFW_SERV_LINE1) - { - inCall_displayData(CALL_ACTIVE_LINE,TxtLine1,NULL, 0); - } - else if(mmi_get_als_selectedLine()==MFW_SERV_LINE2) - { - inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, 0); - } - else - inCall_displayData(CALL_ACTIVE_LINE,TxtNull,NULL, 0); - } - else if(call_data.call_direction==MFW_CM_MTC) - { TRACE_FUNCTION_P1("call_data.call_direction: %d", call_data.call_direction); - if( mfw_get_ALS_type() EQ VOICE_CALL) - { - inCall_displayData(CALL_ACTIVE_LINE,TxtLine1,NULL, 0); - } - else if(mfw_get_ALS_type() EQ AuxVOICE_CALL) - { - inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, 0); - } - else - inCall_displayData(CALL_ACTIVE_LINE,TxtNull,NULL, 0); - } - } + if(CphsPresent() && mmi_cphs_get_als_value()) + { + + TRACE_FUNCTION_P1("call_data.call_direction: %d", call_data.call_direction); + if(call_data.call_direction==MFW_CM_MOC) + { + if(mmi_get_als_selectedLine()==MFW_SERV_LINE1) + { + inCall_displayData(CALL_ACTIVE_LINE,TxtLine1,NULL, 0); + } + else if(mmi_get_als_selectedLine()==MFW_SERV_LINE2) + { + inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, 0); + } + else + inCall_displayData(CALL_ACTIVE_LINE,TxtNull,NULL, 0); + } + else if(call_data.call_direction==MFW_CM_MTC) + { TRACE_FUNCTION_P1("call_data.call_direction: %d", call_data.call_direction); + if( mfw_get_ALS_type() EQ VOICE_CALL) + { + inCall_displayData(CALL_ACTIVE_LINE,TxtLine1,NULL, 0); + } + else if(mfw_get_ALS_type() EQ AuxVOICE_CALL) + { + inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, 0); + } + else + inCall_displayData(CALL_ACTIVE_LINE,TxtNull,NULL, 0); + } + } #endif /* FF_CPHS */ - - memset(line,'\0',sizeof(line)); - - getTimeString(call_data.calls.time[i],(char*)line); - - if (InCallTimer == TRUE) - { - inCall_displayData(CALL_TIMER_CALL, 0, line, 0); - } - break; - case CallTwo : - case CallConference : - default: - - if (call_data.calls.numCalls<MAX_CALLS) - topLine = 2; + + memset(line,'\0',sizeof(line)); + + getTimeString(call_data.calls.time[i],(char*)line); + + if (InCallTimer == TRUE) + { + inCall_displayData(CALL_TIMER_CALL, 0, line, 0); + } + break; + case CallTwo : + case CallConference : + default: + + if (call_data.calls.numCalls<MAX_CALLS) + topLine = 2; else - topLine = 1; - - for (i=0;i<call_data.calls.numCalls;i++) - { - - /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ - /* posY = Mmi_layout_line(topLine+i); */ - Mmi_layout_line(topLine+i); - - memset(line,'\0',sizeof(line)); - memset(name,'\0',sizeof(name)); - memset(tag,'\0',sizeof(tag)); - sprintf(line,"%d",i+1); - - if (call_data.calls.status[i].stat == CALL_ACTIVE) - { + topLine = 1; + + for (i=0;i<call_data.calls.numCalls;i++) + { + + /* x0045876, 14-Aug-2006 (WR - "currentRinger" was set but never used) */ + /* posY = Mmi_layout_line(topLine+i); */ + Mmi_layout_line(topLine+i); + + memset(line,'\0',sizeof(line)); + memset(name,'\0',sizeof(name)); + memset(tag,'\0',sizeof(tag)); + sprintf(line,"%d",i+1); + + if (call_data.calls.status[i].stat == CALL_ACTIVE) + { #ifndef LSCREEN - /* SPR#1352 - SH - Check for TTY*/ + /* SPR#1352 - SH - Check for TTY*/ #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - sprintf(&line[1],"%s","1TTY");//GW Extra ';' removed. - else -#endif - sprintf(&line[1],"%s","1.A."); + if (call_tty_get()) + sprintf(&line[1],"%s","1TTY");//GW Extra ';' removed. + else +#endif + sprintf(&line[1],"%s","1.A."); #else - /* SPR#1352 - SH - Make this a text ID, and check for TTY*/ + /* SPR#1352 - SH - Make this a text ID, and check for TTY*/ #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - inCall_displayData( CALL_STATUS_CALL, TxtActiveTTYCall, 0, i); - else -#endif - inCall_displayData( CALL_STATUS_CALL, TxtActiveCall, 0, i); + if (call_tty_get()) + inCall_displayData( CALL_STATUS_CALL, TxtActiveTTYCall, 0, i); + else +#endif + inCall_displayData( CALL_STATUS_CALL, TxtActiveCall, 0, i); //x0pleela 23 May, 2006 DR: OMAPS00070657 #ifdef FF_CPHS - if(call_data.call_direction==MFW_CM_MOC) - { - if(mmi_get_als_selectedLine()==MFW_SERV_LINE1) - { - inCall_displayData(CALL_ACTIVE_LINE, TxtLine1,NULL, i); - } - else if(mmi_get_als_selectedLine()==MFW_SERV_LINE2) - { - inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, i); - } - } + if(call_data.call_direction==MFW_CM_MOC) + { + if(mmi_get_als_selectedLine()==MFW_SERV_LINE1) + { + inCall_displayData(CALL_ACTIVE_LINE, TxtLine1,NULL, i); + } + else if(mmi_get_als_selectedLine()==MFW_SERV_LINE2) + { + inCall_displayData(CALL_ACTIVE_LINE,TxtLine2,NULL, i); + } + } #endif /* FF_CPHS */ #endif - } - else - { + } + else + { #ifndef LSCREEN - sprintf(&line[1],"%s","1.H."); + sprintf(&line[1],"%s","1.H."); #else #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - inCall_displayData( CALL_STATUS_CALL, TxtHeldTTYCall, 0, i); - else -#endif - inCall_displayData( CALL_STATUS_CALL, TxtHeldCall, 0, i); -#endif - } - + if (call_tty_get()) + inCall_displayData( CALL_STATUS_CALL, TxtHeldTTYCall, 0, i); + else +#endif + inCall_displayData( CALL_STATUS_CALL, TxtHeldCall, 0, i); +#endif + } + #ifndef LSCREEN - inCall_displayData( CALL_STATUS_CALL ,0, line, i); -#endif - - - + inCall_displayData( CALL_STATUS_CALL ,0, line, i); +#endif + + + #ifdef NO_ASCIIZ - if (call_data.calls.status[i].name.len > 0) - { - if (call_data.calls.status[i].name.data[0] == 0x80) - { /*convert string from on-sim unicode to display format*/ - memset(name, 0, MAX_CHAR); - /*make sure we don't go over the end of the name string*/ - if (call_data.calls.status[i].name.len-1 > (MAX_CHAR -2)) - len = MAX_CHAR-2; - else - len = call_data.calls.status[i].name.len-1; - memcpy(&name[2], &call_data.calls.status[i].name.data[1], len); - name[0] = (char)0x80;/*a0393213 lint warnings removal - type casting done*/ - name[1] = 0x7f; - } - else - { - strncpy(name, (char*)call_data.calls.status[i].name.data,MAX_CHAR-1); - } - } + if (call_data.calls.status[i].name.len > 0) + { + if (call_data.calls.status[i].name.data[0] == 0x80) + { /*convert string from on-sim unicode to display format*/ + memset(name, 0, MAX_CHAR); + /*make sure we don't go over the end of the name string*/ + if (call_data.calls.status[i].name.len-1 > (MAX_CHAR -2)) + len = MAX_CHAR-2; + else + len = call_data.calls.status[i].name.len-1; + memcpy(&name[2], &call_data.calls.status[i].name.data[1], len); + name[0] = (char)0x80;/*a0393213 lint warnings removal - type casting done*/ + name[1] = 0x7f; + } + else + { + strncpy(name, (char*)call_data.calls.status[i].name.data,MAX_CHAR-1); + } + } #else - if (strlen((char*)call_data.calls.status[i].name) > 0) - { - alphaUsed = TRUE; - strncpy(name, &call_data.calls.status[i].name,MAX_CHAR-1 ); - } -#endif - - if (strlen((char*)call_data.calls.status[i].number) > 0) - { - TRACE_EVENT("output COLP number"); - /* - *COLP, show the real connected number, - for multi call - */ - if (strlen((char*)call_data.colp_number) > 0) - { strncpy(tag, (char*)call_data.colp_number, MAX_CHAR-1); - } - else - { strncpy(tag, (char*)call_data.calls.status[i].number, MAX_CHAR-1); - } - } - else - { - /*MC SPR 1319*/ + if (strlen((char*)call_data.calls.status[i].name) > 0) + { + alphaUsed = TRUE; + strncpy(name, &call_data.calls.status[i].name,MAX_CHAR-1 ); + } +#endif + + if (strlen((char*)call_data.calls.status[i].number) > 0) + { + TRACE_EVENT("output COLP number"); + /* + *COLP, show the real connected number, + for multi call + */ + if (strlen((char*)call_data.colp_number) > 0) + { strncpy(tag, (char*)call_data.colp_number, MAX_CHAR-1); + } + else + { strncpy(tag, (char*)call_data.calls.status[i].number, MAX_CHAR-1); + } + } + else + { + /*MC SPR 1319*/ #ifdef NO_ASCIIZ - if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE) - { /*prepend string with unicode tag so that we know to display it as unicode*/ - memset(tag, 0, MAX_CHAR); - tag[0] = (char)0x80;/*a0393213 lint warnings removal - typecasting done*/ - tag[1] = 0x7f; + if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE) + { /*prepend string with unicode tag so that we know to display it as unicode*/ + memset(tag, 0, MAX_CHAR); + tag[0] = (char)0x80;/*a0393213 lint warnings removal - typecasting done*/ + tag[1] = 0x7f; #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes - new function to calculate length of unicode string */ - memcpy(&tag[2], GET_TEXT(TxtSoftCall), ATB_string_UCLength((USHORT*)GET_TEXT(TxtSoftCall))*sizeof(USHORT)); + memcpy(&tag[2], GET_TEXT(TxtSoftCall), ATB_string_UCLength((USHORT*)GET_TEXT(TxtSoftCall))*sizeof(USHORT)); #else /* NEW_EDITOR */ - memcpy(&tag[2], GET_TEXT(TxtSoftCall), strlenUnicode((U16*)GET_TEXT(TxtSoftCall))-2); + memcpy(&tag[2], GET_TEXT(TxtSoftCall), strlenUnicode((U16*)GET_TEXT(TxtSoftCall))-2); #endif /* NEW_EDITOR */ - TRACE_EVENT_P1("TxtSoftCall: %s", tag); - } - else -#endif - /*mc end*/ - memcpy(tag, GET_TEXT(TxtSoftCall), MAX_CHAR); - } - - if(alphaUsed == TRUE) - { - alphaUsed = FALSE; - inCall_displayData(CALL_ID_NAME_CALL, 0, name, i); + TRACE_EVENT_P1("TxtSoftCall: %s", tag); + } + else +#endif + /*mc end*/ + memcpy(tag, GET_TEXT(TxtSoftCall), MAX_CHAR); + } + + if(alphaUsed == TRUE) + { + alphaUsed = FALSE; + inCall_displayData(CALL_ID_NAME_CALL, 0, name, i); #ifdef LSCREEN - inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); -#endif - } - else - inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); - - if (((call_data.calls.mode== CallConference)||(call_data.calls.mode== CallMultipartySingle)) - && (i==callIndex(call_data.calls.selected))) - { - multiCall_ActiveCall(CALL_STATUS_CALL, i); - inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); - } - else - { - inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); - } + inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); +#endif + } + else + inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); + + if (((call_data.calls.mode== CallConference)||(call_data.calls.mode== CallMultipartySingle)) + && (i==callIndex(call_data.calls.selected))) + { + multiCall_ActiveCall(CALL_STATUS_CALL, i); + inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); + } + else + { + inCall_displayData(CALL_ID_NUM_CALL, 0, tag, i); + } #ifdef LSCREEN - memset(line,'\0',sizeof(line)); - - getTimeString(call_data.calls.time[i],(char*)line); - - /* JVJ Call timer removed, it makes the display unreadable */ -#endif - } - break; - } - displaySoftKeys(TxtSoftOptions,TxtEnd); + memset(line,'\0',sizeof(line)); + + getTimeString(call_data.calls.time[i],(char*)line); + + /* JVJ Call timer removed, it makes the display unreadable */ +#endif + } + break; + } + displaySoftKeys(TxtSoftOptions,TxtEnd); break; default: - break; + break; } - + return 1; } @@ -5701,199 +5699,199 @@ static int call_kbd_cb (MfwEvt e, MfwKbd *k){ T_MFW_HND win = mfwParent(mfw_header()); //GW Added - int index; - - /* a0393213 (WR - "volStep" was set but never used) */ - /* int volStep; */ + int index; + + /* a0393213 (WR - "volStep" was set but never used) */ + /* int volStep; */ TRACE_FUNCTION("call_kbd_cb"); - /* a0393213 (WR - "volStep" was set but never used) */ - /* - //GW Change volume in large steps if sound has a large range - if (MAX_SOUND < 8) - volStep = 1; - else - volStep = MAX_SOUND / 4; - */ - - switch (k->code) - { - case KCD_MNUUP: - if ((call_data.calls.mode== CallConference)||(call_data.calls.mode== CallMultipartySingle)) - { - index = callIndex(call_data.calls.selected); - if (index ==0) - index = call_data.calls.numCalls; - index = index - 1; - call_data.calls.selected = call_data.calls.status[index].call_number; - winShow(win); - } - else - { + /* a0393213 (WR - "volStep" was set but never used) */ + /* + //GW Change volume in large steps if sound has a large range + if (MAX_SOUND < 8) + volStep = 1; + else + volStep = MAX_SOUND / 4; + */ + + switch (k->code) + { + case KCD_MNUUP: + if ((call_data.calls.mode== CallConference)||(call_data.calls.mode== CallMultipartySingle)) + { + index = callIndex(call_data.calls.selected); + if (index ==0) + index = call_data.calls.numCalls; + index = index - 1; + call_data.calls.selected = call_data.calls.status[index].call_number; + winShow(win); + } + else + { // Nov 29, 2004 REF: CRR 25051 xkundadu // Description: INCALL SCREEN ?ADJUSTING THE VOLUME -// Fix: Added volume level list linked to up/down keys. -// User can select the speaker volume among those levels. - - T_MFW_HND Volmenu_handle; // Menu Handle - UBYTE currentLevel = 0; // Index of the menuitem where the focus should be. - - // Setting the reason why the volume settings is going to be changed. - setSoundsReason(SettingVolume); - // Display the menu, if the user presses the MENU key up - Volmenu_handle = bookMenuStart(call_data.win, ringerVolumeLevels(), SettingVolume); - - switch(FFS_flashData.output_volume) - { - case OutVolumeLevel1: - { - // If the current speaker volume is OutVolumeLevel1, - // focus the first menu item. I.e Level 1. - currentLevel = 0; - } - break; - case OutVolumeLevel2: - { - // Level 2 - currentLevel = 1; - } - break; - case OutVolumeLevel3: - { - // Level 3 - currentLevel = 2; - } - break; - case OutVolumeLevel4: - { - // Level 4 - currentLevel = 3; - } - break; - case OutVolumeLevel5: - { - // Level 5 - currentLevel = 4; - } - break; - default: - { - FFS_flashData.output_volume = OutVolumeLevel3; - currentLevel = 2; - } - } - - // Set the focus to the currently selected volume level menu item. - SEND_EVENT(Volmenu_handle, DEFAULT_OPTION, NULL, ¤tLevel); - - } - break; - - case KCD_MNUDOWN: - if ((call_data.calls.mode== CallConference)||(call_data.calls.mode== CallMultipartySingle)) - { - index = callIndex(call_data.calls.selected); - index = index + 1; - if (index >= call_data.calls.numCalls) - index = 0; - call_data.calls.selected = call_data.calls.status[index].call_number; - winShow(win); - } - else - { +// Fix: Added volume level list linked to up/down keys. +// User can select the speaker volume among those levels. + + T_MFW_HND Volmenu_handle; // Menu Handle + UBYTE currentLevel = 0; // Index of the menuitem where the focus should be. + + // Setting the reason why the volume settings is going to be changed. + setSoundsReason(SettingVolume); + // Display the menu, if the user presses the MENU key up + Volmenu_handle = bookMenuStart(call_data.win, ringerVolumeLevels(), SettingVolume); + + switch(FFS_flashData.output_volume) + { + case OutVolumeLevel1: + { + // If the current speaker volume is OutVolumeLevel1, + // focus the first menu item. I.e Level 1. + currentLevel = 0; + } + break; + case OutVolumeLevel2: + { + // Level 2 + currentLevel = 1; + } + break; + case OutVolumeLevel3: + { + // Level 3 + currentLevel = 2; + } + break; + case OutVolumeLevel4: + { + // Level 4 + currentLevel = 3; + } + break; + case OutVolumeLevel5: + { + // Level 5 + currentLevel = 4; + } + break; + default: + { + FFS_flashData.output_volume = OutVolumeLevel3; + currentLevel = 2; + } + } + + // Set the focus to the currently selected volume level menu item. + SEND_EVENT(Volmenu_handle, DEFAULT_OPTION, NULL, ¤tLevel); + + } + break; + + case KCD_MNUDOWN: + if ((call_data.calls.mode== CallConference)||(call_data.calls.mode== CallMultipartySingle)) + { + index = callIndex(call_data.calls.selected); + index = index + 1; + if (index >= call_data.calls.numCalls) + index = 0; + call_data.calls.selected = call_data.calls.status[index].call_number; + winShow(win); + } + else + { // Nov 29, 2004 REF: CRR 25051 xkundadu // Description: INCALL SCREEN ?ADJUSTING THE VOLUME -// Fix: Added volume level list linked to up/down keys. -// User can select the speaker volume among those levels. - T_MFW_HND Volmenu_handle;// Menu Handle - UBYTE currentLevel = 0;// Index of the menuitem where the focus should me. - - // Setting the reason why the volume settings is going to be changed. - setSoundsReason(SettingVolume); - // Display the menu, if the user presses the MENU key DOWN - Volmenu_handle = bookMenuStart(call_data.win, ringerVolumeLevels(), SettingVolume); - switch(FFS_flashData.output_volume) - { - case OutVolumeLevel1: - { - // If the current speaker volume is OutVolumeLevel1, - // focus the first menu item. I.e Level 1. - currentLevel = 0; - } - break; - case OutVolumeLevel2: - { - currentLevel = 1; - } - break; - case OutVolumeLevel3: - { - currentLevel = 2; - } - break; - case OutVolumeLevel4: - { - currentLevel = 3; - } - break; - case OutVolumeLevel5: - { - currentLevel = 4; - } - break; - default: - { - FFS_flashData.output_volume = OutVolumeLevel3; - currentLevel = 2; - } - } - // Set the focus to the currently selected volume level menu item. - SEND_EVENT(Volmenu_handle, DEFAULT_OPTION, NULL, ¤tLevel); - } - break; - case KCD_LEFT: - { - /*a0393213 lint warning removal - call index bound check done*/ - int call_index=callIndex(call_data.calls.selected); - if(call_index<0 || call_index>=MAX_CALLS) - { - TRACE_ERROR("call_kbd_cb(): call index out of bound"); - break; - } - switch (call_data.calls.mode){ - case CallSingle: - if (call_data.calls.status[call_index].stat == CALL_ACTIVE) - menuCallSingleItems[1].str = (char*)TxtHold; - else - menuCallSingleItems[1].str = (char*)TxtUnhold; - call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallSingle,(T_VOID_FUNC)call_menu_end_cb); - break; - case CallTwo: - if (call_data.calls.status[call_index].stat == CALL_ACTIVE) - menuCallTwoItems[5].str = (char*)TxtHold; - else - menuCallTwoItems[5].str = (char*)TxtUnhold; - call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallTwo,(T_VOID_FUNC)call_menu_end_cb); - break; - case CallConference: - if (call_data.calls.status[call_index].stat == CALL_ACTIVE) - menuCallConferenceItems[5].str = (char*)TxtHold; - else - menuCallConferenceItems[5].str = (char*)TxtUnhold; - menuCallConferenceItems[0].str = (char*)TxtPrivateCall; - call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallConference,(T_VOID_FUNC)call_menu_end_cb); - break; - case CallSingleMultiparty: - case CallMultipartySingle: - menuCallConferenceItems[0].str = (char*)TxtAddToConference; - call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallConference,(T_VOID_FUNC)call_menu_end_cb); - break; - default: - break; - } - break; - } +// Fix: Added volume level list linked to up/down keys. +// User can select the speaker volume among those levels. + T_MFW_HND Volmenu_handle;// Menu Handle + UBYTE currentLevel = 0;// Index of the menuitem where the focus should me. + + // Setting the reason why the volume settings is going to be changed. + setSoundsReason(SettingVolume); + // Display the menu, if the user presses the MENU key DOWN + Volmenu_handle = bookMenuStart(call_data.win, ringerVolumeLevels(), SettingVolume); + switch(FFS_flashData.output_volume) + { + case OutVolumeLevel1: + { + // If the current speaker volume is OutVolumeLevel1, + // focus the first menu item. I.e Level 1. + currentLevel = 0; + } + break; + case OutVolumeLevel2: + { + currentLevel = 1; + } + break; + case OutVolumeLevel3: + { + currentLevel = 2; + } + break; + case OutVolumeLevel4: + { + currentLevel = 3; + } + break; + case OutVolumeLevel5: + { + currentLevel = 4; + } + break; + default: + { + FFS_flashData.output_volume = OutVolumeLevel3; + currentLevel = 2; + } + } + // Set the focus to the currently selected volume level menu item. + SEND_EVENT(Volmenu_handle, DEFAULT_OPTION, NULL, ¤tLevel); + } + break; + case KCD_LEFT: + { + /*a0393213 lint warning removal - call index bound check done*/ + int call_index=callIndex(call_data.calls.selected); + if(call_index<0 || call_index>=MAX_CALLS) + { + TRACE_ERROR("call_kbd_cb(): call index out of bound"); + break; + } + switch (call_data.calls.mode){ + case CallSingle: + if (call_data.calls.status[call_index].stat == CALL_ACTIVE) + menuCallSingleItems[1].str = (char*)TxtHold; + else + menuCallSingleItems[1].str = (char*)TxtUnhold; + call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallSingle,(T_VOID_FUNC)call_menu_end_cb); + break; + case CallTwo: + if (call_data.calls.status[call_index].stat == CALL_ACTIVE) + menuCallTwoItems[5].str = (char*)TxtHold; + else + menuCallTwoItems[5].str = (char*)TxtUnhold; + call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallTwo,(T_VOID_FUNC)call_menu_end_cb); + break; + case CallConference: + if (call_data.calls.status[call_index].stat == CALL_ACTIVE) + menuCallConferenceItems[5].str = (char*)TxtHold; + else + menuCallConferenceItems[5].str = (char*)TxtUnhold; + menuCallConferenceItems[0].str = (char*)TxtPrivateCall; + call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallConference,(T_VOID_FUNC)call_menu_end_cb); + break; + case CallSingleMultiparty: + case CallMultipartySingle: + menuCallConferenceItems[0].str = (char*)TxtAddToConference; + call_data.win_menu = call_menu_start(call_data.win,(T_MFW_MNU_ATTR *)&menuCallConference,(T_VOID_FUNC)call_menu_end_cb); + break; + default: + break; + } + break; + } case KCD_CALL: holdExec(0, 0); break; @@ -5906,7 +5904,7 @@ { voice_buffering_data.rec_stop_reason = CALLING_PARTY_END_CALL; } -#endif +#endif cm_end_all(); break; case KCD_RIGHT: @@ -5917,11 +5915,11 @@ { voice_buffering_data.rec_stop_reason = CALLING_PARTY_END_CALL; } -#endif - if (!call_data.calls.numCalls) - { - cm_force_disconnect(); - call_data.ignore_disconnect = TRUE; +#endif + if (!call_data.calls.numCalls) + { + cm_force_disconnect(); + call_data.ignore_disconnect = TRUE; // Jun 02, 2006 DRT OMAPS00079213 x0039928(sumanth) // Fix: Hook is unregistered when the call is disconnected through keypad or hook. #ifdef FF_MMI_AUDIO_PROFILE @@ -5931,24 +5929,24 @@ if(FFS_flashData.ttyAlwaysOn == FALSE && call_data.tty == CALL_TTY_OFF) #endif - mfw_hook_unregister(); -#endif - /* SPR#1985 - SH - Revert to initial TTY setting*/ + mfw_hook_unregister(); +#endif + /* SPR#1985 - SH - Revert to initial TTY setting*/ #ifdef MMI_TTY_ENABLED - call_tty_revert(); + call_tty_revert(); #endif /* end SH */ - call_destroy(call_data.win); - return 1; - } - // MMI-SPR 13847 xkundadu - // Assign this variable to TRUE to indicate that, host pary started - // the disconnection. - bhostDisconnection = TRUE; - - - switch (call_data.calls.mode) - { + call_destroy(call_data.win); + return 1; + } + // MMI-SPR 13847 xkundadu + // Assign this variable to TRUE to indicate that, host pary started + // the disconnection. + bhostDisconnection = TRUE; + + + switch (call_data.calls.mode) + { case CallConference: case CallMultipartySingle: cm_disconnect(call_data.calls.selected); @@ -5960,12 +5958,12 @@ cm_disconnect(call_data.calls.selected); if (call_data.calls.numCalls==1){ call_data.ignore_disconnect = TRUE; - /* SPR#1985 - SH - Revert to initial TTY setting*/ + /* SPR#1985 - SH - Revert to initial TTY setting*/ #ifdef MMI_TTY_ENABLED - call_tty_revert(); + call_tty_revert(); #endif /* end SH */ - // May 9, 2006 REF:DR OMAPS00074884 xrashmic + // May 9, 2006 REF:DR OMAPS00074884 xrashmic removeCall(call_data.calls.selected, TRUE,FALSE); } break; @@ -5973,22 +5971,22 @@ break; default: - //April 25, 2005 REF: MMI-FIX-30125 x0018858 - //The condition has been modified to support the second call DTMF input. - /* use the DTMF only for single call */ - if (call_data.calls.mode EQ CallNormal ||call_data.calls.mode EQ CallDone || - call_data.calls.mode EQ CallNew ||call_data.calls.mode EQ CallSingle || call_data.calls.mode EQ CallTwo) - { - TRACE_EVENT("send DTMF"); - call_scratchpad_start(call_data.win,editControls[k->code],ViewDTMF, 0); - } - // if (call_data.calls.mode EQ CallTwo ||call_data.calls.mode EQ CallConference || - //call_data.calls.mode EQ CallSingleMultiparty ||call_data.calls.mode EQ CallMultipartySingle) - if (call_data.calls.mode EQ CallConference ||call_data.calls.mode EQ CallSingleMultiparty ||call_data.calls.mode EQ CallMultipartySingle) - { - TRACE_EVENT("send no DTMF and the keys are able for multicall controll"); - call_scratchpad_start(call_data.win,editControls[k->code],ViewMulticallControl, ViewMulticallControlCallWaiting); - } + //April 25, 2005 REF: MMI-FIX-30125 x0018858 + //The condition has been modified to support the second call DTMF input. + /* use the DTMF only for single call */ + if (call_data.calls.mode EQ CallNormal ||call_data.calls.mode EQ CallDone || + call_data.calls.mode EQ CallNew ||call_data.calls.mode EQ CallSingle || call_data.calls.mode EQ CallTwo) + { + TRACE_EVENT("send DTMF"); + call_scratchpad_start(call_data.win,editControls[k->code],ViewDTMF, 0); + } + // if (call_data.calls.mode EQ CallTwo ||call_data.calls.mode EQ CallConference || + //call_data.calls.mode EQ CallSingleMultiparty ||call_data.calls.mode EQ CallMultipartySingle) + if (call_data.calls.mode EQ CallConference ||call_data.calls.mode EQ CallSingleMultiparty ||call_data.calls.mode EQ CallMultipartySingle) + { + TRACE_EVENT("send no DTMF and the keys are able for multicall controll"); + call_scratchpad_start(call_data.win,editControls[k->code],ViewMulticallControl, ViewMulticallControlCallWaiting); + } break; @@ -6039,7 +6037,7 @@ // T_call * data = (T_call *)win_data->user; // RAVI /* a0393213 (WR - "currentRinger" was set but never used) */ -#ifndef FF_MIDI_RINGER +#ifndef FF_MIDI_RINGER #ifndef FF_MMI_RINGTONE UBYTE currentRinger; #endif @@ -6055,7 +6053,7 @@ /*SPR 2646, don't reset window variable till window is destroyed*/ /* a0393213 (WR - "currentRinger" was set but never used) */ -#ifndef FF_MIDI_RINGER +#ifndef FF_MIDI_RINGER #ifndef FF_MMI_RINGTONE currentRinger = getCurrentRingerSettings(); #endif @@ -6081,48 +6079,48 @@ #endif - if (!call_data.calls.numCalls) - mfw_hook_unregister(); + if (!call_data.calls.numCalls) + mfw_hook_unregister(); #endif cm_mt_reject(); //Nov 09, 2005 REF: OMAPS00043190 - x0018858 -// Check to see if the window has not been deinitialized and then de-init +// Check to see if the window has not been deinitialized and then de-init // it on rejecting the call. //begin - if (satDisplayTextWin) - { - SEND_EVENT (satDisplayTextWin, E_ED_DEINIT, INFO_KCD_LEFT, NULL); - } + if (satDisplayTextWin) + { + SEND_EVENT (satDisplayTextWin, E_ED_DEINIT, INFO_KCD_LEFT, NULL); + } //end break; case INFO_KCD_OFFHOOK: case INFO_KCD_LEFT: - + call_data.win_incoming = 0;/*SPR 2646, the dialog is destroyed here too*/ - /* SPR#1983 - SH - Destroy WAP if WAP call is active */ + /* SPR#1983 - SH - Destroy WAP if WAP call is active */ #ifdef FF_WAP if (AUI_wap_in_call()) { - AUI_wap_browser_disconnect(); + AUI_wap_browser_disconnect(); } else { - cm_mt_accept(); + cm_mt_accept(); #else - { - cm_mt_accept(); -#endif - /* MZ cq11080 25/07/03 Remove mute, when incoming call is accepted. */ - if (call_data.calls.muted) - { - if (audio_SetMute(AUDIO_MICROPHONE, AUDIO_MUTING_OFF) == DRV_OK) - { - call_data.calls.muted = false; - menuCallSingleItems[2].str = (char*)TxtMute; - } - } - } + { + cm_mt_accept(); +#endif + /* MZ cq11080 25/07/03 Remove mute, when incoming call is accepted. */ + if (call_data.calls.muted) + { + if (audio_SetMute(AUDIO_MICROPHONE, AUDIO_MUTING_OFF) == DRV_OK) + { + call_data.calls.muted = false; + menuCallSingleItems[2].str = (char*)TxtMute; + } + } + } break; case INFO_KCD_UP: @@ -6131,20 +6129,20 @@ // MZ 3/4/01set the sound reason to volume setting from incomingcall. /*SPR 2646, don't create a volume setting menu more than once*/ setSoundsReason(SettingVolume); - if (!call_data.win_menu) - { + if (!call_data.win_menu) + { // MZ 3/4/01 display the volume settings menu. call_data.win_menu=bookMenuStart(call_data.win, ringerVolumeSetting(), SettingVolume); - } + } break; //this is for the auto answer case INFO_TIMEOUT: -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*MSL Stop */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); @@ -6165,11 +6163,11 @@ { TRACE_EVENT ("call_incoming_cb() with Anykeyanswer"); mmeAudioTone(0, 0, TONE_SWT_OFF); -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); @@ -6178,12 +6176,12 @@ #endif #endif cm_mt_accept(); - } - else /* open the scratchpad for the Multicall Control */ - { - call_scratchpad_start(call_data.win, editControls[identifier], ViewMulticallControl, ViewMulticallControlIncomingCall); - - } + } + else /* open the scratchpad for the Multicall Control */ + { + call_scratchpad_start(call_data.win, editControls[identifier], ViewMulticallControl, ViewMulticallControlIncomingCall); + + } break; @@ -6196,35 +6194,35 @@ #if(0) /* x0039928 - Commented for lint warning removal */ /******************************************************************************* - $Function: call_incoming_animation_cb - - $Description: callback for the in-call animation timer expiring - - $Returns: 1 - - $Arguments: e - event (unused) - t - timer control block (unused) + $Function: call_incoming_animation_cb + + $Description: callback for the in-call animation timer expiring + + $Returns: 1 + + $Arguments: e - event (unused) + t - timer control block (unused) $ History - GW #1555 15/01/03 - Disabled animation code for GOLite b+w display - GW #1555 15/01/03 - Changed code to use data from the icon structure instead of hard - coded values. + GW #1555 15/01/03 - Disabled animation code for GOLite b+w display + GW #1555 15/01/03 - Changed code to use data from the icon structure instead of hard + coded values. *******************************************************************************/ static int call_incoming_animation_cb (MfwEvt e, MfwTim *t) { #ifdef COLOURDISPLAY - MfwIcnAttr *anim; - call_data.animationScreen = (call_data.animationScreen + 1) % CALLANIMATION ; - - if (call_data.incCall != 0) - { - anim = (MfwIcnAttr *)&incoming_call_animate[call_data.animationScreen]; - dspl_BitBlt2(anim->area.px,anim->area.py,anim->area.sx,anim->area.sy,(void*)anim->icons,0,anim->icnType); - timStart(call_data.timer); - } -#endif - return 1; + MfwIcnAttr *anim; + call_data.animationScreen = (call_data.animationScreen + 1) % CALLANIMATION ; + + if (call_data.incCall != 0) + { + anim = (MfwIcnAttr *)&incoming_call_animate[call_data.animationScreen]; + dspl_BitBlt2(anim->area.px,anim->area.py,anim->area.sx,anim->area.sy,(void*)anim->icons,0,anim->icnType); + timStart(call_data.timer); + } +#endif + return 1; } #endif @@ -6244,7 +6242,7 @@ void incomingCall(const T_MFW_CM_CW_INFO* p_pCwInfo) { - + int phbMatch=0; /*May 10,2007 DR:OMAP00127983 x0066814(Geetha)*/ T_MFW_PHB_TEXT *new_cnap_name; @@ -6256,16 +6254,16 @@ //Reject the incoming call if in buffering phase if( (get_voice_memo_type() EQ VOICE_BUFFERING) AND voice_buffering_data.buffering_phase) { - voice_buffering_data.incoming_call_discon = TRUE; - cm_mt_reject(); - return; + voice_buffering_data.incoming_call_discon = TRUE; + cm_mt_reject(); + return; } - -#endif - - /* API - 10/11/2003 - SPR 2472 - Place the call to turn on the backlight here so the backlight comes on for all calls */ + +#endif + + /* API - 10/11/2003 - SPR 2472 - Place the call to turn on the backlight here so the backlight comes on for all calls */ mme_backlightEvent(BL_INCOMING_CALL); - /* API - 10/11/2003 - SPR 2472 - END */ + /* API - 10/11/2003 - SPR 2472 - END */ /*SPR 1392, replaced local variable display_info with call_data.inc_call_data, so incoming calls dialog can be easily resurrected*/ @@ -6273,16 +6271,16 @@ if(p_pCwInfo == 0) return; - //x0pleela 03 Apr, 2007 ER: OMAPS00122561 + //x0pleela 03 Apr, 2007 ER: OMAPS00122561 #ifdef FF_PHONE_LOCK - call_data.call_direction = MFW_CM_MTC; + call_data.call_direction = MFW_CM_MTC; #endif //FF_PHONE_LOCK if (!call_data.win) call_create(0); if (call_data.calls.numCalls == 0) - { + { // Jun 02, 2006 DRT OMAPS00079213 x0039928(sumanth) // Fix: Hook is registered when an incoming call comes. @@ -6290,8 +6288,8 @@ //May 16, 2007 DRT OMAPS00116526 x0066692(Asha) //Moved down the code. mfw_hook_register() is called after starting the Ringer. - SEND_EVENT(call_data.win,CALL_INIT,0,0); - } + SEND_EVENT(call_data.win,CALL_INIT,0,0); + } //set the global status MmiModuleSet(ModuleInCall); @@ -6314,48 +6312,48 @@ } /* end SPR#1983 */ -#if 0 /* FreeCalypso */ - //Daisy tang added for Real Resume feature 20071107 +#if 0 /* FreeCalypso */ + //Daisy tang added for Real Resume feature 20071107 //start if(IsMP3Playing) - { - UINT i; - - IsRealPaused = TRUE; - mfw_fm_audRealPause(); - mp3playTimer = timCreate( 0, 800, (MfwCb)mp3_test_play_Timer_cb); -#if 1 - for(i = 0;i<50;i++) - { - /* - #define AS_STATE_STARTING 3 - #define AS_STATE_STOPPING 5 - */ - if((as_get_state() EQ 3) OR (as_get_state() EQ 5)) - vsi_t_sleep(0,10); /* small delay */ - else - break; - } + { + UINT i; + + IsRealPaused = TRUE; + mfw_fm_audRealPause(); + mp3playTimer = timCreate( 0, 800, (MfwCb)mp3_test_play_Timer_cb); +#if 1 + for(i = 0;i<50;i++) + { + /* + #define AS_STATE_STARTING 3 + #define AS_STATE_STOPPING 5 + */ + if((as_get_state() EQ 3) OR (as_get_state() EQ 5)) + vsi_t_sleep(0,10); /* small delay */ + else + break; + } #endif } #endif /* MZ 1/08/03 issue 2359, generate a call waiting tone/indication in the ear piece. */ if(call_data.calls.numCalls) - /* RAVI - 20-1-2006 */ - /* Silent Implementation */ + /* RAVI - 20-1-2006 */ + /* Silent Implementation */ #ifdef NEPTUNE_BOARD - audio_PlaySoundID( AUDIO_MICROPHONE, TONES_CW, getCurrentVoulmeSettings(), + audio_PlaySoundID( AUDIO_MICROPHONE, TONES_CW, getCurrentVoulmeSettings(), AUDIO_PLAY_INFINITE); #else - audio_PlaySoundID( AUDIO_MICROPHONE, TONES_CW, 0, AUDIO_PLAY_INFINITE); + audio_PlaySoundID( AUDIO_MICROPHONE, TONES_CW, 0, AUDIO_PLAY_INFINITE); #endif /* END RAVI */ else -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh -#ifdef FF_MIDI_RINGER - mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); //May 16, 2007 DRT OMAPS00116526 x0066692(Asha) //mfw_hook_register() is called after starting the Ringer. @@ -6366,7 +6364,7 @@ if(FFS_flashData.ttyAlwaysOn == FALSE && call_data.tty == CALL_TTY_OFF) #endif - mfw_hook_register(); + mfw_hook_register(); #endif #else @@ -6375,19 +6373,19 @@ #ifdef FF_MMI_RINGTONE /* MSL Ring Tone */ audio_PlaySoundID( AUDIO_BUZZER, CALLTONE_SELECT, 0 , AUDIO_PLAY_INFINITE); #else - { - UBYTE currentRinger; - currentRinger=getCurrentRingerSettings(); - audio_PlaySoundID( AUDIO_BUZZER, currentRinger, getCurrentVoulmeSettings(), + { + UBYTE currentRinger; + currentRinger=getCurrentRingerSettings(); + audio_PlaySoundID( AUDIO_BUZZER, currentRinger, getCurrentVoulmeSettings(), AUDIO_PLAY_INFINITE); - } + } #endif #else - { - UBYTE currentRinger; - currentRinger=getCurrentRingerSettings(); - audio_PlaySoundID( AUDIO_BUZZER, currentRinger, 0 , AUDIO_PLAY_INFINITE); - } + { + UBYTE currentRinger; + currentRinger=getCurrentRingerSettings(); + audio_PlaySoundID( AUDIO_BUZZER, currentRinger, 0 , AUDIO_PLAY_INFINITE); + } #endif /* END RAVI */ @@ -6448,36 +6446,36 @@ } /*May 10,2007 DR:OMAP00127983 x0066814(Geetha)-Begin*/ else if (CALL_NAME_NETWORK) - { - /*Name is from Network (rAT_%CNAP)*/ - CALL_NAME_NETWORK=FALSE; - new_cnap_name=get_cnap_name(); - call_data.globalCWInfo.name.len=new_cnap_name->len; -#ifdef NO_ASCIIZ - memcpy(call_data.globalCWInfo.name.data,new_cnap_name->data,sizeof(call_data.globalCWInfo.name.data)); - if (call_data.globalCWInfo.name.len > 0) - { - memset(call_data.phbNameNumber, 0, EDITOR_SIZE); - memcpy(call_data.phbNameNumber,(char*)call_data.globalCWInfo.name.data, sizeof(call_data.phbNameNumber)); - + { + /*Name is from Network (rAT_%CNAP)*/ + CALL_NAME_NETWORK=FALSE; + new_cnap_name=get_cnap_name(); + call_data.globalCWInfo.name.len=new_cnap_name->len; +#ifdef NO_ASCIIZ + memcpy(call_data.globalCWInfo.name.data,new_cnap_name->data,sizeof(call_data.globalCWInfo.name.data)); + if (call_data.globalCWInfo.name.len > 0) + { + memset(call_data.phbNameNumber, 0, EDITOR_SIZE); + memcpy(call_data.phbNameNumber,(char*)call_data.globalCWInfo.name.data, sizeof(call_data.phbNameNumber)); + //String may not be null terminated - add null at end. - if (call_data.entry.name.len < EDITOR_SIZE) - call_data.phbNameNumber[call_data.globalCWInfo.name.len] = 0x00; - - call_data.inc_call_data.TextString2 = call_data.phbNameNumber; - } + if (call_data.entry.name.len < EDITOR_SIZE) + call_data.phbNameNumber[call_data.globalCWInfo.name.len] = 0x00; + + call_data.inc_call_data.TextString2 = call_data.phbNameNumber; + } #else /* NO_ASCIIZ */ //checking for the number from caller strcpy(call_data.globalCWInfo.name.len,new_cnap_name->len); strcpy(call_data.globalCWInfo.name.data,new_cnap_name->data); if (strlen((char*)call_data.globalCWInfo.name) > 0) - { - bookGsm2Alpha((UBYTE*)call_data.globalCWInfo.name); - strncpy((char*)call_data.phbNameNumber,(char*)call_data.globalCWInfo.name,sizeof(call_data.phbNameNumber)); - call_data.inc_call_data.TextString2 = (char*)call_data.phbNameNumber; - } + { + bookGsm2Alpha((UBYTE*)call_data.globalCWInfo.name); + strncpy((char*)call_data.phbNameNumber,(char*)call_data.globalCWInfo.name,sizeof(call_data.phbNameNumber)); + call_data.inc_call_data.TextString2 = (char*)call_data.phbNameNumber; + } #endif /* NO_ASCIIZ */ - } + } /*May 10,2007 DR:OMAP00127983 x0066814(Geetha)- End*/ else { @@ -6485,12 +6483,12 @@ if (strlen((char*)call_data.globalCWInfo.number) > 0) { int max_size = sizeof(call_data.phbNameNumber); - memset((char*)call_data.phbNameNumber, 0x00, max_size); + memset((char*)call_data.phbNameNumber, 0x00, max_size); /* SH 12/02/02. Ensure that '+' is included before international numbers. */ if ((call_data.globalCWInfo.ton == MFW_TON_INTERNATIONAL) && (call_data.globalCWInfo.number[0] != (UBYTE)'+') ) { strcpy((char*)call_data.phbNameNumber,"+"); - max_size--; + max_size--; } /* sbh end */ @@ -6507,31 +6505,31 @@ if (!ALSPresent(NULL, NULL, NULL)) { if (call_data.globalCWInfo.type EQ VOICE_CALL) - call_data.inc_call_data.TextId = TxtLine1; + call_data.inc_call_data.TextId = TxtLine1; if (call_data.globalCWInfo.type EQ AuxVOICE_CALL) - call_data.inc_call_data.TextId = TxtLine2; + call_data.inc_call_data.TextId = TxtLine2; } else { - if (call_data.globalCWInfo.type EQ VOICE_CALL) - { + if (call_data.globalCWInfo.type EQ VOICE_CALL) + { /* SPR#1352 - SH - Modify dialog if this is a TTY call */ /* API - 10-01-03 - 1543 - change the pointer from display_info to call_data.inc_call_data */ #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - { - call_data.inc_call_data.TextId = TxtIncomingTTYCall; - } - else - { - - call_data.inc_call_data.TextId = TxtIncomingCall; - } + if (call_tty_get()) + { + call_data.inc_call_data.TextId = TxtIncomingTTYCall; + } + else + { + + call_data.inc_call_data.TextId = TxtIncomingCall; + } #else /* MMI_TTY_ENABLED */ - call_data.inc_call_data.TextId = TxtIncomingCall; + call_data.inc_call_data.TextId = TxtIncomingCall; #endif /* MMI_TTY_ENABLED */ - } - /* end SH */ + } + /* end SH */ } @@ -6552,22 +6550,22 @@ if (FFS_flashData.settings_status & SettingsAutoAnswerOn) { //Assume we cannot do call deflection if auto-answer is on (not enough time) - // xrashmic 12 Aug, 2004 Bug: 14, 21 - //Disabled the KEY_MNUUP|KEY_MNUDOWN for this dialog. It used to display the alert mode screen in the incoming call screen + // xrashmic 12 Aug, 2004 Bug: 14, 21 + //Disabled the KEY_MNUUP|KEY_MNUDOWN for this dialog. It used to display the alert mode screen in the incoming call screen dlg_initDisplayData_events( &call_data.inc_call_data, (T_VOID_FUNC)call_incoming_cb, THREE_SECS, KEY_RIGHT|KEY_LEFT|KEY_HUP|KEY_CALL|INFO_KCD_ALL ); } /*SPR 1392, if call deflection is off*/ else if (FFS_flashData.call_deflection!= TRUE) { - // xrashmic 12 Aug, 2004 Bug: 14, 21 - //Disabled the KEY_MNUUP|KEY_MNUDOWN for this dialog. It used to display the alert mode screen in the incoming call screen + // xrashmic 12 Aug, 2004 Bug: 14, 21 + //Disabled the KEY_MNUUP|KEY_MNUDOWN for this dialog. It used to display the alert mode screen in the incoming call screen dlg_initDisplayData_events( &call_data.inc_call_data, (T_VOID_FUNC)call_incoming_cb, FOREVER, KEY_RIGHT|KEY_LEFT|KEY_HUP|KEY_CALL|INFO_KCD_ALL ); } else //Call deflection active { call_data.inc_call_data.LeftSoftKey = TxtDeflect; - // xrashmic 12 Aug, 2004 Bug: 14, 21 - //Disabled the KEY_MNUUP|KEY_MNUDOWN for this dialog. It used to display the alert mode screen in the incoming call screen + // xrashmic 12 Aug, 2004 Bug: 14, 21 + //Disabled the KEY_MNUUP|KEY_MNUDOWN for this dialog. It used to display the alert mode screen in the incoming call screen dlg_initDisplayData_events( &call_data.inc_call_data, (T_VOID_FUNC)call_deflection_cb, FOREVER, KEY_RIGHT|KEY_LEFT|KEY_HUP|KEY_CALL|INFO_KCD_ALL ); } @@ -6579,7 +6577,7 @@ * Call Info Screen */ #ifdef COLOURDISPLAY - mmi_dialogs_insert_animation_new(&call_data.inc_call_data,250,(MfwIcnAttr*)incoming_call_animate, CALLANIMATION); + mmi_dialogs_insert_animation_new(&call_data.inc_call_data,250,(MfwIcnAttr*)incoming_call_animate, CALLANIMATION); #endif call_data.win_incoming = info_dialog (call_data.win, &call_data.inc_call_data); @@ -6608,41 +6606,41 @@ T_DISPLAY_DATA display_info; TRACE_FUNCTION("call_calling_show"); - /* SPR#1352 - SH - Modify dialog if this is a TTY call */ + /* SPR#1352 - SH - Modify dialog if this is a TTY call */ #ifdef MMI_TTY_ENABLED - if (call_tty_get()) - { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtEnd, TxtTTYCalling, TxtNull , COLOUR_STATUS_CALLING); - } - else -#endif - { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtEnd, TxtCalling, TxtNull , COLOUR_STATUS_CALLING); - } - /* end SH */ - - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_calling_cb, FOREVER, KEY_RIGHT | KEY_HUP | NUMERIC_KEYS ); - display_info.Identifier = Identifier; - //GW-SPR#762 - Wrap number/name onto 2nd line (if too long) - display_info.WrapStrings = WRAP_STRING_2; - - if (call_data.emergencyCall) - display_info.TextId2 = TxtSOS; - else - display_info.TextString2 = (char*)call_data.phbNameNumber; - //x0035544 Mar 09, 2006 DR:OMAPS00061467 + if (call_tty_get()) + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtEnd, TxtTTYCalling, TxtNull , COLOUR_STATUS_CALLING); + } + else +#endif + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtEnd, TxtCalling, TxtNull , COLOUR_STATUS_CALLING); + } + /* end SH */ + + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_calling_cb, FOREVER, KEY_RIGHT | KEY_HUP | NUMERIC_KEYS ); + display_info.Identifier = Identifier; + //GW-SPR#762 - Wrap number/name onto 2nd line (if too long) + display_info.WrapStrings = WRAP_STRING_2; + + if (call_data.emergencyCall) + display_info.TextId2 = TxtSOS; + else + display_info.TextString2 = (char*)call_data.phbNameNumber; + //x0035544 Mar 09, 2006 DR:OMAPS00061467 #ifdef FF_MMI_SAT_ICON - if(call_data.IconData.dst != NULL) - { - //copy the icon data to be displayed on to the screen. - display_info.IconData.width = call_data.IconData.width; - display_info.IconData.height = call_data.IconData.height; - display_info.IconData.dst = call_data.IconData.dst; - display_info.IconData.selfExplanatory = call_data.IconData.selfExplanatory; - } -#endif - - /* set the user defined identifier */ + if(call_data.IconData.dst != NULL) + { + //copy the icon data to be displayed on to the screen. + display_info.IconData.width = call_data.IconData.width; + display_info.IconData.height = call_data.IconData.height; + display_info.IconData.dst = call_data.IconData.dst; + display_info.IconData.selfExplanatory = call_data.IconData.selfExplanatory; + } +#endif + + /* set the user defined identifier */ call_data.win_calling= info_dialog (call_data.win, &display_info); } @@ -6682,15 +6680,15 @@ { voice_buffering_data.rec_stop_reason = CALL_END_BEF_SETUP; } -#endif - /* destroy the redial windows if exit*/ - cm_redial_abort(); +#endif + /* destroy the redial windows if exit*/ + cm_redial_abort(); if (identifier == MMI_OUTGOING_CALL_DIALOG_SAT) /* in the SAT case, MFW does not know about the call, we therefore * need to disconnect the call without using MFW's call table */ - { + { satDisc(); /* Marcus: Issue 1057: 21/01/2003: Start */ SEND_EVENT(sat_get_call_setup_win(), SAT_CALL_END, 0, NULL); @@ -6702,19 +6700,19 @@ /* Marcus: Issue 1057: 21/01/2003: End */ call_data.ignore_disconnect = TRUE; - if (!call_data.calls.numCalls) - { + if (!call_data.calls.numCalls) + { call_destroy(call_data.win); return; - } - } + } + } else { TRACE_EVENT_P1("disconnecting call %d",call_data.outCall); cm_disconnect(call_data.outCall); - if (!call_data.calls.numCalls) - { + if (!call_data.calls.numCalls) + { call_data.ignore_disconnect = TRUE; call_destroy(call_data.win); return; @@ -6731,30 +6729,30 @@ #endif - if (!call_data.calls.numCalls) - mfw_hook_unregister(); + if (!call_data.calls.numCalls) + mfw_hook_unregister(); #endif break; case INFO_KCD_LEFT: break; case INFO_KCD_ALL: - /*MC 12.04.02 allows scratchpad to be started when call not yet connected*/ - /* use the DTMF only for single call */ - if (call_data.calls.mode EQ CallNormal ||call_data.calls.mode EQ CallDone || - call_data.calls.mode EQ CallNew ||call_data.calls.mode EQ CallSingle || call_data.calls.mode EQ NULL) - { - TRACE_FUNCTION("send DTMF"); - - call_scratchpad_start(call_data.win,editControls[identifier],ViewDTMF, 0); - } - - if (call_data.calls.mode EQ CallTwo ||call_data.calls.mode EQ CallConference || - call_data.calls.mode EQ CallSingleMultiparty ||call_data.calls.mode EQ CallMultipartySingle) - { - TRACE_FUNCTION("send no DTMF and the keys are able for multicall controll"); - call_scratchpad_start(call_data.win,editControls[identifier],ViewMulticallControl, ViewMulticallControlCallWaiting); - } + /*MC 12.04.02 allows scratchpad to be started when call not yet connected*/ + /* use the DTMF only for single call */ + if (call_data.calls.mode EQ CallNormal ||call_data.calls.mode EQ CallDone || + call_data.calls.mode EQ CallNew ||call_data.calls.mode EQ CallSingle || call_data.calls.mode EQ NULL) + { + TRACE_FUNCTION("send DTMF"); + + call_scratchpad_start(call_data.win,editControls[identifier],ViewDTMF, 0); + } + + if (call_data.calls.mode EQ CallTwo ||call_data.calls.mode EQ CallConference || + call_data.calls.mode EQ CallSingleMultiparty ||call_data.calls.mode EQ CallMultipartySingle) + { + TRACE_FUNCTION("send no DTMF and the keys are able for multicall controll"); + call_scratchpad_start(call_data.win,editControls[identifier],ViewMulticallControl, ViewMulticallControlCallWaiting); + } break; } @@ -6840,15 +6838,15 @@ call_data.win_sending_dtmf=0; switch (reason) { - case INFO_KCD_LEFT: - case INFO_KCD_HUP: + case INFO_KCD_LEFT: + case INFO_KCD_HUP: call_data.charSent = 0; call_data.sendingDTMF = FALSE; cm_command_abort(CM_DTMF_AUTO); call_data.current_command = CM_DTMF_AUTO; - break; + break; default: - break; + break; } } @@ -6886,33 +6884,33 @@ call_data.win_ending=0; switch (reason) { - default: + default: endingCall(); - break; + break; } - //MC 17/12/2001 + //MC 17/12/2001 //check if call ended because ACM>=ACMMAX {T_MFW_CM_AOC_INFO aocInfo; - cm_get_aoc_value(CM_AOC_ACMMAX,&aocInfo); - - //Get ACM and ACMMAX + cm_get_aoc_value(CM_AOC_ACMMAX,&aocInfo); + + //Get ACM and ACMMAX cm_get_aoc_value(CM_AOC_ACM,&aocInfo); - //display "No Credit" to user - if((aocInfo.acm >= aocInfo.acm_max) && - ( aocInfo.acm_max > 0)) - { T_DISPLAY_DATA display_info; - - TRACE_EVENT("acm_max exceeded"); - - dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtNo, TxtCredit , COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_acm_max_cb, THREE_SECS, KEY_RIGHT | KEY_LEFT ); - info_dialog (call_data.win, &display_info); - return; -// return; // RAVI - } - else if (call_SATCall == TRUE) + //display "No Credit" to user + if((aocInfo.acm >= aocInfo.acm_max) && + ( aocInfo.acm_max > 0)) + { T_DISPLAY_DATA display_info; + + TRACE_EVENT("acm_max exceeded"); + + dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtNo, TxtCredit , COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_acm_max_cb, THREE_SECS, KEY_RIGHT | KEY_LEFT ); + info_dialog (call_data.win, &display_info); + return; +// return; // RAVI + } + else if (call_SATCall == TRUE) { call_SATCall = FALSE; #if 0 /* CQ16437 : Do not need to return to the SAT menu as it was not exited on Call Setup */ @@ -6924,13 +6922,13 @@ } //Nov 09, 2005 REF: OMAPS00043190 - x0018858 -// Check to see if the window has not been deinitialized and then de-init +// Check to see if the window has not been deinitialized and then de-init // it on ending the call after answering it. //Begin - if (satDisplayTextWin) - { - SEND_EVENT (satDisplayTextWin, E_ED_DEINIT, INFO_KCD_LEFT, NULL); - } + if (satDisplayTextWin) + { + SEND_EVENT (satDisplayTextWin, E_ED_DEINIT, INFO_KCD_LEFT, NULL); + } //end } @@ -7032,11 +7030,11 @@ TRACE_FUNCTION ("call_menu_destroy()"); - if (window == NULL) - { - TRACE_EVENT ("Error : Called with NULL Pointer"); - return; - } + if (window == NULL) + { + TRACE_EVENT ("Error : Called with NULL Pointer"); + return; + } if (data) { @@ -7131,20 +7129,20 @@ static int call_menu_win_cb (MfwEvt e, MfwWin *w) { - T_call_menu * data = (T_call_menu *)w->user; - - MfwMnu * mnu; - - TRACE_FUNCTION ("call_menu_win_cb()"); - switch (e) - { - case MfwWinVisible: - mnu = (MfwMnu *)mfwControl(data->menu); - showDefault(); - softKeys_displayId(TxtSoftSelect, TxtSoftBack, 0, mnu->curAttr->mnuColour ); - break; + T_call_menu * data = (T_call_menu *)w->user; + + MfwMnu * mnu; + + TRACE_FUNCTION ("call_menu_win_cb()"); + switch (e) + { + case MfwWinVisible: + mnu = (MfwMnu *)mfwControl(data->menu); + showDefault(); + softKeys_displayId(TxtSoftSelect, TxtSoftBack, 0, mnu->curAttr->mnuColour ); + break; default: - return 0; + return 0; } return 1; @@ -7186,16 +7184,16 @@ break; case KCD_LEFT: mnuSelect(data->menu); - { - MfwMnu *mnu; - mnu = (MfwMnu *) mfwControl( data->menu ); - if (mnu != NULL) - { - if (mnu->curAttr != NULL) - softKeys_displayId( TxtSoftSelect, TxtSoftBack, 0, mnu->curAttr->mnuColour); - } - } - break; + { + MfwMnu *mnu; + mnu = (MfwMnu *) mfwControl( data->menu ); + if (mnu != NULL) + { + if (mnu->curAttr != NULL) + softKeys_displayId( TxtSoftSelect, TxtSoftBack, 0, mnu->curAttr->mnuColour); + } + } + break; case KCD_RIGHT: case KCD_HUP: mnuEscape(data->menu); @@ -7311,11 +7309,11 @@ memset( (void *) call_data.edtBufDTMF,'\0',sizeof(call_data.edtBufDTMF)); /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - AUI_edit_SetAttr(&call_data.editorAttrDTMF,CALLSCRATCHPAD_EDITOR,COLOUR_EDITOR_XX,EDITOR_FONT, ED_MODE_ALPHA, ED_CURSOR_BAR,ATB_DCS_ASCII, (UBYTE*)call_data.edtBufDTMF,EDITOR_SIZE); + AUI_edit_SetAttr(&call_data.editorAttrDTMF,CALLSCRATCHPAD_EDITOR,COLOUR_EDITOR_XX,EDITOR_FONT, ED_MODE_ALPHA, ED_CURSOR_BAR,ATB_DCS_ASCII, (UBYTE*)call_data.edtBufDTMF,EDITOR_SIZE); data->editor = ATB_edit_Create(&call_data.editorAttrDTMF,0); #else /*NEW_EDITOR*/ - bookSetEditAttributes(CALLSCRATCHPAD_EDITOR, COLOUR_EDITOR_XX,0,edtCurBar1,0,(char*)call_data.edtBufDTMF,EDITOR_SIZE,&call_data.edtAttrDTMF); - data->edt = edtCreate (data->win,&call_data.edtAttrDTMF,MfwEdtVisible,0); + bookSetEditAttributes(CALLSCRATCHPAD_EDITOR, COLOUR_EDITOR_XX,0,edtCurBar1,0,(char*)call_data.edtBufDTMF,EDITOR_SIZE,&call_data.edtAttrDTMF); + data->edt = edtCreate (data->win,&call_data.edtAttrDTMF,MfwEdtVisible,0); #endif /*NEW_EDITOR*/ // xnkulkar SPR-18262 : Added KEY_MAKE flag to detect the key release event. @@ -7363,12 +7361,12 @@ */ /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - /* New editor not destroyed automatically by win_delete, - * so do so here */ - if (data->editor) - { - ATB_edit_Destroy(data->editor); - } + /* New editor not destroyed automatically by win_delete, + * so do so here */ + if (data->editor) + { + ATB_edit_Destroy(data->editor); + } #endif /* NEW_EDITOR */ win_delete (data->win); @@ -7403,7 +7401,7 @@ win_data = ((T_MFW_HDR *) win)->data; data = (T_call_scratchpad *)win_data->user; data->mode = mode; - data->callstatus = callstatus; + data->callstatus = callstatus; SEND_EVENT(win,CALL_SCRATCHPAD_INIT,0,&character);/*a0393213 warnings removal-address of character sent*/ } return win; @@ -7445,15 +7443,15 @@ edtChar(data->edt,ecBottom); #endif /* NEW_EDITOR */ - #if 1//TISH patch for OMAPS00115335 - if (data->mode EQ ViewDTMF || data->mode EQ ViewMulticallControl) - #else - if (data->mode EQ ViewDTMF) - #endif - { - cm_command(call_data.calls.selected,CM_DTMF_ACTIVE,(UBYTE)call_data.edtBufDTMF[0]); - call_data.current_command = CM_DTMF_ACTIVE; - } + #if 1//TISH patch for OMAPS00115335 + if (data->mode EQ ViewDTMF || data->mode EQ ViewMulticallControl) + #else + if (data->mode EQ ViewDTMF) + #endif + { + cm_command(call_data.calls.selected,CM_DTMF_ACTIVE,(UBYTE)call_data.edtBufDTMF[0]); + call_data.current_command = CM_DTMF_ACTIVE; + } winShow(data->win); break; default: @@ -7484,9 +7482,9 @@ { case MfwWinVisible: dspl_ClearAll(); - /* SPR#1428 - SH - New Editor changes */ + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - ATB_edit_Show(data->editor); + ATB_edit_Show(data->editor); #else /* NEW_EDITOR */ edtShow(data->edt); #endif /* NEW_EDITOR */ @@ -7503,18 +7501,18 @@ #if(0) /* x0039928 - Commented for lint warning removal */ static void call_display_call_ended(void) { - T_DISPLAY_DATA display_info; - - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallEnded, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, NULL, THREE_SECS, KEY_CLEAR ); - - /* - * Call Info Screen - */ - info_dialog (0, &display_info); - - - return; + T_DISPLAY_DATA display_info; + + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallEnded, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, NULL, THREE_SECS, KEY_CLEAR ); + + /* + * Call Info Screen + */ + info_dialog (0, &display_info); + + + return; } #endif /******************************************************************************* @@ -7531,58 +7529,58 @@ static int call_scratchpad_kbd_cb (MfwEvt e, MfwKbd *k) { - T_MFW_HND win = mfw_parent (mfw_header()); + T_MFW_HND win = mfw_parent (mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_call_scratchpad * data = (T_call_scratchpad *)win_data->user; // xnkulkar SPR-18262: This BOOL variable is added to detect the key press event in order to call winShow()/windowsUpdate() function BOOL key_pressed_dtmf = FALSE; - //xvilliva SPR13698 - The following two variables are used to find a - //HELD and an active call. - SHORT heldID = -1; - SHORT activeID = -1; - -// int position=0; // RAVI - UBYTE callstatus = data->callstatus; + //xvilliva SPR13698 - The following two variables are used to find a + //HELD and an active call. + SHORT heldID = -1; + SHORT activeID = -1; + +// int position=0; // RAVI + UBYTE callstatus = data->callstatus; TRACE_FUNCTION ("call_scratchpad_kbd_cb()"); - // xnkulkar SPR-18262: Detect the key release event (using !(e & KEY_MAKE)). This event is used to send the - // DTMF stop command. + // xnkulkar SPR-18262: Detect the key release event (using !(e & KEY_MAKE)). This event is used to send the + // DTMF stop command. if (!(e & KEY_MAKE)) { - switch (k->code) - { - case KCD_0: - case KCD_1: - case KCD_2: - case KCD_3: - case KCD_4: - case KCD_5: - case KCD_6: - case KCD_7: - case KCD_8: - case KCD_9: - case KCD_STAR: - case KCD_HASH: - // xnkulkar SPR-18262: A key has been released. Call cm_command() function with CM_DTMF_INACTIVE - // mode to stop sending the DTMF tone. - #if 1 // for OMAPS00115335 + switch (k->code) + { + case KCD_0: + case KCD_1: + case KCD_2: + case KCD_3: + case KCD_4: + case KCD_5: + case KCD_6: + case KCD_7: + case KCD_8: + case KCD_9: + case KCD_STAR: + case KCD_HASH: + // xnkulkar SPR-18262: A key has been released. Call cm_command() function with CM_DTMF_INACTIVE + // mode to stop sending the DTMF tone. + #if 1 // for OMAPS00115335 if(call_data.current_command EQ CM_DTMF_ACTIVE) { cm_command(call_data.calls.selected,CM_DTMF_INACTIVE,(UBYTE)editControls[k->code]); call_data.current_command = CM_DTMF_INACTIVE; } - #else - cm_command(call_data.calls.selected,CM_DTMF_INACTIVE,(UBYTE)editControls[k->code]); - call_data.current_command = CM_DTMF_INACTIVE; - #endif - - default: - return MFW_EVENT_CONSUMED; -// break; // RAVI - } - } - + #else + cm_command(call_data.calls.selected,CM_DTMF_INACTIVE,(UBYTE)editControls[k->code]); + call_data.current_command = CM_DTMF_INACTIVE; + #endif + + default: + return MFW_EVENT_CONSUMED; +// break; // RAVI + } + } + switch(data->mode){ case ViewDTMF: switch (k->code) @@ -7611,25 +7609,25 @@ #endif /* NEW_EDITOR */ #if defined (TI_PS_FF_EM) || defined (MMI_EM_ENABLED) - /*MC, SPR2469 check for engineering mode code*/ - if (strcmp((char*)call_data.edtBufDTMF, "*36446337464#") == 0) - { - TRACE_EVENT("Engineering mode string"); - /*create menu*/ - mmi_em_start_eng_mode_menus(call_data.win); - } - else -#endif - { - // xnkulkar SPR-18262: A key has been pressed. Call cm_command() function with CM_DTMF_ACTIVE - // mode to start sending the DTMF tone. - cm_command(call_data.calls.selected,CM_DTMF_ACTIVE,(UBYTE)editControls[k->code]); - call_data.current_command = CM_DTMF_ACTIVE; - key_pressed_dtmf = TRUE; - // xnkulkar SPR-18262: Call winShow() to update the character on screen. - // Calling windowsUpdate() slows down the process of sending DTMF commands and induces a delay. - win_show(data->win); - } + /*MC, SPR2469 check for engineering mode code*/ + if (strcmp((char*)call_data.edtBufDTMF, "*36446337464#") == 0) + { + TRACE_EVENT("Engineering mode string"); + /*create menu*/ + mmi_em_start_eng_mode_menus(call_data.win); + } + else +#endif + { + // xnkulkar SPR-18262: A key has been pressed. Call cm_command() function with CM_DTMF_ACTIVE + // mode to start sending the DTMF tone. + cm_command(call_data.calls.selected,CM_DTMF_ACTIVE,(UBYTE)editControls[k->code]); + call_data.current_command = CM_DTMF_ACTIVE; + key_pressed_dtmf = TRUE; + // xnkulkar SPR-18262: Call winShow() to update the character on screen. + // Calling windowsUpdate() slows down the process of sending DTMF commands and induces a delay. + win_show(data->win); + } break; /*API - 23/07/03 - 11076 - Add the call to KCD_RIGHT here */ @@ -7640,51 +7638,51 @@ { /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - ATB_edit_DeleteLeft(data->editor, TRUE); /* SPR#2342 - SH */ + ATB_edit_DeleteLeft(data->editor, TRUE); /* SPR#2342 - SH */ #else /* NEW_EDITOR */ - edtChar(data->edt, ecBack); + edtChar(data->edt, ecBack); #endif /* NEW_EDITOR */ - - } - else - call_scratchpad_destroy(data->win); - + + } + else + call_scratchpad_destroy(data->win); + break; case KCD_HUP: - // May 9, 2006 REF:DR OMAPS00074884 xrashmic - // Pressing Red key in scratch pad releses all calls. If there are no calls, - // it would destroy the scratch pad. - { - if (call_data.calls.numCalls==0) - { - call_scratchpad_destroy(data->win); - } - else - { - cm_end_all(); - } - } + // May 9, 2006 REF:DR OMAPS00074884 xrashmic + // Pressing Red key in scratch pad releses all calls. If there are no calls, + // it would destroy the scratch pad. + { + if (call_data.calls.numCalls==0) + { + call_scratchpad_destroy(data->win); + } + else + { + cm_end_all(); + } + } break; case KCD_CALL: case KCD_LEFT: callNumber((UBYTE*)call_data.edtBufDTMF); call_scratchpad_destroy(win); - /* MZ cq11080 25/07/03 Remove mute when activating new call */ - if (call_data.calls.muted) - { - if (audio_SetMute(AUDIO_MICROPHONE, AUDIO_MUTING_OFF) == DRV_OK) - { - call_data.calls.muted = false; - menuCallSingleItems[2].str = (char*)TxtMute; - } - } + /* MZ cq11080 25/07/03 Remove mute when activating new call */ + if (call_data.calls.muted) + { + if (audio_SetMute(AUDIO_MICROPHONE, AUDIO_MUTING_OFF) == DRV_OK) + { + call_data.calls.muted = false; + menuCallSingleItems[2].str = (char*)TxtMute; + } + } return 1; // break; // RAVI - /*API - 23/07/03 - 11076 - Remove duplication of code for The handeling of KCD_RIGHT - problem was also this returned 1 at end of case and stopped - further editor update etc*/ + /*API - 23/07/03 - 11076 - Remove duplication of code for The handeling of KCD_RIGHT + problem was also this returned 1 at end of case and stopped + further editor update etc*/ default: break; @@ -7725,190 +7723,190 @@ break; } break; - case ViewMulticallControl: - { - TRACE_FUNCTION ("ViewMulticallControl()"); - switch (k->code) - { - case KCD_0: - case KCD_1: - case KCD_2: - case KCD_3: - case KCD_4: - case KCD_5: - case KCD_6: - case KCD_7: - case KCD_8: - case KCD_9: -// -// Jun 10, 2004 REF=CRR 13602 Sasken/xreddymn -// Added * and # key handling, to allow the input of -// * and # characters in the scratchpad screen - case KCD_STAR: - case KCD_HASH: - - /* SPR#1428 - SH - New Editor changes */ + case ViewMulticallControl: + { + TRACE_FUNCTION ("ViewMulticallControl()"); + switch (k->code) + { + case KCD_0: + case KCD_1: + case KCD_2: + case KCD_3: + case KCD_4: + case KCD_5: + case KCD_6: + case KCD_7: + case KCD_8: + case KCD_9: +// +// Jun 10, 2004 REF=CRR 13602 Sasken/xreddymn +// Added * and # key handling, to allow the input of +// * and # characters in the scratchpad screen + case KCD_STAR: + case KCD_HASH: + + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - ATB_edit_AsciiChar(data->editor, editControls[k->code], TRUE); + ATB_edit_AsciiChar(data->editor, editControls[k->code], TRUE); #else /* NEW_EDITOR */ - edtChar(data->edt, editControls[k->code]); + edtChar(data->edt, editControls[k->code]); #endif /* NEW_EDITOR */ - break; - - case KCD_MNUUP: - /* SPR#1428 - SH - New Editor changes */ + break; + + case KCD_MNUUP: + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - ATB_edit_MoveCursor(data->editor, ctrlRight, TRUE); + ATB_edit_MoveCursor(data->editor, ctrlRight, TRUE); #else /* NEW_EDITOR */ - edtChar(data->edt, ecRight); + edtChar(data->edt, ecRight); #endif /* NEW_EDITOR */ - break; - - case KCD_MNUDOWN: - /* SPR#1428 - SH - New Editor changes */ + break; + + case KCD_MNUDOWN: + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - ATB_edit_MoveCursor(data->editor, ctrlLeft, TRUE); + ATB_edit_MoveCursor(data->editor, ctrlLeft, TRUE); #else /* NEW_EDITOR */ - edtChar(data->edt, ecLeft); + edtChar(data->edt, ecLeft); #endif /* NEW_EDITOR */ - break; - case KCD_CALL: - case KCD_LEFT: - /*MC 12/04/02 Check for ECT string and display appropriate waiting screen*/ - if (call_data.edtBufDTMF[0]== '4' && strlen(call_data.edtBufDTMF) == 1) - { call_data.current_command = CM_ETC; - callSetMode(ViewWaitingAnswer, TRUE); - } - // xvilliva SPR13698 - // We find out if the current call is an emergency call, we check if there is an - // active call and a held call currently, we release all the calls to make way to - // establish an emergency call. - // When we try to disconnect the active+held calls using cm_disconnect() and - // establish an emergency call using cm_mo_call(), ECC doesnot get through - // as we do not get E_CM_DISCONNECT immediately. This is varying with - // service providers. To avoid this we take the approach of ending all calls - // and after we receive the E_CM_DISCONNECT_ALL event we initiate the - // emergency call. - makeECC = FALSE; - strcpy(strECC,""); - if (cm_check_emergency((UBYTE*)call_data.edtBufDTMF) EQ TRUE) - { - if ((cm_search_callId(CAL_STAT_Held, &heldID) == CM_OK) - AND (cm_search_callId(CAL_STAT_Active, &activeID) == CM_OK)) - { - strcpy(strECC,call_data.edtBufDTMF);// Store the emergency number. - makeECC = TRUE; // Set the flag for making ECC. - cm_end_all(); // We end all other calls. - if (call_data.win) - call_destroy(call_data.win); // Clear the call status window. - } - } - if(makeECC == FALSE) // We make call only if it is not - { // handled in the above "if". - cm_mo_call((UBYTE*)call_data.edtBufDTMF, VOICE_CALL); - } - call_scratchpad_destroy(data->win); - - // June 22, 2004 MMI-SPR 16573 CW+CLIP : blanck screen - // Issue description: 1 active call + 1 Call Waiting (calling number is correctly - //displayed) - // The user releases the active call (11+SEND) - // Call Waiting but the screen is empty (yellow screen !) - // The user answers the call (yellow screen..) - // Solution: After the scratchpad window destruction, if there is an incoming call, - // show the incoming call window - - // Checking whether the there is an incoming call is present or not - if(call_data.incCall) - { - // Checking the callstatus. If there is a call is waiting and if the user presses - // any of the key betweem 0-9, from the function call_incoming_cb(), - // call_scratchpad_start() will be called with the status parameter ViewMulticallControlIncomingCall - // here it's checking whethere the status variable is ViewMulticallControlIncomingCall - if(callstatus EQ ViewMulticallControlIncomingCall) - { - // Checking whether the incoming call window is exisiting - // IF window is not there, display it. - if (call_data.win_incoming == 0) - { - call_data.win_incoming = info_dialog(call_data.win, &call_data.inc_call_data); - } - } - } - - - - break; - case KCD_RIGHT: - TRACE_EVENT ("press right"); - if (strlen(call_data.edtBufDTMF) > 0) - { - /* SPR#1428 - SH - New Editor changes */ + break; + case KCD_CALL: + case KCD_LEFT: + /*MC 12/04/02 Check for ECT string and display appropriate waiting screen*/ + if (call_data.edtBufDTMF[0]== '4' && strlen(call_data.edtBufDTMF) == 1) + { call_data.current_command = CM_ETC; + callSetMode(ViewWaitingAnswer, TRUE); + } + // xvilliva SPR13698 + // We find out if the current call is an emergency call, we check if there is an + // active call and a held call currently, we release all the calls to make way to + // establish an emergency call. + // When we try to disconnect the active+held calls using cm_disconnect() and + // establish an emergency call using cm_mo_call(), ECC doesnot get through + // as we do not get E_CM_DISCONNECT immediately. This is varying with + // service providers. To avoid this we take the approach of ending all calls + // and after we receive the E_CM_DISCONNECT_ALL event we initiate the + // emergency call. + makeECC = FALSE; + strcpy(strECC,""); + if (cm_check_emergency((UBYTE*)call_data.edtBufDTMF) EQ TRUE) + { + if ((cm_search_callId(CAL_STAT_Held, &heldID) == CM_OK) + AND (cm_search_callId(CAL_STAT_Active, &activeID) == CM_OK)) + { + strcpy(strECC,call_data.edtBufDTMF);// Store the emergency number. + makeECC = TRUE; // Set the flag for making ECC. + cm_end_all(); // We end all other calls. + if (call_data.win) + call_destroy(call_data.win); // Clear the call status window. + } + } + if(makeECC == FALSE) // We make call only if it is not + { // handled in the above "if". + cm_mo_call((UBYTE*)call_data.edtBufDTMF, VOICE_CALL); + } + call_scratchpad_destroy(data->win); + + // June 22, 2004 MMI-SPR 16573 CW+CLIP : blanck screen + // Issue description: 1 active call + 1 Call Waiting (calling number is correctly + //displayed) + // The user releases the active call (11+SEND) + // Call Waiting but the screen is empty (yellow screen !) + // The user answers the call (yellow screen..) + // Solution: After the scratchpad window destruction, if there is an incoming call, + // show the incoming call window + + // Checking whether the there is an incoming call is present or not + if(call_data.incCall) + { + // Checking the callstatus. If there is a call is waiting and if the user presses + // any of the key betweem 0-9, from the function call_incoming_cb(), + // call_scratchpad_start() will be called with the status parameter ViewMulticallControlIncomingCall + // here it's checking whethere the status variable is ViewMulticallControlIncomingCall + if(callstatus EQ ViewMulticallControlIncomingCall) + { + // Checking whether the incoming call window is exisiting + // IF window is not there, display it. + if (call_data.win_incoming == 0) + { + call_data.win_incoming = info_dialog(call_data.win, &call_data.inc_call_data); + } + } + } + + + + break; + case KCD_RIGHT: + TRACE_EVENT ("press right"); + if (strlen(call_data.edtBufDTMF) > 0) + { + /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - ATB_edit_DeleteLeft(data->editor, TRUE); /* SPR#2342 - SH */ + ATB_edit_DeleteLeft(data->editor, TRUE); /* SPR#2342 - SH */ #else /* NEW_EDITOR */ - edtChar(data->edt, ecBack); + edtChar(data->edt, ecBack); #endif /* NEW_EDITOR */ - } - else - { - TRACE_EVENT ("now destroy"); - call_scratchpad_destroy(data->win); - // June 22, 2004 MMI-SPR 16573: CW+CLIP : blanck screen - // Issue description: 1 active call + 1 Call Waiting (calling number is correctly - //displayed) - // Solution: Here also retain the incoming call window. - // Checking whether the there is an incoming call is present or not - if(call_data.incCall) - { - // Checking the callstatus. If there is a call is waiting and if the user presses - // any of the key betweem 0-9, from the function call_incoming_cb(), - // call_scratchpad_start() will be called with the status parameter ViewMulticallControlIncomingCall - // here it's checking whethere the status variable is ViewMulticallControlIncomingCall - if(callstatus EQ ViewMulticallControlIncomingCall) - { - // Checking whether the incoming call window is exisiting - // IF window is not there, display it. - if (call_data.win_incoming == 0) - { - call_data.win_incoming = info_dialog(call_data.win, &call_data.inc_call_data); - } - } - } - } - break; - case KCD_HUP: - // May 9, 2006 REF:DR OMAPS00074884 xrashmic - // Pressing Red key in scratch pad releses all calls. If there are no calls, - //it would destroy the scratch pad. - if (call_data.calls.numCalls==0) - { - call_scratchpad_destroy(data->win); - } - else - { - cm_end_all(); - } - break; + } + else + { + TRACE_EVENT ("now destroy"); + call_scratchpad_destroy(data->win); + // June 22, 2004 MMI-SPR 16573: CW+CLIP : blanck screen + // Issue description: 1 active call + 1 Call Waiting (calling number is correctly + //displayed) + // Solution: Here also retain the incoming call window. + // Checking whether the there is an incoming call is present or not + if(call_data.incCall) + { + // Checking the callstatus. If there is a call is waiting and if the user presses + // any of the key betweem 0-9, from the function call_incoming_cb(), + // call_scratchpad_start() will be called with the status parameter ViewMulticallControlIncomingCall + // here it's checking whethere the status variable is ViewMulticallControlIncomingCall + if(callstatus EQ ViewMulticallControlIncomingCall) + { + // Checking whether the incoming call window is exisiting + // IF window is not there, display it. + if (call_data.win_incoming == 0) + { + call_data.win_incoming = info_dialog(call_data.win, &call_data.inc_call_data); + } + } + } + } + break; + case KCD_HUP: + // May 9, 2006 REF:DR OMAPS00074884 xrashmic + // Pressing Red key in scratch pad releses all calls. If there are no calls, + //it would destroy the scratch pad. + if (call_data.calls.numCalls==0) + { + call_scratchpad_destroy(data->win); + } + else + { + cm_end_all(); + } + break; default: break; } - /* if true, call the incoming call screen back on the screen because it - was destroyed by the scratchpad function */ - if (callstatus EQ ViewMulticallControlIncomingCall && data EQ NULL) - { - TRACE_EVENT ("call the incoming call screen back on the screen"); - incomingCall(&call_data.globalCWInfo); - } - } - break; - default: - break; + /* if true, call the incoming call screen back on the screen because it + was destroyed by the scratchpad function */ + if (callstatus EQ ViewMulticallControlIncomingCall && data EQ NULL) + { + TRACE_EVENT ("call the incoming call screen back on the screen"); + incomingCall(&call_data.globalCWInfo); + } + } + break; + default: + break; } /* API - 30/10/2003 - SPR 2667 - Remove the call to winShow(call_data.win); and replace with this call - this means that all windows will be updated from idle up */ + this means that all windows will be updated from idle up */ // xnkulkar SPR-18262: As windowsUpdate() keeps the system busy for more time and hinders the process of // sending DTMF commands, it's called when no key is pressed. @@ -7955,37 +7953,37 @@ winUpdate((MfwWin*)mfwControl(data->win)); return MFW_EVENT_CONSUMED; } - else - { - - //Sep 2, 2004 REF: CRR 21370 xkundadu - //Added the long press of '*' key to display 'w' - if(e & KEY_STAR) - { - #ifdef NEW_EDITOR - ATB_edit_DeleteLeft(data->editor, FALSE); - ATB_edit_AsciiChar(data->editor, 'w', TRUE); - #else - edtChar(data->edt, ecBack); - edtChar(data->edt,'w'); - #endif - - return MFW_EVENT_CONSUMED; - } - } - - //Sep 2, 2004 REF: CRR 21370 xkundadu - //Changed the long press of '#' key to display 'p' - + else + { + + //Sep 2, 2004 REF: CRR 21370 xkundadu + //Added the long press of '*' key to display 'w' + if(e & KEY_STAR) + { + #ifdef NEW_EDITOR + ATB_edit_DeleteLeft(data->editor, FALSE); + ATB_edit_AsciiChar(data->editor, 'w', TRUE); + #else + edtChar(data->edt, ecBack); + edtChar(data->edt,'w'); + #endif + + return MFW_EVENT_CONSUMED; + } + } + + //Sep 2, 2004 REF: CRR 21370 xkundadu + //Changed the long press of '#' key to display 'p' + if (e & KEY_HASH) { /* SPR#1428 - SH - New Editor changes */ #ifdef NEW_EDITOR - ATB_edit_DeleteLeft(data->editor, FALSE); /* SPR#2342 - SH */ - ATB_edit_AsciiChar(data->editor, 'p', TRUE); + ATB_edit_DeleteLeft(data->editor, FALSE); /* SPR#2342 - SH */ + ATB_edit_AsciiChar(data->editor, 'p', TRUE); #else /* NEW_EDITOR */ - edtChar(data->edt, ecBack); - edtChar(data->edt,'p'); + edtChar(data->edt, ecBack); + edtChar(data->edt,'p'); #endif /* NEW_EDITOR */ return MFW_EVENT_CONSUMED; @@ -8014,7 +8012,7 @@ void call_failure_cb(T_MFW_HND win, UBYTE identifier, UBYTE reason) { // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // RAVI -// T_call * data = (T_call *)win_data->user; // RAVI +// T_call * data = (T_call *)win_data->user; // RAVI /* * Who has initiated the information screen */ @@ -8084,8 +8082,8 @@ static void showCCNotify (T_MFW_HND win, T_MFW_CM_NOTIFY * cc_notify) { - T_DISPLAY_DATA display_info; - USHORT txtId2 = TxtNull; + T_DISPLAY_DATA display_info; + USHORT txtId2 = TxtNull; TRACE_FUNCTION("++ showCCNotify"); @@ -8106,8 +8104,8 @@ if (txtId2 != TxtNull ) { - dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull,TxtSoftCall, txtId2 , COLOUR_STATUS_CCNOTIFY); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_info_cb, THREE_SECS, KEY_CLEAR | KEY_LEFT ); + dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull,TxtSoftCall, txtId2 , COLOUR_STATUS_CCNOTIFY); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)call_info_cb, THREE_SECS, KEY_CLEAR | KEY_LEFT ); display_info.Identifier = E_CM_NOTIFY; /* @@ -8174,8 +8172,8 @@ InCallTimer = TRUE; flash_write(); - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtActivated, TxtInCallTimer, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtActivated, TxtInCallTimer, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); /* Call Info Screen */ info_dialog( win, &display_info ); @@ -8202,8 +8200,8 @@ InCallTimer = FALSE; flash_write(); - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtDeActivated, TxtInCallTimer, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtDeActivated, TxtInCallTimer, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); /* Call Info Screen */ @@ -8593,7 +8591,7 @@ // T_CCBS_LIST_ITEM_STR *item = &ccbs_list.item[ccbs_list.count]; T_MFW_PHB_ENTRY entry; // Structure to pass to bookFindNameInPhonebook int max_num_size = sizeof(ccbs_list.item[ccbs_list.count].number); - + TRACE_EVENT_P1("ccbs_list.count = %d", ccbs_list.count); // TRACE_EVENT_P1("item: %p", item); @@ -8603,7 +8601,7 @@ if ((para->ton == MFW_TON_INTERNATIONAL) && (para->number[0] != '+')) { strcpy((char *)ccbs_list.item[ccbs_list.count].number, "+"); - max_num_size--; + max_num_size--; } strncat((char *)ccbs_list.item[ccbs_list.count].number, (char *)para->number, max_num_size); @@ -8701,11 +8699,11 @@ $Function: call_create_ccbs_menu_list - $Description: Creates a list of registered CCBS for selection. - - $Returns: Nothing - - $Arguments: None + $Description: Creates a list of registered CCBS for selection. + + $Returns: Nothing + + $Arguments: None *******************************************************************************/ static void call_create_ccbs_menu_list(void) @@ -8757,12 +8755,12 @@ { ccbs_list.list_menu_data->List[index].str = (char *)ccbs_list.item[index].name.data; TRACE_EVENT_P2("name.data: %p %s", ccbs_list.item[index].name.data, ccbs_list.item[index].name.data); - } + } #else if (strlen((char *)ccbs_list.item[index].name) != 0) { ccbs_list.list_menu_data->List[index].str = (char *)ccbs_list.item[index].name; - } + } #endif else { @@ -8800,11 +8798,11 @@ $Function: call_ccbs_menu_list_cb - $Description: Callback function for the registered CCBS list + $Description: Callback function for the registered CCBS list $Returns: Nothing - $Arguments: T_MFW_HND win - the list's window handle + $Arguments: T_MFW_HND win - the list's window handle ListMenuData * - pointer to list data *******************************************************************************/ @@ -8825,19 +8823,19 @@ #ifdef NO_ASCIIZ if (ccbs_list.item[ccbs_list.sel].name.len != 0 ) { - TRACE_EVENT_P3("selected item %d idx %d %s", - ccbs_list.sel, - ccbs_list.item[ccbs_list.sel].idx, - (char *)ccbs_list.item[ccbs_list.sel].name.data); - } + TRACE_EVENT_P3("selected item %d idx %d %s", + ccbs_list.sel, + ccbs_list.item[ccbs_list.sel].idx, + (char *)ccbs_list.item[ccbs_list.sel].name.data); + } #else if (strlen((char *)ccbs_list.item[ccbs_list.sel].name) != 0 ) { - TRACE_EVENT_P3("selected item %d idx %d %s", - ccbs_list.sel, - ccbs_list.item[ccbs_list.sel].idx, - (char *)ccbs_list.item[ccbs_list.sel].name); - } + TRACE_EVENT_P3("selected item %d idx %d %s", + ccbs_list.sel, + ccbs_list.item[ccbs_list.sel].idx, + (char *)ccbs_list.item[ccbs_list.sel].name); + } #endif else { @@ -8966,11 +8964,11 @@ } /******************************************************************************* - $Function: call_offer_ccbs_registration_callback - - $Description: Handle the Callback Registration Query callback - - $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED + $Function: call_offer_ccbs_registration_callback + + $Description: Handle the Callback Registration Query callback + + $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED $Arguments: T_MFW_HND win - pointer to the parent window USHORT identifier - Identifier supplied in T_DISPLAY_DATA @@ -9239,48 +9237,48 @@ unicode_strcat((USHORT *)ccbs_recall_text_buffer, (USHORT *)MmiRsrcGetText(TxtId)); - size = unicode_strlen((USHORT *)ccbs_recall_text_buffer); + size = unicode_strlen((USHORT *)ccbs_recall_text_buffer); } else /* Not Chinese UniCode */ { int max_recallbuf_size = sizeof(ccbs_recall_text_buffer); - int cur_recallbuf_size = 0; + int cur_recallbuf_size = 0; TRACE_EVENT("Not Chinese UniCode - ASCII TxtIds"); strcpy(ccbs_recall_text_buffer, MmiRsrcGetText(TxtCallBack)); strcat(ccbs_recall_text_buffer, "\n"); - cur_recallbuf_size = strlen(ccbs_recall_text_buffer); - max_recallbuf_size -= cur_recallbuf_size; - + cur_recallbuf_size = strlen(ccbs_recall_text_buffer); + max_recallbuf_size -= cur_recallbuf_size; + #ifdef NO_ASCIIZ if (ccbs_recall.name.len > 0) { TRACE_EVENT("NO_ASCIIZ ASCII name"); strncat(ccbs_recall_text_buffer, (char *)ccbs_recall.name.data, max_recallbuf_size); - max_recallbuf_size -= strlen((char *)ccbs_recall.name.data); + max_recallbuf_size -= strlen((char *)ccbs_recall.name.data); } #else if (strlen((char *)ccbs_recall.name) > 0) { TRACE_EVENT("ASCIIZ ASCII name"); strncat(ccbs_recall_text_buffer, (char *)ccbs_recall.name, max_recallbuf_size); - max_recallbuf_size -= strlen((char *)ccbs_recall.name); + max_recallbuf_size -= strlen((char *)ccbs_recall.name); } #endif else { TRACE_EVENT("ASCII number"); strncat(ccbs_recall_text_buffer, (char *)ccbs_recall.number, max_recallbuf_size); - max_recallbuf_size -= strlen((char *)ccbs_recall.number); - } - - if (max_recallbuf_size > 1) - { - strcat(ccbs_recall_text_buffer, "\n"); - strncat(ccbs_recall_text_buffer, MmiRsrcGetText(TxtId), max_recallbuf_size-1); - } - - size = strlen(ccbs_recall_text_buffer); + max_recallbuf_size -= strlen((char *)ccbs_recall.number); + } + + if (max_recallbuf_size > 1) + { + strcat(ccbs_recall_text_buffer, "\n"); + strncat(ccbs_recall_text_buffer, MmiRsrcGetText(TxtId), max_recallbuf_size-1); + } + + size = strlen(ccbs_recall_text_buffer); } TRACE_EVENT_P1("size = %d", size); @@ -9312,16 +9310,16 @@ } else { - /* SPR#1428 - SH - New editor changes */ - #ifdef NEW_EDITOR - T_AUI_EDITOR_DATA editor_data; - #else /* NEW_EDITOR */ + /* SPR#1428 - SH - New editor changes */ + #ifdef NEW_EDITOR + T_AUI_EDITOR_DATA editor_data; + #else /* NEW_EDITOR */ T_EDITOR_DATA editor_data; // Structure for (read-only) editor - #endif /* NEW_EDITOR */ + #endif /* NEW_EDITOR */ T_MFW_PHB_ENTRY entry; // Structure to pass to bookFindNameInPhonebook - int max_recall_size = sizeof(ccbs_recall.number); + int max_recall_size = sizeof(ccbs_recall.number); /* Clear the ccbs_recall structure for a new CCBS recall offering */ memset((void *)&ccbs_recall, 0, sizeof(ccbs_recall)); @@ -9332,7 +9330,7 @@ if ((para->ton == MFW_TON_INTERNATIONAL) && (para->number[0] != '+')) { strcpy((char *)ccbs_recall.number, "+"); - max_recall_size--; + max_recall_size--; } strncat((char *)ccbs_recall.number, (char *)para->number, max_recall_size); @@ -9381,49 +9379,49 @@ #endif } - switch (ccbs_recall.type) - { - case VOICE_CALL: - TxtId = TxtVoice; - break; - - case DATA_CALL: - TxtId = TxtData; - break; - - case FAX_CALL: - TxtId = TxtFax; - break; - - default: - TxtId = TxtNull; - TRACE_EVENT_P1("Unexpected ccbs_recall.type %d", ccbs_recall.type); - break; + switch (ccbs_recall.type) + { + case VOICE_CALL: + TxtId = TxtVoice; + break; + + case DATA_CALL: + TxtId = TxtData; + break; + + case FAX_CALL: + TxtId = TxtFax; + break; + + default: + TxtId = TxtNull; + TRACE_EVENT_P1("Unexpected ccbs_recall.type %d", ccbs_recall.type); + break; } size = fill_ccbs_recall_text_buffer(TxtId); /* SPR#1428 - SH - New editor changes */ #ifdef NEW_EDITOR - AUI_edit_SetDefault(&editor_data); - AUI_edit_SetDisplay(&editor_data, ZONE_FULLSOFTKEYS, COLOUR_EDITOR_XX, EDITOR_FONT); - AUI_edit_SetTextStr(&editor_data, TxtAccept, TxtReject, TxtNull, 0); - AUI_edit_SetEvents(&editor_data, 0, TRUE, FOREVER, (T_AUI_EDIT_CB)call_offer_ccbs_recall_callback); - AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ccbs_recall_text_buffer, size); - AUI_edit_SetMode(&editor_data, ED_MODE_READONLY, ED_CURSOR_NONE); + AUI_edit_SetDefault(&editor_data); + AUI_edit_SetDisplay(&editor_data, ZONE_FULLSOFTKEYS, COLOUR_EDITOR_XX, EDITOR_FONT); + AUI_edit_SetTextStr(&editor_data, TxtAccept, TxtReject, TxtNull, 0); + AUI_edit_SetEvents(&editor_data, 0, TRUE, FOREVER, (T_AUI_EDIT_CB)call_offer_ccbs_recall_callback); + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ccbs_recall_text_buffer, size); + AUI_edit_SetMode(&editor_data, ED_MODE_READONLY, ED_CURSOR_NONE); if ((ccbs_recall.win = AUI_edit_Start(NULL, &editor_data)) != NULL) { TRACE_EVENT_P3("AUI_edit_Start(%p, %p): %p", NULL, &editor_data, ccbs_recall.win); -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh -#ifdef FF_MIDI_RINGER - mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); #else #ifdef NEPTUNE_BOARD #ifdef FF_MMI_RINGTONE /* MSL Ring tone */ audio_PlaySoundID(AUDIO_BUZZER, CALLTONE_SELECT, 0 , AUDIO_PLAY_ONCE ); #else - audio_PlaySoundID(AUDIO_BUZZER, getCurrentRingerSettings(), + audio_PlaySoundID(AUDIO_BUZZER, getCurrentRingerSettings(), getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE ); /* GW#2355 /CQ11341 */ #endif #else @@ -9442,20 +9440,20 @@ edtCurNone, 0, ccbs_recall_text_buffer, size, COLOUR_EDITOR_XX); editor_data_init(&editor_data, (T_EDIT_CB)call_offer_ccbs_recall_callback, TxtAccept, TxtReject, TxtNull, 0, READ_ONLY_MODE, FOREVER); - if ((ccbs_recall.win = editor_start(NULL, &editor_data)) != NULL) + if ((ccbs_recall.win = editor_start(NULL, &editor_data)) != NULL) { TRACE_EVENT_P3("editor_start(%p, %p): %p", NULL, &editor_data, ccbs_recall.win); -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh -#ifdef FF_MIDI_RINGER - mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_start(AS_RINGER_MODE_IC,true,sounds_midi_ringer_start_cb); #else #ifdef NEPTUNE_BOARD #ifdef FF_MMI_RINGTONE /* MSL Ring Tone */ audio_PlaySoundID(AUDIO_BUZZER, CALLTONE_SELECT, 0 , AUDIO_PLAY_ONCE ); #else - audio_PlaySoundID(AUDIO_BUZZER, getCurrentRingerSettings(), + audio_PlaySoundID(AUDIO_BUZZER, getCurrentRingerSettings(), getCurrentVoulmeSettings(), AUDIO_PLAY_ONCE ); /* GW#2355 /CQ11341 */ #endif #else @@ -9475,11 +9473,11 @@ /******************************************************************************* - $Function: call_offer_ccbs_recall_callback - - $Description: Handle the Callback Registration Query callback - - $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED + $Function: call_offer_ccbs_recall_callback + + $Description: Handle the Callback Registration Query callback + + $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED $Arguments: T_MFW_HND win - pointer to the parent window USHORT identifier - Identifier supplied in T_DISPLAY_DATA @@ -9542,11 +9540,11 @@ * so the window handle is no longer valid. */ ccbs_recall.win = NULL; -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); @@ -9573,9 +9571,9 @@ size_t size; /* The length of the string to be displayed */ ULONG duration; /* The duration of this display - 3s or forever */ LangTxt lsk; /* The LSK label - OK if forever else none */ - /* SPR#1428 - SH - New editor data */ + /* SPR#1428 - SH - New editor data */ #ifdef NEW_EDITOR - T_AUI_EDITOR_DATA editor_data; + T_AUI_EDITOR_DATA editor_data; #else /* NEW_EDITOR */ T_EDITOR_DATA editor_data; // Structure for (read-only) editor #endif /* NEW_EDITOR */ @@ -9586,18 +9584,18 @@ if (ccbs_recall.win != NULL) { TRACE_EVENT_P1("Destroying editor %p", ccbs_recall.win); - /* SPR#1428 - SH - New editor changes */ + /* SPR#1428 - SH - New editor changes */ #ifdef NEW_EDITOR - AUI_edit_Destroy(ccbs_recall.win); + AUI_edit_Destroy(ccbs_recall.win); #else /* NEW_EDITOR */ editor_destroy(ccbs_recall.win); #endif /* NEW_EDITOR */ ccbs_recall.win = NULL; -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); @@ -9624,14 +9622,14 @@ zoneId = ZONE_FULLSCREEN; } - /* SPR#1428 - SH - New editor changes */ + /* SPR#1428 - SH - New editor changes */ #ifdef NEW_EDITOR - AUI_edit_SetDefault(&editor_data); - AUI_edit_SetDisplay(&editor_data, zoneId, COLOUR_EDITOR_XX, EDITOR_FONT); - AUI_edit_SetTextStr(&editor_data, lsk, TxtNull, TxtNull, 0); - AUI_edit_SetEvents(&editor_data, 0, TRUE, duration, NULL); - AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ccbs_recall_text_buffer, size); - AUI_edit_SetMode(&editor_data, ED_MODE_READONLY, ED_CURSOR_NONE); + AUI_edit_SetDefault(&editor_data); + AUI_edit_SetDisplay(&editor_data, zoneId, COLOUR_EDITOR_XX, EDITOR_FONT); + AUI_edit_SetTextStr(&editor_data, lsk, TxtNull, TxtNull, 0); + AUI_edit_SetEvents(&editor_data, 0, TRUE, duration, NULL); + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)ccbs_recall_text_buffer, size); + AUI_edit_SetMode(&editor_data, ED_MODE_READONLY, ED_CURSOR_NONE); AUI_edit_Start(NULL, &editor_data); #else /* NEW_EDITOR */ editor_attr_init(&editor_data.editor_attr, zoneId, edtCurNone, 0, @@ -9646,11 +9644,11 @@ /******************************************************************************* - $Function: call_ccbs_show_status - - $Description: Display the CCBS Status Display - - $Returns: Nothing + $Function: call_ccbs_show_status + + $Description: Display the CCBS Status Display + + $Returns: Nothing $Arguments: None @@ -9683,11 +9681,11 @@ /******************************************************************************* - $Function: call_ccbs_callback - - $Description: Handle the CCBS Status Display callback - - $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED + $Function: call_ccbs_callback + + $Description: Handle the CCBS Status Display callback + + $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED $Arguments: T_MFW_HND win - pointer to the parent window USHORT identifier - Identifier supplied in T_DISPLAY_DATA @@ -9749,11 +9747,11 @@ /******************************************************************************* - $Function: call_ccbs - - $Description: Handle the CCBS sub-menu - - $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED + $Function: call_ccbs + + $Description: Handle the CCBS sub-menu + + $Returns: int: MFW_EVENT_CONSUMED or MFW_EVENT_REJECTED $Arguments: MfwMnu *menu - pointer to current menu MfwMnuItem *item - pointer to current menu item @@ -9853,15 +9851,15 @@ Function added for SPR 1392 *******************************************************************************/ int call_deflection_on(MfwMnu* m, MfwMnuItem* i) -{T_MFW_HND win = mfwParent( mfw_header() ); +{ + T_MFW_HND win = mfwParent( mfw_header() ); T_DISPLAY_DATA display_info; - - FFS_flashData.call_deflection = TRUE; + FFS_flashData.call_deflection = TRUE; flash_write(); - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtActivated, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtActivated, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); /* Call Info Screen */ info_dialog( win, &display_info ); @@ -9882,14 +9880,15 @@ Function added for SPR 1392 *******************************************************************************/ int call_deflection_off(MfwMnu* m, MfwMnuItem* i) -{T_MFW_HND win = mfwParent( mfw_header() ); +{ + T_MFW_HND win = mfwParent( mfw_header() ); T_DISPLAY_DATA display_info; - FFS_flashData.call_deflection = FALSE; + FFS_flashData.call_deflection = FALSE; flash_write(); - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtDeActivated, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallDeflection, TxtDeActivated, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_CLEAR|KEY_LEFT|KEY_RIGHT ); /* Call Info Screen */ @@ -9912,93 +9911,93 @@ *******************************************************************************/ void cm_mt_deflect(T_MFW_HND win, USHORT identifier, SHORT reason) { - T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; - T_call * data = (T_call *)win_data->user; - T_DISPLAY_DATA display_info; - BOOL result; + T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; + T_call * data = (T_call *)win_data->user; + T_DISPLAY_DATA display_info; + BOOL result; TRACE_FUNCTION("cm_mt_deflect"); TRACE_EVENT_P1("cm_mt_deflect reason=%d",reason); - switch (reason) - { - case INFO_KCD_LEFT: - - TRACE_EVENT("cm_mt_deflect-left"); - /*destroy the editor, we don't need it anymore*/ - /* SPR#1428 - SH - New editor */ - #ifdef NEW_EDITOR - AUI_edit_Destroy(call_data.win_deflectEdit); - #else /* NEW_EDITOR */ - editor_destroy(call_data.win_deflectEdit); - #endif /* NEW_EDITOR */ - - call_data.win_deflectEdit = 0; - /*deflect to number in editor*/ - result = cm_deflect_incoming_call(data->editor_buffer); - - if (result == TRUE) - { - // Jan 05, 2006 REF:DR OMAPS00050454 x0039928 - // Fix: Destroy the calling window - if (!call_data.calls.numCalls) - { if (call_data.win) - { - call_destroy(call_data.win); - } - } - - /*Show that we're attempting to deflect the call*/ - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtDeflectingCallTo, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); - display_info.TextString2 =data->editor_buffer; - call_data.win_deflecting = info_dialog(idle_get_window(), &display_info); - } - else - { /*Show that deflection of call failed*/ - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtDeflect, TxtFailed, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); - info_dialog(idle_get_window(), &display_info); - - /*delete all deflection windows if deflection has failed*/ - deflect_destroy(TRUE); - } - break; + switch (reason) + { + case INFO_KCD_LEFT: + + TRACE_EVENT("cm_mt_deflect-left"); + /*destroy the editor, we don't need it anymore*/ + /* SPR#1428 - SH - New editor */ + #ifdef NEW_EDITOR + AUI_edit_Destroy(call_data.win_deflectEdit); + #else /* NEW_EDITOR */ + editor_destroy(call_data.win_deflectEdit); + #endif /* NEW_EDITOR */ + + call_data.win_deflectEdit = 0; + /*deflect to number in editor*/ + result = cm_deflect_incoming_call(data->editor_buffer); + + if (result == TRUE) + { + // Jan 05, 2006 REF:DR OMAPS00050454 x0039928 + // Fix: Destroy the calling window + if (!call_data.calls.numCalls) + { if (call_data.win) + { + call_destroy(call_data.win); + } + } + + /*Show that we're attempting to deflect the call*/ + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtDeflectingCallTo, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); + display_info.TextString2 =data->editor_buffer; + call_data.win_deflecting = info_dialog(idle_get_window(), &display_info); + } + else + { /*Show that deflection of call failed*/ + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtDeflect, TxtFailed, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); + info_dialog(idle_get_window(), &display_info); + + /*delete all deflection windows if deflection has failed*/ + deflect_destroy(TRUE); + } + break; case INFO_KCD_ALTERNATELEFT: - /*start the phonebook serach window to select a number*/ - deflPhbExec(); - - break; - case INFO_KCD_HUP: - case INFO_KCD_RIGHT: // (Exit from Editor) - TRACE_EVENT("cm_mt_deflect-right"); - /*destroy the editor*/ - /* SPR#1428 - SH - New editor */ - #ifdef NEW_EDITOR - AUI_edit_Destroy(call_data.win_deflectEdit); - #else /* NEW_EDITOR */ - editor_destroy(call_data.win_deflectEdit); - #endif /* NEW_EDITOR */ - call_data.win_deflectEdit = 0; - /*resurrect the incoming call screen*/ - if (call_data.win_incoming == 0) - { call_data.win_incoming=info_dialog(call_data.win, &call_data.inc_call_data); - } - else - { winShow(call_data.win_incoming); - } - - break; - - default: - - break; - - } - - return; + /*start the phonebook serach window to select a number*/ + deflPhbExec(); + + break; + case INFO_KCD_HUP: + case INFO_KCD_RIGHT: // (Exit from Editor) + TRACE_EVENT("cm_mt_deflect-right"); + /*destroy the editor*/ + /* SPR#1428 - SH - New editor */ + #ifdef NEW_EDITOR + AUI_edit_Destroy(call_data.win_deflectEdit); + #else /* NEW_EDITOR */ + editor_destroy(call_data.win_deflectEdit); + #endif /* NEW_EDITOR */ + call_data.win_deflectEdit = 0; + /*resurrect the incoming call screen*/ + if (call_data.win_incoming == 0) + { call_data.win_incoming=info_dialog(call_data.win, &call_data.inc_call_data); + } + else + { winShow(call_data.win_incoming); + } + + break; + + default: + + break; + + } + + return; } @@ -10016,7 +10015,7 @@ T_call * data = (T_call *)win_data->user; /* a0393213 (WR - "currentRinger" was set but never used) */ -#ifndef FF_MIDI_RINGER +#ifndef FF_MIDI_RINGER #ifndef FF_MMI_RINGTONE UBYTE currentRinger; #endif @@ -10025,7 +10024,7 @@ #ifdef NEW_EDITOR T_AUI_EDITOR_DATA editor_data; #else /* NEW_EDITOR */ - T_EDITOR_DATA editor_data; + T_EDITOR_DATA editor_data; #endif /* NEW_EDITOR */ TRACE_FUNCTION("call_deflection_cb"); @@ -10050,7 +10049,7 @@ call_data.win_deflecting = 0; /* a0393213 (WR - "currentRinger" was set but never used) */ -#ifndef FF_MIDI_RINGER +#ifndef FF_MIDI_RINGER #ifndef FF_MMI_RINGTONE currentRinger = getCurrentRingerSettings(); #endif @@ -10061,12 +10060,12 @@ //reject case INFO_KCD_HUP: case INFO_KCD_RIGHT: - TRACE_EVENT("reject deflection"); -// Apr 05, 2005 REF: ENH 29994 xdeepadh + TRACE_EVENT("reject deflection"); +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // terminate the ringing -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); @@ -10074,94 +10073,94 @@ audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); #endif #endif - cm_mt_reject(); - break; - //deflect - case INFO_KCD_LEFT: - TRACE_EVENT("deflect call"); + cm_mt_reject(); + break; + //deflect + case INFO_KCD_LEFT: + TRACE_EVENT("deflect call"); // Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); #else - audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); -#endif -#endif - /* SPR#1428 - SH - New editor */ - #ifdef NEW_EDITOR - AUI_edit_SetDefault(&editor_data); - AUI_edit_SetDisplay(&editor_data, ZONE_FULL_SK_TITLE, COLOUR_EDITOR_XX, EDITOR_FONT); - editor_data.editor_attr.win_size.py += Mmi_layout_line_height() ; - editor_data.editor_attr.win_size.sy -= Mmi_layout_line_height() ; - AUI_edit_SetTextStr(&editor_data, TxtDeflect, TxtSoftBack, TxtDeflectCallTo, NULL); - AUI_edit_SetEvents(&editor_data, identifier, FALSE, FOREVER, (T_AUI_EDIT_CB)cm_mt_deflect); - AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)data->editor_buffer, 20); - AUI_edit_SetAltTextStr(&editor_data, 1, TxtSoftContacts, FALSE, TxtNull); - AUI_edit_SetMode(&editor_data, 0, ED_CURSOR_BAR); - /* create the editor handler */ - call_data.win_deflectEdit = AUI_edit_Start(win, &editor_data); /* start the editor */ - #else /* NEW_EDITOR */ - editor_attr_init(&editor_data.editor_attr, ZONE_FULL_SK_TITLE, edtCurBar1, 0, data->editor_buffer, 20, COLOUR_EDITOR_XX ); - editor_data.editor_attr.win.py += Mmi_layout_line_height() ; - editor_data.editor_attr.win.sy -= Mmi_layout_line_height() ; - editor_data.AlternateLeftSoftKey = TxtSoftContacts;/*get phonebook list*/ - editor_data.LeftSoftKey = TxtDeflect; /*deflect to entered number*/ - editor_data.RightSoftKey = TxtSoftBack; - editor_data.TextId = TxtDeflectCallTo; - editor_data.Identifier = identifier; - editor_data.min_enter = 1; - editor_data.hide = FALSE; - editor_data.timeout =FOREVER; - editor_data.Callback = (T_EDIT_CB)cm_mt_deflect; - editor_data.destroyEditor = FALSE; - editor_data.mode = DIGITS_MODE; - /* create the editor handler */ - call_data.win_deflectEdit = editor_start(win, &editor_data); /* start the editor */ + audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); +#endif +#endif + /* SPR#1428 - SH - New editor */ + #ifdef NEW_EDITOR + AUI_edit_SetDefault(&editor_data); + AUI_edit_SetDisplay(&editor_data, ZONE_FULL_SK_TITLE, COLOUR_EDITOR_XX, EDITOR_FONT); + editor_data.editor_attr.win_size.py += Mmi_layout_line_height() ; + editor_data.editor_attr.win_size.sy -= Mmi_layout_line_height() ; + AUI_edit_SetTextStr(&editor_data, TxtDeflect, TxtSoftBack, TxtDeflectCallTo, NULL); + AUI_edit_SetEvents(&editor_data, identifier, FALSE, FOREVER, (T_AUI_EDIT_CB)cm_mt_deflect); + AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)data->editor_buffer, 20); + AUI_edit_SetAltTextStr(&editor_data, 1, TxtSoftContacts, FALSE, TxtNull); + AUI_edit_SetMode(&editor_data, 0, ED_CURSOR_BAR); + /* create the editor handler */ + call_data.win_deflectEdit = AUI_edit_Start(win, &editor_data); /* start the editor */ + #else /* NEW_EDITOR */ + editor_attr_init(&editor_data.editor_attr, ZONE_FULL_SK_TITLE, edtCurBar1, 0, data->editor_buffer, 20, COLOUR_EDITOR_XX ); + editor_data.editor_attr.win.py += Mmi_layout_line_height() ; + editor_data.editor_attr.win.sy -= Mmi_layout_line_height() ; + editor_data.AlternateLeftSoftKey = TxtSoftContacts;/*get phonebook list*/ + editor_data.LeftSoftKey = TxtDeflect; /*deflect to entered number*/ + editor_data.RightSoftKey = TxtSoftBack; + editor_data.TextId = TxtDeflectCallTo; + editor_data.Identifier = identifier; + editor_data.min_enter = 1; + editor_data.hide = FALSE; + editor_data.timeout =FOREVER; + editor_data.Callback = (T_EDIT_CB)cm_mt_deflect; + editor_data.destroyEditor = FALSE; + editor_data.mode = DIGITS_MODE; + /* create the editor handler */ + call_data.win_deflectEdit = editor_start(win, &editor_data); /* start the editor */ #endif /* NEW_EDITOR */ - break; + break; //Accept call - case INFO_KCD_OFFHOOK: - - TRACE_EVENT("accept call -deflection"); -// Apr 05, 2005 REF: ENH 29994 xdeepadh + case INFO_KCD_OFFHOOK: + + TRACE_EVENT("accept call -deflection"); +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); #else - audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); -#endif -#endif - - cm_mt_accept(); + audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); +#endif +#endif + + cm_mt_accept(); break; // break; // RAVI //this is for the auto answer case INFO_TIMEOUT: -// Apr 05, 2005 REF: ENH 29994 xdeepadh +// Apr 05, 2005 REF: ENH 29994 xdeepadh //Nov 02, 2005 REF:ER OMAPS00039044 xdeepadh // Stopping the current ring tone. -#ifdef FF_MIDI_RINGER - mfw_ringer_stop(sounds_midi_ringer_stop_cb); +#ifdef FF_MIDI_RINGER + mfw_ringer_stop(sounds_midi_ringer_stop_cb); #else #ifdef FF_MMI_RINGTONE /*Stop MSL */ audio_StopSoundbyID( AUDIO_BUZZER, CALLTONE_SELECT); #else - audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); -#endif -#endif - - cm_mt_accept(); + audio_StopSoundbyID( AUDIO_BUZZER, currentRinger ); +#endif +#endif + + cm_mt_accept(); break; default: @@ -10192,11 +10191,11 @@ { // T_MFW_HND win = mfwParent(mfw_header()); // RAVI - // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // RAVI + // T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; // RAVI // T_call_menu * data = (T_call_menu *)win_data->user; // RAVI call_data.win_deflectSearch = bookPhonebookStart(call_data.win,PhbkFromDeflect); - return 1; + return 1; } @@ -10206,297 +10205,297 @@ /******************************************************************************* - $Function: call_tty_init - - $Description: Initialise TTY - - $Returns None - - $Arguments: None + $Function: call_tty_init + + $Description: Initialise TTY + + $Returns None + + $Arguments: None *******************************************************************************/ void call_tty_init(void) { - /* SPR#1985 - SH - By default, don't display update dialogs */ - - TTYDisplayDialog = FALSE; - - if (FFS_flashData.ttyAlwaysOn==TRUE) - { - cm_tty_enable(TRUE); - } - else - { - FFS_flashData.ttyAlwaysOn = FALSE; /* Ensures it's either TRUE or FALSE */ - call_tty_set(CALL_TTY_OFF); - } - - return; -} - -/******************************************************************************* - - $Function: call_tty_get - - $Description: Obtain status of TTY - - $Returns Status byte - - $Arguments: None + /* SPR#1985 - SH - By default, don't display update dialogs */ + + TTYDisplayDialog = FALSE; + + if (FFS_flashData.ttyAlwaysOn==TRUE) + { + cm_tty_enable(TRUE); + } + else + { + FFS_flashData.ttyAlwaysOn = FALSE; /* Ensures it's either TRUE or FALSE */ + call_tty_set(CALL_TTY_OFF); + } + + return; +} + +/******************************************************************************* + + $Function: call_tty_get + + $Description: Obtain status of TTY + + $Returns Status byte + + $Arguments: None *******************************************************************************/ UBYTE call_tty_get(void) { - return call_data.tty; -} - -/******************************************************************************* - - $Function: call_tty_set - - $Description: Change status of TTY in RAM. Called when an appropriate response - is received from ACI. - - $Returns None - - $Arguments: Status byte, one of: CALL_TTY_OFF, CALL_TTY_ALWAYSON, - CALL_TTY_ONNEXTCALL + return call_data.tty; +} + +/******************************************************************************* + + $Function: call_tty_set + + $Description: Change status of TTY in RAM. Called when an appropriate response + is received from ACI. + + $Returns None + + $Arguments: Status byte, one of: CALL_TTY_OFF, CALL_TTY_ALWAYSON, + CALL_TTY_ONNEXTCALL *******************************************************************************/ void call_tty_set(UBYTE tty) { - call_data.tty = tty; -#ifdef FF_TTY_HCO_VCO - call_data_tty = call_data.tty; -#endif - - if (tty) - iconsSetState(iconIdTTY); - else - iconsDeleteState(iconIdTTY); - - return; -} - - -/******************************************************************************* - - $Function: call_tty_menu - - $Description: Initialise menu for TTY - - $Returns None - - $Arguments: None + call_data.tty = tty; +#ifdef FF_TTY_HCO_VCO + call_data_tty = call_data.tty; +#endif + + if (tty) + iconsSetState(iconIdTTY); + else + iconsDeleteState(iconIdTTY); + + return; +} + + +/******************************************************************************* + + $Function: call_tty_menu + + $Description: Initialise menu for TTY + + $Returns None + + $Arguments: None *******************************************************************************/ int call_tty_menu(MfwMnu* menu, MfwMnuItem* item) { - T_MFW_HND win = mfwParent(mfw_header()); - T_MFW_HND menuWin; - UBYTE selection; - - /* SPR#1985 - SH - Query TTY status, to update menu */ - TTYDisplayDialog = FALSE; - cm_tty_query(); - - selection = call_data.tty; - menuWin = bookMenuStart(win, TTYAttributes(), 0); - SEND_EVENT(menuWin, DEFAULT_OPTION, NULL, &selection); /* Set the default option to the value of tty */ - - return 1; + T_MFW_HND win = mfwParent(mfw_header()); + T_MFW_HND menuWin; + UBYTE selection; + + /* SPR#1985 - SH - Query TTY status, to update menu */ + TTYDisplayDialog = FALSE; + cm_tty_query(); + + selection = call_data.tty; + menuWin = bookMenuStart(win, TTYAttributes(), 0); + SEND_EVENT(menuWin, DEFAULT_OPTION, NULL, &selection); /* Set the default option to the value of tty */ + + return 1; } /*x0039928 OMAPS00097714 HCO/VCO option - menu handlers added*/ #ifdef FF_TTY_HCO_VCO /******************************************************************************* - $Function: call_tty_co_menuselect_nextcall - - $Description: when an item is selected in TTY --> On next call menu - - $Returns None - - $Arguments: None + $Function: call_tty_co_menuselect_nextcall + + $Description: when an item is selected in TTY --> On next call menu + + $Returns None + + $Arguments: None *******************************************************************************/ int call_tty_co_menuselect_nextcall(MfwMnu* menu, MfwMnuItem* item) { - UBYTE tty_co; - - tty_co = menu->lCursor[menu->level]; - - ttyPfType = tty_co; - - if (FFS_flashData.ttyAlwaysOn!=FALSE) - { - FFS_flashData.ttyAlwaysOn = FALSE; - flash_write(); - } + UBYTE tty_co; + + tty_co = menu->lCursor[menu->level]; + + ttyPfType = tty_co; + + if (FFS_flashData.ttyAlwaysOn!=FALSE) + { + FFS_flashData.ttyAlwaysOn = FALSE; + flash_write(); + } TTYDisplayDialog = TRUE; - cm_tty_enable(TRUE); - return MFW_EVENT_CONSUMED; -} - -/******************************************************************************* - - $Function: call_tty_co_menuselect_always - - $Description: when an item is selected in TTY --> Always menu - - $Returns None - - $Arguments: None + cm_tty_enable(TRUE); + return MFW_EVENT_CONSUMED; +} + +/******************************************************************************* + + $Function: call_tty_co_menuselect_always + + $Description: when an item is selected in TTY --> Always menu + + $Returns None + + $Arguments: None *******************************************************************************/ int call_tty_co_menuselect_always(MfwMnu* menu, MfwMnuItem* item) { - UBYTE tty_co; - - tty_co = menu->lCursor[menu->level]; - - if (tty_co == TTY_ONLY_PF) - { - if (FFS_flashData.ttyAlwaysOn!= TRUE) - { - FFS_flashData.ttyAlwaysOn = TRUE; - flash_write(); - } - - FFS_flashData.ttyPfType = TTY_ONLY_PF; - flash_write(); - } - else if(tty_co == TTY_VCO_PF) - { - if (FFS_flashData.ttyAlwaysOn!=TRUE) - { - FFS_flashData.ttyAlwaysOn = TRUE; - flash_write(); - } - - FFS_flashData.ttyPfType = TTY_VCO_PF; - flash_write(); - } - else if(tty_co == TTY_HCO_PF) - { - if (FFS_flashData.ttyAlwaysOn!=TRUE) - { - FFS_flashData.ttyAlwaysOn = TRUE; - flash_write(); - } - - FFS_flashData.ttyPfType = TTY_HCO_PF; - flash_write(); - } + UBYTE tty_co; + + tty_co = menu->lCursor[menu->level]; + + if (tty_co == TTY_ONLY_PF) + { + if (FFS_flashData.ttyAlwaysOn!= TRUE) + { + FFS_flashData.ttyAlwaysOn = TRUE; + flash_write(); + } + + FFS_flashData.ttyPfType = TTY_ONLY_PF; + flash_write(); + } + else if(tty_co == TTY_VCO_PF) + { + if (FFS_flashData.ttyAlwaysOn!=TRUE) + { + FFS_flashData.ttyAlwaysOn = TRUE; + flash_write(); + } + + FFS_flashData.ttyPfType = TTY_VCO_PF; + flash_write(); + } + else if(tty_co == TTY_HCO_PF) + { + if (FFS_flashData.ttyAlwaysOn!=TRUE) + { + FFS_flashData.ttyAlwaysOn = TRUE; + flash_write(); + } + + FFS_flashData.ttyPfType = TTY_HCO_PF; + flash_write(); + } TTYDisplayDialog = TRUE; - cm_tty_enable(TRUE); - - return 1; -} -#endif -/******************************************************************************* - - $Function: call_tty_menuselect - - $Description: Select menu option for TTY. Switches "always on" on or off in the - flash, then requests the ACI appropriately. - - $Returns None - - $Arguments: None + cm_tty_enable(TRUE); + + return 1; +} +#endif +/******************************************************************************* + + $Function: call_tty_menuselect + + $Description: Select menu option for TTY. Switches "always on" on or off in the + flash, then requests the ACI appropriately. + + $Returns None + + $Arguments: None *******************************************************************************/ int call_tty_menuselect(MfwMnu* menu, MfwMnuItem* item) { - T_MFW_HND win = mfwParent(mfw_header()); - T_DISPLAY_DATA display_info; - UBYTE tty; - - tty = menu->lCursor[menu->level]; - /* SPR#1985 - SH - Remove duplicate call */ + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + UBYTE tty; + + tty = menu->lCursor[menu->level]; + /* SPR#1985 - SH - Remove duplicate call */ // Aug 03, 2006 REF:OMAPS00088329 x0039928 // Fix: If headset is already connected then tty is not enabled. - if(tty != CALL_TTY_OFF) - { -#ifdef FF_MMI_AUDIO_PROFILE - if(headsetInserted == TRUE) - { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNotAllowed, NULL, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); - info_dialog(idle_get_window(), &display_info); - - return 1; - } -#endif - } - - /* Check if "Always on" status has changed */ - - if (tty==CALL_TTY_ALWAYSON) - { + if(tty != CALL_TTY_OFF) + { +#ifdef FF_MMI_AUDIO_PROFILE + if(headsetInserted == TRUE) + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtNotAllowed, NULL, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT ); + info_dialog(idle_get_window(), &display_info); + + return 1; + } +#endif + } + + /* Check if "Always on" status has changed */ + + if (tty==CALL_TTY_ALWAYSON) + { #ifdef FF_TTY_HCO_VCO /*x0039928 OMAPS00097714 HCO/VCO option - Added to provide HCO/VCO option*/ - bookMenuStart(win, TTYCOAlwaysAttributes(), 0); + bookMenuStart(win, TTYCOAlwaysAttributes(), 0); #else - if (FFS_flashData.ttyAlwaysOn!=TRUE) - { - FFS_flashData.ttyAlwaysOn = TRUE; - flash_write(); - } -#endif - } - else - { + if (FFS_flashData.ttyAlwaysOn!=TRUE) + { + FFS_flashData.ttyAlwaysOn = TRUE; + flash_write(); + } +#endif + } + else + { #ifdef FF_TTY_HCO_VCO /*x0039928 OMAPS00097714 HCO/VCO option - Added to provide HCO/VCO option*/ - if (tty==CALL_TTY_ONNEXTCALL) - bookMenuStart(win, TTYCONextCallAttributes(), 0); - else -#endif - if (FFS_flashData.ttyAlwaysOn!=FALSE) - { - FFS_flashData.ttyAlwaysOn = FALSE; - flash_write(); - } - } - - /* Send request to MFW->ACI - * SPR#1985 - SH - Don't show status dialog */ - - - TTYDisplayDialog = TRUE; - -#ifdef FF_TTY_HCO_VCO - if (!tty) - cm_tty_enable(FALSE); + if (tty==CALL_TTY_ONNEXTCALL) + bookMenuStart(win, TTYCONextCallAttributes(), 0); + else +#endif + if (FFS_flashData.ttyAlwaysOn!=FALSE) + { + FFS_flashData.ttyAlwaysOn = FALSE; + flash_write(); + } + } + + /* Send request to MFW->ACI + * SPR#1985 - SH - Don't show status dialog */ + + + TTYDisplayDialog = TRUE; + +#ifdef FF_TTY_HCO_VCO + if (!tty) + cm_tty_enable(FALSE); #else - if (tty) - cm_tty_enable(TRUE); - else - cm_tty_enable(FALSE); -#endif - - return 1; + if (tty) + cm_tty_enable(TRUE); + else + cm_tty_enable(FALSE); +#endif + + return 1; } #ifdef NEPTUNE_BOARD /* Mar 27, 2006 REF:ER OMAPS00071798 */ /******************************************************************************* - $Function: ctty_audio_mode_text + $Function: ctty_audio_mode_text $Description: sets the audio mode then requests the ACI appropriately. - $Returns None - - $Arguments: None + $Returns None + + $Arguments: None *******************************************************************************/ int ctty_audio_mode_text(MfwMnu* m, MfwMnuItem* i) @@ -10509,7 +10508,7 @@ dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtAudioModeText, TxtActivated, COLOUR_STATUS); dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT); - + info_dialog( win, &display_info ); } @@ -10517,13 +10516,13 @@ /******************************************************************************* - $Function: ctty_audio_mode_text + $Function: ctty_audio_mode_text $Description: sets the audio mode then requests the ACI appropriately. - $Returns None - - $Arguments: None + $Returns None + + $Arguments: None *******************************************************************************/ @@ -10537,20 +10536,20 @@ dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtAudioModeVco, TxtActivated, COLOUR_STATUS); dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT); - + info_dialog( win, &display_info ); } /******************************************************************************* - $Function: ctty_audio_mode_text + $Function: ctty_audio_mode_text $Description: sets the audio mode then requests the ACI appropriately. - $Returns None - - $Arguments: None + $Returns None + + $Arguments: None *******************************************************************************/ @@ -10564,7 +10563,7 @@ dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtNull, TxtAudioModeUnknown, TxtActivated, COLOUR_STATUS); dlg_initDisplayData_events(&display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_LEFT); - + info_dialog( win, &display_info ); } @@ -10573,122 +10572,122 @@ /******************************************************************************* - $Function: call_tty_statuswin - - $Description: If TTY status changes, inform the user with a window - - $Returns None - - $Arguments: None + $Function: call_tty_statuswin + + $Description: If TTY status changes, inform the user with a window + + $Returns None + + $Arguments: None *******************************************************************************/ void call_tty_statuswin(void) { - T_MFW_HND win = mfwParent(mfw_header()); - T_DISPLAY_DATA display_info; - - TRACE_FUNCTION("call_tty_statuswin()"); - - /* SPR#1985 - SH - Now checks to see if dialog should be displayed */ - - if (TTYDisplayDialog) - { -// May 28, 2007 DR: OMAPS00123948 x0066692 + T_MFW_HND win = mfwParent(mfw_header()); + T_DISPLAY_DATA display_info; + + TRACE_FUNCTION("call_tty_statuswin()"); + + /* SPR#1985 - SH - Now checks to see if dialog should be displayed */ + + if (TTYDisplayDialog) + { +// May 28, 2007 DR: OMAPS00123948 x0066692 //Added Specific Dailogs when TTy_VCO, TTY_HCO are selected - if (call_data.tty == CALL_TTY_ALWAYSON) - { - if(flash_read() >= EFFS_OK) - { - if( FFS_flashData.ttyPfType == TTY_ONLY_PF) - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTY, TxtActivated, COLOUR_STATUS); - else if(FFS_flashData.ttyPfType == TTY_VCO_PF) - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYVco, TxtActivated, COLOUR_STATUS); - - else if(FFS_flashData.ttyPfType == TTY_HCO_PF ) - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYHco, TxtActivated, COLOUR_STATUS); - } - } - else if( call_data.tty == CALL_TTY_ONNEXTCALL ) - { - if( ttyPfType == TTY_ONLY_PF ) - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTY, TxtActivated, COLOUR_STATUS); - else if (ttyPfType == TTY_VCO_PF ) - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYVco, TxtActivated, COLOUR_STATUS); - else if(ttyPfType == TTY_HCO_PF ) - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYHco, TxtActivated, COLOUR_STATUS); - - } - else - { - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTY, TxtDeActivated, COLOUR_STATUS); - } - - dlg_initDisplayData_events( &display_info, NULL, THREE_SECS, NULL ); - info_dialog (win, &display_info); - TTYDisplayDialog = FALSE; - } - - return; -} - -/******************************************************************************* - - $Function: call_tty_revert - - $Description: Called when call terminates, to revert TTY settings back to their original - values (when appropriate) - - $Returns None - - $Arguments: None + if (call_data.tty == CALL_TTY_ALWAYSON) + { + if(flash_read() >= EFFS_OK) + { + if( FFS_flashData.ttyPfType == TTY_ONLY_PF) + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTY, TxtActivated, COLOUR_STATUS); + else if(FFS_flashData.ttyPfType == TTY_VCO_PF) + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYVco, TxtActivated, COLOUR_STATUS); + + else if(FFS_flashData.ttyPfType == TTY_HCO_PF ) + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYHco, TxtActivated, COLOUR_STATUS); + } + } + else if( call_data.tty == CALL_TTY_ONNEXTCALL ) + { + if( ttyPfType == TTY_ONLY_PF ) + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTY, TxtActivated, COLOUR_STATUS); + else if (ttyPfType == TTY_VCO_PF ) + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYVco, TxtActivated, COLOUR_STATUS); + else if(ttyPfType == TTY_HCO_PF ) + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTYHco, TxtActivated, COLOUR_STATUS); + + } + else + { + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtTTY, TxtDeActivated, COLOUR_STATUS); + } + + dlg_initDisplayData_events( &display_info, NULL, THREE_SECS, NULL ); + info_dialog (win, &display_info); + TTYDisplayDialog = FALSE; + } + + return; +} + +/******************************************************************************* + + $Function: call_tty_revert + + $Description: Called when call terminates, to revert TTY settings back to their original + values (when appropriate) + + $Returns None + + $Arguments: None *******************************************************************************/ void call_tty_revert(void) { - /* If "on next call" status is true, and stored status isn't "always on", - * then TTY has been temporarily switched on from the "off" state, - * and must be switched off again. */ - - if (call_tty_get()==CALL_TTY_ONNEXTCALL) - { - if (FFS_flashData.ttyAlwaysOn) /* TTY must stay on */ - cm_tty_enable(TRUE); - else - cm_tty_enable(FALSE); - } - - /* If we're in "off" status but the stored status is "always on", then - * TTY has been temporarily switched off - switch it on again */ - - else if (call_tty_get()==CALL_TTY_OFF && FFS_flashData.ttyAlwaysOn) - { - cm_tty_enable(TRUE); - } - - return; + /* If "on next call" status is true, and stored status isn't "always on", + * then TTY has been temporarily switched on from the "off" state, + * and must be switched off again. */ + + if (call_tty_get()==CALL_TTY_ONNEXTCALL) + { + if (FFS_flashData.ttyAlwaysOn) /* TTY must stay on */ + cm_tty_enable(TRUE); + else + cm_tty_enable(FALSE); + } + + /* If we're in "off" status but the stored status is "always on", then + * TTY has been temporarily switched off - switch it on again */ + + else if (call_tty_get()==CALL_TTY_OFF && FFS_flashData.ttyAlwaysOn) + { + cm_tty_enable(TRUE); + } + + return; } #endif static void call_ending_all_cb(T_MFW_HND win, UBYTE identifier, UBYTE reason) { - /* - ** Send an Idle Update to trigger the idle screen to be updated if required, - ** it will also trigger the Pin Entry screen to be reactivated if an emergency call - ** was made before the Pin/Puk was entered. - */ - idleEvent(IdleUpdate); + /* + ** Send an Idle Update to trigger the idle screen to be updated if required, + ** it will also trigger the Pin Entry screen to be reactivated if an emergency call + ** was made before the Pin/Puk was entered. + */ + idleEvent(IdleUpdate); #ifdef NEPTUNE_BOARD #ifdef MMI_POWER_MANAGEMENT_TEST - iIncomingCall = 0; -#endif -#endif - - return; + iIncomingCall = 0; +#endif +#endif + + return; } @@ -10698,8 +10697,8 @@ TRACE_EVENT("call_show_ending_all()"); - dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallEnded, TxtNull, COLOUR_STATUS); - dlg_initDisplayData_events( &display_info,(T_VOID_FUNC)call_ending_all_cb, THREE_SECS, KEY_CLEAR ); + dlg_initDisplayData_TextId( &display_info, TxtNull, TxtNull, TxtCallEnded, TxtNull, COLOUR_STATUS); + dlg_initDisplayData_events( &display_info,(T_VOID_FUNC)call_ending_all_cb, THREE_SECS, KEY_CLEAR ); /* * Call Info Screen */ @@ -10729,17 +10728,17 @@ } -// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. - -/******************************************************************************* - +// Apr 26 2006, a0393213 (Prabakar R), OMAPS00074886 : No option in MMI to release the held call. + +/******************************************************************************* + $Function: item_flag_endheld - $Description: This function decides if the 'End held' menu item needs to be displayed or not. - The return value 0 indicates to display and 1 to hide + $Description: This function decides if the 'End held' menu item needs to be displayed or not. + The return value 0 indicates to display and 1 to hide $Arguments: m, ma, mi - not used - + *******************************************************************************/ @@ -10751,11 +10750,11 @@ //some call is in hold state, so display 'End held' menu option return 0; } - else - { - //there is no call in hold state, so don't display 'End held' menu option - return 1; - } + else + { + //there is no call in hold state, so don't display 'End held' menu option + return 1; + } } @@ -10787,116 +10786,116 @@ /******************************************************************************* - $Function: call_IsAlertScreenActive - - $Description: Returns the status of the incoming call window. TRUE- If the incoming call window is active - - - $Returns TRUE/FALSE - - $Arguments: None + $Function: call_IsAlertScreenActive + + $Description: Returns the status of the incoming call window. TRUE- If the incoming call window is active + + + $Returns TRUE/FALSE + + $Arguments: None *******************************************************************************/ BOOL call_IsAlertScreenActive( void ) { - if(call_data.win_incoming != NULL) - return TRUE; - - return FALSE; -} -// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 + if(call_data.win_incoming != NULL) + return TRUE; + + return FALSE; +} +// xpradipg - LOCOSTO-ENH-31895 : 23 June 2005 #ifdef FF_MMI_AUDIO_PROFILE /******************************************************************************* - $Function: item_loudspeaker_status - - $Description: This function decides if the loudspeaker menu item needs to be displayed or not. - The return value 0 indicates to display and 1 to hide - - $Returns TRUE/FALSE - - $Arguments: None + $Function: item_loudspeaker_status + + $Description: This function decides if the loudspeaker menu item needs to be displayed or not. + The return value 0 indicates to display and 1 to hide + + $Returns TRUE/FALSE + + $Arguments: None *******************************************************************************/ USHORT item_loudspeaker_status( struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi ) { - int device; - TRACE_FUNCTION("item_loudspeaker_status"); - device = mfw_get_current_audioDevice( ); - if ( device == MFW_AUD_CARKIT || carkitInserted == TRUE|| device == MFW_AUD_LOUDSPEAKER) - return TRUE; - return FALSE; -} -/******************************************************************************* - - $Function: item_headset_status - - $Description: The menu item "Headset" is displayed when the function returns ''0", the required - condition is the current device is not headset or and the headset is not inserted - - $Returns TRUE/FALSE - - $Arguments: None + int device; + TRACE_FUNCTION("item_loudspeaker_status"); + device = mfw_get_current_audioDevice( ); + if ( device == MFW_AUD_CARKIT || carkitInserted == TRUE|| device == MFW_AUD_LOUDSPEAKER) + return TRUE; + return FALSE; +} +/******************************************************************************* + + $Function: item_headset_status + + $Description: The menu item "Headset" is displayed when the function returns ''0", the required + condition is the current device is not headset or and the headset is not inserted + + $Returns TRUE/FALSE + + $Arguments: None *******************************************************************************/ USHORT item_headset_status( struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi ) { - int device; - TRACE_FUNCTION("item_headset_status"); - device = mfw_get_current_audioDevice( ); - if ( device == MFW_AUD_HEADSET || headsetInserted == FALSE) - return TRUE; - return FALSE; -} -/******************************************************************************* - - $Function: item_carkit_status - - $Description: The menu item "carkit" is displayed when the function returns ''0", the required - condition is the current device is not handheld or not carkit or the headset is not - inserted - $Returns TRUE/FALSE - - $Arguments: None + int device; + TRACE_FUNCTION("item_headset_status"); + device = mfw_get_current_audioDevice( ); + if ( device == MFW_AUD_HEADSET || headsetInserted == FALSE) + return TRUE; + return FALSE; +} +/******************************************************************************* + + $Function: item_carkit_status + + $Description: The menu item "carkit" is displayed when the function returns ''0", the required + condition is the current device is not handheld or not carkit or the headset is not + inserted + $Returns TRUE/FALSE + + $Arguments: None *******************************************************************************/ USHORT item_carkit_status( struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi ) { - int device; - TRACE_FUNCTION("item_carkit_status"); - device = mfw_get_current_audioDevice( ); - if ( device == MFW_AUD_CARKIT || carkitInserted == FALSE) - return TRUE; - return FALSE; -} -/******************************************************************************* - - $Function: item_handheld_status - - $Description: The menu item "Handheld" is displayed when the function returns ''0" - - $Returns TRUE/FALSE - - $Arguments: None + int device; + TRACE_FUNCTION("item_carkit_status"); + device = mfw_get_current_audioDevice( ); + if ( device == MFW_AUD_CARKIT || carkitInserted == FALSE) + return TRUE; + return FALSE; +} +/******************************************************************************* + + $Function: item_handheld_status + + $Description: The menu item "Handheld" is displayed when the function returns ''0" + + $Returns TRUE/FALSE + + $Arguments: None *******************************************************************************/ USHORT item_handheld_status( struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi ) { - int device; - TRACE_FUNCTION("item_handheld_status"); - device = mfw_get_current_audioDevice( ); - if ( device == MFW_AUD_CARKIT || headsetInserted == TRUE || device == MFW_AUD_HANDHELD) - return TRUE; - return FALSE; -} -/******************************************************************************* - - $Function: M_exeHandheld - - $Description: Set the audio device to handheld - - $Returns none + int device; + TRACE_FUNCTION("item_handheld_status"); + device = mfw_get_current_audioDevice( ); + if ( device == MFW_AUD_CARKIT || headsetInserted == TRUE || device == MFW_AUD_HANDHELD) + return TRUE; + return FALSE; +} +/******************************************************************************* + + $Function: M_exeHandheld + + $Description: Set the audio device to handheld + + $Returns none $Arguments: m and i are not used @@ -10906,19 +10905,19 @@ T_MFW_HND win = mfwParent(mfw_header()); - TRACE_FUNCTION("M_exeHandheld"); - mfw_audio_set_device(MFW_AUD_HANDHELD); + TRACE_FUNCTION("M_exeHandheld"); + mfw_audio_set_device(MFW_AUD_HANDHELD); call_menu_destroy(win); call_data.win_menu = 0; - return 1; /*a0393213 warnings removal-added return statement*/ -} -/******************************************************************************* - - $Function: M_exeHeadset - - $Description: Set the audio device to Headset - - $Returns none + return 1; /*a0393213 warnings removal-added return statement*/ +} +/******************************************************************************* + + $Function: M_exeHeadset + + $Description: Set the audio device to Headset + + $Returns none $Arguments: m and i are not used @@ -10928,19 +10927,19 @@ T_MFW_HND win = mfwParent(mfw_header()); - TRACE_FUNCTION("M_exeHeadset"); + TRACE_FUNCTION("M_exeHeadset"); mfw_audio_set_device(MFW_AUD_HEADSET); call_menu_destroy(win); call_data.win_menu = 0; - return 1; /*a0393213 warnings removal-added return statement*/ -} -/******************************************************************************* - - $Function: M_exeLoudspeaker - - $Description: Set the audio device to Loudspeaker - - $Returns none + return 1; /*a0393213 warnings removal-added return statement*/ +} +/******************************************************************************* + + $Function: M_exeLoudspeaker + + $Description: Set the audio device to Loudspeaker + + $Returns none $Arguments: m and i are not used @@ -10950,19 +10949,19 @@ T_MFW_HND win = mfwParent(mfw_header()); - TRACE_FUNCTION("M_exeLoudspeaker"); - mfw_audio_set_device(MFW_AUD_LOUDSPEAKER); + TRACE_FUNCTION("M_exeLoudspeaker"); + mfw_audio_set_device(MFW_AUD_LOUDSPEAKER); call_menu_destroy(win); call_data.win_menu = 0; - return 1; /*a0393213 warnings removal-added return statement*/ -} -/******************************************************************************* - - $Function: M_exeCarkit - - $Description: Set the audio device to Carkit - - $Returns none + return 1; /*a0393213 warnings removal-added return statement*/ +} +/******************************************************************************* + + $Function: M_exeCarkit + + $Description: Set the audio device to Carkit + + $Returns none $Arguments: m and i are not used @@ -10972,19 +10971,19 @@ T_MFW_HND win = mfwParent(mfw_header()); - TRACE_FUNCTION("M_exeCarkit"); - mfw_audio_set_device(MFW_AUD_CARKIT); + TRACE_FUNCTION("M_exeCarkit"); + mfw_audio_set_device(MFW_AUD_CARKIT); call_menu_destroy(win); call_data.win_menu = 0; - return 1; /*a0393213 warnings removal-added return statement*/ -} -/******************************************************************************* - - $Function: mmi_hook_handle - - $Description: Performs the action of the right softkey in connected call screen - - $Returns none + return 1; /*a0393213 warnings removal-added return statement*/ +} +/******************************************************************************* + + $Function: mmi_hook_handle + + $Description: Performs the action of the right softkey in connected call screen + + $Returns none $Arguments: @@ -10992,29 +10991,29 @@ void mmi_hook_handle() { - MfwKbd kbdvar; - - TRACE_FUNCTION("mmi_hook_handle"); - kbdvar.code = KCD_RIGHT; - call_kbd_cb(0,&kbdvar); -} -#endif - -/******************************************************************************* - - $Function: get_call_data_tty - - $Description: Gives the tty status - - $Returns tty status - + MfwKbd kbdvar; + + TRACE_FUNCTION("mmi_hook_handle"); + kbdvar.code = KCD_RIGHT; + call_kbd_cb(0,&kbdvar); +} +#endif + +/******************************************************************************* + + $Function: get_call_data_tty + + $Description: Gives the tty status + + $Returns tty status + $Arguments: None *******************************************************************************/ #ifdef FF_TTY_HCO_VCO UBYTE get_call_data_tty(void) { - return call_data_tty; + return call_data_tty; } #endif @@ -11022,45 +11021,45 @@ /******************************************************************************* - $Function: bmi_incomingcall_set_ringer_status - - $Description: Sets the Ringer Status during Incoming Call - - $Returns None - + $Function: bmi_incomingcall_set_ringer_status + + $Description: Sets the Ringer Status during Incoming Call + + $Returns None + $Arguments: Ringer Status Value (Input) *******************************************************************************/ void bmi_incomingcall_set_ringer_status(E_IN_CALL_RINGER_STATUS eStatus) { - if ( ( eStatus < BMI_INCOMING_CALL_NONE ) || - ( eStatus > BMI_INCOMING_CALL_RINGERSTOPPED ) ) - { - return; - } - - iIncomingCallRingerStop = eStatus; -} - -/******************************************************************************* - - $Function: bmi_incomingcall_get_ringer_status - - $Description: Gives the Ringer Status during Incoming Call - - $Returns None - + if ( ( eStatus < BMI_INCOMING_CALL_NONE ) || + ( eStatus > BMI_INCOMING_CALL_RINGERSTOPPED ) ) + { + return; + } + + iIncomingCallRingerStop = eStatus; +} + +/******************************************************************************* + + $Function: bmi_incomingcall_get_ringer_status + + $Description: Gives the Ringer Status during Incoming Call + + $Returns None + $Arguments: Ringer Status Value (Output) *******************************************************************************/ void bmi_incomingcall_get_ringer_status(E_IN_CALL_RINGER_STATUS *peStatus) { - if (!peStatus) - { - return; - } - - *peStatus = iIncomingCallRingerStop; + if (!peStatus) + { + return; + } + + *peStatus = iIncomingCallRingerStop; } /*August 01, 2007 DR: OMAPS00137399 x0080701 (Bharat) -- End */