comparison g23m/condat/ms/src/bmi/MmiSimToolkit.c @ 0:509db1a7b7b8

initial import: leo2moko-r1
author Space Falcon <falcon@ivan.Harhan.ORG>
date Mon, 01 Jun 2015 03:24:05 +0000
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:509db1a7b7b8
1 /*******************************************************************************
2
3 CONDAT (UK)
4
5 ********************************************************************************
6
7 This software product is the property of Condat (UK) Ltd and may not be
8 disclosed to any third party without the express permission of the owner.
9
10 ********************************************************************************
11
12 $Project name: Basic MMI
13 $Project code: BMI (6349)
14 $Module: MMI
15 $File: MmiSimToolkit.c
16 $Revision: 1.0
17
18 $Author: Condat(UK)
19 $Date: 22/02/01
20
21 ********************************************************************************
22
23 Description:
24
25
26
27 ********************************************************************************
28
29 $History: MmiSimToolkit.c
30
31 xrashmic 16 Feb, 2006 OMAPS00064413
32 When a SIM RESET occurs, while recreating the simtoolkit list view, the list win is also recreated.
33
34
35 Mar 11, 2006 REF:DR:OMAPS00061467 x0035544
36 Description: 27.22.4.13.3 SET UP CALL (display of icons) fails.
37 Solution: In the function sim_toolkit_exec() for the event SAT_SETUP_CALL copied the icon data which is
38 got through the sat command on to the structures data->call_setup_parameter.iconInfo and to the data->call_setup_parameter.iconInfo2
39 appropriately.And For the event SAT_CALL_END freed the memory allocated for the icon data.
40 on to the
41
42 Feb 02, 2006 DR: OMAPS00061468 - x0035544.
43 Description: SAT 27.22.4.22.2 SET UP IDLE MODE TEXT (Icon support) fails
44 Solution : SAT SET UP IDLE MODE TEXT (Icon) support added.
45
46 Jan 16, 2006 DR: OMAPS00061460 - Shashi Shekar B.S.
47 Description: SAT Icon support
48 Solution : SAT icon support added.
49
50 Dec 23, 2005 REF: OMAPS00062166 x0039928
51 Bug: CT-TIB-GCF[27.22.4.24.1]-sequence 1.2 crashes
52 Fix: Initialize the editor buffer. Initialization is taken care for DTMF and also for SS.
53
54
55 xreddymn Sep-06-2005 MMI-SPR-33876:
56 Initialize editor buffer when displaying message box
57 in case of SAT_SEND_SMS
58
59 Aug 16, 2004 REF: CRR 24323 Deepa M.D
60 Bug:Clenup of sprintf used for tracing
61 Fix:Replace the char buf[]; sprintf (buf, "...", ...); TRACE_EVENT (buf); statements by TRACE_EVENT_PX
62
63 25/10/00 Original Condat(UK) BMI version.
64 21/02/03 removed all calls to function sat_add_unicode_tag_if_needed() and the
65 function itself
66 26-05-04 CRR 19656 Sandip and Deepa M.D
67 Fix for The Dsample doesn't display lines ( <CR> or <LF> ) in the SETUP IDLE
68 TEXT command.
69 Fix for The idle screen is empty when a SETUP IDLE TEXT command is sent with
70 a long text ( 239 characters ).
71
72
73 $End
74
75 *******************************************************************************/
76
77 #define ENTITY_MFW
78
79 /* includes */
80 #include <string.h>
81 #include <stdio.h>
82 #include <stdlib.h>
83
84 #if defined (NEW_FRAME)
85
86 #include "typedefs.h"
87 #include "vsi.h"
88 #include "pei.h"
89 #include "custom.h"
90 #include "gsm.h"
91
92 #else
93
94 #include "STDDEFS.H"
95 #include "custom.h"
96 #include "gsm.h"
97 #include "vsi.h"
98
99 #endif
100
101 #include "pconst.cdg"
102 #include "mconst.cdg"
103 #include "message.h"
104 #include "ccdapi.h"
105 #include "prim.h"
106 #include "cus_aci.h"
107 #include "cnf_aci.h"
108 #include "mon_aci.h"
109
110 #include "tok.h"
111
112 #include "prim.h"
113 #ifndef PCM_2_FFS
114 #include "pcm.h"
115 #endif
116
117
118 #include "mfw_mfw.h"
119 #include "mfw_kbd.h"
120 #include "mfw_tim.h"
121 #include "mfw_lng.h"
122 #include "mfw_win.h"
123 #include "mfw_icn.h"
124 #include "mfw_sim.h"
125 #include "mfw_nm.h"
126 #include "mfw_sat.h" // x0021334 : To test SAT session end - CQ33597
127 /* SPR#1428 - SH - New Editor changes */
128 #ifndef NEW_EDITOR
129 #include "mfw_edt.h"
130 #endif
131 #include "mfw_mnu.h"
132 #include "mfw_phb.h"
133 #include "mfw_sms.h"
134
135 #include "dspl.h"
136
137
138 #include "p_mmi.h"
139 #include "message.h"
140 #include "prim.h"
141 #include "aci_cmh.h"
142 #include "mfw_mme.h"
143
144 #include "MmiMmi.h"
145
146 #include "Mmiicons.h"
147 #include "MmiPins.h"
148 #include "MmiMain.h"
149 #include "MmiDialogs.h"
150 #include "MmiIdle.h"
151 #include "MmiStart.h"
152 #include "mmiCall.h"
153 #include "MmiSimToolkit.h"
154 #include "gdi.h"
155 #include "audio.h"
156 #include "MmiLists.h"
157 #include "MmiSounds.h"
158 #include "MmiResources.h"
159 #include "MmiTimeDate.h"
160 #include "mmiSat_i.h"
161 /* SPR#1428 - SH - New Editor changes */
162 #ifdef NEW_EDITOR
163 #include "ATBCommon.h"
164 #include "ATBDisplay.h"
165 #include "ATBEditor.h"
166 #include "AUIEditor.h"
167 #else
168 #include "MmiEditor.h"
169 #endif
170 #include "MmiMenu.h" // SH - 20/11/01 - included to provide symbol SimMenuFunc
171 #include "mmiSmsRead.h" /*MC SPR 940/2*/
172
173 #include "cus_aci.h"
174 #include "prim.h"
175
176 #ifndef PCM_2_FFS
177 #include "pcm.h"
178 #endif
179
180 #include "mmiSatClassE.h"
181
182 #include "mmiColours.h" /* SPR#2321 - DS */
183 #include "MmiDialogs.h" /* SPR#2321 - DS */
184
185
186 #ifdef MMI_HOMEZONE_ENABLED
187 #include "MmiHomezone.h"
188 #endif
189
190 #ifdef FF_WAP
191 #include "AUIWapext.h"
192 #endif
193
194 #if defined(FF_WAP)
195 #define MMI_TEST_SAT_LAUNCH_BROWSER
196 #endif
197
198 #ifdef MMI_TEST_SAT_LAUNCH_BROWSER
199 void mmiOpenDummyBrowser(T_MFW_HND win,char* information);
200 #define INFORMATION_SIZE 100
201 char information[INFORMATION_SIZE];
202 #endif
203 /*
204 * Local definitions
205 */
206 typedef struct
207 {
208 T_MMI_CONTROL mmi_control;
209 T_MFW_HND win;
210 T_MFW_HND sat_handle;
211 T_SAT_CMD * sat_command; /* mfw storage of actual command */
212 T_SAT_CMD * sat_setup_menu_command; /* dynamic storage of setup menu */
213 T_MFW_HND sat_setup_menu_win; /* c030 rsa window associated with the setup menu command */
214 T_MFW_HND sat_setup_menu_listmnu_win; /* NDH : Window associated with the SAT ListMenu */
215 T_MFW_HND info_win; /* window used for simple info screens */
216 T_MFW_HND sat_call_setup_win; /* window associated with the call setup command */
217 T_SAT_call_setup_parameter * call_setup_parameter; /* parameter psace of call setup to be passed to call() */
218 T_SAT_EVENTS active_sat_session; /* event which caused the currently active session */
219 #ifdef NEW_EDITOR
220 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor data */
221 #else
222 T_EDITOR_DATA editor_data;
223 #endif
224 UBYTE satCallWithRedial; /* SPR#1784 - DS - Flag for SAT call 'with redial' */
225 UBYTE sat_available_on_SIM;
226 } T_sim_toolkit;
227
228 static T_sim_toolkit * g_sim_toolkit_data;
229
230 /*MC SPR 1257, merged in from b-sample version of this file*/
231 char * sat_mainmenu_label = NULL;
232 UBYTE header_len;
233 /*MC end*/
234
235 BOOL sat_call_active = FALSE; // Marcus: Issue 1812: 13/03/2003
236
237 /* PROTOTYPES */
238 static T_MFW_HND sim_toolkit_create (T_MFW_HND parent_window);
239 static void sim_toolkit_destroy (T_MFW_HND own_window);
240 //sandip 16292 . added this new function
241 unsigned char DecodeGSM7ToASCII(U8 * encoded, U8 * plain, U8 Length);
242 /*
243 * Marcus: Issue 1057: 21/01/2003: Removed "static" from the following two
244 * function prototypes for their use in MmiCall.c
245 */
246 T_MFW_HND sat_get_setup_menu_win (void);
247 T_MFW_HND sat_get_call_setup_win (void);
248
249 static void sat_setup_menu_proc (T_SAT_CMD * sat_command);
250 static void sat_info_cb (T_MFW_HND win, UBYTE identifier, UBYTE reason);
251
252 extern UBYTE call_SATCall; // Marcus: Issue 1057: 21/01/2003
253
254
255
256 /*******************************************************************************
257
258 $Function: sim_toolkit_check
259
260 $Description: If there is no support for SAT on SIM card
261 the item SIM TOOLKIT will not appear in the menulist
262
263 $Returns:
264
265 $Arguments:
266
267 *******************************************************************************/
268 USHORT sim_toolkit_check (struct MfwMnuTag *m, struct MfwMnuAttrTag *ma, struct MfwMnuItemTag *mi)
269 {
270
271 T_sim_toolkit * data = g_sim_toolkit_data;
272
273 TRACE_FUNCTION("sim_toolkit_check");
274
275 if (data->sat_available_on_SIM EQ TRUE)
276 {
277 //show the SAT item in the menulist
278 return 0;
279 }
280 else
281 {
282 return 1;
283 }
284
285 }
286
287
288
289
290 /*******************************************************************************
291
292 $Function: simToolkitInit
293
294 $Description: This is the start-up time initialisation routine.
295 For compatibility reasons the functions is still there.
296
297
298 $Returns: none.
299
300 $Arguments:
301
302 *******************************************************************************/
303 void simToolkitInit (T_MFW_HND parent_window)
304 {
305 TRACE_FUNCTION("simToolkitInit");
306
307 g_sim_toolkit_data = (T_sim_toolkit *)ALLOC_MEMORY (sizeof (T_sim_toolkit));
308
309 winAutoFocus (TRUE);
310 sat_set_setup_menu_win(NULL);
311 sat_set_call_setup_win(NULL);
312 sim_toolkit_create (parent_window);
313 }
314 /*******************************************************************************
315
316 $Function: simToolkitExit
317
318 $Description: This is the shutdown time clean-up routine.
319
320 $Returns: none.
321
322 $Arguments:
323
324 *******************************************************************************/
325 void simToolkitExit(void)
326 {
327 TRACE_FUNCTION("simTookitExit");
328 sim_toolkit_destroy (g_sim_toolkit_data->win);
329 // FREE_MEMORY ((U8 *)g_sim_toolkit_data, sizeof (T_sim_toolkit));
330 if (sat_mainmenu_label != NULL)
331 {
332 sat_destroy_TEXT_ASCIIZ (sat_mainmenu_label);
333 sat_mainmenu_label = NULL;
334 }
335 }
336
337
338 /********************************************************************
339 *
340 * SIM Toolkit Dialog
341 *
342 * Window - Structure
343 *
344 * sim_toolkit ----> sat_play_tone
345 * ----> sat_display_text
346 * ----> sat_get_key
347 * ----> sat_setup_call
348 * ----> sat_get_string
349 * ----> sat_setup_menu
350 * ----> sat_select_item
351 * ----> sat_send_sms
352 * ----> sat_send_ss
353 *
354 ********************************************************************/
355 static const UBYTE sat_terminal_profile [13] =
356 {
357 #ifdef SAT_TP1_PRF_DNL
358 (SAT_TP1_PRF_DNL | SAT_TP1_MENU_SEL),
359
360 (SAT_TP2_CMD_RES|SAT_TP2_CC|SAT_TP2_ALPHA_ID|
361 SAT_TP2_UCS2_ENTRY|SAT_TP2_UCS2_DSPL),
362
363 (SAT_TP3_DSPL_TXT|SAT_TP3_GET_INKEY|SAT_TP3_GET_INPUT|
364 SAT_TP3_PLAY_TONE),
365
366 (SAT_TP4_SEL_ITEM|SAT_TP4_SEND_SMS|SAT_TP4_SEND_SS|
367 SAT_TP4_SEND_USSD|SAT_TP4_SETUP_CALL|SAT_TP4_SETUP_MENU),
368
369 (SAT_TP5_EVENT_LIST | SAT_TP5_USER_ACT | SAT_TP5_SCR_AVAIL),
370 0x0, 0x0,
371 (SAT_TP8_BIN_GET_INKEY | SAT_TP8_IDLE_TXT | SAT_TP8_AI2_SETUP_CALL),
372
373 #if defined(FF_WAP)
374 (SAT_TP9_SUST_DSPL_TXT|SAT_TP9_LAUNCH_BROWSER),
375 #else
376 SAT_TP9_SUST_DSPL_TXT,
377 #endif
378 0x0, 0x0,
379 (SAT_TP12_OPEN_CHANNEL | SAT_TP12_CLOSE_CHANNEL | SAT_TP12_RECEIVE_DATA |
380 SAT_TP12_SEND_DATA),
381
382 (SAT_TP13_CSD_SUPP_BY_ME | SAT_TP13_GPRS_SUPP_BY_ME)
383 #else
384 0x09, 0x73, 0x17, 0x37,0x00 // c032 rsa
385 #endif
386 };
387
388 static void sim_toolkit_destroy (T_MFW_HND own_window);
389 static void sim_toolkit_exec (T_MFW_HND win, USHORT event, SHORT value, T_SAT_CMD * sat_command);
390 static int sim_toolkit_sat_cb (T_MFW_EVENT event, T_MFW_SAT * sat_bits);
391 /*******************************************************************************
392
393 $Function: sim_toolkit_create
394
395 $Description: Creation of an instance for the SIM Toolkit dialog.
396 Type of dialog : SINGLE_STATIC
397 Top Window must be available at any time, only one instance.
398
399
400 $Returns: none.
401
402 $Arguments:
403
404 *******************************************************************************/
405 static T_MFW_HND sim_toolkit_create (T_MFW_HND parent_window)
406 {
407 T_sim_toolkit * data = g_sim_toolkit_data;
408 T_MFW_WIN * win;
409
410 TRACE_FUNCTION("sim_toolkit_create");
411
412 data->win = win_create (parent_window, 0, 0, NULL); // c013 rsa
413
414 if (data->win EQ NULL)
415 return NULL;
416
417 /*
418 * Create window handler
419 */
420 data->mmi_control.dialog = (T_DIALOG_FUNC)sim_toolkit_exec;
421 data->mmi_control.data = data;
422 win = ((T_MFW_HDR *)data->win)->data;
423 win->user = (MfwUserDataPtr)data;
424
425 data->sat_command = (T_SAT_CMD *)ALLOC_MEMORY (sizeof (T_SAT_CMD)); // c022 rsa
426
427 /*
428 * Create any other handler
429 */
430 data->sat_handle = sat_create (
431 data->win, // parent window
432 /* possible SAT events */
433 MfwSatSessionEnd | /* end of session */
434 MfwSatRefresh | /* refresh SIM fields */
435 MfwSatDataRefreshed | /*data Refreshed */
436 MfwSatTextOut| /* display string */
437 MfwSatGetKey| /* get user keystroke */
438 MfwSatGetString| /* get user input */
439 MfwSatPlayTone| /* play audio tone */
440 MfwSatSetupMenu| /* setup toolkit menu */
441 MfwSatSelectItem| /* select menu item */
442 MfwSatSendSMS| /* send short message */
443 MfwSatSendSS| /* send service command */
444 MfwSatSendUSSD| /* send USSD command */
445 MfwSatSendDTMF| /* send dtmf command */
446 MfwSatCall| /* setup a call */
447 MfwSatSetEvents| /* setup event lists */
448 MfwSatIdleText| /* set idle text */
449 MfwSatCcRes| /* call control result */
450 MfwSatCcAlert /* call control alerting */
451 #if defined(FF_WAP)
452 |MfwSatLaunchBrowser
453 #else
454 #endif
455 |MfwSatOpenChannel|
456 MfwSatCloseChannel|
457 MfwSatSendData|
458 MfwSatReceiveData|
459 MfwSatErrBusy /* SAT error handling */
460 ,
461 (T_MFW_CB)sim_toolkit_sat_cb, // event callback
462 data->sat_command); // control block for MFW
463
464 /*
465 * initialize global variables
466 */
467 data->sat_setup_menu_command = NULL;
468 data->sat_command = NULL;
469 data->info_win = NULL;
470 data->call_setup_parameter = NULL;
471 data->active_sat_session = SAT_SESSION_END;
472 data->sat_available_on_SIM = FALSE;
473 data->satCallWithRedial = 0; /* SPR#1784 - DS - Initialise 'with redial' flag */
474 sat_mainmenu_label = NULL;
475
476 /*
477 * Initialise MFW
478 */
479 sat_init ((UBYTE *)sat_terminal_profile, (UBYTE)sizeof (sat_terminal_profile));
480
481 /*
482 * return window handle
483 */
484 win_show(data->win);
485 return data->win;
486 }
487 /*******************************************************************************
488
489 $Function: sim_toolkit_destroy
490
491 $Description: Destroy the sim toolkit dialog.
492
493 $Returns: none.
494
495 $Arguments:
496
497 *******************************************************************************/
498 static void sim_toolkit_destroy (T_MFW_HND own_window)
499 {
500 T_MFW_WIN * win;
501 T_sim_toolkit * data;
502
503 if (own_window)
504 {
505 win = ((T_MFW_HDR *)own_window)->data;
506 data = (T_sim_toolkit *)win->user;
507
508 if (data)
509 {
510 /*
511 * Exit SAT and Delete SAT Handler
512 */
513 sat_exit ();
514 sat_delete (data->sat_handle);
515
516 /*
517 * Delete WIN Handler
518 */
519 win_delete (data->win);
520 /*
521 * Free Memory
522 */
523 if (data->sat_setup_menu_command NEQ NULL)
524 {
525 FREE_MEMORY ((U8 *)data->sat_setup_menu_command, sizeof (T_SAT_CMD));
526 data->sat_setup_menu_command = NULL;
527 }
528 if (data->sat_command != NULL)
529 {
530 FREE_MEMORY ((U8 *)data->sat_command, sizeof (T_SAT_CMD)); // c022 rsa
531 data->sat_command = NULL;
532 }
533 FREE_MEMORY ((U8 *)data, sizeof (T_sim_toolkit));
534 }
535 }
536 }
537
538 /*******************************************************************************
539
540 $Function: sim_toolkit_exec
541
542 $Description: Dialog function for sim toolkit top window.
543 Handle the SAT commands delivered by MFW<-ACI<-SIM
544
545 $Returns: none.
546
547 $Arguments:
548
549 *******************************************************************************/
550 static void sim_toolkit_exec (T_MFW_HND win, USHORT event, SHORT value, T_SAT_CMD * sat_command)
551 {
552 T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data;
553 T_sim_toolkit * data = (T_sim_toolkit *)win_data->user;
554 T_MFW_HND sat_win;
555 T_SAT_RES sat_res;
556
557 // Shashi Shekar B.S., a0876501, Jan 16, 2006, DR: OMAPS00061460
558 #ifdef FF_MMI_SAT_ICON
559 USHORT icon_length;
560 #endif
561
562 TRACE_FUNCTION ("sim_toolkit_exec()");
563
564 if (event NEQ SAT_SESSION_END)
565 data->active_sat_session = (T_SAT_EVENTS) event;
566
567 if (data->info_win != NULL)
568 {
569 SEND_EVENT (data->info_win, E_ED_DEINIT, 0, NULL);
570 data->info_win = NULL;
571 }
572
573
574 switch (event)
575 {
576 case SAT_DISPLAY_TEXT:
577 TRACE_EVENT("SAT_DISPLAY_TEXT");
578 /*
579 * Text with normal priority will be displayed
580 * only in idle screen and in SAT Menu Item
581 */
582 if ((sat_command->qual & SAT_M_TEXT_HIGH_PRIO) EQ 0)
583 {
584 TRACE_EVENT("NOT SAT_M_TEXT_HIGH_PRIO");
585 /* Check if Idle AND Sat Session are inactiv */
586 if ((!g_SATsession_is_active)&&(!idleIsFocussed()))
587 {
588 TRACE_EVENT("BUSY SCREEN");
589 /* idle is not in focus and not currently in a SAT session: we are busy elsewhere */
590 sat_res[SAT_ERR_INDEX] = SAT_RES_BUSY_ME;
591 sat_res[SAT_AI_INDEX] = SatResAiBusyScreen;
592 sat_done (sat_command, sat_res);
593 return;
594 }
595 }
596
597 sat_win = sat_display_text_create (data->win);
598 if (sat_win)
599 {
600 data->sat_command = sat_command;
601 SEND_EVENT (sat_win, event, 0, data->sat_command);
602 }
603 else
604 {
605 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
606 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
607 sat_done (sat_command, sat_res);
608 }
609 break;
610
611 case SAT_PLAY_TONE:
612 TRACE_EVENT("SAT_PLAY_TONE");
613 /*
614 * Create and initiate Play Tone Window
615 */
616 sat_win = sat_play_tone_create (data->win);
617 if (sat_win)
618 {
619 data->sat_command = sat_command;
620 SEND_EVENT (sat_win, event, 0, data->sat_command);
621 }
622 else
623 {
624 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
625 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
626 sat_done (sat_command, sat_res);
627 }
628 break;
629
630 case SAT_GET_KEY:
631 TRACE_EVENT("SAT_GET_KEY");
632 /*
633 * Create and initiate Get Key Window
634 */
635 sat_win = sat_get_key_create (data->win);
636 if (sat_win)
637 {
638 data->sat_command = sat_command;
639 SEND_EVENT (sat_win, event, 0, data->sat_command);
640 }
641 else
642 {
643 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
644 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
645 sat_done (sat_command, sat_res);
646 }
647 break;
648 case SAT_GET_STRING:
649 TRACE_EVENT("SAT_GET_STRING");
650 /*
651 * Create and initiate Get String Window
652 */
653 sat_win = sat_get_string_create (data->win);
654 if (sat_win)
655 {
656 data->sat_command = sat_command;
657 SEND_EVENT (sat_win, event, 0, data->sat_command);
658 }
659 else
660 {
661 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
662 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
663 sat_done (sat_command, sat_res);
664 }
665 break;
666
667 // c016 rsa
668 case SAT_SETUP_MENU:
669 TRACE_EVENT("SAT_SETUP_MENU");
670
671 sat_call_active = FALSE; // Marcus: Issue 1812: 13/03/2003
672 //SAT is on the SIM available
673 data->sat_available_on_SIM = TRUE;
674
675 /*
676 * initiate Setup Menu
677 */
678 sat_setup_menu_proc(sat_command);
679 sat_res[SAT_ERR_INDEX] = SatResSuccess;
680 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
681 sat_done (sat_command, sat_res);
682 break;
683
684 case SAT_SELECT_ITEM:
685 TRACE_EVENT("SAT_SELECT_ITEM");
686 /*
687 * Create and initiate select item Window
688 */
689 sat_win = sat_select_item_create (data->win);
690 if (sat_win)
691 {
692 data->sat_command = sat_command;
693 SEND_EVENT (sat_win, event, 0, data->sat_command);
694 }
695 else
696 {
697 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
698 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
699 sat_done (sat_command, sat_res);
700 }
701 break;
702 // end c016 rsa
703
704 // c001 xas
705 case SAT_SEND_SMS:
706 TRACE_EVENT("SAT_SEND_SMS");
707 /*
708 * --> display alpha identifier if available
709 */
710 if ((sat_command->c.sms.info.len NEQ 0) &&
711 (sat_command->c.sms.info.len NEQ (U8)-1))
712 {
713 char *TextString = (char *)sat_create_TEXT_ASCIIZ (&sat_command->c.sms.info);
714 /*
715 * Setup an editor to display a string
716 */
717
718
719
720 /* SPR#1428 - SH - New Editor changes */
721 #ifdef NEW_EDITOR
722 AUI_edit_SetDefault(&data->editor_data);
723 AUI_edit_SetTextStr(&data->editor_data, TxtNull, TxtNull, TxtNull, (UBYTE *)TextString);
724 AUI_edit_SetMode(&data->editor_data, ED_MODE_READONLY, ED_CURSOR_NONE);
725 AUI_edit_SetEvents(&data->editor_data, event, TRUE, FOREVER, (T_AUI_EDIT_CB)sat_info_cb);
726 // xreddymn Sep-06-2005 MMI-SPR-33876: Initialize editor buffer
727 AUI_edit_SetBuffer(&data->editor_data, ATB_DCS_ASCII, (UBYTE*)"", 1);
728 // Shashi Shekar B.S., a0876501, Jan 16, 2006, DR: OMAPS00061460
729 #ifdef FF_MMI_SAT_ICON
730 /*Check if the SAT command has icon*/
731 if(sat_command->c.sms.info.icon.qual != 0xFF)
732 {
733 /* Copy the icon data to the editor attributes*/
734 data->editor_data.editor_attr.TitleIcon.width = sat_command->c.sms.info.iconInfo.width;
735 data->editor_data.editor_attr.TitleIcon.height = sat_command->c.sms.info.iconInfo.height;
736
737 icon_length = sat_command->c.sms.info.iconInfo.width * sat_command->c.sms.info.iconInfo.height;
738
739 data->editor_data.editor_attr.TitleIcon.data = (char *)ALLOC_MEMORY (icon_length);
740
741 memcpy(data->editor_data.editor_attr.TitleIcon.data, sat_command->c.sms.info.iconInfo.dst, icon_length);
742 data->editor_data.editor_attr.TitleIcon.isTitle = TRUE;
743
744 /* Icon is self-explanatory. No need to display text for this case.*/
745 if(sat_command->c.sms.info.icon.qual == 0x00)
746 {
747 /* Icon is self-explanatory. Do not display the text*/
748 data->editor_data.editor_attr.TitleIcon.selfExplanatory = TRUE;
749 }
750
751 /* Free the memory of icon data that we got through the SATK command*/
752 mfwFree((U8 *)sat_command->c.sms.info.iconInfo.dst, icon_length);
753 sat_command->c.sms.info.iconInfo.dst = NULL;
754
755 }
756 #endif
757
758 data->info_win = AUI_edit_Start(win, &data->editor_data);
759 #else /* NEW_EDITOR */
760 data->editor_data.LeftSoftKey = TxtNull;
761 data->editor_data.AlternateLeftSoftKey = TxtNull;
762 data->editor_data.RightSoftKey = TxtNull;
763 data->editor_data.hide = FALSE;
764 data->editor_data.mode = E_EDIT_READ_ONLY_MODE;
765 data->editor_data.timeout = FOREVER;
766 data->editor_data.Identifier = event;
767 data->editor_data.destroyEditor = TRUE;
768 data->editor_data.Callback = (T_EDIT_CB)sat_info_cb;
769 data->editor_data.TextString = (char *)TextString;
770 data->editor_data.min_enter = 0;
771 data->info_win = editor_start(win, &data->editor_data);
772 #endif /* NEW_EDITOR */
773 }
774 break;
775
776 case SAT_SEND_SS:
777 TRACE_EVENT("SAT_SEND_SS");
778 /*
779 * --> display alpha identifier if available
780 */
781 if ((sat_command->c.ss.info.len NEQ 0) &&
782 (sat_command->c.ss.info.len NEQ (U8)-1))
783 {
784 char *TextString = (char *)sat_create_TEXT_ASCIIZ (&sat_command->c.ss.info);
785
786
787 /*
788 * Setup an editor to display a string
789 */
790 /* SPR#1428 - SH - New Editor changes */
791 #ifdef NEW_EDITOR
792 AUI_edit_SetDefault(&data->editor_data);
793 AUI_edit_SetTextStr(&data->editor_data, TxtNull, TxtNull, TxtNull, (UBYTE *)TextString);
794 AUI_edit_SetMode(&data->editor_data, ED_MODE_READONLY, ED_CURSOR_NONE);
795 AUI_edit_SetEvents(&data->editor_data, event, TRUE, FOREVER, (T_AUI_EDIT_CB)sat_info_cb);
796 // Dec 23, 2005 REF: OMAPS00062166 x0039928
797 // Fix: Initialize the editor buffer
798 AUI_edit_SetBuffer(&data->editor_data, ATB_DCS_ASCII, (UBYTE*)"", 1);
799
800 // Shashi Shekar B.S., a0876501, Jan 16, 2006, DR: OMAPS00061460
801 #ifdef FF_MMI_SAT_ICON
802 /*Check if the SAT command has icon*/
803 if(sat_command->c.ss.info.icon.qual != 0xFF)
804 {
805 /* Copy the icon data to the editor attributes*/
806 data->editor_data.editor_attr.TitleIcon.width = sat_command->c.ss.info.iconInfo.width;
807 data->editor_data.editor_attr.TitleIcon.height = sat_command->c.ss.info.iconInfo.height;
808
809 icon_length = sat_command->c.ss.info.iconInfo.width * sat_command->c.ss.info.iconInfo.height;
810
811 data->editor_data.editor_attr.TitleIcon.data = (char *)ALLOC_MEMORY (icon_length);
812
813 memcpy(data->editor_data.editor_attr.TitleIcon.data, sat_command->c.ss.info.iconInfo.dst, icon_length);
814 data->editor_data.editor_attr.TitleIcon.isTitle = TRUE;
815
816 /* Icon is self-explanatory. No need to display text for this case.*/
817 if(sat_command->c.ss.info.icon.qual == 0x00)
818 {
819 /* Icon is self-explanatory. Do not display the text*/
820 data->editor_data.editor_attr.TitleIcon.selfExplanatory = TRUE;
821 }
822
823 /* Free the memory of icon data that we got through the SATK command*/
824 mfwFree((U8 *)sat_command->c.ss.info.iconInfo.dst, icon_length);
825 sat_command->c.ss.info.iconInfo.dst = NULL;
826
827 }
828 #endif
829
830 data->info_win = AUI_edit_Start(win, &data->editor_data);
831
832 #else /* NEW_EDITOR */
833 data->editor_data.LeftSoftKey = TxtNull;
834 data->editor_data.AlternateLeftSoftKey = TxtNull;
835 data->editor_data.RightSoftKey = TxtNull;
836 data->editor_data.hide = FALSE;
837 data->editor_data.mode = E_EDIT_READ_ONLY_MODE;
838 data->editor_data.timeout = FOREVER;
839 data->editor_data.Identifier = event;
840 data->editor_data.Callback = (T_EDIT_CB)sat_info_cb;
841 data->editor_data.destroyEditor = TRUE;
842 data->editor_data.TextString = TextString;
843
844 data->editor_data.min_enter = 0;
845 data->info_win = editor_start(win, &data->editor_data);
846 #endif /* NEW_EDITOR */
847 }
848 break;
849 // end c001 xas
850
851
852 case SAT_SEND_DTMF:
853 TRACE_EVENT("SAT_SEND_DTMF");
854 /*
855 * --> display alpha identifier if available
856 */
857 if ((sat_command->c.cmd.info.len NEQ 0) &&
858 (sat_command->c.cmd.info.len NEQ (U8)-1))
859 {
860 char *TextString = (char *)sat_create_TEXT_ASCIIZ (&sat_command->c.cmd.info);
861
862
863 /*
864 * Setup an editor to display a string
865 */
866 /* SPR#1428 - SH - New Editor changes */
867 #ifdef NEW_EDITOR
868 AUI_edit_SetDefault(&data->editor_data);
869 AUI_edit_SetTextStr(&data->editor_data, TxtNull, TxtNull, TxtNull, (UBYTE *)TextString);
870 AUI_edit_SetMode(&data->editor_data, ED_MODE_READONLY, ED_CURSOR_NONE);
871 AUI_edit_SetEvents(&data->editor_data, event, TRUE, THREE_SECS, (T_AUI_EDIT_CB)sat_info_cb);
872 // Dec 23, 2005 REF: OMAPS00062166 x0039928
873 // Fix: Initialize the editor buffer
874 AUI_edit_SetBuffer(&data->editor_data, ATB_DCS_ASCII, (UBYTE*)"", 1);
875
876 // Shashi Shekar B.S., a0876501, Jan 16, 2006, DR: OMAPS00061460
877 #ifdef FF_MMI_SAT_ICON
878 /*Check if the SAT command has icon*/
879 if(sat_command->c.cmd.info.icon.qual != 0xFF)
880 {
881 /* Copy the icon data to the editor attributes*/
882 data->editor_data.editor_attr.TitleIcon.width = sat_command->c.cmd.info.iconInfo.width;
883 data->editor_data.editor_attr.TitleIcon.height = sat_command->c.cmd.info.iconInfo.height;
884
885 icon_length = sat_command->c.cmd.info.iconInfo.width * sat_command->c.cmd.info.iconInfo.height;
886
887 data->editor_data.editor_attr.TitleIcon.data = (char *)ALLOC_MEMORY (icon_length);
888
889 memcpy(data->editor_data.editor_attr.TitleIcon.data, sat_command->c.cmd.info.iconInfo.dst, icon_length);
890 data->editor_data.editor_attr.TitleIcon.isTitle = TRUE;
891
892 /* Icon is self-explanatory. No need to display text for this case.*/
893 if(sat_command->c.cmd.info.icon.qual == 0x00)
894 {
895 /* Icon is self-explanatory. Do not display the text*/
896 data->editor_data.editor_attr.TitleIcon.selfExplanatory = TRUE;
897 }
898
899 /* Free the memory of icon data that we got through the SATK command*/
900 mfwFree((U8 *)sat_command->c.cmd.info.iconInfo.dst, icon_length);
901 sat_command->c.cmd.info.iconInfo.dst = NULL;
902
903 }
904 #endif
905
906 data->info_win = AUI_edit_Start(win, &data->editor_data);
907
908 #else /* NEW_EDITOR */
909 data->editor_data.LeftSoftKey = TxtNull;
910 data->editor_data.AlternateLeftSoftKey = TxtNull;
911 data->editor_data.RightSoftKey = TxtNull;
912 data->editor_data.hide = FALSE;
913 data->editor_data.mode = E_EDIT_READ_ONLY_MODE;
914 data->editor_data.timeout = THREE_SECS;
915 data->editor_data.Identifier = event;
916 data->editor_data.Callback = (T_EDIT_CB)sat_info_cb;
917 data->editor_data.destroyEditor = TRUE;
918 data->editor_data.TextString = TextString;
919
920 data->editor_data.min_enter = 0;
921 data->info_win = editor_start(win, &data->editor_data);
922 #endif /* NEW_EDITOR */
923 }
924 break;
925 case SAT_SETUP_CALL:
926 TRACE_EVENT("SAT_SETUP_CALL");
927
928 TRACE_EVENT_P2("Redial durUnit %d durValue %d",
929 sat_command->c.call.durUnit,sat_command->c.call.durValue);
930 data->sat_command = sat_command;
931
932 /* create parameter space for call, or reuse old */
933 if (data->call_setup_parameter EQ NULL)
934 {
935 data->call_setup_parameter =
936 (T_SAT_call_setup_parameter *)ALLOC_MEMORY (sizeof(T_SAT_call_setup_parameter));
937 }
938
939 /* SPR#1784 - DS - If command qualifier is set to 'with redial' (01, 03 or 05) set a global redial flag */
940 if ( (sat_command->qual & 0x01) == TRUE )
941 {
942 if (sat_command->qual > 0x05)
943 {
944 TRACE_EVENT("Invalid call command qualifier!");
945 }
946 else
947 {
948 set_sat_redial_flag(1);
949 }
950 }
951
952
953 /* gather the name of the called party (if any) */
954 if ((sat_command->c.call.info.len NEQ 0) &&
955 (sat_command->c.call.info.len NEQ (U8)-1))
956 {
957 TRACE_EVENT("call.info contains data.");
958 data->call_setup_parameter->TextString = sat_create_TEXT_ASCIIZ(&sat_command->c.call.info);
959 //x0035544 Feb 07, 2006 DR:OMAPS00061467
960 //copy the icon data for the first alpha identifier
961 #ifdef FF_MMI_SAT_ICON
962 if (sat_command->c.call.info.icon.qual != 0xFF)
963 {
964 data->call_setup_parameter->IconInfo.width = sat_command->c.call.info.iconInfo.width;
965 data->call_setup_parameter->IconInfo.height= sat_command->c.call.info.iconInfo.height;
966 icon_length = sat_command->c.call.info.iconInfo.width * sat_command->c.call.info.iconInfo.height;
967 if(sat_command->c.call.info.iconInfo.dst != NULL)
968 {
969 data->call_setup_parameter->IconInfo.dst = (char *)ALLOC_MEMORY (icon_length);
970 memcpy(data->call_setup_parameter->IconInfo.dst, sat_command->c.call.info.iconInfo.dst, icon_length);
971 }
972 if(sat_command->c.call.info.icon.qual == 0x00)
973 {
974 /* Icon is self-explanatory. Do not display the text*/
975 data->call_setup_parameter->IconInfo.selfExplanatory = TRUE;
976
977 }
978 else
979 data->call_setup_parameter->IconInfo.selfExplanatory = FALSE;
980
981 /* Free the memory of icon data that we got through the SATK command*/
982 if(sat_command->c.call.info.iconInfo.dst != NULL)
983 {
984 mfwFree((U8 *)sat_command->c.call.info.iconInfo.dst, icon_length);
985 sat_command->c.call.info.iconInfo.dst = NULL;
986 }
987 }
988 else
989 {
990 data->call_setup_parameter->IconInfo.dst = NULL;
991 data->call_setup_parameter->IconInfo.width = 0;
992 data->call_setup_parameter->IconInfo.height = 0;
993 data->call_setup_parameter->IconInfo.selfExplanatory = FALSE;
994 }
995
996 #endif
997 }
998 else
999 {
1000 /* provide an empty string; NULL would crash in info_dialog() */
1001 TRACE_EVENT("call.info contains no data!");
1002 sat_command->c.call.info.len = 0;
1003
1004 /* SPR#1700 - DS - Set string to NULL */
1005 data->call_setup_parameter->TextString = NULL;
1006
1007 /* SPR#1700 - DS - Commented out code below. Checks in call() in mmiCall.c ensure
1008 * a NULL string is not sent to info_dialog
1009 */
1010 #if 0
1011 data->call_setup_parameter->TextString = sat_create_TEXT_ASCIIZ(&sat_command->c.call.info);
1012 #endif /* 0 */
1013 }
1014
1015 /* SPR#1700 - DS - Save info2 (if available). This should be used for the "calling" dialog.
1016 * If not available, info (above) can be used.
1017 */
1018
1019 /* gather the name of the called party (if any) */
1020 if ((sat_command->c.call.info2.len NEQ 0) &&
1021 (sat_command->c.call.info2.len NEQ (U8)-1))
1022 {
1023 TRACE_EVENT("call.info2 contains data.");
1024 data->call_setup_parameter->TextString2 = sat_create_TEXT_ASCIIZ(&sat_command->c.call.info2);
1025 //x0035544 Feb 07, 2006 DR:OMAPS00061467
1026 //copy the icon data for the second alpha identifier
1027 #ifdef FF_MMI_SAT_ICON
1028 if (sat_command->c.call.info2.icon.qual != 0xFF)
1029 {
1030 data->call_setup_parameter->IconInfo2.width= sat_command->c.call.info2.iconInfo.width;
1031 data->call_setup_parameter->IconInfo2.height = sat_command->c.call.info2.iconInfo.height;
1032 data->call_setup_parameter->IconInfo2.dst = data->call_setup_parameter->IconInfo.dst;
1033 if(sat_command->c.call.info2.icon.qual == 0x00)
1034 {
1035 // Icon is self-explanatory. Do not display the text
1036 data->call_setup_parameter->IconInfo2.selfExplanatory = TRUE;
1037 }
1038 else
1039 data->call_setup_parameter->IconInfo2.selfExplanatory = FALSE;
1040 }
1041 else
1042 {
1043 data->call_setup_parameter->IconInfo2.dst = NULL;
1044 data->call_setup_parameter->IconInfo2.width = 0;
1045 data->call_setup_parameter->IconInfo2.height = 0;
1046 data->call_setup_parameter->IconInfo2.selfExplanatory = FALSE;
1047 }
1048
1049 #endif
1050 #ifdef NO_ASCIIZ/*MC SPR 940/2 Add tag to Unicode strings so info dialogue displays them correctly*/
1051 sat_add_unicode_tag_if_needed(data->call_setup_parameter->TextString2);
1052 #endif
1053 }
1054 else
1055 {
1056 /* provide an empty string; NULL would crash in info_dialog() */
1057 TRACE_EVENT("call.info2 contains no data!");
1058 sat_command->c.call.info2.len = 0;
1059
1060 /* SPR#1700 - DS - Set string to NULL */
1061 data->call_setup_parameter->TextString2 = NULL;
1062
1063 /* SPR#1700 - DS - Commented out code below. Checks in call() in mmiCall.c ensure
1064 * a NULL string is not sent to info_dialog
1065 */
1066 #if 0
1067 data->call_setup_parameter->TextString2 = sat_create_TEXT_ASCIIZ(&sat_command->c.call.info2);
1068 #ifdef NO_ASCIIZ/*MC SPR 940/2 Add tag to Unicode strings so info dialogue displays them correctly*/
1069 sat_add_unicode_tag_if_needed(data->call_setup_parameter->TextString2);
1070 #endif
1071 #endif /* 0 */
1072 }
1073 break;
1074
1075 case SAT_CALL_RESULT:
1076 if (data->call_setup_parameter EQ NULL)
1077 {
1078 /* we are NOT in a SETUP CALL session;this is a "normal" Call Result */
1079 TRACE_EVENT("SAT_CALL_RESULT a");
1080 /*
1081 * --> display alpha identifier if available
1082 */
1083
1084 TRACE_EVENT_P1("Redial Time %d",sat_command->c.ccres.redialTime);
1085
1086 if ((sat_command->c.ccres.info.len NEQ 0) &&
1087 (sat_command->c.ccres.info.len NEQ (U8)-1))
1088 {
1089 char *TextString = (char *)sat_create_TEXT_ASCIIZ (&sat_command->c.ccres.info);
1090
1091
1092 /*
1093 * Setup an editor to display a string
1094 */
1095 /* SPR#1428 - SH - New Editor changes */
1096 #ifdef NEW_EDITOR
1097 AUI_edit_SetDefault(&data->editor_data);
1098 AUI_edit_SetTextStr(&data->editor_data, TxtNull, TxtNull, TxtNull, (UBYTE *)TextString);
1099 AUI_edit_SetMode(&data->editor_data, ED_MODE_READONLY, ED_CURSOR_NONE);
1100 AUI_edit_SetEvents(&data->editor_data, event, TRUE, FOREVER, (T_AUI_EDIT_CB)sat_info_cb);
1101
1102 data->info_win = AUI_edit_Start(win, &data->editor_data);
1103 #else /* NEW_EDITOR */
1104 SmsSend_loadEditDefault(&data->editor_data);
1105 data->editor_data.LeftSoftKey = TxtNull;
1106 data->editor_data.AlternateLeftSoftKey = TxtNull;
1107 data->editor_data.RightSoftKey = TxtNull;
1108 data->editor_data.hide = FALSE;
1109 data->editor_data.mode = E_EDIT_READ_ONLY_MODE;
1110 data->editor_data.timeout = FOREVER;
1111 data->editor_data.Identifier = event;
1112 data->editor_data.Callback = (T_EDIT_CB)sat_info_cb;
1113 data->editor_data.destroyEditor = TRUE;
1114 data->editor_data.TextId = TxtNull;
1115 data->editor_data.TextString = TextString;
1116 data->editor_data.min_enter = 0;
1117 data->info_win = editor_start(win, &data->editor_data);
1118 #endif /* NEW_EDITOR */
1119
1120 }
1121 }
1122 else
1123 {
1124 /* we are in a SETUP CALL session;this is a SATN return */
1125 U8 general_result;
1126 U8 additional_info;
1127
1128 TRACE_EVENT("SAT_CALL_RESULT b");
1129
1130 /* process result of a call setup */
1131 general_result = (U8)(sat_command->c.ccres.result); /*SPR#2042 - DS - Changed from .redialTime */
1132 additional_info = (U8)(sat_command->c.ccres.callId);
1133
1134 if (((general_result & (U8)0xF0) EQ (U8)0x00) ||
1135 ((general_result & (U8)0xF0) EQ (U8)0x10))
1136 {
1137 /* command has been performed */
1138 /*
1139 * destroying the display of SETUP MENU will focus the idle screen (in order to show the incall info)
1140 * furthermore it's necessary to keep track of the used resources
1141 */
1142 #if 0 /* CQ16437 : Do not need to exit menu in order to handle the call correctly */
1143 TRACE_EVENT("destroy SETUP menu");
1144 SEND_EVENT (sat_get_setup_menu_win(), SAT_EXIT, 0, NULL);
1145 #endif
1146 return;
1147 }
1148 else if ((general_result & (U8)0xF0) EQ (U8)0x20)
1149 {
1150 /* command failed: may be worth to retry */
1151 switch (general_result)
1152 {
1153 case 0x20: /* ME currently unable to process command */
1154 TRACE_EVENT("SAT: ME unable");
1155 break;
1156 case 0x21: /* NW currently unable to process command */
1157 TRACE_EVENT("SAT: NW unable");
1158 #ifdef FF_2TO1_PS
1159 if ((additional_info EQ (U8)CAUSE_NWCC_USER_BUSY) &&
1160 #else
1161 if ((additional_info EQ (U8)CAUSE_USER_BUSY) &&
1162 #endif
1163 (data->call_setup_parameter NEQ NULL))
1164 {
1165 SEND_EVENT (sat_get_call_setup_win(), SAT_CALL_REDIAL, 0, data->call_setup_parameter); /* redial */
1166 return; /* do NOT release the call setup parameter */
1167 }
1168 break;
1169 case 0x22: /* user rejected call setup */
1170 TRACE_EVENT("user rejected call setup");
1171 case 0x23: /* user cleared down call */
1172 TRACE_EVENT("user cleared down call");
1173 default:
1174 TRACE_EVENT("default reason");
1175 break;
1176 }
1177 }
1178 else if ((general_result & (U8)0xF0) EQ (U8)0x30)
1179 {
1180 /* command failed: not worth to retry with identical command */
1181 TRACE_EVENT("SAT_CALL_RESULT permanent problem");
1182 /* await SAT_SESSION_END in order to react */
1183 }
1184 else
1185 {
1186 TRACE_EVENT("SAT_CALL_RESULT unexp. result code");
1187 }
1188 SEND_EVENT (win, SAT_CALL_END, 0, NULL); /* release the call setup parameter */
1189 }
1190 break;
1191
1192 case SAT_CALL_ALERT:
1193 TRACE_EVENT("SAT_CALL_ALERT");
1194 if (data->call_setup_parameter EQ NULL)
1195 {
1196 /* in case we are called withoud previous CALL_SETUP (which shouldn't happen!) */
1197 data->call_setup_parameter =
1198 (T_SAT_call_setup_parameter *)ALLOC_MEMORY (sizeof(T_SAT_call_setup_parameter));
1199
1200 /* provide an empty string; NULL would crash in info_dialog() */
1201 sat_command->c.ccres.info.len = 0;
1202 data->call_setup_parameter->TextString = sat_create_TEXT_ASCIIZ(&sat_command->c.ccres.info);
1203
1204 }
1205
1206 /* gather callId and redialTime */
1207 data->call_setup_parameter->callId = sat_command->c.ccres.callId;
1208 data->call_setup_parameter->redialTime = sat_command->c.ccres.redialTime;
1209
1210 /* start a dialog to accept or reject the call */
1211 sat_win = sat_call_setup_create(data->win);
1212 if (sat_win)
1213 {
1214 data->sat_command = sat_command;
1215 SEND_EVENT (sat_win, event,0,data->call_setup_parameter);
1216 }
1217 else
1218 {
1219 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
1220 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1221 sat_done (sat_command, sat_res);
1222 }
1223 break;
1224
1225 case SAT_SESSION_END:
1226 ETRACE(sprintf(buf, "SAT_SESSION_END %d", data->active_sat_session));
1227 data->active_sat_session = (T_SAT_EVENTS)event;
1228
1229 if (data->info_win NEQ NULL)
1230 {
1231 /* destroy any infoscreen */
1232 /* SPR#1428 - SH - New Editor changes */
1233 #ifdef NEW_EDITOR
1234 SEND_EVENT (data->info_win, E_ED_DEINIT, 0, NULL);
1235 #else /* NEW_EDITOR */
1236 SEND_EVENT (data->info_win, E_EDITOR_DEINIT, 0, NULL);
1237 #endif /* NEW_EDITOR */
1238 data->info_win = NULL;
1239 }
1240
1241
1242 /*
1243 * Marcus: Issue 1057: 21/01/2003: Made SEND_EVENT conditional on
1244 * call_SATCall being FALSE.
1245 */
1246 if (call_SATCall == FALSE)
1247 {
1248 /* Marcus: Issue 1812: 13/03/2003: Start */
1249 if (sat_call_active)
1250 {
1251 sat_call_active = FALSE;
1252 SEND_EVENT (sat_get_setup_menu_win(), SAT_EXIT, 0, NULL);
1253 }
1254 else
1255 {
1256 SEND_EVENT (sat_get_setup_menu_win(), SAT_RETURN, 0, NULL); /* recreate the SETUP MENU */
1257 }
1258 /* Marcus: Issue 1812: 13/03/2003: End */
1259 }
1260 break;
1261
1262 case SAT_CALL_END:
1263 TRACE_EVENT("SAT_CALL_END");
1264 if (data->call_setup_parameter NEQ NULL)
1265 {
1266 /* release the call setup parameters */
1267 sat_destroy_TEXT_ASCIIZ(data->call_setup_parameter->TextString);
1268
1269 //x0035544 Feb 07, 2006 DR:OMAPS00061467 ARUNKS
1270 //Release the icon data.
1271 #ifdef FF_MMI_SAT_ICON
1272 if (data->call_setup_parameter->IconInfo.dst != NULL)
1273 {
1274 FREE_MEMORY((U8 *)data->call_setup_parameter->IconInfo.dst, data->call_setup_parameter->IconInfo.width *
1275 data->call_setup_parameter->IconInfo.height);
1276 data->call_setup_parameter->IconInfo.dst = NULL;
1277 }
1278
1279 #endif
1280 FREE_MEMORY ((U8 *)data->call_setup_parameter, sizeof (T_SAT_call_setup_parameter));
1281 data->call_setup_parameter = NULL;
1282
1283 SEND_EVENT (sat_get_call_setup_win(), event, 0, NULL); /* destroy the window */
1284
1285
1286 }
1287
1288 /* SPR#1784 - DS - Destroy any information screen.
1289 */
1290 if (data->info_win NEQ NULL)
1291 {
1292 TRACE_EVENT("Destroy the info screen");
1293
1294 /* destroy any infoscreen */
1295 #ifdef NEW_EDITOR
1296 SEND_EVENT (data->info_win, E_ED_DEINIT, 0, NULL);
1297 #else /* NEW_EDITOR */
1298 SEND_EVENT (data->info_win, E_EDITOR_DEINIT, 0, NULL);
1299 #endif /* NEW_EDITOR */
1300 data->info_win = NULL;
1301 }
1302
1303 break;
1304
1305 case SAT_UNKNOWN:
1306 TRACE_EVENT("SAT_UNKNOWN");
1307 /*
1308 * unknown SAT commands are rejected
1309 */
1310 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
1311 sat_res[SAT_AI_INDEX] = SatResAiNoService;
1312 sat_done (sat_command, sat_res);
1313 break;
1314
1315 case SAT_REFRESH:
1316 TRACE_EVENT("SAT_REFRESH");
1317 #ifdef MMI_HOMEZONE_ENABLED
1318 {
1319 int i;
1320 for (i=0;i<sat_command->c.refFiles.files_nr;i++)
1321 {
1322 switch(sat_command->c.refFiles.files[i])
1323 {
1324 case HZ_SIM_PARAMETERS:
1325 case HZ_SIM_CELL_CACHE:
1326 case HZ_SIM_CELL_CACHE+1:
1327 case HZ_SIM_CELL_CACHE+2:
1328 case HZ_SIM_CELL_CACHE+3:
1329 /* Read new sim fields into memory. SPR877 - SH - Parameter specifies that SIM fields
1330 * should be read in, even if they were already read at startup. */
1331 homezoneReadSim(HZ_READ_SIM_AGAIN);
1332 return;
1333 default:
1334 break;
1335 }
1336 }
1337 }
1338 #endif
1339 break;
1340
1341 case SAT_SET_EVENTS:
1342 break;
1343 case SAT_IDLE_TEXT:
1344 {
1345 SatTxt *inText;
1346 char *txtBuf;
1347 UBYTE outDCS;
1348
1349 inText = &sat_command->c.text;
1350
1351 if (inText->len == 0)
1352 {
1353 // 09-Dec-2005, Shashi Shekar B.S., a0876501, START
1354 #ifdef FF_MMI_SAT_ICON
1355 addSatMessage(NULL, 0, 0, NULL, FALSE, SAT_ICON_IDLEMODE_TEXT);
1356 /* Free the memory of icon data that we got through the SATK command*/
1357 if(sat_command->c.text.iconInfo.dst != NULL)
1358 {
1359 mfwFree((U8 *)sat_command->c.text.iconInfo.dst, sat_command->c.text.iconInfo.width *
1360 sat_command->c.text.iconInfo.height);
1361 sat_command->c.text.iconInfo.dst = NULL;
1362 }
1363
1364 #else
1365 addSatMessage(NULL);
1366 #endif
1367
1368
1369 sat_res[SAT_ERR_INDEX] = SatResUnknownData;
1370 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1371 sat_done(sat_command, sat_res);
1372 }
1373 else
1374 {
1375 txtBuf = (char *)ALLOC_MEMORY(MAX_CBMSG_LEN);
1376
1377 if (!txtBuf)
1378 {
1379 sat_res[SAT_ERR_INDEX] = SatResImpossible;
1380 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1381 sat_done(sat_command, sat_res);
1382 }
1383 else
1384 {
1385 memset(txtBuf, 0x00, MAX_CBMSG_LEN);
1386
1387 /*
1388 ** What is the required format for the output text? UCS2 or ASCII?
1389 */
1390 if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
1391 outDCS = MFW_DCS_UCS2;
1392 else
1393 outDCS = MFW_ASCII;
1394
1395 TRACE_EVENT_P3("NDH >>> inDcs : %02x, outDCS : %02x, Text Len : %d", inText->code,
1396 outDCS, inText->len);
1397
1398 if ((inText->code == 0x00) || ((inText->code & 0x0c) == 0x00)) // GSM 7-Bit
1399 {
1400 ATB_convert_String((char *)inText + inText->text,
1401 MFW_DCS_7bits, inText->len,
1402 txtBuf,
1403 outDCS, MAX_CBMSG_LEN-1,
1404 TRUE);
1405 }
1406 else if ((inText->code & 0x0c) == 0x04) // ASCII 8-Bit
1407 {
1408 if (outDCS == MFW_ASCII)
1409 {
1410 if (inText->len > MAX_CBMSG_LEN-1)
1411 {
1412 //CQ - 19656 Sandip Start
1413 //For Input DCS 0x00, we are handling long strings , so also for input DCS 0x04 we should handle long strings
1414 #if 0
1415 /*
1416 ** Display Text too long ... Send failure TR to SIM
1417 */
1418 sat_res[SAT_ERR_INDEX] = SatResImpossible;
1419 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1420 sat_done(sat_command, sat_res);
1421
1422 FREE_MEMORY((U8 *)txtBuf, MAX_CBMSG_LEN);
1423 return;
1424 #endif
1425 //CQ - 19656 Sandip
1426 ATB_convert_String((char *)inText + inText->text,
1427 MFW_DCS_8bits, inText->len,
1428 txtBuf,
1429 outDCS, MAX_CBMSG_LEN-1,
1430 TRUE);
1431 //CQ - 19656 Sandip End
1432 }
1433 else
1434 {
1435 //MMI_FIX-19656 Using 8 bit table for dispay start
1436 ATB_convert_String((char *)inText + inText->text,
1437 MFW_DCS_8bits, inText->len,
1438 txtBuf,
1439 outDCS, MAX_CBMSG_LEN-1,
1440 TRUE);
1441 //MMI_FIX-19656 Using 8 bit table for dispay end
1442 //memcpy(txtBuf, (char *)inText + inText->text, inText->len);
1443 }
1444 }
1445 else
1446 {
1447 ATB_convert_String((char *)inText + inText->text,
1448 MFW_DCS_8bits, inText->len,
1449 txtBuf,
1450 outDCS, MAX_CBMSG_LEN-1,
1451 TRUE);
1452 }
1453 }
1454 else // UCS2
1455 {
1456 if (outDCS == MFW_DCS_UCS2)
1457 {
1458 if (inText->len > MAX_CBMSG_LEN-1)
1459 {
1460 /*
1461 ** Display Text too long ... Send failure TR to SIM
1462 */
1463 sat_res[SAT_ERR_INDEX] = SatResImpossible;
1464 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1465 sat_done(sat_command, sat_res);
1466
1467 FREE_MEMORY((U8 *)txtBuf, MAX_CBMSG_LEN);
1468 return;
1469 }
1470 else
1471 {
1472 memcpy(txtBuf, (char *)inText + inText->text, inText->len);
1473 }
1474 }
1475 else
1476 {
1477 ATB_convert_String((char *)inText + inText->text,
1478 MFW_DCS_UCS2, inText->len,
1479 txtBuf,
1480 outDCS, MAX_CBMSG_LEN-1,
1481 TRUE);
1482 }
1483 }
1484
1485 TRACE_EVENT_P1("NDH >>> txtBuf is : %s", txtBuf);
1486
1487 // 09-Dec-2005, Shashi Shekar B.S., a0876501, START
1488 #ifdef FF_MMI_SAT_ICON
1489 /*Check if the SAT command has icon*/
1490 if(sat_command->c.text.icon.qual != 0xFF)
1491 {
1492 /* Icon is self-explanatory. No need to display text for this case.*/
1493 if(sat_command->c.text.icon.qual == 0x00)
1494 {
1495 /* Icon is self-explanatory. Do not display the text.
1496 Send a TRUE to the Idle window. */
1497 addSatMessage(txtBuf, sat_command->c.text.iconInfo.width, sat_command->c.text.iconInfo.height,
1498 (char *)sat_command->c.text.iconInfo.dst, TRUE, SAT_ICON_IDLEMODE_TEXT);
1499 }
1500 else
1501 addSatMessage(txtBuf, sat_command->c.text.iconInfo.width, sat_command->c.text.iconInfo.height,
1502 (char *)sat_command->c.text.iconInfo.dst, FALSE, SAT_ICON_IDLEMODE_TEXT);
1503 }
1504 else
1505 {
1506 addSatMessage(txtBuf, 0, 0, NULL, FALSE, SAT_ICON_NONE);
1507 }
1508
1509 #else
1510 addSatMessage(txtBuf);
1511 #endif
1512
1513 sat_res[SAT_ERR_INDEX] = SatResSuccess;
1514 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1515 sat_done(sat_command, sat_res);
1516 // 09-Dec-2005, Shashi Shekar B.S., a0876501, START
1517 #ifdef FF_MMI_SAT_ICON
1518 /* Free the memory of icon data that we got through the SATK command*/
1519 if(sat_command->c.text.iconInfo.dst != NULL)
1520 {
1521 mfwFree((U8 *)sat_command->c.text.iconInfo.dst, sat_command->c.text.iconInfo.width *
1522 sat_command->c.text.iconInfo.height);
1523 sat_command->c.text.iconInfo.dst = NULL;
1524 }
1525 #endif
1526
1527 FREE_MEMORY((U8 *)txtBuf, MAX_CBMSG_LEN);
1528 }
1529 }
1530 }
1531 break;
1532
1533 #ifdef FF_WAP
1534 case SAT_LAUNCH_BROWSER:
1535
1536 break;
1537 #endif
1538 case SAT_OPEN_CHANNEL:
1539 TRACE_EVENT("SAT_OPEN_CHANNEL");
1540
1541 /*
1542 * Create and initiate Open Channel Window
1543 */
1544 sat_win = sat_class_e_create (data->win);
1545
1546 if (sat_win)
1547 {
1548 data->sat_command = sat_command;
1549 SEND_EVENT (sat_win, event, 0, data->sat_command);
1550 }
1551 else
1552 {
1553 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
1554 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1555 sat_done (sat_command, sat_res);
1556 }
1557 break;
1558 case SAT_CLOSE_CHANNEL:
1559 TRACE_EVENT("SAT_CLOSE_CHANNEL");
1560
1561 /*
1562 * Create and initiate Close Channel window
1563 */
1564 sat_win = sat_class_e_create (data->win);
1565
1566 if (sat_win)
1567 {
1568 data->sat_command = sat_command;
1569 SEND_EVENT (sat_win, event, 0, data->sat_command);
1570 }
1571 else
1572 {
1573 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
1574 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1575 sat_done (sat_command, sat_res);
1576 }
1577 break;
1578 case SAT_SEND_DATA:
1579 TRACE_EVENT("SAT_SEND_DATA");
1580
1581 /*
1582 * Create and initiate Send Data window
1583 */
1584 sat_win = sat_class_e_create (data->win);
1585
1586 if (sat_win)
1587 {
1588 data->sat_command = sat_command;
1589 SEND_EVENT (sat_win, event, 0, data->sat_command);
1590 }
1591 else
1592 {
1593 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
1594 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1595 sat_done (sat_command, sat_res);
1596 }
1597 break;
1598 case SAT_RECEIVE_DATA:
1599
1600 TRACE_EVENT("SAT_RECEIVE_DATA");
1601
1602 /*
1603 * Create and initiate Receive Data window
1604 */
1605 sat_win = sat_class_e_create (data->win);
1606
1607 if (sat_win)
1608 {
1609 data->sat_command = sat_command;
1610 SEND_EVENT (sat_win, event, 0, data->sat_command);
1611 }
1612 else
1613 {
1614 sat_res[SAT_ERR_INDEX] = SAT_RES_IMPOSSIBLE;
1615 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1616 sat_done (sat_command, sat_res);
1617 }
1618 break;
1619 default:
1620 TRACE_EVENT("sim_toolkit_exec() unexp. event");
1621 break;
1622 }
1623 }
1624 /*******************************************************************************
1625
1626 $Function: sim_toolkit_sat_cb
1627
1628 $Description: Callback function for SAT handler of top window
1629
1630 $Returns: none.
1631
1632 $Arguments:
1633
1634 *******************************************************************************/
1635 static int sim_toolkit_sat_cb ( T_MFW_EVENT event, T_MFW_SAT * sat_bits)
1636 {
1637 USHORT sat_event = 0; // RAVI
1638
1639 TRACE_EVENT("sim_toolkit_sat_cb");
1640 /*
1641 * check whether a decoded message is available
1642 */
1643 if ((sat_bits EQ NULL) || (g_sim_toolkit_data->win EQ NULL))
1644 {
1645 TRACE_EVENT("sim_toolkit_sat_cb() unexp. event");
1646 return MFW_EVENT_CONSUMED;
1647 }
1648
1649 /* convert the flag into an event */
1650 if (event == MfwSatSessionEnd)
1651 {
1652 sat_event = SAT_SESSION_END;
1653 }
1654 else
1655 {
1656 switch (event)
1657 {
1658 case MfwSatTextOut: /* display string */
1659 sat_event = SAT_DISPLAY_TEXT;
1660 break;
1661 case MfwSatGetKey: /* get user keystroke */
1662 sat_event = SAT_GET_KEY;
1663 break;
1664 case MfwSatGetString: /* get user input */
1665 sat_event = SAT_GET_STRING;
1666 break;
1667 case MfwSatPlayTone: /* play audio tone */
1668 sat_event = SAT_PLAY_TONE;
1669 break;
1670 case MfwSatSetupMenu: /* setup toolkit menu */
1671 sat_event = SAT_SETUP_MENU;
1672 break;
1673 case MfwSatSelectItem: /* select menu item */
1674 sat_event = SAT_SELECT_ITEM;
1675 break;
1676 case MfwSatSendSMS: /* send short message */
1677 sat_event = SAT_SEND_SMS;
1678 break;
1679 case MfwSatSendUSSD:
1680 case MfwSatSendSS: /* send service command */
1681 sat_event = SAT_SEND_SS;
1682 break;
1683 case MfwSatSendDTMF: /* send service command */
1684 sat_event = SAT_SEND_DTMF;
1685 break;
1686 case MfwSatCall: /* setup a call */
1687 sat_event = SAT_SETUP_CALL;
1688 break;
1689 case MfwSatCcRes: /* call control result */
1690 sat_event = SAT_CALL_RESULT;
1691 break;
1692 case MfwSatCcAlert: /* call control alerting */
1693 sat_event = SAT_CALL_ALERT;
1694 break;
1695 case MfwSatRefresh: /* refresh SIM fields */
1696 sat_event = SAT_REFRESH;
1697 break;
1698 case MfwSatSetEvents: /* Sat Set Events updated */
1699 sat_event = SAT_SET_EVENTS;
1700 break;
1701 case MfwSatIdleText: /* Sat Set Events updated */
1702 sat_event = SAT_IDLE_TEXT;
1703 break;
1704 case MfwSatDataRefreshed: /* Data refreshed */
1705 TRACE_EVENT("MfwSatDataRefreshed event sent");
1706 break;
1707 case MfwSatOpenChannel: /* Open channel */
1708 sat_event = SAT_OPEN_CHANNEL;
1709 break;
1710 case MfwSatCloseChannel: /* Close channel */
1711 sat_event = SAT_CLOSE_CHANNEL;
1712 break;
1713 case MfwSatSendData: /* Send data */
1714 sat_event = SAT_SEND_DATA;
1715 break;
1716 case MfwSatReceiveData: /* Receive data */
1717 sat_event = SAT_RECEIVE_DATA;
1718 break;
1719 #ifdef FF_WAP /*Disable for testing without WAP*/
1720 case MfwSatLaunchBrowser:
1721 TRACE_EVENT("SAT_LAUNCH_BROWSER got to MMI");
1722 #ifdef MMI_TEST_SAT_LAUNCH_BROWSER
1723 {
1724 #define LENGTH_URL 40
1725 T_SAT_RES sat_res;
1726 SatLaunchBrowser laun_brow;
1727 char prov_url[LENGTH_URL];
1728 short pos = 0;
1729 int i;
1730
1731 sat_res[SAT_ERR_INDEX] = SAT_RES_SUCCESS;
1732 sat_res[SAT_AI_INDEX] = SatResAiNoCause;
1733 sat_done (sat_bits->cmd, sat_res);
1734 sat_event = SAT_LAUNCH_BROWSER;
1735 laun_brow = sat_bits->cmd->c.browser;
1736 memset(information,'\0',INFORMATION_SIZE);
1737 TRACE_EVENT_P1("Browser identity -> %d",laun_brow.identity);
1738 memcpy(&prov_url,laun_brow.url,LENGTH_URL);
1739 prov_url[LENGTH_URL-1] = '\0';
1740 TRACE_EVENT_P1("Browser url -> %s",prov_url);
1741 pos += sprintf(information+pos,
1742 "BROWSER\n-Identity=%d\n-Url=%s\n-Bearers(%d)=",
1743 laun_brow.identity,
1744 prov_url,
1745 laun_brow.n_bearer);
1746 for (i=0;i<5;i++)
1747 pos+=sprintf(information+pos," %d",*laun_brow.bearer++);
1748 mmiOpenDummyBrowser(g_sim_toolkit_data->win,information);
1749 }
1750 break;
1751 #endif /*FF_WAP*/
1752 #endif /* MMI_TEST_SAT_LAUNCH_BROWSER */
1753 case MfwSatErrBusy:
1754 TRACE_EVENT("MfwSatError reached BMI");
1755 {
1756 T_DISPLAY_DATA display_info;
1757
1758 /* SPR#2321 - DS - Display "SAT Busy" dialog */
1759
1760 dlg_initDisplayData_TextStr( &display_info, TxtNull, TxtNull, "SAT Busy", "Reset App" , COLOUR_STATUS);
1761 dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)NULL, THREE_SECS, KEY_RIGHT | KEY_LEFT );
1762 info_dialog (g_sim_toolkit_data->win, &display_info);
1763 }
1764
1765 /* No SEND_EVENT */
1766
1767 return MFW_EVENT_CONSUMED;
1768 // break; // RAVI
1769 default:
1770 sat_event = SAT_UNKNOWN;
1771 break;
1772 }
1773 }
1774 SEND_EVENT (g_sim_toolkit_data->win, sat_event, 0, sat_bits->cmd);
1775 return MFW_EVENT_CONSUMED;
1776 }
1777
1778 /*******************************************************************************
1779
1780 $Function: sat_setup_menu_proc
1781
1782 $Description: process SAT_SETUP_MENU event
1783
1784 $Returns: none.
1785
1786 $Arguments:
1787
1788 *******************************************************************************/
1789 static void sat_setup_menu_proc(T_SAT_CMD * sat_command)
1790 {
1791 TRACE_FUNCTION("sat_setup_menu_proc");
1792
1793 if (sat_command->c.menu.items[0].len EQ 0)
1794 {
1795 /*
1796 * "Item data object for item 1" is a null data object:
1797 * hide the SIM toolkit menu item in the main menu
1798 */
1799 menuDisableSimMenu();
1800 g_sim_toolkit_data->sat_available_on_SIM = FALSE;
1801 //release the labe of the mainmenu
1802 //GW-SPR#1035 Free memory using sat_destroy_TEXT_ASCIIZ (as it is allocated using corresponding procedure)
1803 if (sat_mainmenu_label NEQ NULL)
1804 {
1805 sat_destroy_TEXT_ASCIIZ (sat_mainmenu_label);
1806 sat_mainmenu_label = NULL;
1807 }
1808
1809 if (sat_get_setup_menu_win() NEQ NULL)
1810 {
1811 /* there's an active SETUP MENU */
1812 SEND_EVENT (sat_get_setup_menu_win(), SAT_EXIT, 0, NULL); /* SETUP_MENU shall selfdestroy */
1813 }
1814 if (g_sim_toolkit_data->sat_setup_menu_command NEQ NULL)
1815 {
1816 FREE_MEMORY ((U8 *)(g_sim_toolkit_data->sat_setup_menu_command), sizeof (T_SAT_CMD));
1817 g_sim_toolkit_data->sat_setup_menu_command = NULL;
1818 }
1819 }
1820 else
1821 {
1822 /* install new setup menu */
1823 if (sat_get_setup_menu_win() NEQ NULL)
1824 {
1825 /* there's already an active SETUP MENU */
1826 SEND_EVENT (sat_get_setup_menu_win(), SAT_EXIT, 0, NULL); /* SETUP_MENU shall selfdestroy */
1827 //xrashmic 16 Feb, 2006 OMAPS00064413
1828 //List win should be set to null, when destroying the setup menu.
1829 sat_set_setup_menu_listmnu_win(NULL);
1830 }
1831
1832 /* store command contents for later use in sat_setup_menu_start() */
1833 if (g_sim_toolkit_data->sat_setup_menu_command EQ NULL)
1834 {
1835 /* if not already allocated, get storage for the SETUP MENU command */
1836 g_sim_toolkit_data->sat_setup_menu_command =
1837 (T_SAT_CMD *)ALLOC_MEMORY (sizeof (T_SAT_CMD));
1838 }
1839 *(g_sim_toolkit_data->sat_setup_menu_command) = *sat_command; /* copy contents */
1840
1841 /*#ifdef CHINESE_MMI*/
1842 /*
1843 The label for the main menu
1844
1845 */
1846 TRACE_EVENT("SAT: Creating main menu label");
1847 {
1848 #ifdef NO_ASCIIZ
1849 /*MC, SPR 940/2if we're in chinese, header may be converted from ASCII to Unicode*/
1850 if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
1851 header_len = g_sim_toolkit_data->sat_setup_menu_command->c.menu.header.len *2;
1852 else
1853 #endif
1854 /* taking the label from menu command file and convert to ascii */
1855 header_len = g_sim_toolkit_data->sat_setup_menu_command->c.menu.header.len;
1856
1857
1858 sat_mainmenu_label = sat_create_TEXT_ASCIIZ (&g_sim_toolkit_data->sat_setup_menu_command->c.menu.header);
1859 if(sat_mainmenu_label)
1860 {
1861 sat_mainmenu_label[header_len] = '\0';
1862 /*JVJ #1576 The SimToolkit Title string is set here */
1863 res_set_SIMToolkit_title_string(sat_mainmenu_label);
1864 }
1865 }
1866 /* unhide the SIM toolkit menu item in the main menu */
1867 menuEnableSimMenu
1868 (
1869 "", /* label */
1870 (SimMenuFunc)sat_setup_menu_start, /* callback when menu entered */
1871 g_sim_toolkit_data->sat_setup_menu_command /* parameter to callback */
1872 );
1873 }
1874 sat_set_setup_menu_win(NULL); // avoid notifications to a non-existent window
1875 }
1876
1877
1878 /*******************************************************************************
1879
1880 $Function: sat_win_cb
1881
1882 $Description: Default sat window event handler. Avoid intermediate visibility of lower menus
1883
1884
1885 $Returns: none.
1886
1887 $Arguments:
1888
1889 *******************************************************************************/
1890 int sat_win_cb (T_MFW_EVENT event, T_MFW_WIN * win)
1891 {
1892 TRACE_FUNCTION("sat_win_cb");
1893
1894 if (win EQ NULL)
1895 return MFW_EVENT_CONSUMED;
1896
1897 switch (event)
1898 {
1899 case E_WIN_VISIBLE: /* window changed visibility */
1900 if (win->flags & E_WIN_VISIBLE)
1901 {
1902 /* window becomes visible */
1903 dspl_ClearAll(); /* overwrite redraw of lower menus with cleared screen */
1904 dspl_TextOut(0,12,/*DSPL_TXTATTR_NORMAL*/DSPL_TXTATTR_CURRENT_MODE/*MC*/,GET_TEXT(TxtPleaseWait)); /* sbh - so we don't get blank screen */
1905 }
1906 break;
1907 default:
1908 return MFW_EVENT_REJECTED;
1909 }
1910 return MFW_EVENT_CONSUMED;
1911 }
1912
1913 /*******************************************************************************
1914
1915 $Function: sat_kbd_cb
1916
1917 $Description: Default sat window keyboard handler
1918
1919
1920 $Returns: none.
1921
1922 $Arguments:
1923
1924 *******************************************************************************/
1925 int sat_kbd_cb (T_MFW_EVENT event, T_MFW_KBD * key)
1926 {
1927 T_MFW_HND win = mfwParent( mfw_header() );
1928
1929 TRACE_FUNCTION("sat_kbd_cb");
1930
1931 /* make sure we handle null keyboards
1932 */
1933 if ( key == NULL )
1934 return MFW_EVENT_CONSUMED;
1935
1936 /* deal with the incoming key code
1937 */
1938 switch( key->code )
1939 {
1940
1941 /* Destroy the window on either right softkey or hangup keypresses */
1942 case KCD_HUP:
1943 case KCD_RIGHT:
1944 {
1945 SEND_EVENT(win, SAT_DESTROY_WINDOW, 0, 0);
1946 break;
1947 }
1948 }
1949
1950 return MFW_EVENT_CONSUMED;
1951 }
1952
1953
1954 /*******************************************************************************
1955
1956 $Function: sat_info_cb
1957
1958 $Description: Callback function information dialog.
1959
1960 $Returns: none.
1961
1962 $Arguments:
1963
1964 *******************************************************************************/
1965 static void sat_info_cb(T_MFW_HND win, UBYTE identifier, UBYTE reason)
1966 {
1967 /* INFO DISPLAY */
1968 T_MFW_WIN * info_win_data = ((T_MFW_HDR *)win)->data;
1969 T_sim_toolkit * info_data = (T_sim_toolkit *)info_win_data->user;
1970
1971 TRACE_FUNCTION("sat_info_cb");
1972
1973 if (win EQ NULL)
1974 return;
1975
1976 /*
1977 * Who has initiated the information screen
1978 */
1979 switch (identifier)
1980 {
1981 //x0035544 added fix done by x0021334 for CQ-33597 21-11-2005
1982 case SAT_SEND_DTMF: // x0021334 : To test SAT session end - CQ33597
1983 {
1984 // Shashi Shekar B.S., a0876501, Jan 16, 2006, DR: OMAPS00061460
1985 #ifdef FF_MMI_SAT_ICON
1986 if (info_data->editor_data.editor_attr.TitleIcon.data != NULL)
1987 {
1988 FREE_MEMORY((U8 *)info_data->editor_data.editor_attr.TitleIcon.data, info_data->editor_data.editor_attr.TitleIcon.width *
1989 info_data->editor_data.editor_attr.TitleIcon.height);
1990 info_data->editor_data.editor_attr.TitleIcon.data = NULL;
1991 }
1992 #endif
1993
1994 switch(reason)
1995 {
1996 case INFO_KCD_RIGHT:
1997 case INFO_KCD_HUP:
1998 // Call mfw function to end the session
1999 Mfw_SAT_DTMF_EndSession();
2000 #ifdef NEW_EDITOR
2001 AUI_edit_Destroy(info_data->info_win);
2002 #else /* NEW_EDITOR */
2003 editor_destroy(info_data->info_win);
2004 #endif /* NEW_EDITOR */
2005 info_data->info_win = NULL;
2006 break;
2007 default:
2008 TRACE_EVENT("sat_info_cb(): unexp. event");
2009 break;
2010 }
2011 }
2012 break;
2013
2014 case SAT_SEND_SMS:
2015 case SAT_SEND_SS:
2016 //case SAT_SEND_DTMF: x0035544 CQ-33597 21-11-2005
2017 case SAT_CALL_RESULT:
2018 if ((info_win_data EQ NULL) || (info_data EQ NULL))
2019 return;
2020
2021 // Shashi Shekar B.S., a0876501, Jan 16, 2006, DR: OMAPS00061460
2022 #ifdef FF_MMI_SAT_ICON
2023 if (info_data->editor_data.editor_attr.TitleIcon.data != NULL)
2024 {
2025 FREE_MEMORY((U8 *)info_data->editor_data.editor_attr.TitleIcon.data, info_data->editor_data.editor_attr.TitleIcon.width *
2026 info_data->editor_data.editor_attr.TitleIcon.height);
2027 info_data->editor_data.editor_attr.TitleIcon.data = NULL;
2028 }
2029 #endif
2030 /* SPR#1428 - SH - New Editor changes */
2031 #ifdef NEW_EDITOR
2032 sat_destroy_TEXT_ASCIIZ((char*)info_data->editor_data.TitleString); /* displayed text */
2033 #else /* NEW_EDITOR */
2034 sat_destroy_TEXT_ASCIIZ((char*)info_data->editor_data.TextString); /* displayed text */
2035 #endif /* NEW_EDITOR */
2036 break;
2037 default:
2038 TRACE_EVENT("sat_info_cb(): unexp. event");
2039 break;
2040 }
2041 }
2042
2043
2044 /*******************************************************************************
2045
2046 $Function: sat_set_setup_menu_win
2047
2048 $Description: set the window associated with the setup menu command
2049
2050 $Returns: none.
2051
2052 $Arguments:
2053
2054 *******************************************************************************/
2055 void sat_set_setup_menu_win(T_MFW_HND win)
2056 {
2057 TRACE_FUNCTION("sat_set_setup_menu_win");
2058
2059 g_sim_toolkit_data->sat_setup_menu_win = win;
2060 }
2061
2062
2063 /*******************************************************************************
2064
2065 $Function: sat_get_setup_menu_win
2066
2067 $Description: get the window associated with the setup menu command
2068
2069 $Returns: none.
2070
2071 $Arguments:
2072
2073 *******************************************************************************/
2074 T_MFW_HND sat_get_setup_menu_win(void)
2075 {
2076 TRACE_EVENT("sat_get_setup_menu_win");
2077 return g_sim_toolkit_data->sat_setup_menu_win;
2078 }
2079
2080
2081 /*******************************************************************************
2082
2083 $Function: sat_set_setup_menu_listmnu_win
2084
2085 $Description: set the window associated with the sat list menu
2086
2087 $Returns: none.
2088
2089 $Arguments:
2090
2091 *******************************************************************************/
2092 void sat_set_setup_menu_listmnu_win(T_MFW_HND win)
2093 {
2094 TRACE_FUNCTION("sat_set_setup_menu_listmnu_win");
2095
2096 g_sim_toolkit_data->sat_setup_menu_listmnu_win= win;
2097 }
2098
2099
2100 /*******************************************************************************
2101
2102 $Function: sat_get_setup_menu_listmnu_win
2103
2104 $Description: get the window associated with the setup list menu
2105
2106 $Returns: none.
2107
2108 $Arguments:
2109
2110 *******************************************************************************/
2111 T_MFW_HND sat_get_setup_menu_listmnu_win(void)
2112 {
2113 TRACE_EVENT("sat_get_setup_menu_listmnu_win");
2114 return g_sim_toolkit_data->sat_setup_menu_listmnu_win;
2115 }
2116
2117
2118 /*******************************************************************************
2119
2120 $Function: sat_set_call_setup_win
2121
2122 $Description: set the window associated with the call setup command
2123
2124 $Returns: none.
2125
2126 $Arguments:
2127
2128 *******************************************************************************/
2129 void sat_set_call_setup_win(T_MFW_HND win)
2130 {
2131 TRACE_FUNCTION("sat_set_call_setup_win");
2132 g_sim_toolkit_data->sat_call_setup_win = win;
2133 }
2134
2135
2136 /*******************************************************************************
2137
2138 $Function: sat_get_call_setup_win
2139
2140 $Description: get the window associated with the call setup command
2141
2142 $Returns: none.
2143
2144 $Arguments:
2145
2146 *******************************************************************************/
2147 /* Marcus: Issue 1057: 21/01/2003: Made public */
2148 T_MFW_HND sat_get_call_setup_win(void)
2149 {
2150 TRACE_FUNCTION("sat_get_call_setup_win");
2151 return g_sim_toolkit_data->sat_call_setup_win;
2152 }
2153
2154 /*******************************************************************************
2155
2156 $Function: g_ascii_gsm_table
2157
2158 $Description: convert a string coded in ASCIIZ into GSM alphabet
2159
2160 $Returns: none.
2161
2162 $Arguments:
2163
2164 *******************************************************************************/
2165 static const char g_ascii_gsm_table[256] = {
2166 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //000-007
2167 0x20,0x20, 10,0x20,0x20, 13,0x20,0x20, //008-015
2168 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //016-023
2169 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //024-031
2170 32, 33, 34, 35, 2, 37, 38, 39, //032-039
2171 40, 41, 42, 43, 44, 45, 46, 47, //040-047
2172 48, 49, 50, 51, 52, 53, 54, 55, //048-055
2173 56, 57, 58, 59, 60, 61, 62, 63, //056-063
2174 0, 65, 66, 67, 68, 69, 70, 71, //064-071
2175 72, 73, 74, 75, 76, 77, 78, 79, //072-079
2176 80, 81, 82, 83, 84, 85, 86, 87, //080-087
2177 88, 89, 90,0x20,0x20,0x20,0x20,0x20, //088-095
2178 0x20, 97, 98, 99, 100, 101, 102, 103, //096-103
2179 104, 105, 106, 107, 108, 109, 110, 111, //104-111
2180 112, 113, 114, 115, 116, 117, 118, 119, //112-119
2181 120, 121, 122,0x20,0x20,0x20,0x20,0x20, //120-127
2182 9, 126, 5,0x20, 123, 127, 15,0x20, //128-135
2183 0x20,0x20, 4,0x20,0x20, 7, 91, 14, //136-143
2184 31, 29, 28,0x20, 124, 8,0x20, 6, //144-151
2185 0x20, 92, 94,0x20, 1, 3,0x20,0x20, //152-159
2186 0x20,0x20,0x20,0x20, 125, 93,0x20,0x20, //160-167
2187 96, 17,0x20,0x20,0x20, 64,0x20,0x20, //168-175
2188 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //176-183
2189 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //184-191
2190 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //192-199
2191 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //200-207
2192 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //208-215
2193 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //216-223
2194 0x20, 30, 19, 22, 24,0x20,0x20,0x20, //224-231
2195 18, 25, 21,0x20,0x20,0x20,0x20, 20, //232-239
2196 26,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //240-247
2197 0x20,0x20,0x20,0x20,0x20,0x20,0x20,0x20, //248-255
2198 };
2199
2200 void sat_ascii_to_gsm (char * gsm_string, char * ascii_string, U16 length)
2201 {
2202 U16 i;
2203 TRACE_FUNCTION("sat_ascii_to_gsm");
2204
2205 for (i = 0; i < length; i++)
2206 gsm_string[i] = g_ascii_gsm_table[ascii_string[i]];
2207 }
2208
2209 /*******************************************************************************
2210
2211 $Function: sat_ascii_to_ucode
2212
2213 $Description: convert a string coded in ASCIIZ into UCS2 alphabet
2214
2215 $Returns: none.
2216
2217 $Arguments:
2218
2219 *******************************************************************************/
2220 void sat_ascii_to_ucode (wchar_t * UCS2_chars, char * ascii_string, U16 length)
2221 {
2222 U16 i;
2223 TRACE_FUNCTION("sat_ascii_to_ucode");
2224 for (i = 0; i < length; i++)
2225 UCS2_chars[i] = (wchar_t)ascii_string[i];
2226 }
2227
2228 /*******************************************************************************
2229
2230 $Function: sat_ucode_to_ascii
2231
2232 $Description: convert a string coded in UCS2 into ASCII alphabet
2233
2234 $Returns: none.
2235
2236 $Arguments:
2237
2238 *******************************************************************************/
2239 void sat_ucode_to_ascii (char * ascii_string, wchar_t * UCS2_chars, U16 length)
2240 {
2241 U16 i;
2242 TRACE_FUNCTION("sat_ucode_to_asci");
2243
2244 for (i = 0; i < length; i++)
2245 ascii_string[i] = (char)UCS2_chars[i];
2246 ascii_string[i] = '\0';
2247 }
2248 /*******************************************************************************
2249
2250 $Function: g_gsm_ascii_table
2251
2252 $Description: convert a string coded in GSM alphabet into an ASCIIZ string
2253
2254 $Returns: none.
2255
2256 $Arguments:
2257
2258 *******************************************************************************/
2259
2260 static const char g_gsm_ascii_table[128] = {
2261 64, 156, 36, 157, 138, 130, 151, 141,
2262 149, 128, 10,0x20 , 32, 13, 143, 134,
2263 0x20, 169, 232, 226, 239, 234, 227,0x20,
2264 228, 233, 240,0x20, 146, 145, 225, 144,
2265 32, 33, 34, 35,0x20, 37, 38, 39,
2266 40, 41, 42, 43, 44, 45, 46, 47,
2267 48, 49, 50, 51, 52, 53, 54, 55,
2268 56, 57, 58, 59, 60, 61, 62, 63,
2269 173, 65, 66, 67, 68, 69, 70, 71,
2270 72, 73, 74, 75, 76, 77, 78, 79,
2271 80, 81, 82, 83, 84, 85, 86, 87,
2272 88, 89, 90, 142, 153, 165, 154,0x20,
2273 168, 97, 98, 99, 100, 101, 102, 103,
2274 104, 105, 106, 107, 108, 109, 110, 111,
2275 112, 113, 114, 115, 116, 117, 118, 119,
2276 120, 121, 122, 132, 148, 164, 129, 133
2277 };
2278
2279 void sat_gsm_to_ascii (char * ascii_string, char * gsm_string, U16 length)
2280 {
2281 U16 i;
2282 TRACE_FUNCTION("sat_gsm_to_ascii");
2283 // Jun 02, 2004 REF: CRR 15747 xpradipg-SASKEN
2284 // Fix: The string is terminated if the length is reached or if it encounters '0xFF'
2285 // gsm_string[i]!=0xFF is introduced to check if the string is terminated prior to the specified length
2286 for (i = 0; i < length && gsm_string[i]!=0xFF; i++)
2287 ascii_string[i] = g_gsm_ascii_table[(gsm_string[i] & (U8)0x7F)];
2288 ascii_string[i] = '\0';
2289 }
2290
2291
2292 /*******************************************************************************
2293
2294 $Function: sat_TEXT_to_ASCIIZ
2295
2296 $Description: This routine converts a MFW SAT text descriptor into a
2297 conventional ASCIIZ string
2298 $Returns: none.
2299
2300 $Arguments:
2301
2302 *******************************************************************************/
2303 void sat_TEXT_to_ASCIIZ (char * destination, T_SAT_TXT * txt)
2304 {
2305 UBYTE * temp_buffer;
2306 UBYTE len;
2307 char* txt_start;
2308
2309 TRACE_FUNCTION("sat_TEXT_to_ASCIIZ");
2310
2311 TRACE_EVENT_P1("T_SAT_TXT txt->code=%x", txt->code);
2312
2313 switch (txt->code)
2314 {
2315 case MFW_DCS_7bits:
2316 temp_buffer = (UBYTE *)ALLOC_MEMORY(((txt->len*8)/7)+1);
2317 len = utl_cvt7To8 ((UBYTE *)txt + txt->text, txt->len, temp_buffer);
2318 //Sandip CQ 16292 . commented
2319 /*sat_gsm_to_ascii (destination, (char *)temp_buffer, len);*/
2320 /*Sandip CQ 16292 . added this new function . Problem with current TI GSM 7-bit default function*/
2321 DecodeGSM7ToASCII((unsigned char*)txt+txt->text, (unsigned char*) destination, txt->len);
2322 FREE_MEMORY ((U8 *)temp_buffer, ((txt->len*8)/7)+1);
2323 break;
2324 case MFW_DCS_8bits:
2325 /* SPR#1700 - DS - Modified to handle 0x80 style unicode */
2326 txt_start = (char*)txt + txt->text;
2327 if ((*txt_start == 0x80) && (txt->len & 1))
2328 {
2329 TRACE_EVENT("0x80 style unicode");
2330 memset(destination,0,txt->len+2);
2331 memcpy(destination,txt_start+1,txt->len-1);
2332 txt->code = MFW_DCS_UCS2;
2333 }
2334 else
2335 {
2336 sat_gsm_to_ascii (destination, (char *)txt + txt->text, (UBYTE)txt->len);
2337 }
2338 break;
2339 case MFW_DCS_UCS2:
2340 sat_ucode_to_ascii (destination, (wchar_t *)((char *)txt + txt->text), txt->len);
2341 break;
2342 default:
2343 sat_gsm_to_ascii (destination, (char *)txt + txt->text, (UBYTE)txt->len); /* SH - got txt->code=244, so need generic response to this*/
2344 TRACE_EVENT("sat_TEXT_to_ASCIIZ() unexp. DCS");
2345 }
2346 }
2347
2348 //sandip 16292
2349 // Converts a given 8-bit encoded string into original 7-bit GSM data string according to TS 31.102
2350 /*******************************************************************************
2351
2352 $Function: DecodeGSM7ToASCII
2353
2354 $Description: This function decodes a GSM 7-bit string into ASCII equivalent
2355
2356 $Returns: length of decoded string
2357
2358 $Arguments: encoded - GSM string pointer
2359 plain - Buffer to hold the decoded ASCII string
2360 Length - Length of the encoded GSM string
2361
2362
2363 *******************************************************************************/
2364 unsigned char DecodeGSM7ToASCII(U8 * encoded, U8 * plain, U8 Length)
2365 {
2366 U8 bits, i, j;
2367 U8 c;
2368
2369 /* Extract the ascii characters from the bytes,
2370 */
2371
2372 for (i = j = bits = 0; j < Length; i++, j++)
2373 {
2374 if (bits > 0)
2375 c = encoded[i-1] >> (8-bits);
2376 else
2377 c=0;
2378
2379 if (bits < 7)
2380 c |= encoded[i] << bits;
2381
2382 *plain++ = c & 0x7f;
2383 bits = (++bits)%8;
2384 if (bits == 0)
2385 {
2386 i -= 1;
2387 Length++;
2388 }
2389 }
2390
2391 *plain = '\0';
2392 return (Length);
2393 }
2394 /*******************************************************************************
2395
2396 $Function: sat_create_TEXT_ASCIIZ
2397
2398 $Description: This routine creates out of an MFW SAT text descriptor an
2399 dynamically allocated ASCIIZ string pointer
2400
2401 $Returns: none.
2402
2403 $Arguments:
2404
2405 MC, Note: text returned by this function has no Unicode tag at beginning
2406 $Returns: none.
2407
2408 $Arguments:
2409
2410 *******************************************************************************/
2411 /*MC, SPR 940/2 uncommented function back in, and then rewrote it :)*/
2412 void sat_TEXT_to_UCODE (char* destination, int size, T_SAT_TXT * txt)
2413 {
2414
2415 UBYTE * temp_buffer;
2416 UBYTE len;
2417 char debug[50];
2418
2419
2420 TRACE_EVENT("sat_TEXT_to_UCODE()");
2421
2422 switch (txt->code) /*DCS of Text*/
2423 {
2424 case MFW_DCS_7bits:
2425 temp_buffer = (UBYTE *)ALLOC_MEMORY(((txt->len*8)/7)+1);
2426 /*convert from 7 to 8 bit*/
2427 len = utl_cvt7To8 ((UBYTE *)txt + txt->text, txt->len, temp_buffer, 0);
2428
2429 /*MC, convert from 8 bit to UCS2*/
2430 /*SPR2175, use new function for conversion*/
2431 ATB_convert_String((char*)temp_buffer, MFW_DCS_8bits, (((txt->len*8)/7)+1), (char*)destination, MFW_DCS_UCS2, /*txt->len*2*/size, FALSE);
2432 FREE_MEMORY ((U8 *)temp_buffer, ((txt->len*8)/7)+1);
2433 break;
2434 case MFW_DCS_8bits:/*DCS tends to come out as 8 bit whatever it is*/
2435 if (*((UBYTE*)txt+txt->text) !=0x80)/*MC, if ASCII, convert to Unicode*/
2436 {
2437 #ifdef SAT_TEXT_TRACING
2438 //string_GSM_to_UCS2((UBYTE)txt->len, (UBYTE *)txt + txt->text, (USHORT)(txt->len), destination);
2439 sprintf(debug, "Length of MENU HEADER:%d", txt->len);
2440 TRACE_EVENT(debug);
2441 #endif
2442 /*MC, convert from 8 bit to UCS2*/
2443 /*SPR2175, use new function for conversion*/
2444 ATB_convert_String((char *)txt +txt->text, MFW_DCS_8bits, txt->len, (char*)destination, MFW_DCS_UCS2, /*txt->len*2*/size, FALSE);
2445 }
2446 else
2447 {
2448 /*MC, unicode string, convert to our display format*/
2449 destination[0] =0x80;/*SPR 1728, add unicode tag*/
2450 destination[1] = 0x7f;
2451
2452 memcpy(&destination[2], (UBYTE*)txt+txt->text+1, txt->len-1);
2453
2454 }
2455 break;
2456 case MFW_DCS_UCS2:/*MC, unicode string, convert to our display format*/
2457 { destination[0] =0x80;/*SPR 1728, add unicode tag*/
2458 destination[1] = 0x7f;
2459
2460 //memcpy(&destination[2], (UBYTE*)txt+txt->text+1, txt->len-1);
2461 memcpy(&destination[2], (UBYTE*)txt+txt->text, txt->len); /* SPR#2340 - DS - Corrected len */
2462
2463 }
2464
2465 break;
2466 default:
2467 TRACE_EVENT("sat_TEXT_to_UCODE() unexp. DCS");
2468 }
2469 /*MC, SPR 1086 Commented out traces here, as long buffers cause a crash*/
2470 {int i;
2471
2472 for (i=0; i <size && i<20; i++)
2473 { if (destination[i] == 0)
2474 debug[i] ='0';
2475 else
2476 debug[i] = destination[i];
2477 }
2478 debug[i+1] = 0x00; /* SPR#2321 - DS - Terminate debug buffer after UCS2 string */
2479 TRACE_EVENT(debug);
2480 }
2481 }
2482 /*JVJE*/
2483
2484 /*******************************************************************************
2485
2486 $Function: sat_create_TEXT_ASCIIZ
2487
2488 $Description: This routine creates out of an MFW SAT text descriptor an
2489 dynamically allocated ASCIIZ string pointer
2490
2491 $Returns: none.
2492
2493 $Arguments:
2494
2495 *******************************************************************************/
2496 #define SAT_LEN_SIZE (U16)sizeof(U16) /* used to hold the allocation size */
2497 #define SAT_TERMINATOR_SIZE (U16)sizeof(U16) /* used to hold terminating '\0' in U8 and U16 */
2498
2499 char * sat_create_TEXT_ASCIIZ (T_SAT_TXT * txt)
2500 {
2501
2502 char * res;
2503 U16 size;
2504 UBYTE first_char= *((UBYTE*)txt+txt->text);/*SPR 1728*/
2505 TRACE_EVENT("sat_create_TEXT_ASCIIZ ()");
2506 #ifdef NO_ASCIIZ
2507 TRACE_EVENT_P3("DCS:%d first_char:%d len: %d", txt->code, first_char, txt->len);
2508 /*SPR 1728, if unicode string format it for display*/
2509 if ( first_char==0x80 ||txt->code==MFW_DCS_UCS2)
2510 { return (char*)sat_create_TEXT_UCODE (txt);}
2511 #endif
2512
2513 /* SPR#2321 - DS - Format not Unicode therefore return NULL if string length is zero */
2514 if (txt->len == 0)
2515 return NULL;
2516
2517 /* SPR#2321 - DS - SAT has sent a NULL string. Set first char to ASCII code for <space> */
2518 if (txt->len == 1 && first_char == 0x00)
2519 {
2520 *((UBYTE*)txt+txt->text) = 0x20;
2521 }
2522
2523 /* SPR#2321 - DS - Check if SAT has supplied a NULL string (first_char 0x00, dcs not UCS2) */
2524 if (first_char == 0x00 && txt->code != MFW_DCS_UCS2)
2525 return NULL;
2526
2527 /* allocate sufficient space for the converted string */
2528 if (txt->code == MFW_DCS_7bits)
2529 size = SAT_LEN_SIZE + ((txt->len*8)/7)*sizeof(char) + SAT_TERMINATOR_SIZE;
2530 else
2531 size = SAT_LEN_SIZE + txt->len*sizeof(char) + SAT_TERMINATOR_SIZE;
2532 res = (char *)ALLOC_MEMORY (size);
2533 *(U16 *) res = size; /* store allocated size in first 2 bytes (for deallocation purposes) */
2534 res += SAT_LEN_SIZE, /* set the pointer to the string, not to the alloc size */
2535
2536 /* convert the string */
2537 sat_TEXT_to_ASCIIZ (res, txt);
2538
2539
2540 return res;
2541 }
2542
2543 /*******************************************************************************
2544
2545 $Function: sat_create_TEXT_UCODE
2546
2547 $Description: This routine creates out of an MFW SAT text descriptor an
2548 dynamically allocated UCS2 string pointer
2549
2550 $Returns: none.
2551
2552 $Arguments:
2553
2554 *******************************************************************************/
2555 /*JVJE*/
2556 /*MC, SPR 940/2 uncommneted and then re-written function, pointers to wide chars now are pointers to chars*/
2557 char* sat_create_TEXT_UCODE (T_SAT_TXT * txt)
2558 {
2559 char * res;
2560 U16 size;
2561
2562 TRACE_EVENT("sat_create_TEXT_UCODE()");
2563
2564 if (txt->code == MFW_DCS_7bits) /*MC SPR 1086, add 2 extra chars in case UCS2 tag is to be added later*/
2565 size = SAT_LEN_SIZE + sizeof(char) + ((txt->len*8)/7) * /*sizeof(wchar_t)*/2+SAT_TERMINATOR_SIZE*2;
2566 else /*MC SPR 1086, add 2 extra chars in case UCS2 tag is to be added later*/
2567 //size = SAT_LEN_SIZE + sizeof(char) + txt->len * /*sizeof(wchar_t)*/2+SAT_TERMINATOR_SIZE*2;
2568 size = SAT_LEN_SIZE + (sizeof(U16) * txt->len) + SAT_TERMINATOR_SIZE*2; /* SPR#2321 - DS - Improve clarity of mem alloc */
2569 res = (char *)ALLOC_MEMORY (size);
2570 *(U16 *)res = size;
2571 res = ((char *)res + SAT_LEN_SIZE);
2572
2573 TRACE_EVENT_P1("size: %d", size);
2574
2575 sat_TEXT_to_UCODE (res,size, txt);
2576
2577 return res;
2578 }
2579
2580
2581 /*******************************************************************************
2582
2583 $Function: sat_create_ITEM_ASCIIZ
2584
2585 $Description: This routine converts a MFW SAT Item descriptor into a
2586 conventional String pointer
2587 MC, note: this function will add a Unicode tag to the beginning of Unicode
2588 strings returned
2589
2590 $Returns: none.
2591
2592 $Arguments:
2593
2594 *******************************************************************************/
2595 /*MC, SPR 940/2 changed this func to output Unicode string when appropriate*/
2596 extern char * sat_create_ITEM_ASCIIZ (SatItem * item)
2597 {
2598 char * res;
2599 U16 size;
2600 UBYTE first_char= *((UBYTE*)item+item->text);
2601
2602 TRACE_FUNCTION("sat_create_ITEM_ASCIIZ()");
2603
2604 TRACE_EVENT_P2("first_char:%d len: %d", first_char, item->len);
2605
2606 /* SPR#2321 - DS - Return NULL if string length is zero */
2607 if (item->len == 0)
2608 {
2609 //return NULL;//sandip-CQ 16306
2610 *((UBYTE*)item+item->text) = 0x20;
2611 }
2612
2613 /* SPR#2321 - DS - SAT has sent a NULL string. Set first char to ASCII code for <space> */
2614 if ((item->len == 1) && (first_char == 0x00))
2615 {
2616 *((UBYTE*)item+item->text) = 0x20;
2617 }
2618
2619 /* allocate sufficient space for the converted string */
2620 size = SAT_LEN_SIZE + item->len/**sizeof(wchar_t)*/*2 + 3*SAT_TERMINATOR_SIZE;
2621 res = (char *)ALLOC_MEMORY (size);
2622 *(U16 *) res = size; /* store allocated size in first 2 bytes (for deallocation purposes) */
2623 res += SAT_LEN_SIZE; /* set the pointer to the string, not to the alloc size */
2624
2625 /*
2626 * item->text is offset of string from start of item
2627 */
2628 #ifdef NO_ASCIIZ /*MC SPR 940/2 check if we're in Chinese or string is unicode and deal with it*/
2629
2630 if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)/*if chinese*/
2631 {
2632 #ifdef SAT_TEXT_TRACING
2633 /***************************Go-lite Optimization changes Start***********************/
2634 //Aug 16, 2004 REF: CRR 24323 Deepa M.D
2635 TRACE_EVENT_P1("Length of menu item:%d", item->len);
2636 /***************************Go-lite Optimization changes end***********************/
2637 #endif
2638 if (*((char*)item+item->text) != 0x80)/*MC, if item ASCII*/
2639 { // int i; // RAVI
2640 /*convert to unicode*/
2641 TRACE_EVENT("Adding menu item in ASCII->UCS2");
2642 // SmsRead_convertSMSmsg((char *)item + item->text, MFW_DCS_8bits, item->len, &res[2], MFW_DCS_UCS2, size-4, FALSE);
2643 // res[0] = 0x80;/*add tag to beginning of string*/
2644 // res[1] =0x7F;
2645 /*MC, SPR 1086 8 bit to UCS2 conversion causes menu update problems*/
2646 /*Thought it might be due to memory leaks/overwrites, but can't find any*/
2647 /*Easy solution is to convert to ASCII rather than UCS2*/
2648 sat_gsm_to_ascii (res, (char *)item + item->text, item->len);
2649 }
2650 else /*if Unicode tag*/
2651 { TRACE_EVENT("Adding menu item in UCS2");
2652 /*Shift string up one byte*/
2653 memcpy(res+2, (char *)item + item->text+1, item->len-1);
2654 res[0] = 0x80;/*add tag at beginning of string*/
2655 res[1] = 0x7f;
2656 }
2657 }
2658 else /*if not chinese BUT unicode tag, convert to display Unicode format*/
2659 { if (*((char*)item+item->text) == 0x80)
2660 { memcpy(res+2, (char *)item + item->text+1, item->len-1);
2661 res[0] = 0x80;
2662 res[1] = 0x7f;
2663 }
2664
2665 else /*if not chinese and ascii string, convert from GSM to ASCII*/
2666 #endif
2667 sat_gsm_to_ascii (res, (char *)item + item->text, item->len);
2668 #ifdef NO_ASCIIZ
2669 }
2670 #endif
2671
2672
2673 return res;
2674 }
2675
2676 /*******************************************************************************
2677
2678 $Function: sat_destroy_TEXT_ASCIIZ
2679
2680 $Description: destroy an ASCIIZ string previously created with
2681 sat_create_TEXT_ASCIIZ() or sat_create_ITEM_ASCIIZ()
2682
2683 $Returns: none.
2684
2685 $Arguments:
2686
2687 *******************************************************************************/
2688 void sat_destroy_TEXT_ASCIIZ (char * str)
2689 {
2690 /*MC, SPR 940/2 if we're in chinese, use Unicode string destuctor*/
2691 if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
2692 { sat_destroy_TEXT_UCODE(str);
2693 return;
2694 }
2695
2696 TRACE_FUNCTION("sat_destroy_TEXT_ASCIIZ");
2697
2698 if (str NEQ NULL)
2699 {
2700 /* the two bytes before the string are holding the alloc size info */
2701 FREE_MEMORY ((U8 *)(str-SAT_LEN_SIZE), *(U16 *) (str-SAT_LEN_SIZE));
2702 str = NULL;
2703 }
2704 }
2705
2706 #ifdef MMI_TEST_SAT_LAUNCH_BROWSER
2707 void mmiOpenDummyBrowser(T_MFW_HND win,char* information)
2708 {
2709 #ifdef NEW_EDITOR
2710 T_AUI_EDITOR_DATA editor_data; /* SPR#1428 - SH - New Editor data */
2711 #else
2712 T_EDITOR_DATA editor_data;
2713 #endif
2714
2715 TRACE_FUNCTION("mmiOpenDummyBrowser");
2716
2717 /* SPR#1428 - SH - New Editor changes */
2718
2719 #ifdef NEW_EDITOR
2720 AUI_edit_SetDefault(&editor_data);
2721 AUI_edit_SetTextStr(&editor_data, TxtNull, TxtNull, TxtNull, NULL);
2722 AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, (UBYTE *)information, INFORMATION_SIZE);
2723 AUI_edit_SetMode(&editor_data, ED_MODE_READONLY, ED_CURSOR_NONE);
2724
2725 AUI_edit_Start(win, &editor_data);
2726 #else /* NEW_EDITOR */
2727
2728 #ifdef DBG1
2729 editor_data_init();
2730 #endif
2731 editor_data.TextString = "WAP";
2732 editor_data.LeftSoftKey = TxtSoftOK;
2733 editor_data.RightSoftKey = NULL;
2734 editor_data.AlternateLeftSoftKey = NULL;
2735 editor_data.Callback = NULL;
2736 editor_data.Identifier = 0;
2737 editor_data.hide = FALSE;
2738 editor_data.mode = READ_ONLY_MODE;
2739 editor_data.timeout = FOREVER;
2740 editor_data.min_enter = 0;
2741 editor_data.destroyEditor = TRUE;
2742 editor_data.editor_attr.win.px = 0;
2743 editor_data.editor_attr.win.py = 8;
2744 editor_data.editor_attr.win.sx = 84;
2745 editor_data.editor_attr.win.sy = 24;
2746 editor_data.editor_attr.font = 0;
2747 editor_data.editor_attr.mode = edtCurNone;
2748 editor_data.editor_attr.controls = 0;
2749 editor_data.editor_attr.size = INFORMATION_SIZE;
2750
2751 editor_data.editor_attr.text = information;
2752
2753 /* create the dialog handler */
2754 editor_start(win, &editor_data); /* start the editor */
2755 #endif
2756
2757 return;
2758 }
2759
2760 #endif
2761 //GW SPR#1035 - Added SAT changes
2762 /*******************************************************************************
2763
2764 $Function: sat_release_the_editor
2765
2766 $Description: The SAT-application initiate a setup call and
2767 the MMI opens for this call status a new editor.
2768 Normally the event "SAT_SESSION_END" release the editor
2769 but for some reason this event doesnt come up !
2770 This function allows from the MMICall.c in the case of "disconnect"
2771 to release the editor as well.
2772
2773 $Returns: none.
2774
2775 $Arguments:
2776
2777 *******************************************************************************/
2778 void sat_release_the_editor (void)
2779 {
2780 TRACE_FUNCTION("sat_release_the_editor()");
2781
2782 if (g_sim_toolkit_data->info_win NEQ NULL)
2783 {
2784 /* destroy any infoscreen if exist */
2785 /* SPR#1428 - SH - New Editor changes */
2786 #ifdef NEW_EDITOR
2787 SEND_EVENT (g_sim_toolkit_data->info_win, E_ED_DEINIT, 0, NULL);
2788 #else /* NEW_EDITOR */
2789 SEND_EVENT (g_sim_toolkit_data->info_win, E_EDITOR_DEINIT, 0, NULL);
2790 #endif /* NEW_EDITOR */
2791 g_sim_toolkit_data->info_win = NULL;
2792 }
2793 }
2794
2795 /*MC, SPR 940/2 uncommented function and changed param to char* */
2796 void sat_destroy_TEXT_UCODE (/*cp_wstring_t*/char* str)
2797 {
2798 if (str NEQ NULL)
2799 {
2800 FREE_MEMORY ((U8 *)((char *)str-SAT_LEN_SIZE), *(U16 *) ((char *)str-SAT_LEN_SIZE));
2801 str = NULL;
2802 }
2803 }
2804 /*******************************************************************************
2805
2806 $Function: sat_add_unicode_tag_if_needed
2807
2808 $Description: Checks if string ought to be pre-pended with a unicode tag and if it ought to,
2809 adds the tag (note, the string has to already have 2 "extra" chars allocated
2810 to it; this normally happens in the create_TEXT_UCODE function)
2811
2812 $Returns: none.
2813
2814 $Arguments: string
2815
2816 *******************************************************************************/
2817 /*SPR1257, new function*/
2818 void sat_add_unicode_tag_if_needed(char* string)
2819 {/*Add tag to Unicode strings so info dialogue displays them correctly*/
2820 if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE&& string[0]!=0x80 )
2821 {
2822 char TempString[MAX_MSG_LEN_SGL];/*MC, SPR 1292, more sensible length*/
2823 #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes - new function to calculate length of unicode string */
2824 memcpy(&TempString[2], GET_TEXT(TxtSoftCall), ATB_string_UCLength((USHORT*)string)*sizeof(USHORT));
2825 #else /* NEW_EDITOR */
2826 memcpy(&TempString[2], string, strlenUnicode((U16*) string));
2827 #endif /* NEW_EDITOR */
2828
2829 TempString[0] = 0x80;
2830 TempString[1] = 0x7f;
2831 #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes - new function to calculate length of unicode string */
2832 memcpy(string, TempString, (ATB_string_UCLength((USHORT*)TempString)+1)*sizeof(USHORT));
2833 #else /* NEW_EDITOR */
2834 memcpy( string, TempString, strlenUnicode((U16*)TempString));
2835 #endif /* NEW_EDITOR */
2836
2837 }
2838 }
2839
2840 /*******************************************************************************
2841
2842 $Function: set_sat_redial_flag
2843
2844 $Description: Sets the SAT call 'with redial' flag.
2845
2846 $Returns: none.
2847
2848 $Arguments: Value to set flag to.
2849
2850 $History: SPR#1784 - DS - Created function.
2851
2852 *******************************************************************************/
2853 void set_sat_redial_flag(UBYTE flag)
2854 {
2855 TRACE_FUNCTION("set_sat_redial_flag()");
2856
2857 TRACE_EVENT_P1("flag %d", flag);
2858
2859 g_sim_toolkit_data->satCallWithRedial = flag;
2860 }
2861
2862 /*******************************************************************************
2863
2864 $Function: get_sat_redial_flag
2865
2866 $Description: Gets the value of the SAT call 'with redial' flag.
2867
2868 $Returns: current value of redial flag.
2869
2870 $Arguments: none.
2871
2872 $History: SPR#1784 - DS - Created function.
2873
2874 *******************************************************************************/
2875 UBYTE get_sat_redial_flag(void)
2876 {
2877 TRACE_FUNCTION("get_sat_redial_flag");
2878
2879 return (g_sim_toolkit_data->satCallWithRedial);
2880 }
2881