view g23m/condat/ms/src/bmi/mmiSmsRead.c @ 73:9db082cacbeb

l1_cmplx.c: l1s_read_fb() reconstructed
author Mychaela Falconia <falcon@ivan.Harhan.ORG>
date Mon, 28 Mar 2016 05:42:52 +0000
parents 509db1a7b7b8
children
line wrap: on
line source

/*******************************************************************************

					CONDAT (UK)

********************************************************************************                                                                              

 This software product is the property of Condat (UK) Ltd and may not be
 disclosed to any third party without the express permission of the owner.                                 
                                                                              
********************************************************************************

 $Project name:	Basic MMI                                                      
 $Project code:	BMI                                                            
 $Module:		SMS
 $File:		    MmiSmsRead.c
 $Revision:		1.0                                                       
                                                                              
 $Author:		Condat(UK)                                                         
 $Date:		    25/10/00                                                      
                                                                               
********************************************************************************
                                                                              
 Description:
 
    Shared definitions of data elements are made in here
    and accessed via the primitive operations supplied
                        
********************************************************************************

 $History: MmiSmsRead.c

       Feb 07, 2006    DR: OMAPS00059261 x0pleela
   	Description: SMS is not forwarding STATUS reports that are read from SIM storage to ACI 
   	Solution: smsread_r_exec_cb(): avoiding display of sender's address in header for status reports during listing
   			smsread_getstatustext():renamed txtreport to txtreport
   			Replaced MT_STATUS_RPT with MFW_SMS_STATRPT as MT_STATUS_RPT is removed

      	Feb 01, 2006    DR: OMAPS00059261 x0pleela
   	Description: SMS is not forwarding STATUS reports that are read from SIM storage to ACI 
   	Solution: Added a check for Status report to display a text "Report:Pending" during listing of this message
			Made changes as per review comments
   	
      	Jan 30, 2006    DR: OMAPS00059261 x0pleela
   	Description: SMS is not forwarding STATUS reports that are read from SIM storage to ACI 
   	Solution: Added code to read and display MT Status report
 	
	Mar 28, 2006    MMI-FIX-47813 x0035544
   	Description: Not Available transient screen is displayed when Extract number option is selected 
   	in messages option screen.
   	Solution: The necessary functionality is provided to extract the numbers in a message and display 
   	them appropriately.
   	
 	May 27, 2005    MMI-FIX-29869 x0018858
   	Description: There is a limitation on the number of messages that can be downloaded from 
   	server even though there is space on the sim.
   	Solution: The limitation has been removed and the number of messages that can be dowloaded
   	has been modified to the masimum number that can be stored.

       March 2, 2005    REF: CRR 11536 x0018858
       Description: Reply path not supported while sending a reply.
       Solution: Added menu option for the reply path.

       Feb 16, 2005 REF: CRR MMI-SPR-27900 xnkulkar 
  	Issue description:  BMI: using the tool nowSMS the voicemail indication via sms does not work
  	Solution: Instead of identifying voice using addr[0] and pid, we use dcs. Also, messages belonging
  	              to group "1100" are deleted when voicemail icon is displayed.

 	Feb 16, 2005 REF: CRR 28966 x0012851
 	Description: Editing or forwarding of large MT messages (>160 characters) 
 				shouldn't be allowed when Concatenation is set to 'OFF'
 	Solution: If the 'ConcatenateStatus' flag is FALSE, the 'if' check condition
 				which allows the message to be edited or forwarded has been 
 				modified for the same.

	Dec 15,2004 REF: CRR 24396 xkundadu
	Description: Phone crashes when a message is received while the 
			    'List Empty' dialog is displayed.
	Solution: NULL check is added for the list_win handle before calling 
			listsDestroy() when an MT sms is receieved.
 
	 Dec 01, 2004   REF: CRR 24225 xnkulkar
	 Description: Reset when forwarding SMS
	 Solution: The message content is sent excluding the date/time info from the 
	               original message, which was causing the reset as the max limit (161) was crossed.
 	
	 Sep 08, 2004    REF: CRR 24393  Deepa M. D
	 Bug:Phone crashes when user tries to reply to a saved message in the Inbox
	 Fix:The reply and Callnumber Option has been removed for the saved message.
	25/10/00			Original Condat(UK) BMI version.	
	14/10/00			SPR 1257 - merged in issue 888 from b-sample line (extract
						number from SMS improvements) and made changes to accommodate
						Unicode SMSs containing numbers. 
	May 03, 2004    REF: CRR 13845  Deepa M
	The  Forward menuitem added.
 $End

*******************************************************************************/

#define MMI_SMSREAD_C

#define ENTITY_MFW

/* includes */
#include <string.h>
#include <stdio.h>
#include <stdlib.h>

#if defined (NEW_FRAME)

#include "typedefs.h"
#include "vsi.h"
#include "pei.h"
#include "custom.h"
#include "gsm.h"

#else

#include "STDDEFS.H"
#include "custom.h"
#include "gsm.h"
#include "vsi.h"

#endif
#include "prim.h"


#include "mfw_mfw.h"
#include "mfw_win.h"
#include "mfw_kbd.h"
/* SPR#1428 - SH - New Editor changes */
#ifndef NEW_EDITOR
#include "mfw_edt.h"
#endif
#include "mfw_tim.h"
#include "mfw_phb.h"
#include "ksd.h"
#include "psa.h"
#include "mfw_sms.h"
#include "mfw_smsi.h"
#include "mfw_icn.h"
#include "mfw_mnu.h"
#include "mfw_lng.h"
#include "mfw_sat.h"
#include "mfw_kbd.h"
#include "mfw_nm.h"
#include "mfw_mme.h"

#include "psa_util.h"

#include "dspl.h"

#include "MmiMain.h"
#include "MmiDummy.h"
#include "MmiMmi.h"
#include "mmiCall.h"//GW 29/11/01 for 'callNumber'

#include "MmiDialogs.h"
#include "MmiLists.h"
#include "MmiMenu.h"
#include "MmiSoftKeys.h"
/* SPR#1428 - SH - New Editor changes */
#ifdef NEW_EDITOR
#include "ATBCommon.h"
#include "ATBDisplay.h"
#include "ATBEditor.h"
#include "AUIEditor.h"
#else
#include "MmiEditor.h"
#endif
#include "MmiBookShared.h" // MZ 
#include "mmiSmsMenu.h"
#include "mmismssend.h"
#include "mmiSmsRead.h"
#include "mmiSmsIdle.h"
#include "MmiResources.h"/*MC*/
#include "mfw_ffs.h"

#include "cus_aci.h"

#include "prim.h"
#ifndef PCM_2_FFS
#include "pcm.h"
#endif


#include "message.h"
#include "prim.h"
#include "aci_cmh.h"	//GW 29/11/01 added for types in aci_fd.h
#include "aci_fd.h"		//GW 29/11/01 added for types in 'cmh.h'
#include "cmh.h" 		//GW 29/11/01 added for types in 'cmh_phb.h'
#include "cmh_phb.h"	//GW 29/11/01 added for cmhPHB_getAdrStr

#include "mmiColours.h"
#include "audio.h"
//GW 29/11/01 - added header file - removed extern void callNumber(UBYTE* number);
MfwWin* getWinData( MfwHnd win);

/*SPR 1453*/
#ifdef LSCREEN
#define UCS2_MENU_TEXT_LEN ((MFW_TAG_LEN +10)*2 +4)/*SPR 2686 only need name+status text*/
#else
#define UCS2_MENU_TEXT_LEN 36 /*mc SPR 1242, no of bytes in latin unicode string which fills one whole line*/ 
#endif

#define MAX_EDITOR_HEADER_LENGTH 25

// Dec 01, 2004   REF: CRR 24225 xnkulkar
// Description: Reset when forwarding SMS
// Added to exclude the original date/time info from forwarded message
#define ORIGINAL_DATE_TIME_INFO 17
//Mar 28, 2006 DR:OMAPS00047813 x0035544
#define MAX_NUMBER_SIZE 10 //Max Size of the number array to hold the extracted numbers
#define MIN_NUM_LENGTH 3 //minimum length of the number to be extracted.

// Feb 16, 2005 REF: CRR MMI-SPR-27900 xnkulkar 
extern BOOL invalidVm;

extern UBYTE reply_path_bit;
/*********************************************************************

				 DYNAMIC MENU WINDOW. DECLARATION

**********************************************************************/

typedef enum
{
    E_DELETE,
    E_REPLY,
    E_CALL_SENDER,
    E_SAVE_NUMBER,
    E_DATE_TIME,
    E_FORWARD
};

// Those information are passed to the sms editor
typedef struct
{
	SHORT          sms_index;
	T_MMI_SMS_STAT sms_type;
	T_MFW_SMS_PARA *sms_info;
	char *assoc_name;
}T_SMS_EDITOR_DATA;


/* This variable is used to know in which state we are when MFW callback function is called */
typedef struct
{
	SHORT nb_sms_stored;
	/*SPR 2530, need more info than just indexes*/
	
//    May 27, 2005    MMI-FIX-29869 x0018858
//   	Description: There is a limitation on the number of messages that can be downloaded from 
//   	server even though there is space on the sim.
//   	Solution: The limitation has been removed and the number of messages that can be dowloaded
//   	has been modified to the maximum number that can be stored.
#ifdef FF_MMI_SMS_DYNAMIC
	T_MFW_SMS_MSG* sms_messages; /* store info about the SMS: index... */

//    May 27, 2005    MMI-FIX-29869 x0018858
//   	Changed from static to dynamic
	wstring_t** sms_header; /* header displayed in the dynamic menu */
#else  
	T_MFW_SMS_MSG sms_messages[MAX_MESSAGES]; /* store info about the SMS: index... */
	wstring_t* sms_header[MAX_MESSAGES]; /* header displayed in the dynamic menu */
#endif
}T_SMS_LIST_DATA;

typedef struct
{
    /* administrative data */

    T_MMI_CONTROL   mmi_control;
    T_MFW_HND       win;
    SHORT           id;
    T_MFW_HND       parent;

    /* associated handlers */

    T_MFW_HND       sms_handle;         /* MFW sms handler      */

    /* internal data */
	T_SMS_LIST_DATA sms_list_data;
	T_SMS_EDITOR_DATA sms_editor_data;
	ListMenuData *menu_list_data;
	/*SPR 2686, removed unused data field*/

} T_SMSREAD_R;
T_SMSREAD_R* getUserData_T_SMSREAD_R( T_MFW_WIN *win)
{
	if (win == NULL)
		return (NULL);
	return((T_SMSREAD_R *)win->user);
}


typedef struct
{
    /* administrative data */

    T_MMI_CONTROL   mmi_control;
    T_MFW_HND       win;
    SHORT           id;
    T_MFW_HND       parent;
    T_MFW_HND       editor_win;

    /* associated handlers */


    /* internal data */
	T_SMS_EDITOR_DATA *sms_editor_data;
/*SPR 2686, removed unused data field*/
} T_SMSREAD_R_TEXTEDT2;

T_SMSREAD_R_TEXTEDT2* getUserData_T_SMSREAD_R_TEXTEDT2( T_MFW_WIN *win)
{
	if (win == NULL)
		return (NULL);
	return((T_SMSREAD_R_TEXTEDT2 *)win->user);
}



typedef struct
{
    /* administrative data */

    T_MMI_CONTROL   mmi_control;
    T_MFW_HND       win;
    SHORT           id;
    T_MFW_HND       parent;

    /* associated handlers */

    /* !!! **************************************** modify here **************************************** !!!*/
    T_MFW_HND       kbd;
    T_MFW_HND       kbd_long;
    T_MFW_HND       menu;
    /* !!! **************************************** end modify here **************************************** !!! */

    /* internal data */

    /* !!! **************************************** modify here **************************************** !!!*/
/*SPR 2686, removed unused data field*/
	T_MFW_HND		sms;
    T_MFW_HND       dialog_win;

    /* !!! **************************************** end modify here **************************************** !!! */
	T_SMS_EDITOR_DATA *sms_editor_data;    //NM 25.8
} T_SMSREAD_R_OPT;
T_SMSREAD_R_OPT* getUserData_T_SMSREAD_R_OPT( T_MFW_WIN *win)
{
	if (win == NULL)
		return (NULL);
	return((T_SMSREAD_R_OPT *)win->user);
}





static enum
{
	READ_SMS_LIST,
	READ_SELECTED_SMS
} g_sms_state;	

//MZ 7/02/01 tmp enums.
static enum
{
	MFW_MB_LINE1,
	MFW_MB_DATA
}mfw_mailBox_type;

/*MC SPR2175, removed alphabet conversion tables which are now in ATBCommon.c*/

static const MfwMnuAttr readSMS_menuAttrib =
{
    &readSMS_menuArea,
    MNU_LEFT | MNU_LIST | MNU_CUR_LINE, /* centered page menu       */
    -1,                                 /* use default font         */
    NULL,                               /* with these items         */
    0,                                   /* number of items     */
	COLOUR_LIST_SMS,
	TxtMessages,
	NULL, 
	MNUATTRSPARE

};

//Mar 28, 2006 DR:OMAPS00047813 x0035544
/*default static menu*/
static const MfwMnuAttr menuSearchNumListAttr =
{
	&menuArea,
	MNU_LEFT | MNU_LIST | MNU_CUR_LINE,		/* centered page menu */
	-1,										/* use default font  */
	NULL,									/* with these items (filled in later) */
	0,										/* number of items (filled in leter)  

*/
	COLOUR_LIST_XX,							/* Colour */
	TxtExtractNumber,								/* Hdr Id */
	NULL,									/* Background */
	MNUATTRSPARE							/* unused */
};



static SHORT g_sms_list_counter;

static SHORT g_nb_line_sms;
static int search_index;	/* SPR888 - SH - keeps track of position within SMS for extract number */

static  T_MFW_HND       info_win=0;
static T_MFW_HND        deleting_win = 0;
static  T_MFW_HND       list_win=0;
static T_MFW_HND		sms_read_win = 0;/*MC 1991 main SMS read window*/
static T_MFW_HND 		message_win = 0; /*MC 2132, individual message display win*/
static T_MFW_HND        option_mnu_win = 0;/*MC 2132, options menu window*/

static char sms_text_ascii[MAX_EDITOR_LEN];

/* we need this variable "read_status" to know which sms message we are going
   to edit (user pressed in the sms menu-> EDIT)
   because SMS_MT & SMS_MO have different size of character 
   (current length saved in "current_sms_len") !!
   SMS_MT includes additional TIME, DATE and NUMBER and we dont want
   to show it when we are editing.
*/
static UBYTE read_status;
static USHORT current_sms_len= 0;

//	Dec 15,2004 REF: CRR 24396 xkundadu
//	Description: Phone crashes when a message is received while the 
//			    'List Empty' dialog is displayed.
//	Solution: NULL check is added for the list_win handle before calling 
//			listsDestroy() function  when an MT sms is receieved.

// This checks whether the 'List Empty' dialog is present or not.
static BOOL SmsListEmptyDlgPresent = 0;

static T_SmsUserData   SmsData;
int SmsRead_GetStatusText( char* op_text_str, int status); // RAVI
static T_MFW_HND smsRead_NumberName_info_screen(T_MFW_HND parent_window, T_SmsUserData *UserData,char* name);
UBYTE check_assoc_name(char *name, T_MFW_SMS_ADDR sms_addr);


static T_MFW_HND SmsRead_R_OPT_create (T_MFW_HND parent);
static void SmsRead_R_OPT_destroy (T_MFW_HND window);
static void SmsRead_R_OPT_StandardDialog(T_MFW_HND win, char *text, ULONG duration);
static void SmsRead_R_OPT_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter);
static int SmsRead_R_OPT_win_cb (MfwEvt e, MfwWin *w);
static int SmsRead_R_OPT_mfw_cb (MfwEvt event, void *parameter);
static int SmsRead_R_OPT_dialog_cb(T_MFW_HND win, USHORT Identifier, USHORT Reason);
static int SmsRead_R_OPT_kbd_cb (MfwEvt e, MfwKbd *k);
static int SmsRead_R_OPT_mnu_cb (MfwEvt e, MfwMnu *m);
static int SmsRead_R_OPTExeDelete(MfwMnu* m, MfwMnuItem* i);
static int SmsRead_R_OPTExeReply(MfwMnu* m, MfwMnuItem* i);
static int SmsRead_R_OPTExeStoreNumber(MfwMnu* m, MfwMnuItem* i);
void SmsRead_StoreNumber(void);
static int SmsRead_R_OPTExeEdit(MfwMnu* m, MfwMnuItem* i);

/*SPR 2530,, old code which displays the contents of the SMS messages in the SMS list
has been compiled out using the macro ORIGINAL_SMS_LIST.  
If ORGINAL_SMS_LIST is defined, then the old list is shown, otherwise the new kind of SMS
list is shown*/


/*SPR 2530,compiled out unused global vars*/
#ifdef ORIGINAL_SMS_LIST
static SHORT g_sms_list_counter;

static SHORT g_nb_line_sms;
#endif
T_MFW_HND retry_handle;/*handle for the timer to retry reading an SMS. */
int retry_index=0;/*index of message we're trying to read again.*/
void retry_sms_read(int index);		
int retry_sms_read_tim_cb(MfwEvt event, MfwTim *timer_info);

/* R is the identifier used for the function of the Read menu window */
static T_MFW_HND SmsRead_R_create (T_MFW_HND parent);
static void SmsRead_R_destroy (T_MFW_HND window);
static void SmsRead_R_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter);
static int SmsRead_R_win_cb (MfwEvt e, MfwWin *w);
static int SmsRead_R_mfw_cb(MfwEvt event, void *parameter);
static int SmsRead_R_dialog_cb(T_MFW_HND win, USHORT Identifier, USHORT Reason);
static void SmsRead_R_smslist_cb(T_MFW_HND * Parent, ListMenuData * ListData);
static void SmsRead_R_BuildList(T_MFW_HND win,int inUnicode);

// Fill an unicode structure for display
void string_CopyW2W(wstring_t *strDestination, charw_t *strSource, USHORT count );


static T_MFW_HND SmsRead_R_TEXTEDT2_create (T_MFW_HND parent);
static void SmsRead_R_TEXTEDT2_destroy (T_MFW_HND window);
static void SmsRead_R_TEXTEDT2_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter);
static int SmsRead_R_TEXTEDT2_win_cb (MfwEvt e, MfwWin *w);
static void SmsRead_R_TEXTEDT2_editor_cb(T_MFW_HND win, USHORT Identifier, USHORT Reason);
static void SmsRead_R_TEXTEDT2_smslist_cb(T_MFW_HND * Parent, ListMenuData * ListData);



static BOOL Search_forNextNumber(T_SmsUserData *UserData);
//Mar 27, 2006 DR:OMAPS00047813 x0035544
static void SmsRead_numlist_destroy(MfwHnd own_window);
static void SmsRead_numlist_cb(T_MFW_HND Parent, ListMenuData * ListData);
void smsread_numlist_exec_cb (T_MFW_HND win, USHORT event);
static T_MFW_HND SmsRead_BuildNumList_Menu(T_MFW_HND win);
static int smsread_numlist_win_cb (MfwEvt e, MfwWin *w);
void Search_forNumberInSMS(T_SmsUserData *UserData);


//Mar 24, 2006 REF: SPR 47813 x0035544
static int smsread_num_ctr;
static char **num_buffer=NULL;

static  const MfwMnuItem SmsRead_R_OPTItems [] =
{
    {0,0,0,(char *)TxtDelete,0,(MenuFunc)SmsRead_R_OPTExeDelete,item_flag_none},
    {0,0,0,(char *)TxtReply,0,(MenuFunc)SmsRead_R_OPTExeReply,item_flag_none},
    {0,0,0,(char *)TxtEdit,0,(MenuFunc)SmsRead_R_OPTExeEdit,item_flag_none},
    {0,0,0,(char *)TxtForward,0,(MenuFunc)SmsRead_R_OPTExeEdit,item_flag_none},//May 03, 2004    REF: CRR 13845  Deepa M -Menu item to forward SMS
    {0,0,0,(char *)TxtExtractNumber,0,(MenuFunc)SmsRead_R_OPTExeStoreNumber,item_flag_none},
    {0,0,0,(char *)TxtCallNumber,0,(MenuFunc)SmsRead_StoreNumber,item_flag_none}
};

static  const MfwMnuAttr SmsRead_R_OPTAttrib =
{
    &SmsRead_R_OPTArea,
    MNU_LEFT | MNU_LIST | MNU_CUR_LINE, /* centered page menu       */
    -1,                                 /* use default font         */
    (MfwMnuItem*) SmsRead_R_OPTItems,                      /* with these items         */
    sizeof(SmsRead_R_OPTItems)/sizeof(MfwMnuItem) /* number of items     */
};

//Sep 08, 2004    REF: CRR 24393  Deepa M. D
//New menu item for the saved/unsent messages.
static  const MfwMnuItem SmsRead_R_Unsent_OPTItems [] =
{
    {0,0,0,(char *)TxtDelete,0,(MenuFunc)SmsRead_R_OPTExeDelete,item_flag_none},
    {0,0,0,(char *)TxtEdit,0,(MenuFunc)SmsRead_R_OPTExeEdit,item_flag_none},
	{0,0,0,(char *)TxtForward,0,(MenuFunc)SmsRead_R_OPTExeEdit,item_flag_none},
    {0,0,0,(char *)TxtExtractNumber,0,(MenuFunc)SmsRead_R_OPTExeStoreNumber,item_flag_none},
    
};

//Sep 08, 2004    REF: CRR 24393  Deepa M. D
//Menu attributes for the saved/unsent messages.
static  const MfwMnuAttr SmsRead_R_Unsent_OPTAttrib =
{
    &SmsRead_R_OPTArea,
    MNU_LEFT | MNU_LIST | MNU_CUR_LINE, /* centered page menu       */
    -1,                                 /* use default font         */
    (MfwMnuItem*) SmsRead_R_Unsent_OPTItems,                      /* with these items         */
    sizeof(SmsRead_R_Unsent_OPTItems)/sizeof(MfwMnuItem) /* number of items     */
};



/*******************************************************************************

 $Function:    	charPtrToUBYTEPtr

 $Description:	Converts a char ptr to a UBYTE ptr. The procedures can be replaced by macro 
 				once all conversions are confirmed as valid.
 				
 $Returns:		data set to new type

 $Arguments:	data -data item of input type.
 
*******************************************************************************/
#ifndef MMI_USE_MACROS
UBYTE 	charToUBYTE				( char chr )	{	return((UBYTE)chr);		}
UBYTE* 	charPtrToUBYTEPtr		( char *ptr )	{	return((UBYTE*)ptr);	}
UBYTE 	SHORTToUBYTE			( SHORT data )	{	return((UBYTE)data);	}

char	UBYTEToChar				( UBYTE data)	{	return((char)data);		}
char*	UBYTEPtrToCharPtr		( UBYTE* data)	{	return((char*)data);	}
char*	USHORTPtrToCharPtr	( USHORT* data)	{	return((char*)data);		}

USHORT 	charToUSHORT			( char chr )	{	return((USHORT)chr);	}
USHORT	UBYTEToUSHORT			( UBYTE data)	{	return((USHORT)data);	}
USHORT*	charPtrToUSHORTPtr	(char* data)		{	return((USHORT*)data);	}

#else
#define 	charToUBYTE			(UBYTE)
#define 	charPtrToUBYTEPtr	(UBYTE*)
#define 	SHORTToUBYTE		(UBYTE)	

#define		UBYTEPtrToCharPtr	(char*)
#define		UBYTEToChar			(char)
#define		USHORTPtrToCharPtr	(char*)

#define 	charToUSHORT		(USHORT)	
#define 	UBYTEToUSHORT		(USHORT)
#define		charPtrToUSHORTPtr	(USHORT*)
#endif
/*MC SPR2175, removed GSM<->ASCII<->UCS2 conversion functions, moved to ATBCommon*/

/**/

/*******************************************************************************

 $Function:    	SmsRead_R_start

 $Description:	Start the creation of the main window for SMS reading
 
 $Returns:		mfw window handler 

 $Arguments:	parent_window - Parent window handler
 				menuAttr	  - Menu attributes.
 
*******************************************************************************/
T_MFW_HND SmsRead_R_start(T_MFW_HND parent_window, MfwMnuAttr *menuAttr)
{
   TRACE_EVENT_P1("sms_read_win:%d", sms_read_win);
    /*SPR2132, if the list window already exists, destroy it before creating a new one*/
	if (sms_read_win != NULL)
		SmsRead_R_destroy(sms_read_win);
	
    TRACE_FUNCTION ("SmsRead_R_start()");
	/*SPR 1991 use ssms_read_win rather than a local var*/
    sms_read_win = SmsRead_R_create (parent_window);

    if (sms_read_win NEQ NULL)
	{
		/* We transmit to the SMS editor the address of the data buffer */
	    SEND_EVENT (sms_read_win, E_INIT, SmsRead_R_ID, (void *)menuAttr);
	}
    return sms_read_win;
}

/*******************************************************************************

 $Function:    	SmsRead_R_create

 $Description:	create the SMS read window (dynamic list of all the SMS)
 
 $Returns:		mfw window handler 

 $Arguments:	parent_window - Parent window handler
 
*******************************************************************************/
static T_MFW_HND SmsRead_R_create(MfwHnd parent_window)
{
    T_SMSREAD_R      * data = (T_SMSREAD_R *)ALLOC_MEMORY (sizeof (T_SMSREAD_R));
    T_MFW_WIN  * win;

    TRACE_FUNCTION ("SmsRead_R_create()");

    /*
     * Create window handler
     */

    data->win = 
	win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)SmsRead_R_win_cb);
    if (data->win EQ NULL)
	{
	    return NULL;
	}
    /* 
     * connect the dialog data to the MFW-window
     */

    data->mmi_control.dialog = (T_DIALOG_FUNC)SmsRead_R_exec_cb;
    data->mmi_control.data   = data;
    win                      = getWinData(data->win);
    win->user                = (void *)data;
    data->parent             = parent_window;
	winShow(data->win);

    /*
     * return window handle
     */

    return data->win;
}

/*******************************************************************************

 $Function:    	SmsRead_R_destroy

 $Description:	Destroy the SMS read window (dynamic list of all the SMS)
 
 $Returns:		none

 $Arguments:	own_window - window handler
 
*******************************************************************************/

static void SmsRead_R_destroy(MfwHnd own_window)
{
    T_MFW_WIN * win_data;
    T_SMSREAD_R     * data;
	USHORT i;

	
    TRACE_FUNCTION ("SmsRead_R_destroy()");

    if (own_window)
	{
	    win_data = getWinData(own_window); //((T_MFW_HDR *))->data;
	    data = getUserData_T_SMSREAD_R(win_data);
	    if (data)
		{
		    /*
		     * Delete WIN handler
		     */ 
			sms_delete(data->sms_handle);

			
			/*SPR 2132, if the message options menu or the messaeg display screen exist, 
			destroy them */
			if (option_mnu_win)
			{	
				SmsRead_R_OPT_destroy(option_mnu_win);
				
			}
			if (message_win)
			{
   	           SmsRead_R_TEXTEDT2_destroy(message_win);
   	           message_win = 0;
			}	
			/*SPR 2132 end*/
			
			if (info_win)
			{
   	           SEND_EVENT(info_win,DIALOG_DESTROY,0,0 );
   	           info_win = 0;
   	        }
			if (list_win){
				
   	           SEND_EVENT(list_win/*SPR1991*/,E_LIST_DESTROY/*SPR 2132*/,0,0 );
   	           list_win = 0;
			}	
		    win_delete (data->win);
		   	{

		    }

		    /*     
		     * Free Memory
		     */

			/* Free the data allocated for the name associated to the phone number */
			if (data->sms_editor_data.assoc_name != NULL)
				FREE_MEMORY( (void *)data->sms_editor_data.assoc_name, strlen(data->sms_editor_data.assoc_name) + 1);
			
			/* Free the data allocated for the dynamic list */
			if (data->menu_list_data != NULL)
			{
				for (i = 0; i < ((data->sms_list_data).nb_sms_stored); i++)
					{
					FREE_MEMORY( (void *)data->sms_list_data.sms_header[i], UCS2_MENU_TEXT_LEN+ 1/*SPR1242*/);
					}
				/*SPR 2686, only de-allocate memory for the number of messages displayed*/
				FREE_MEMORY ((void *)data->menu_list_data->List,((data->sms_list_data).nb_sms_stored) * sizeof(T_MFW_MNU_ITEM));
				FREE_MEMORY ((UBYTE *)data->menu_list_data, sizeof(ListMenuData));
			}
#ifdef FF_MMI_SMS_DYNAMIC
			FREE_MEMORY((void*)data->sms_list_data.sms_messages,g_max_messages * sizeof(T_MFW_SMS_MSG) );
			FREE_MEMORY((void*)data->sms_list_data.sms_header, g_max_messages * sizeof(wstring_t));
#endif
			FREE_MEMORY ((void *)data, sizeof (T_SMSREAD_R));
			sms_read_win = 0;
		}
	    else
		{
		    TRACE_EVENT ("SmsRead_R_destroy() called twice");
		}
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_exec_cb

 $Description:	Exec callback function of the SMS read window (dynamic list of 
 				all the SMS)
 
 $Returns:		none

 $Arguments:	win - window handler
 				event - mfw event
 				parameter - optional data.
 
*******************************************************************************/
void SmsRead_R_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter)
    /* callback handler for events sent to to trigger execution */
{
    T_MFW_WIN      * win_data;
    T_SMSREAD_R    * data;
    T_SMS_LIST_DATA * list_data;
	T_MFW_EVENT		MfwEvents;

	T_MFW_SMS_STAT sms_list_type = *(T_MFW_SMS_STAT *)parameter;

	T_MFW_HND l_parent;
	T_DISPLAY_DATA DisplayInfo;
	// Status of SMS reading
	T_MFW status;
	int i;

	win_data = getWinData(win); //((T_MFW_HDR *))->data;
	data = getUserData_T_SMSREAD_R(win_data);
    list_data = &data->sms_list_data;
	
    TRACE_FUNCTION ("SmsRead_R_exec_cb()");

    switch (event)
	{
	case E_INIT:
		// May 27, 2005    MMI-FIX-29869 x0018858
#ifdef FF_MMI_SMS_DYNAMIC
	       // Memory allocation done here
		if(list_data->sms_messages == NULL)
			list_data->sms_messages = (T_MFW_SMS_MSG*)ALLOC_MEMORY (g_max_messages * sizeof(T_MFW_SMS_MSG)  );
#endif
	    /* initialization of administrative data */
		info_win=0;
	    data->id = value;
		data->menu_list_data = NULL;


		//NM 24.8
		/* Verify that SMS handling has been correctly initialised */
		if (!smsidle_get_ready_state())
		{
			SmsMenu_loadDialogDefault(&DisplayInfo);

            DisplayInfo.TextId	= TxtPleaseWait;
            //DisplayInfo.TextId2  = TxtReady;
			// Generic function for info messages
			DisplayInfo.Callback = (T_VOID_FUNC)SmsRead_R_dialog_cb; 

            info_dialog(win, &DisplayInfo);
	
			break;
		}		
		/* We have to handle E_SMS_MO and E_SMS_MT MFW events, in order to retrieve the SMS */
		MfwEvents = E_SMS_MT  | E_SMS_MO | E_SMS_MT_RECEIVED | E_SMS_MO_AVAIL| 
		            E_SMS_ERR | E_SMS_OK | E_SMS_MEM_FREE    | E_SMS_MEM_FULL; 
		
  		data->sms_handle = sms_create(win,MfwEvents,(MfwCb)SmsRead_R_mfw_cb);


  		/* Get info on the stored messages 
		   According to sms_list_type filter some specific type (new, read...) */
  		/*MC SPR 2530, change sms_index_list to sms_message_list, we need additional info*/
#ifdef FF_MMI_SMS_DYNAMIC
  		list_data->nb_sms_stored = sms_message_list(sms_list_type, list_data->sms_messages, g_max_messages); 
#else
  		list_data->nb_sms_stored = sms_message_list(sms_list_type, list_data->sms_messages, MAX_MESSAGES); 
#endif
  		/* we want to get the whole SMS list */
  		if (list_data->nb_sms_stored > 0)
  		{
  		#ifdef ORIGINAL_SMS_LIST
			if (!info_win)
				info_win = mmi_dialog_information_screen_forever(win,TxtPleaseWait, NULL, COLOUR_STATUS_WAIT);

  			// We want to read all the SMS
  			g_sms_state = READ_SMS_LIST;
			/* global counter to decrement each time a message is read */
			g_sms_list_counter = list_data->nb_sms_stored - 1;

			/* Initialise counter for number of entries in sms list. used to call the correct 
			   no of FreeAllocs MZ 8/03/01  */
			g_nb_line_sms =0;
	
  			status = sms_read(MFW_SMS_MESSAGE, (unsigned char)(list_data->sms_messages[g_sms_list_counter]).index);
  		#else
  		/*SPR 2530, instead of starting to raed the SMS list in a chain , just copy SMS status info
  		and sender names to list*/
  			int i, txt_len;
  			/*we're assuming the default language is a latin one*/
  			T_MFW_PHB_ENTRY phonebook_entry;
  			BOOL unicode_flag= FALSE;
  			UBYTE output_alphabet= MFW_ASCII;
  			char* name_pointer = NULL;
				
			// May 27, 2005    MMI-FIX-29869 x0018858
#ifdef FF_MMI_SMS_DYNAMIC
		      //  Memory allocation done here
			list_data->sms_header = (wstring_t **) ALLOC_MEMORY (g_max_messages * sizeof(wstring_t)  );
#endif	

			/*for each entry in the message list*/
			for (i=0;i<list_data->nb_sms_stored; i++)
			{	/*allocate memory in the list*/

				if(list_data->sms_header[i] == NULL)
				list_data->sms_header[i] = (wstring_t *) ALLOC_MEMORY (UCS2_MENU_TEXT_LEN + 1);
				/*SPR2530 clear buffer*/
				memset(sms_text_ascii, 0, MAX_EDITOR_LEN);
				memset(list_data->sms_header[i], 0, UCS2_MENU_TEXT_LEN + 1);

				//Use common procedure to display status info.]
				//x0pleela 07 Feb, 2006 DR: OMAPS00059261
				//check for Status report type and send MFW_SMS_STATRPT as status
				if( list_data->sms_messages[i].msg_type  EQ MFW_SMS_STATRPT) 
				{
				  strcpy(sms_text_ascii, MmiRsrcGetText(TxtReport));
				  txt_len = strlen( sms_text_ascii);
				}
				else
				  txt_len = SmsRead_GetStatusText( sms_text_ascii, list_data->sms_messages[i].stat);

				/*if we're in chinese, then all string handling is in Unicode*/
				if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
				{	unicode_flag = TRUE;
					output_alphabet= MFW_DCS_UCS2;
				}
				/*if incoming SMS, copy name or number to list*/
				if (list_data->sms_messages[i].stat == MFW_SMS_UNREAD || list_data->sms_messages[i].stat == MFW_SMS_READ)
				{	/*if phonebook entry found*/
					if (bookFindNameInPhonebook( list_data->sms_messages[i].addr.number, &phonebook_entry ))
					{	
						/*if name isn't blank*/
						if (phonebook_entry.name.len >0)
						{	/*if unicode tag we have to make some adjustments*/
							if (phonebook_entry.name.data[0] == 0x80)
							{	name_pointer = (char*)&phonebook_entry.name.data[2];
								phonebook_entry.name.dcs = MFW_DCS_UCS2;
								phonebook_entry.name.len-=2;
								/*SPR2530 moved conversion here*/
								//x0pleela 07 Feb, 2006 DR: OMAPS00059261
								//Donot display sender's address for status report
								if( list_data->sms_messages[i].msg_type  NEQ MFW_SMS_STATRPT) 
								  ATB_convert_String(name_pointer, phonebook_entry.name.dcs&0x0c,  phonebook_entry.name.len,
												  &sms_text_ascii[txt_len],output_alphabet , UCS2_MENU_TEXT_LEN-txt_len, TRUE);
							}
							else
							{	name_pointer = (char*)phonebook_entry.name.data;
							/*copy (and convert) name to buffer*/
							/*SPR2530 explicitly convert from ASCII to current alphabet*/
							//x0pleela 07 Feb, 2006 DR: OMAPS00059261
							//Donot display sender's address for status report
							if( list_data->sms_messages[i].msg_type  NEQ MFW_SMS_STATRPT)
							  ATB_convert_String(name_pointer, MFW_ASCII,  phonebook_entry.name.len,
								&sms_text_ascii[txt_len],output_alphabet , UCS2_MENU_TEXT_LEN-txt_len, TRUE);
						
							}
						}
					}
					else
					{
						//x0pleela 07 Feb, 2006 DR: OMAPS00059261
						//Donot display sender's address for status report
					     if( list_data->sms_messages[i].msg_type  NEQ MFW_SMS_STATRPT)
					       /*copy (and convert) number to buffer*/
						ATB_convert_String(list_data->sms_messages[i].addr.number, MFW_ASCII,  MFW_NUM_LEN,
							&sms_text_ascii[txt_len],output_alphabet ,UCS2_MENU_TEXT_LEN-txt_len, TRUE);
					}
						
				}
				/* use truncation function to copy message header to list*/
				resources_truncate_to_screen_width((char*)sms_text_ascii,0,(char*) list_data->sms_header[i], UCS2_MENU_TEXT_LEN, SCREEN_SIZE_X, unicode_flag);
			}
			//*All the messages have been retrieved --> display the list of SMS*/
				if (Mmi_getCurrentLanguage() != CHINESE_LANGUAGE)
					SmsRead_R_BuildList(win,0);
				else
					SmsRead_R_BuildList(win,1);
		#endif
		}
		else
			SmsRead_DisplayStandardDialog(win, TxtNoMessages, THREE_SECS);
		break;

	case E_RETURN:
		/* Call the recreate function that will create and display a dynamic list from the list of SMS */
	    listDisplayListMenu(win, data->menu_list_data, (ListCbFunc_t)SmsRead_R_smslist_cb,0);
		break;
		
	case E_BACK:
		/* Received an E_BACK event from the dynamic list --> suicide and E_RETURN to parent */
	    l_parent = data->parent;
		SmsRead_R_destroy(win);
		SEND_EVENT(l_parent, E_RETURN, data->id, NULL);		
	
	case E_EXIT: // Terminate exit from sms send...
	// May 27, 2005    MMI-FIX-29869 x0018858
#ifdef FF_MMI_SMS_DYNAMIC
		for (i=0;i<list_data->nb_sms_stored; i++)
			{
				FREE_MEMORY((U8*)list_data->sms_header[i], UCS2_MENU_TEXT_LEN + 1 );
			}
		FREE_MEMORY((U8*)list_data->sms_header, g_max_messages * sizeof(wstring_t) );		
		FREE_MEMORY((U8*)list_data->sms_messages, g_max_messages * sizeof(T_MFW_SMS_MSG));		
#endif
	    listDisplayListMenu(win, data->menu_list_data, (ListCbFunc_t)SmsRead_R_smslist_cb,0);
// 	FREE_MEMORY((U8*)list_data->sms_messages, g_max_messages * sizeof(T_MFW_SMS_MSG));

	    break;
	default:
	    break;
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_win_cb

 $Description:	Window callback function of the SMS read window (dynamic list of 
 				all the SMS)
 
 $Returns:		none

 $Arguments:	w - mfw window handler
 				e - mfw event
 				
*******************************************************************************/

static int SmsRead_R_win_cb (MfwEvt e, MfwWin *w)    /* yyy window event handler */
{
	TRACE_FUNCTION ("SmsRead_R_win_cb()");
	switch (e)
	{
	case MfwWinVisible:  /* window is visible  */	    
		break;
	case MfwWinFocussed: /* input focus / selected   */	
	case MfwWinDelete:   /* window will be deleted   */        
	default:	    
		return MFW_EVENT_REJECTED;
	}
	return MFW_EVENT_CONSUMED;
}

/*******************************************************************************

 $Function:    	SmsRead_GetStatusText

 $Description:	Function to copy status string into array provided. 
 
 $Returns:		number of characters used in the output array.

 $Arguments:	op_text_str - pointer to array to store the string
 				status - read status of text message.

 $History
  SPR#780-GW-Created to allow consistent display of status in text message list 
*******************************************************************************/
int SmsRead_GetStatusText( char* op_text_str, int status)
{
	int txt_len, txtId;

	TRACE_FUNCTION("SmsRead_GetStatusText()");

	if (status == MFW_SMS_READ)
		txtId = TxtOld;
	else if(status == MFW_SMS_UNREAD)
		txtId = TxtNew;
	else if(status == MFW_SMS_STOR_UNSENT)
		txtId = TxtSaved;
	else if(status == MFW_SMS_STOR_SENT)
		txtId = TxtSend;
	else if(status == MFW_SMS_INVALID)/*SPR 2530*/
		txtId = TxtInvalidMessage;
	else //assume if it is not marked as new/old/sent/unsent
		txtId = TxtNull;
	
	// Check for the READ/UNREAD status of the MT message.
	if (Mmi_getCurrentLanguage() != CHINESE_LANGUAGE)
	{
		strcpy(op_text_str,MmiRsrcGetText(txtId));
		/* Only add colon if a non-empty string and valid message*/
		/*SPR2530 only out in a colon if the message is MT*/
		if (txtId == TxtOld || txtId == TxtNew)
			strcat(op_text_str,":");
		txt_len = strlen(op_text_str);
	}
	else //language = Chinese, copy unicode string
	{
		USHORT* unicodeStr; 
		USHORT* txtStr;
		int uIndex;

		unicodeStr = charPtrToUSHORTPtr(op_text_str);

		txtStr = charPtrToUSHORTPtr(MmiRsrcGetText(txtId));

		uIndex = 0;
		txt_len = 0;
		while ((*txtStr!= 0)  && (uIndex*2 <MENU_TEXT_LENGTH))
		{
			unicodeStr[uIndex] = *txtStr;
			txtStr++;
			uIndex++;
			txt_len = txt_len+2; // 2bytes per chinese char
		}
		/*SPR2530 only out in a colon if the message is MT*/
		if ((uIndex*2 <MENU_TEXT_LENGTH) &&(txtId == TxtOld || txtId == TxtNew))
		{
			unicodeStr[uIndex] = ((charToUSHORT)(':'))<<8;
			uIndex++;
			txt_len = txt_len+2; // 2bytes per chinese char
		}
	}
	/* Return number of characters copied into the array  */
	return (txt_len);
}

/*******************************************************************************

 $Function:    	SmsRead_R_mfw_cb

 $Description:	MFW callback function of the SMS read window (dynamic list of all the SMS).
 				Only interesting events for reading are handled here
 
 $Returns:		event status

 $Arguments:	parameter - optional data
 				event - mfw event

*******************************************************************************/
int SmsRead_R_mfw_cb(MfwEvt event, void *parameter)
{
    T_MFW_HND    win  = mfwParent((MfwHdr *)mfw_header());
    T_MFW_WIN  * win_data;
    T_SMSREAD_R      * data;
    T_SMS_LIST_DATA * list_data;
	T_MFW_SMS_MO * MoMessage;
	T_MFW_SMS_MT * MtMessage;
	
	T_MFW_SMS_IDX msg_info;

	UBYTE input_type;/*SPR1242, UCS2 or GSM string*/

  	T_DISPLAY_DATA DisplayInfo;
	int input_length = 0; /*MC, SPR 1453*/
	BOOL unicode = FALSE;/*MC, SPR 1442*/
	USHORT sms_len;
	char *sms_text;
//	int i;                      // RAVI
	int txt_len;

	win_data = getWinData(win); 
	data = getUserData_T_SMSREAD_R(win_data);
	list_data = &(data->sms_list_data);
	
	TRACE_FUNCTION("SmsRead_R_mfw_cb");

	switch(event)
	{
 		case E_SMS_OK: 
			TRACE_EVENT("SmsRead_R_mfw_cb case:E_SMS_OK ");
			if(deleting_win)
			{
				T_MFW_SMS_STAT  sms_list_type = MFW_SMS_ALL;
				
				listsDestroy(list_win);
				list_win=0;
			    SmsRead_R_destroy(data->win);
				SmsRead_R_start(NULL, (MfwMnuAttr*)&sms_list_type);
   	            SEND_EVENT(deleting_win,DIALOG_DESTROY,0,0 );

				//API - Added line to show if the message was deleted!
				dlg_initDisplayData_TextId( &DisplayInfo, TxtNull, TxtNull, TxtDeleted,  TxtNull, COLOUR_STATUS_WAIT);
				dlg_initDisplayData_events( &DisplayInfo, NULL, TWO_SECS, KEY_HUP );
				info_dialog (0, &DisplayInfo);
    
				deleting_win = 0;
			}

		break;
	case E_SMS_MO:
		TRACE_EVENT("SmsRead_R_mfw_cb case:E_SMS_MO ");
		MoMessage = (T_MFW_SMS_MO *)parameter;
	/*SPR 2530, don't need to craete SMS list here anymore*/
#ifdef ORIGINAL_SMS_LIST
		// We are reading all the SMS on the SIM
		if (g_sms_state EQ READ_SMS_LIST)
		{
			// If no message text, display the address: TBD international format and phonebook
			if (MoMessage->msg_len == 0)
			{
				// If there is an associated name, it is displayed (but not stored here, we will have to retrieve it again if detailed view)
				sms_text = (MoMessage->dest_addr).number;
				sms_len = strlen(sms_text);
			}
			else
			{
				sms_text = MoMessage->sms_msg;
				sms_len = MoMessage->msg_len;
			}

			memset((char*)sms_text_ascii,'\0',UCS2_MENU_TEXT_LEN + 1);

			TRACE_EVENT_P1("MO Message Status = %d", msg_info.stat);
			sms_copy_idx(MoMessage->msg_ref, &msg_info);

			//GW-SPR#780-Use common procedure to display status info.
			txt_len = SmsRead_GetStatusText( sms_text_ascii, msg_info.stat);

			/*MC, SPR1242 don't trust the DCS, check for Unicode tag*/
			if (MoMessage->sms_msg[0] == 0x80 ||MoMessage->dcs == MFW_DCS_UCS2 )
			{	input_type = MFW_DCS_UCS2;
				input_length =  MoMessage->msg_len-1;/*MC,SPR 1453, prevent @ symbol on end of string*/
			}
			else
			{	input_type = MFW_DCS_8bits;
				input_length =  MoMessage->msg_len;/*MC, SPR 1453*/
			}

			/*mc end*/
			
			if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
			{	unicode = TRUE;/*MC, SPR 1442, we'll be displaying messages as unicode*/
				/*SPR2175, use new function for conversion*/
				ATB_convert_String(	MoMessage->sms_msg, input_type /*MC SPR1242*/, MoMessage->msg_len,
										&sms_text_ascii[txt_len], MFW_DCS_UCS2,  UCS2_MENU_TEXT_LEN-(txt_len+1), TRUE);

			}
			else
			{	unicode = FALSE;/*MC, SPR 1442, we'll be displaying messages as ASCII*/
				/*SPR2175, use new function for conversion*/
				ATB_convert_String(	MoMessage->sms_msg, input_type /*MC SPR1242*/, input_length/*SPR 1453*/,
										&sms_text_ascii[txt_len] , MFW_ASCII,  MENU_TEXT_LENGTH-(txt_len+1), TRUE);
				
			}


		/* just in case  */
	  if (g_sms_list_counter >= 0)
	  {
				list_data->sms_header[g_sms_list_counter] = (wstring_t *) ALLOC_MEMORY (UCS2_MENU_TEXT_LEN + 1/*MC SPR1242*/);
				/*MC, SPR 1442, use truncation function to copy message header to list*/
				resources_truncate_to_screen_width(sms_text_ascii,0,(char*) list_data->sms_header[g_sms_list_counter], UCS2_MENU_TEXT_LEN, SCREEN_SIZE_X, unicode);
		}
			TRACE_EVENT_P1("g_sms_list_counter = %d", g_sms_list_counter);
			
			g_sms_list_counter--;

	        if (g_sms_list_counter >= 0)
	        {
	        	// There are still messages to read.
	        	/*SPR2260, if reading SMS fails, retry*/
	            if (sms_read(MFW_SMS_MESSAGE, SHORTToUBYTE(list_data->sms_messages[g_sms_list_counter].index))== MFW_SMS_FAIL)
	            {
					retry_sms_read(SHORTToUBYTE(list_data->sms_messages[g_sms_list_counter].index));
	            }
	            else
	      		g_nb_line_sms++;
	        }
	        else
	        {
	        	// All the messages have been retrieved --> display the list of SMS
				if (Mmi_getCurrentLanguage() != CHINESE_LANGUAGE)
					SmsRead_R_BuildList(win,0);
				else
					SmsRead_R_BuildList(win,1);
			}
		}
		// A particular SMS has been selected. We need to get all the info: full text, time stamp...
		else 
#endif
			if (g_sms_state EQ READ_SELECTED_SMS)

		{
			data->sms_editor_data.sms_info = (T_MFW_SMS_PARA *)ALLOC_MEMORY (sizeof (T_MFW_SMS_PARA));
			data->sms_editor_data.sms_type = MMI_SMS_MO;
		
    		      memcpy(data->sms_editor_data.sms_info, (T_MFW_SMS_PARA *)MoMessage, sizeof(T_MFW_SMS_PARA));
		      SmsRead_R_TEXTEDT2_start(win, (MfwMnuAttr *)&(data->sms_editor_data));
		}
	
		break;				
		case E_SMS_MT:

		MtMessage = (T_MFW_SMS_MT *)parameter;

	/*SPR 2530, don't need to craete SMS list here anymore*/
#ifdef  ORIGINAL_SMS_LIST

		if (g_sms_state EQ READ_SMS_LIST)
		{	
			/*SPR 2176, if message is the last one requested from MFW*/
			if (list_data->sms_messages[g_sms_list_counter].index == MtMessage->index)
			{

			// If no message text, display the address: TBD international format and phonebook
			if (MtMessage->msg_len == 0)
			{
				// If there is an associated name, it is displayed (but not stored here, we will have to retrieve it again if detailed view)
				// MZ check for assoc_name !!! 14/2/01
				sms_text = (MtMessage->orig_addr).number;
				sms_len = strlen(sms_text);
			}
			else
			{
			
				sms_text = MtMessage->sms_msg;
				sms_len = MtMessage->msg_len;
			}

   			//MZ 24/05/01 clear the temp sms text buffer.
   			memset((char*)sms_text_ascii,'\0',UCS2_MENU_TEXT_LEN + 1);

			sms_copy_idx(MtMessage->index, &msg_info);
			//x0pleela 07 Feb, 2006 DR: OMAPS00059261
			//Display "Report" for status report
			//GW-SPR#780-Use common procedure to display status info.
			TRACE_EVENT_P1("Status of message = %d", msg_info.stat);
			if( list_data->sms_messages[i].msg_type  EQ MFW_SMS_STATRPT)
			{
			  strcpy(sms_text_ascii, MmiRsrcGetText(TxtReport));
			  txt_len = strlen( sms_text_ascii);
			}
			else
			  txt_len = SmsRead_GetStatusText( sms_text_ascii, msg_info.stat);
	
			/*MCSPR1242 don't trust the DCS, check for Unicode tag*/
			if (MtMessage->sms_msg[0] == 0x80||MtMessage->dcs == MFW_DCS_UCS2 )
			{	input_type = MFW_DCS_UCS2;/*MC*/
				input_length =  MtMessage->msg_len-1;/*1498, use MT length*/
			}
			else
			{	input_type = MFW_DCS_8bits;/*MC*/
				input_length =  MtMessage->msg_len;/*1498, use MT length*/
			}
			
			/*mc end*/
			if (Mmi_getCurrentLanguage() != CHINESE_LANGUAGE)
			{	unicode = FALSE; /*MC, SPR 1442, we'll be displaying messages as ASCII*/
				/*SPR2175, use new function for conversion*/
				//x0pleela 07 Feb, 2006 DR: OMAPS00059261
				//Donot display sender's address for status report
				if( list_data->sms_messages[i].msg_type  NEQ MFW_SMS_STATRPT)
				ATB_convert_String(	MtMessage->sms_msg, input_type/*MC SPR1242*/, input_length/*SPR 1453*/,
										&sms_text_ascii[txt_len], MFW_ASCII /*MC SPR1242*/,  MENU_TEXT_LENGTH-(txt_len+1)/*MC SPR1242*/, TRUE);
			}
			else //language = Chinese
			{	unicode = TRUE;/*MC, SPR 1442, we'll be displaying messages as unicode*/
				/*SPR2175, use new function for conversion*/
				//x0pleela 07 Feb, 2006 DR: OMAPS00059261
				//Donot display sender's address for status report
				if( list_data->sms_messages[i].msg_type  NEQ MFW_SMS_STATRPT)
				ATB_convert_String(	MtMessage->sms_msg, input_type /*SH*/, MtMessage->msg_len,
											&sms_text_ascii[txt_len], MFW_DCS_UCS2,  UCS2_MENU_TEXT_LEN-txt_len/*MC SPR1242*/, TRUE);
			}
			list_data->sms_header[g_sms_list_counter] = (wstring_t *) ALLOC_MEMORY (UCS2_MENU_TEXT_LEN + 1/*MC SPR1242*/);

			//Check for allocation fail before using memory
		    if(list_data->sms_header[g_sms_list_counter]  != NULL)
		    {	/*MC, SPR 1442, use truncation function to copy message header to list*/
		    	resources_truncate_to_screen_width(sms_text_ascii,0,(char*) list_data->sms_header[g_sms_list_counter], UCS2_MENU_TEXT_LEN, SCREEN_SIZE_X, unicode);
				
			}
			else
				TRACE_EVENT(" Memory allocation failed ");
				
			g_sms_list_counter--;

	        if (g_sms_list_counter >= 0)
	        {
	        	// There are  still messages to read.
	        	/*SPR2260, if reading SMS fails, retry*/
	        	if (sms_read(MFW_SMS_MESSAGE, (UBYTE)list_data->sms_messages[g_sms_list_counter].index) == MFW_SMS_FAIL)
	        	{
					retry_sms_read(SHORTToUBYTE(list_data->sms_messages[g_sms_list_counter].index));
	            }
	        	g_nb_line_sms++;
	         }
	        else
	        {
	        	// All the messages have been retrieved --> display the list of SMS
				if (Mmi_getCurrentLanguage() != CHINESE_LANGUAGE)
					SmsRead_R_BuildList(win,0);
				else
					SmsRead_R_BuildList(win,1);
	        }
		  }
		  else 
		  {	/*if index is not the one expected, pass event on to SmsIdle module*/
		  	return MFW_EVENT_PASSED;
		  }
		  
		}
		else 
#endif
		if (g_sms_state EQ READ_SELECTED_SMS)
		{
			TRACE_EVENT_P1("MtMessage len: %d", MtMessage->msg_len);
			/*SPR 2176, if this was the message we requested*/
			if (MtMessage->index == data->sms_editor_data.sms_index)
			{
				data->sms_editor_data.sms_info = (T_MFW_SMS_PARA *)ALLOC_MEMORY (sizeof (T_MFW_SMS_PARA));
				
				data->sms_editor_data.sms_type = MMI_SMS_MT;
			    memcpy(data->sms_editor_data.sms_info, (T_MFW_SMS_PARA *)MtMessage, sizeof(T_MFW_SMS_PARA));
				sms_copy_idx(MtMessage->index, &msg_info);
			
				
				SmsRead_R_TEXTEDT2_start(win, (MfwMnuAttr *)&(data->sms_editor_data));
			}
			else
			{	/*if index is not the one expected, pass event on to SmsIdle module*/
				return MFW_EVENT_PASSED;
			}
		}
		break;
    case E_SMS_ERR:
      TRACE_EVENT("SMS Error");
      if (info_win){
        SEND_EVENT(info_win,DIALOG_DESTROY,0,0 );
        info_win = 0;
      }
#ifndef    ORIGINAL_SMS_LIST
      /*SPR 2530 Delete and recreate SMS list window to show updates*/
		{ T_MFW_SMS_STAT  sms_list_type = MFW_SMS_ALL;

			listsDestroy(list_win);
			list_win=0;
			SmsRead_R_destroy(sms_read_win);
			SmsRead_R_start(NULL, (MfwMnuAttr*)&sms_list_type);
      	}
#endif
	break;
		/*SPR 2530 handle new message event*/
	case E_SMS_MT_RECEIVED:
		/*if we are not currently displaying a message*/
		// Feb 16, 2005 REF: CRR MMI-SPR-27900 xnkulkar 
		// Added condition ' invalidVm == FALSE' before updating sms list
		// to ensure that no blank voice mail sms entry is shown. 
		if (message_win == NULL &&  invalidVm == FALSE) 
 		/*SPR 2530 Delete and recreate SMS list window to show updates*/
		{ T_MFW_SMS_STAT  sms_list_type = MFW_SMS_ALL;

//	Dec 15,2004 REF: CRR 24396 xkundadu
//	Description: Phone crashes when a message is received while the 
//			    'List Empty' dialog is displayed.
//	Solution: NULL check is added for the list_win handle before calling 
//			listsDestroy() function  when an MT sms is receieved.

			// Check whether the sms list window is already destroyed or not.
			TRACE_EVENT(" MT SMS RECEIVED ");
			if(list_win != NULL)
			{
				listsDestroy(list_win);
				list_win=0;
			}

			// If the 'List empty' dialog is being displayed,
			// wait for 3 seconds and continue.
			if(SmsListEmptyDlgPresent)
			{
				vsi_t_sleep (VSI_CALLER 3000);
			}
			SmsRead_R_destroy(sms_read_win);
			SmsRead_R_start(NULL, (MfwMnuAttr*)&sms_list_type);
      	}
		/*pass event to next handler*/
		return MFW_EVENT_REJECTED;
//	break;    // RAVI
    	/*SPR 2530 end*/
    default:
    		TRACE_EVENT(" SmsRead_R_mfw_cb case: Default");
    	return MFW_EVENT_REJECTED;
		}
    return MFW_EVENT_CONSUMED;
}

/*******************************************************************************

 $Function:    	retry_sms_read.  Added for SPR2260

 $Description:	set up a timer to re-read sms at passed index in 100ms
 
 $Returns:		none

 $Arguments:	index of sms to be re-read
 				
*******************************************************************************/
void retry_sms_read(int index)
{	TRACE_EVENT("retry_sms_read()");
	retry_handle = tim_create(NULL, 1000, (MfwCb)retry_sms_read_tim_cb);
	tim_start(retry_handle);
	retry_index = index;

}
/*******************************************************************************

 $Function:    	retry_sms_read_tim_cb.  Added for SPR2260

 $Description:	Callback function for retry SMS read timer
 
 $Returns:		status int

 $Arguments:	event, timer data structure
 				
*******************************************************************************/
int retry_sms_read_tim_cb(MfwEvt event, MfwTim *timer_info)
{	TRACE_EVENT("retry_sms_read_tim_cb()");
	if (sms_read(MFW_SMS_MESSAGE, retry_index) == MFW_SMS_FAIL)
	{	tim_start(retry_handle);}
	else
	{	tim_delete(retry_handle);
		retry_handle = NULL;
	}
	return MFW_EVENT_CONSUMED;

}
/*******************************************************************************

 $Function:    	SmsRead_R_smslist_cb

 $Description:	Callback function for the dynamic list of the SMS read window.
 
 $Returns:		none

 $Arguments:	Parent - window handler
 				ListData - Menu list data.
 				
*******************************************************************************/

void SmsRead_R_smslist_cb(T_MFW_HND * Parent, ListMenuData * ListData)
{



    T_MFW_WIN       * win_data;
    T_SMSREAD_R * data;    
	  
//	T_MFW_HND      * l_parent;   // RAVI
 //   SHORT            l_id;   // RAVI


	TRACE_FUNCTION("SmsRead_R_smslist_cb ");
	
	win_data = getWinData(Parent); 
	data = getUserData_T_SMSREAD_R(win_data);

	// In all the case, we need the index of the selected message
	data->sms_editor_data.sms_index = data->sms_list_data.sms_messages[ListData->ListPosition].index;
	
	if (ListData->Reason EQ LISTS_REASON_SELECT/* && ListData->KeyReason EQ KCD_LEFT*/)
	{
		TRACE_EVENT(">>> Reason:LISTS_REASON_SELECT ");
		// We want only to retrieve the selected SMS
		g_sms_state = READ_SELECTED_SMS;

		if (!info_win)
			info_win = mmi_dialog_information_screen_forever(Parent,TxtPleaseWait, NULL, COLOUR_STATUS_WAIT);

		/*NM p030 just in case not to using the '0' index for reading */
		if (data->sms_editor_data.sms_index NEQ 0)
   		{	/*SPR 2530, if read fails, retry later*/

   			if (sms_read(MFW_SMS_MESSAGE, SHORTToUBYTE(data->sms_editor_data.sms_index ))== MFW_SMS_FAIL)
	            {
					retry_sms_read(SHORTToUBYTE(data->sms_editor_data.sms_index ));
	            }		
		}
	}

	/*NM p032 check if the TEST SIM is inserted.
	  During testing FTA 34.2.3 we would like to delete
	  the sms from the list without changing the sms-status
	  from unread to read
	*/
	if (test_sim EQ TRUE)
	{

	 if (ListData->Reason EQ LISTS_REASON_HANGUP)
	{
		TRACE_EVENT(">>> Reason: LISTS_REASON_HANGUP ");
		listsDestroy(ListData->win);
		list_win=0;
	    SmsRead_R_destroy(data->win);
	}
	/*
	the right-soft-key  deletes
	the selected sms in the list-menu without changing
	the read-status of the sms.

	go-back key is now on the "Hang_up"
	*/
	if ((ListData->Reason EQ LISTS_REASON_BACK )
    || (ListData->Reason EQ LISTS_REASON_CLEAR ))
	{
		T_DISPLAY_DATA DisplayInfo;
		
		TRACE_EVENT(">>> Reason: LISTS_REASON_BACK/CLEAR ");
		
		/* show for a short period  "Message deleted" and go
		   back to the previous menu-screen
		*/
		if((sms_msg_delete((UBYTE)data->sms_editor_data.sms_index) EQ MFW_SMS_OK)
		   && (data->sms_editor_data.sms_index NEQ 0))
		{
		
	    	DisplayInfo.TextString   = '\0';
		    DisplayInfo.TextString2  = '\0';
    		DisplayInfo.LeftSoftKey  = 0;
		    DisplayInfo.RightSoftKey = 0;
			DisplayInfo.Time         = THREE_SECS;
			DisplayInfo.KeyEvents    = KEY_CLEAR|KEY_LEFT|KEY_RIGHT;;
	    	DisplayInfo.TextId       = TxtMessage;
		    DisplayInfo.TextId2      = TxtDeleted;
    		DisplayInfo.Identifier   = NULL;
			DisplayInfo.Callback     = NULL;

			info_dialog(data->win, &DisplayInfo);

		}
	
		/* destroy the read-sms-menu and go back to 
		the previous screen
		*/
		listsDestroy(ListData->win);
		list_win=0;
	    SmsRead_R_destroy(data->win);

		}

	}
	else
	{
	 if ((ListData->Reason EQ LISTS_REASON_BACK /*&& ListData->KeyReason EQ KCD_RIGHT*/)
    || (ListData->Reason EQ LISTS_REASON_CLEAR /*&& ListData->KeyReason EQ KCD_HUP */)
    || (ListData->Reason EQ LISTS_REASON_HANGUP))	// sbh - added hangup key
	{
		TRACE_EVENT(">>> Reason: LISTS_REASON_BACK/CLEAR ");
		listsDestroy(ListData->win);
		list_win=0;
	    SmsRead_R_destroy(data->win);
	}

	
	}
	/*NM p032 end*/
	
}

/*******************************************************************************

 $Function:    	SmsRead_R_dialog_cb

 $Description:	Dialog callback function of the SMS read window (dynamic list of all the SMS)
 				Case where SMS has not been initialized yet
 
 $Returns:		status

 $Arguments:	win - current window handler
 				Identifier - window id
 				Reason - Event cause.
 				
*******************************************************************************/

int SmsRead_R_dialog_cb(T_MFW_HND win, USHORT Identifier, USHORT Reason)
{
    T_MFW_WIN       * win_data;
    T_SMSREAD_R * data;    
	T_MFW_HND *lparent;

	win_data = getWinData(win); 
	data = getUserData_T_SMSREAD_R(win_data);
	lparent = data->parent;
	
    TRACE_FUNCTION ("SmsRead_dialog_cb()");
	
	switch (Reason)
	{
	case INFO_TIMEOUT:
	case INFO_KCD_HUP:
		// Commit suicide
		SmsRead_R_destroy(win);
		// Send E_RETURN event to parent window
		SEND_EVENT(lparent, E_RETURN, data->id, NULL);

//	Dec 15,2004 REF: CRR 24396 xkundadu
//	Description: Phone crashes when a message is received while the 
//			    'List Empty' dialog is displayed.

	// set the variable to FALSE, since  'List empty' dialog has been destroyed 		.
		SmsListEmptyDlgPresent = FALSE;
		return MFW_EVENT_CONSUMED;

	default:
		return MFW_EVENT_REJECTED;
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_BuildList

 $Description:	Build the list of SMS for the dynamic list.
 
 $Returns:		status

 $Arguments:	win - current window handler
 
*******************************************************************************/

void SmsRead_R_BuildList(T_MFW_HND win, int inUnicode)
{

    T_MFW_WIN       * win_data;
    T_SMSREAD_R * data;    

    /* List is complete so present menu. */
    USHORT i;

    TRACE_FUNCTION("SmsRead_R_BuildList");
	
	win_data = getWinData(win); 
	data = getUserData_T_SMSREAD_R(win_data);
	
	data->menu_list_data = (ListMenuData *)ALLOC_MEMORY(sizeof(ListMenuData));

	if(data->menu_list_data == 0)
	{
		TRACE_EVENT("Failed memory alloc 1 ");
		return;
	}
		/*SPR 2686, only allocate memory for the number of messages displayed*/	
	data->menu_list_data->List = (T_MFW_MNU_ITEM *)ALLOC_MEMORY( ((data->sms_list_data).nb_sms_stored) * sizeof(T_MFW_MNU_ITEM) );//JVJE

	if(data->menu_list_data->List == 0)
	{
		TRACE_EVENT("Failed memory alloc 2");
		return;
	}
		
	
	for (i = 0; i < ((data->sms_list_data).nb_sms_stored); i++)
	{
		mnuInitDataItem(&data->menu_list_data->List[i]);
		data->menu_list_data->List[i].str  = (char *)(data->sms_list_data).sms_header[i];
		data->menu_list_data->List[i].flagFunc = item_flag_none; 
	}
	
   	data->menu_list_data->ListLength =(data->sms_list_data).nb_sms_stored;
	data->menu_list_data->ListPosition = 1;
	data->menu_list_data->CursorPosition = 1;
	data->menu_list_data->SnapshotSize =(data->sms_list_data).nb_sms_stored;
	data->menu_list_data->Font = 0;
	data->menu_list_data->LeftSoftKey = TxtSoftSelect;
	/*NM p032*/
	if(test_sim EQ TRUE)
		data->menu_list_data->RightSoftKey = TxtDelete;
	else
		data->menu_list_data->RightSoftKey = TxtSoftBack;
		
	data->menu_list_data->KeyEvents = KEY_ALL;
	data->menu_list_data->Reason = 0;
	data->menu_list_data->Strings = TRUE;
 	data->menu_list_data->Attr   = (MfwMnuAttr*)&readSMS_menuAttrib;
	data->menu_list_data->autoDestroy    = FALSE;
 	
    /* Create the dynamic menu window */
listDisplayListMenu(win, data->menu_list_data, (ListCbFunc_t)SmsRead_R_smslist_cb,inUnicode);
list_win = data->menu_list_data->win;
	if (info_win){
          SEND_EVENT(info_win,DIALOG_DESTROY,0,0 );
          info_win = 0;
	}
}



/*******************************************************************************

 $Function:    	SmsRead_R_OPTExeDelete

 $Description:	Called when the user press Delete in the Option menu
 			
 $Returns:		event status.

 $Arguments:	m - pointer to menu.
 				i - index if selected menu item.
*******************************************************************************/

static int SmsRead_R_OPTExeDelete(MfwMnu* m, MfwMnuItem* item)
{
    T_MFW_HND     	   win      = mfwParent(mfw_header());
    T_MFW_WIN        * win_data = ((T_MFW_HDR *)win)->data;
    T_SMSREAD_R_OPT  * data     = (T_SMSREAD_R_OPT *)win_data->user;

	/* access to data from parent   */
    T_MFW_HDR    * parent      =  data->parent;
    T_MFW_WIN    * win_data2   =  ((T_MFW_HDR *)parent)->data;
    
    T_SMSREAD_R_TEXTEDT2  * parent_data =  (T_SMSREAD_R_TEXTEDT2 *)win_data2->user;
//    May 27, 2005    MMI-FIX-29869 x0018858
#ifdef FF_MMI_SMS_DYNAMIC
//   	Changed from static to dynamic
	T_MFW_SMS_IDX* temp_message_list;/*SPR2530*/
#else
	T_MFW_SMS_IDX temp_message_list[MAX_MESSAGES];/*SPR2530*/
#endif
	int no_of_messages, i;/*SPR2530*/
	BOOL message_currently_in_list = FALSE;/*SPR2530*/
	UBYTE deleting_index = parent_data->sms_editor_data->sms_index;/*SPR2686*/
#ifdef FF_MMI_SMS_DYNAMIC
	temp_message_list = (T_MFW_SMS_IDX*)ALLOC_MEMORY(g_max_messages*sizeof(T_MFW_SMS_IDX));	  
#endif
	TRACE_FUNCTION("SmsRead_R_OPTExeDelete");
#ifdef MMI_LITE
	/*SPR 2686 destroy option window to reduce memory usage*/
		if (mfwCheckMemoryLeft() < 400)
			SmsRead_R_OPT_destroy(option_mnu_win);
#endif	
	/*SPR2530, check if message index in current list of messages*/
#ifdef FF_MMI_SMS_DYNAMIC
	no_of_messages = sms_index_list(MFW_SMS_ALL, temp_message_list, g_max_messages);
#else
	no_of_messages = sms_index_list(MFW_SMS_ALL, temp_message_list, MAX_MESSAGES);
#endif
	for (i= 0; i< no_of_messages;i++)
	{
		if (temp_message_list[i].index == deleting_index)
			message_currently_in_list =  TRUE;
	}

	if (message_currently_in_list == TRUE)
	{
		
		if(sms_msg_delete((UBYTE)deleting_index/*SPR 2686*/)== MFW_SMS_OK)
		{
	       /* set the status that the user selected the delete item */
			if(deleting_win == 0)
				deleting_win= mmi_dialog_information_screen_forever(0,TxtPleaseWait, NULL, COLOUR_STATUS_WAIT);

			{
		   		// Destroy the text editor and free memory.
		   		SmsRead_R_TEXTEDT2_destroy(parent_data->win);
		   		/*SPR 2686, only destroy option menu window if it hasn't already been destroyed*/
		   		if (option_mnu_win)
		   				SmsRead_R_OPT_destroy(option_mnu_win);
		   		
			}

		}
		else
		{		   		
			
			/*SPR2530, don't delete option and display windows, just show failure*/
			mmi_dialog_information_screen(0,TxtFailed, NULL, NULL, COLOUR_STATUS_WAIT);
		}
	}
	else
	{
		/*SPR2530, don't delete option and display windows, just show failure*/
		mmi_dialog_information_screen(0,TxtFailed, NULL, NULL, COLOUR_STATUS_WAIT);
	}
   
//    May 27, 2005    MMI-FIX-29869 x0018858
#ifdef FF_MMI_SMS_DYNAMIC
//   Free the allocated memory
   FREE_MEMORY((U8*)temp_message_list, g_max_messages*sizeof(T_MFW_SMS_IDX));
#endif
   return 1;   // ADDED BY RAVI - 28-11-2005
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPTExeReply

 $Description:	Called when the user press Reply in the Option menu
 			
 $Returns:		event status.

 $Arguments:	m - pointer to menu.
 				i - index if selected menu item.
*******************************************************************************/

static int SmsRead_R_OPTExeReply(MfwMnu* m, MfwMnuItem* i)
{

    T_MFW_HND       win  = mfwParent(mfw_header());
    T_MFW_WIN     * win_data = ((T_MFW_HDR *)win)->data;
    T_SMSREAD_R_OPT         * data = (T_SMSREAD_R_OPT *)win_data->user;	
	
	T_MFW_HDR    * parent      =  data->parent;
    T_MFW_WIN    * win_data2   =  ((T_MFW_HDR *)parent)->data;
    
    T_SMSREAD_R_TEXTEDT2  * parent_data =  (T_SMSREAD_R_TEXTEDT2 *)win_data2->user;
    // March 2, 2005    REF: CRR 11536 x0018858
   //  T_MFW_SMS_INFO	sms_parameter;//Added for retreiving the Reply path. // RAVI
	

	TRACE_FUNCTION("SmsRead_R_OPTExeReply");
		
	    /* Copy the number and name information to the SMS buffer
	    */
	 /*MC SPR 1257, clear whole buffer in case of Unicode entry*/
    memset(SmsData.TextBuffer, '\0', MAX_MSG_LEN_ARRAY);
		//Copy the calling number for pasting into the number buffer;
	/* Marcus: Issue 1804: 12/03/2003: Start */
	if(parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.ton == MFW_TON_INTERNATIONAL)
	{
		if(parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number[0] == '+')
		{
			strcpy((char *)SmsData.NumberBuffer,(char *)parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number); 
		}
		else
		{
			strcpy((char *)SmsData.NumberBuffer,"+");				
			strncat((char *)SmsData.NumberBuffer,(char *)parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number,sizeof(SmsData.NumberBuffer)-2); 
		}
	}
	else
		strcpy((char *)SmsData.NumberBuffer,(char *)parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number); 
	/* Marcus: Issue 1804: 12/03/2003: End */

              // March 2, 2005    REF: CRR 11536 x0018858
	      // Retreive and check the reply bit from the structure.
	      // see if we should use our own service centre number
		if ( reply_path_bit && parent_data->sms_editor_data->sms_info->sms_mt.rp &&
			strlen(parent_data->sms_editor_data->sms_info->sms_mt.sc_addr) != 0 )
		{
			TRACE_EVENT_P1("The receivers SCA is %s",parent_data->sms_editor_data->sms_info->sms_mt.sc_addr);
			SmsData.called_from_reply_item = TRUE;
	  	  	/* copy the service center number as well */
			strcpy((char *)SmsData.CentreBuffer, (char *)parent_data->sms_editor_data->sms_info->sms_mt.sc_addr);
		}
		else
		{
			TRACE_EVENT_P1("The senders SCA is %s",SmsData.NumberBuffer);
			/* use the own Service Center Number if the caller doesnt send one*/
			SmsData.called_from_reply_item = FALSE;
		}

	/* p304 SH save window pointer */
		win = parent_data->win;
		// Destroy the text editor, free memory
	    SmsRead_R_TEXTEDT2_destroy(parent_data->win);
		/* Destroy the Options Menu and text editor.before starting the Send Editor.*/
		SmsRead_R_OPT_destroy(data->win);

		/*SPR 2686 destroy the SMS read window to free memory*/
		/*destroy the built list window*/
		listsDestroy(list_win);
		list_win=0;
		/*destroy the main control window*/
		if (sms_read_win)/*SPR 2132, check window exists before destroying it*/
		{
			SmsRead_R_destroy(sms_read_win);
			sms_read_win = NULL;
		}
		/* NM,  FTA 34.2.8  */
		
		/* p304 SH - call this after destroying editor & windows. parent_data is lost,
		so use pointer saved from above */
		SmsSend_SEND_start(win, (void *) &SmsData);
    

    
	
    return 1;
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPTExeStoreNumber

 $Description:	Called when the user press Store Number in the Option menu
 			
 $Returns:		event status.

 $Arguments:	m - pointer to menu.
 				i - index if selected menu item.
*******************************************************************************/

static int SmsRead_R_OPTExeStoreNumber(MfwMnu* m, MfwMnuItem* i)
{
    T_MFW_HND       win  = mfwParent(mfw_header());
    T_MFW_HND       win2; //Mar 27, 2006 DR:OMAPS00047813 x0035544
    T_MFW_WIN     * win_data = ((T_MFW_HDR *)win)->data;
    T_SMSREAD_R_OPT         * data = (T_SMSREAD_R_OPT *)win_data->user;

	T_MFW_HDR    * parent      =  data->parent;
    T_MFW_WIN    * win_data2   =  ((T_MFW_HDR *)parent)->data;
    T_SMSREAD_R_TEXTEDT2  * parent_data =  (T_SMSREAD_R_TEXTEDT2 *)win_data2->user;
	T_MFW_PHB_ENTRY  pb_data;
	// UBYTE found_name;			/*SPR888 -SH*/   // RAVI
	//Mar 27, 2006 DR:OMAPS00047813 x0035544
	 CHAR  number[MFW_NUM_LEN];
	T_MFW_PHB_TON ton;
	
	TRACE_FUNCTION("SmsRead_R_OPTExeStoreNumber");

	 /* Copy the number and name information to the SMS buffer
    */
    //Mar 27, 2006 DR:OMAPS00047813 x0035544
	ton = parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.ton;
   	strcpy(number, parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number);
    	
	/*SPR 2686 destroy windows before attempting to extract numbers.*/
	// Destroy the text editor, rel memory. 
    SmsRead_R_TEXTEDT2_destroy(parent_data->win);
	/* Destroy the Options Menu and text editor. */
	SmsRead_R_OPT_destroy(data->win);
	
	//Mar 27, 2006 DR:OMAPS00047813 x0035544	
	if(ton == MFW_TON_INTERNATIONAL &&
		number[0]!='+' && strlen((char *)number)>0 )
		/* SPR888 - SH - do not add + if already there */
	{
		strcpy((char *)SmsData.NumberBuffer,"+");
		strcat((char *)SmsData.NumberBuffer,(char *)number); 		
	}
	else
	{
		strcpy((char *)SmsData.NumberBuffer,(char *)number); 
	}	
	
	if (read_status EQ MMI_SMS_MT)
	{
		/* MT -SMS has the additional information (Date, Time & Number)
		   we dont want to show these when we are editing       */
    	memcpy(SmsData.TextBuffer,&sms_text_ascii[current_sms_len],MAX_MSG_LEN_ARRAY);
	}
	else
	{
		//when we were reading the saved-SMS with the length of MAX_MSG_LEN
  		memcpy(SmsData.TextBuffer,sms_text_ascii,MAX_MSG_LEN_ARRAY);/* assumption: sms_text_ascii is still filled from reading the SMS*/
	}
	
	/* SPR888 - SH - Start looking for numbers from beginning of SMS text */
#if 0 //Mar 24, 2006 DR:OMAPS00047813 x0035544
	search_index = 0;
	if (strlen((char *)SmsData.NumberBuffer)==0)
	{
		Search_forNextNumber(&SmsData);
	}

	if (strlen((char *)SmsData.NumberBuffer)==0)
	{
		mmi_dialog_information_screen(0, TxtNotAvailable, NULL, NULL, NULL);
	}
	else
	{
		//Search the phonebook for the sender number entry and display the tag and number.
		if (bookFindNameInPhonebook((const char*)&SmsData.NumberBuffer[0], &pb_data) !=0)
		{
#ifdef NO_ASCIIZ			
			//Display the tag and number dialog.
			/* SPR888 - SH - parent_data->parent changed to parent_data->win */
			smsRead_NumberName_info_screen(0,(void *)&SmsData, (char*)pb_data.name.data);
#else
			//Display the tag and number dialog.
			/* SPR888 - SH - parent_data->parent changed to parent_data->win */
			smsRead_NumberName_info_screen(0,(void *)&SmsData, (char*)pb_data.name);
#endif

		}
		else
		{
			/* SPR888 - SH - parent_data->parent changed to parent_data->win */
			smsRead_NumberName_info_screen(0,(void *)&SmsData,NULL);
		}
	}
#endif //Mar 24, 2006 DR:OMAPS00047813 x0035544

//Mar 24, 2006 DR:OMAPS00047813 x0035544
Search_forNumberInSMS(&SmsData);
win2 = SmsRead_BuildNumList_Menu( win);
if (win2 NEQ NULL)
{
  SEND_EVENT (win2, E_INIT, 0, 0);
}

   	
    return 1;
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPTExeEdit

 $Description:	Called when the user press Forward in the Option menu
 			
 $Returns:		event status.

 $Arguments:	m - pointer to menu.
 				i - index if selected menu item.
*******************************************************************************/

static int SmsRead_R_OPTExeEdit(MfwMnu* m, MfwMnuItem* i)
{
	T_MFW_HND       win  = mfwParent(mfw_header());
    	T_MFW_WIN     * win_data = ((T_MFW_HDR *)win)->data;
    	T_SMSREAD_R_OPT         * data = (T_SMSREAD_R_OPT *)win_data->user;

	T_MFW_HDR    * parent      =  data->parent;
    	T_MFW_WIN    * win_data2   =  ((T_MFW_HDR *)parent)->data;
    	T_SMSREAD_R_TEXTEDT2  * parent_data =  (T_SMSREAD_R_TEXTEDT2 *)win_data2->user;
	T_DISPLAY_DATA Dialog;

	TRACE_FUNCTION("SmsRead_R_OPTExeEdit");
	if (FFS_flashData.ConcatenateStatus == TRUE )
	{
		 /* Copy the number and name information to the SMS buffer
	    	*/
	    	SmsData.NumberBuffer[0] = '\0';
		if (read_status EQ MMI_SMS_MT)
		{
			/* MT -SMS has the additional information (Date, Time & Number)
			   we dont want to show these when we are editing       */
			   
//	       	Dec 01, 2004   REF: CRR 24225 xnkulkar
//	 		Description: Reset when forwarding SMS
//	 		Solution: The message content is sent excluding the date/time info from the 
//	               	original message, which was causing the reset as the max limit was crossed.
	    		memcpy(SmsData.TextBuffer,&sms_text_ascii[current_sms_len + ORIGINAL_DATE_TIME_INFO],MAX_MSG_LEN_ARRAY);
		}
		else
		{
			//when we were reading the saved-SMS with the length of MAX_MSG_LEN
	  		memcpy(SmsData.TextBuffer,sms_text_ascii,MAX_MSG_LEN_ARRAY);/* assumption: sms_text_ascii is still filled from reading the SMS*/
		}
		SmsData.called_from_reply_item = FALSE;
		
		/* p304 SH save window pointer */
		win = parent_data->win;
		// Destroy the text editor, free memory
	    	SmsRead_R_TEXTEDT2_destroy(parent_data->win);
		/* Destroy the Options Menu and text editor.before starting the Send Editor.*/
		SmsRead_R_OPT_destroy(data->win);
		/*SPR 1991 destroy the SMS read window to free memory*/
		/*destroy the built list window*/
		listsDestroy(list_win);
		list_win=0;
		/*destroy the main control window*/
		if (sms_read_win)/*SPR 2132, check window exists before destroying it*/
		{
			SmsRead_R_destroy(sms_read_win);
			sms_read_win = NULL;
		}
				
   	     	/*SPR 1991 end*/
		/* NM,  FTA 34.2.8  */
		
		/* p304 SH - call this after destroying editor & windows. parent_data is lost,
		so use pointer saved from above */
		SmsSend_SEND_start(win, (void *) &SmsData);
	}
	/* API - 28-01-03 - 1628 - Allow the editing of a single SMS if ConcatenateStatus is FALSE */
	/* API - 19-03-03 - 1825 - Allow the editing of a single saved SMS if ConcatenateStatus is FLASE*/

//	Feb 16, 2005 REF: CRR 28966 x0012851
//	Description: Editing or forwarding of large MT messages (>160 characters) 
// 				shouldn't be allowed when Concatenation is set to 'OFF'
// 	Solution: If the 'ConcatenateStatus' flag is FALSE, the 'if' check condition
//				which allows the message to be edited or forwarded has been 
// 				modified for the same.
	else if (FALSE==FFS_flashData.ConcatenateStatus)
	{
		if (((read_status EQ MMI_SMS_MT) && (parent_data->sms_editor_data->sms_info->sms_mt.msg_len <= BASIC_MAX_MSG_LEN))
			||((read_status EQ MMI_SMS_MO) && (parent_data->sms_editor_data->sms_info->sms_mo.msg_len <= BASIC_MAX_MSG_LEN)))
		{
			TRACE_EVENT_P1("msg_len in edit is = %d", parent_data->sms_editor_data->sms_info->sms_mt.msg_len);
			/* Copy the number and name information to the SMS buffer
	    		*/
	    		SmsData.NumberBuffer[0] = '\0';
			if (read_status EQ MMI_SMS_MT)
			{
			/* MT -SMS has the additional information (Date, Time & Number)
			   we dont want to show these when we are editing       */
//	       	Dec 01, 2004   REF: CRR 24225 xnkulkar
//	 		Description: Reset when forwarding SMS
//	 		Solution: The message content is sent excluding the date/time info from the 
//	               		    original message, which was causing the reset as the max limit was crossed.
	    		memcpy(SmsData.TextBuffer,&sms_text_ascii[current_sms_len + ORIGINAL_DATE_TIME_INFO],MAX_MSG_LEN_SGL);
		}
		else
		{
			//when we were reading the saved-SMS with the length of MAX_MSG_LEN
	  		memcpy(SmsData.TextBuffer,sms_text_ascii,MAX_MSG_LEN_SGL);/* assumption: sms_text_ascii is still filled from reading the SMS*/
		}
		SmsData.called_from_reply_item = FALSE;

		win = parent_data->win;
		// Destroy the text editor, free memory
	    	SmsRead_R_TEXTEDT2_destroy(parent_data->win);
		/* Destroy the Options Menu and text editor.before starting the Send Editor.*/
		SmsRead_R_OPT_destroy(data->win);
		/*SPR 1991 destroy the SMS read window to free memory*/
		/*destroy the built list window*/
		listsDestroy(list_win);
		list_win=0;
		/*destroy the main control window*/
		if (sms_read_win)/*SPR 2132, check window exists before destroying it*/
		{
			SmsRead_R_destroy(sms_read_win);
			sms_read_win = NULL;
		}
		/*SPR 1991 end*/		
		SmsSend_SEND_start(win, (void *) &SmsData);
	}
	/* API - 28-01-03 - 1628 - END */
	else
	{
	/* Initialise the dialog control block with default information
	*/
	dlg_initDisplayData_TextId( &Dialog, TxtNull, TxtNull, TxtNotAllowed, TxtNull , COLOUR_STATUS_WAIT);
	dlg_initDisplayData_events( &Dialog, (T_VOID_FUNC)NULL, 3000, KEY_CLEAR );

	/* Show the dialog
	*/
	info_dialog( win, &Dialog );
	
	}
    }
    return 1;
}

/*******************************************************************************

 $Function:    	SmsRead_R_READSMS_OPT_start

 $Description:	Start the creation of the Option Window from the Read SMS
  				Text window.
 			
 $Returns:		mfw window handler

 $Arguments:	parent_window- pointer to menu.
 				menuAttr - menu attributes.
*******************************************************************************/

T_MFW_HND SmsRead_R_READSMS_OPT_start(T_MFW_HND parent_window, MfwMnuAttr *menuAttr)
{
   /*SPR 2132, setting global var to keep track of options window*/

    TRACE_FUNCTION ("SmsRead_R_OPT_start()");

    option_mnu_win = SmsRead_R_OPT_create (parent_window);

    if (option_mnu_win  NEQ NULL)
	{
	    SEND_EVENT (option_mnu_win , E_INIT, SmsRead_R_READSMS_OPT_ID, (void *)menuAttr);
	}
    return option_mnu_win;
}

/*SPR 2132, removed obsolete function*/
/*******************************************************************************

 $Function:    	SmsRead_R_OPT_create

 $Description:	Create the Options window
 			
 $Returns:		window handler

 $Arguments:	parent_window- pointer to parent window
*******************************************************************************/

static T_MFW_HND SmsRead_R_OPT_create(MfwHnd parent_window)
{
    T_SMSREAD_R_OPT      * data = (T_SMSREAD_R_OPT *)ALLOC_MEMORY (sizeof (T_SMSREAD_R_OPT));
    T_MFW_WIN  * win;

    TRACE_FUNCTION ("SmsRead_R_OPT_create()");

    /*
     * Create window handler
     */

    data->win = 
	win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)SmsRead_R_OPT_win_cb);
    if (data->win EQ NULL)
	{
	    return NULL;
	}
    /* 
     * connect the dialog data to the MFW-window
     */

    data->mmi_control.dialog = (T_DIALOG_FUNC)SmsRead_R_OPT_exec_cb;
    data->mmi_control.data   = data;
    win                      = ((T_MFW_HDR *)data->win)->data;
    win->user                = (void *)data;
    data->parent             = parent_window;

    /*
     * return window handle
     */
	
    return data->win;
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_destroy

 $Description:	Destroy the Option window
 			
 $Returns:		none

 $Arguments:	own_window- current window
*******************************************************************************/

static void SmsRead_R_OPT_destroy(MfwHnd own_window)
{
    T_MFW_WIN * win_data;
    T_SMSREAD_R_OPT     * data;

    TRACE_FUNCTION ("SmsRead_R_OPT_destroy()");

    if (own_window)
	{
	    win_data = ((T_MFW_HDR *)own_window)->data;
	    data = (T_SMSREAD_R_OPT *)win_data->user;

	    if (data)
		{	
		    /*
		     * Delete WIN handler
		     */ 
		     win_delete (data->win);

		    /*     
		     * Free Memory
		     */
		    FREE_MEMORY ((void *)data, sizeof (T_SMSREAD_R_OPT));
		    option_mnu_win =0;/*SPR2132, make sure window pointer is reset*/
		}
	    else
		{
		    TRACE_EVENT ("SmsRead_R_OPT_destroy() called twice");
		}
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_exec_cb

 $Description:	Exec callback function for the Option window
 			
 $Returns:		none

 $Arguments:	win- current window
 				event - window event Id
 				value - unique Id
 				parameter- optional data.
*******************************************************************************/

void SmsRead_R_OPT_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter)
    /* callback handler for events sent to to trigger execution */
{
    T_MFW_WIN        * win_data = ((T_MFW_HDR *) win)->data;
    T_SMSREAD_R_OPT  * data     = (T_SMSREAD_R_OPT *)win_data->user;
    T_MFW_HND      * l_parent = NULL;  // RAVI
    SHORT            l_id = 0;  // RAVI

	T_MFW_EVENT         MfwEvents;
	
    TRACE_FUNCTION ("SmsRead_R_OPT_exec_cb()");


    switch (event)
	{
	case E_INIT:
		TRACE_EVENT(">> SmsRead_R_OPT_exec_cb(), E_INIT ");
		/* initialization of administrative data */
		data->id = value;
		
		if(value == SmsRead_R_READSMS_OPT_ID)
		{
			data->kbd =      kbdCreate(data->win,KEY_ALL,         (MfwCb)SmsRead_R_OPT_kbd_cb);
			data->kbd_long = kbdCreate(data->win,KEY_ALL|KEY_LONG,(MfwCb)SmsRead_R_OPT_kbd_cb);
			//Sep 08, 2004    REF: CRR 24393  Deepa M. D
			//If the message is a saved/unsent message, then provide a different menu with the Reply option removed.
			if(read_status EQ MMI_SMS_MO)
			{
				data->menu =     mnuCreate(data->win,(MfwMnuAttr *)&SmsRead_R_Unsent_OPTAttrib, E_MNU_ESCAPE, (MfwCb)SmsRead_R_OPT_mnu_cb);
			}
			else
			{
				data->menu =     mnuCreate(data->win,(MfwMnuAttr *)&SmsRead_R_OPTAttrib, E_MNU_ESCAPE, (MfwCb)SmsRead_R_OPT_mnu_cb);
			}
			mnuLang(data->menu,mainMmiLng);
			
			/* put the (new) dialog window on top of the window stack */
			mnuUnhide(data->menu);
			winShow(win);
			break;
		}	
		else
		{
			// Catch the events concerning delete
			MfwEvents = E_SMS_ERR | E_SMS_OK;
			
			data->sms = sms_create(data->win,MfwEvents,(MfwCb)SmsRead_R_OPT_mfw_cb);
			data->sms_editor_data = (T_SMS_EDITOR_DATA *)parameter;
		}
	case E_RETURN:
		/* create the dialog handler */
		data->kbd =      kbdCreate(data->win,KEY_ALL,         (MfwCb)SmsRead_R_OPT_kbd_cb);
		data->kbd_long = kbdCreate(data->win,KEY_ALL|KEY_LONG,(MfwCb)SmsRead_R_OPT_kbd_cb);
		//Sep 08, 2004    REF: CRR 24393  Deepa M. D
		//If the message is a saved/unsent message, then provide a different menu with the Reply option removed.
		if(read_status EQ MMI_SMS_MO)
		{
			data->menu =     mnuCreate(data->win,(MfwMnuAttr *)&SmsRead_R_Unsent_OPTAttrib, E_MNU_ESCAPE, (MfwCb)SmsRead_R_OPT_mnu_cb);
		}
		else
		{
			data->menu =     mnuCreate(data->win,(MfwMnuAttr *)&SmsRead_R_OPTAttrib, E_MNU_ESCAPE, (MfwCb)SmsRead_R_OPT_mnu_cb);
		}
		mnuLang(data->menu,mainMmiLng);
		
		/* put the (new) dialog window on top of the window stack */
		mnuUnhide(data->menu);
   	    winShow(win);
		break;
	    
	case E_BACK:
	    l_parent = data->parent;
		l_id = data->id;
	    SmsRead_R_OPT_destroy(data->win);
	    SEND_EVENT (l_parent, E_RETURN, l_id, NULL); /* forward event to parent */
	
	case E_ABORT:
	case E_EXIT:
	    SmsRead_R_OPT_destroy(data->win);
	    SEND_EVENT (l_parent, event, l_id, NULL); /* forward event to parent */
	    break;
	default:
	    return;
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_mfw_cb

 $Description:	Exec callback function for the DEL_ALL_ACK window
 			
 $Returns:		status

 $Arguments:	event - window event Id
 				parameter- optional data.
*******************************************************************************/

int SmsRead_R_OPT_mfw_cb (MfwEvt event, void *parameter)
{
    T_MFW_HND          win       = mfwParent((MfwHdr *)mfw_header());
    T_MFW_WIN        * win_data  = (T_MFW_WIN *)((T_MFW_HDR *)win)->data;
    T_SMSREAD_R_OPT  * data      = (T_SMSREAD_R_OPT *)win_data->user;
//	T_MFW_EVENT        MfwEvents;   // RAVI


    TRACE_FUNCTION ("SmsRead_R_OPT_mfw_cb()");

    switch (event)
	{

	case E_SMS_ERR:

		winDelete(data->dialog_win);

    	/* Display "All SMS deleted" and after timeout go back to parent */
		SmsRead_R_OPT_StandardDialog(win, "SMS not deleted", THREE_SECS); // TBD remplacer par ID

		break;

	case E_SMS_OK: 

		/* go now back to the parent             */

     	/* destroy the dialog at first           */
		winDelete(data->dialog_win);

    	/* Display "All SMS deleted" and after timeout go back to parent */
		SmsRead_R_OPT_StandardDialog(win, "SMS deleted", THREE_SECS); // TBD remplacer par ID
		break;
	}
	return 1; // ADDED BY RAVI - 28-11-2005
}	

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_mnu_cb

 $Description:	Menu callback function for the Option window
 			
 $Returns:		status

 $Arguments:	e - mfw event Id
 				m - menu handle
*******************************************************************************/

static int SmsRead_R_OPT_mnu_cb (MfwEvt e, MfwMnu *m)
    /* SmsRead_R_OPT menu event handler */
{
    T_MFW_HND    win  = mfwParent(mfw_header());
    T_MFW_WIN  * win_data = ((T_MFW_HDR *)win)->data;
    T_SMSREAD_R_OPT      * data = (T_SMSREAD_R_OPT *)win_data->user;
    T_MFW_HND  * l_parent;
    SHORT        l_id;

    TRACE_FUNCTION ("SmsRead_R_OPT_mnu_cb()");

    switch (e)
        {
	case E_MNU_ESCAPE: /* back to previous menu */
	    l_parent = data->parent;
	    l_id = data->id;
	    SmsRead_R_OPT_destroy(data->win);
	    SEND_EVENT (l_parent, E_RETURN, data->id, NULL);
	    break;
	default: /* in mnuCreate() only E_MNU_ESCAPE has been enabled! */
	    return MFW_EVENT_REJECTED;
        }
    return MFW_EVENT_CONSUMED;
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_win_cb

 $Description:	Window callback function for the Option window
 			
 $Returns:		status

 $Arguments:	e - mfw event Id
 				w - window handler
*******************************************************************************/

static int SmsRead_R_OPT_win_cb (MfwEvt e, MfwWin *w)
    /* SmsRead_R_OPT window event handler */
{
    TRACE_FUNCTION ("SmsRead_R_OPT_win_cb()");

    switch (e)
	{
        case MfwWinVisible:  /* window is visible  */
	    displaySoftKeys(TxtSoftSelect,TxtSoftBack);
	    break;
	case MfwWinFocussed: /* input focus / selected   */
	case MfwWinDelete:   /* window will be deleted   */
        default:
	    return MFW_EVENT_REJECTED;
	}
    return MFW_EVENT_CONSUMED;
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_kbd_cb

 $Description:	Exec callback function for the Option window
 			
 $Returns:		status

 $Arguments:	e - keyboard event Id
 				k - keyboard data 
*******************************************************************************/

static int SmsRead_R_OPT_kbd_cb (MfwEvt e, MfwKbd *k)
    /* SmsRead_R_OPT keyboard event handler */
{
    T_MFW_HND    win  = mfwParent(mfw_header());
    T_MFW_WIN  * win_data = ((T_MFW_HDR *)win)->data;
    T_SMSREAD_R_OPT      * data = (T_SMSREAD_R_OPT *)win_data->user;

    TRACE_FUNCTION ("SmsRead_R_OPT_kbd_cb()");

    if (e & KEY_LONG)
	{
	    switch (k->code)
		{
		case KCD_HUP: /* back to previous menu */
		    mnuEscape(data->menu);
		    break;
		case KCD_RIGHT: /* Power Down */
		    return MFW_EVENT_REJECTED; /* handled by idle */
		default: /* no response to all other keys */
		    return MFW_EVENT_CONSUMED;
		}
	}
    else
	{
	    switch (k->code)
		{
		case KCD_MNUUP: /* highlight previous entry */
		    mnuUp(data->menu);
		    break;
		case KCD_MNUDOWN: /* highlight next entry */
		    mnuDown(data->menu);
		    break;
		case KCD_MNUSELECT:
		case KCD_LEFT: /* activate this entry */
		    mnuSelect(data->menu);
		    break;
		case KCD_HUP: /* back to previous menu */
		case KCD_RIGHT: /* back to previous menu */
		    mnuEscape(data->menu);
		    break;
		default: /* no response to all other keys */
		    return MFW_EVENT_CONSUMED;
		}
	}
    return MFW_EVENT_CONSUMED;
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_dialog_cb

 $Description:	Dialog callback function of the SMS read window (dynamic list 
 				of all the SMS). Case where SMS has not been initialized yet.
 			
 $Returns:		status

 $Arguments:	win - window handler.
 				Identifier -  unique identifier.
 				Reason - cause of event.
*******************************************************************************/

int SmsRead_R_OPT_dialog_cb(T_MFW_HND win, USHORT Identifier, USHORT Reason)
{
	T_MFW_WIN *win_data = ((T_MFW_HDR *)win)->data;
	T_SMSREAD_R_OPT *data = (T_SMSREAD_R_OPT *)win_data->user;
	T_MFW_HND *lparent = data->parent;
	
    TRACE_FUNCTION ("SmsRead_dialog_cb()");
	
	switch (Reason)
	{
	case INFO_TIMEOUT:
	case INFO_KCD_HUP:
		// Commit suicide
		SmsRead_R_OPT_destroy(win);
		// Send E_RETURN event to parent window
		SEND_EVENT(lparent, E_RETURN, data->id, NULL);
		return MFW_EVENT_CONSUMED;

	default:
		return MFW_EVENT_REJECTED;
	}
}

/*******************************************************************************

 $Function:    	SmsRead_DisplayStandardDialog

 $Description:	Display a standard dialog with no soft key and 3 seconds of display
 			
 $Returns:		none

 $Arguments:	win - window handler.
 				text -  text string.
 				duration - seconds
*******************************************************************************/

void SmsRead_DisplayStandardDialog(T_MFW_HND win, int TextId, ULONG duration)
{
	T_DISPLAY_DATA DisplayInfo;
	
	SmsMenu_loadDialogDefault(&DisplayInfo);

       DisplayInfo.TextId = TextId;
	DisplayInfo.Time = duration;
	DisplayInfo.Callback = (T_VOID_FUNC)SmsRead_R_dialog_cb; 

//	Dec 15,2004 REF: CRR 24396 xkundadu
//	Description: Phone crashes when a message is received while the 
//			    'List Empty' dialog is displayed.

	// set the variable to TRUE since  'List empty' dialog is going to display. 
	SmsListEmptyDlgPresent = TRUE;
   	 info_dialog(win, &DisplayInfo);
}

/*******************************************************************************

 $Function:    	SmsRead_R_OPT_StandardDialog

 $Description:	Display a standard dialog with no soft key and 3 seconds of display
 			
 $Returns:		none

 $Arguments:	win - window handler.
 				text -  text string.
 				duration - seconds
*******************************************************************************/

void SmsRead_R_OPT_StandardDialog(T_MFW_HND win, char *text, ULONG duration)
{
	T_MFW_WIN *win_data = ((T_MFW_HDR *)win)->data;
	T_SMSREAD_R_OPT *data = (T_SMSREAD_R_OPT *)win_data->user;

	T_DISPLAY_DATA DisplayInfo;
	
	SmsMenu_loadDialogDefault(&DisplayInfo);

    DisplayInfo.TextId = 0;
	DisplayInfo.Time = duration;
    DisplayInfo.TextString = text;
	DisplayInfo.Callback = (T_VOID_FUNC)SmsRead_R_OPT_dialog_cb; //TBD

    data->dialog_win = info_dialog(win, &DisplayInfo);
}


/*SPR2175, removed unused function*/


/*******************************************************************************

 $Function:    	string_CopyW2W

 $Description:	
 			
 $Returns:		none

 $Arguments:	strDestination - destination string
 				strSource -  source string
 				count -number of character.
*******************************************************************************/

void string_CopyW2W(wstring_t *strDestination, charw_t *strSource, USHORT count )
	// Copy characters of an ascii string to a wide counted string
{
	charw_t *pout = strDestination;
	while(count!=0)
	{
		*pout++ = *strSource++;
		count--;
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXTEDT2_start

 $Description:	Start the creation of the SMS editor window (display of the text 
 				of one SMS)
 
 $Returns:		win - window handler.

 $Arguments:	parent_window - current window handler
 				data - Menu attributes.
 
*******************************************************************************/

T_MFW_HND SmsRead_R_TEXTEDT2_start(T_MFW_HND parent_window, MfwMnuAttr *data)
{
   /*SPR 2132, use global var*/
    TRACE_FUNCTION ("SmsRead_R_TEXTEDT2_start()");

    message_win = SmsRead_R_TEXTEDT2_create (parent_window);

    if (message_win NEQ NULL)
	{
	    SEND_EVENT (message_win, E_INIT, SmsRead_R_TEXTEDT2_ID, (void *)data);
	}
    return message_win;
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXTEDT2_create

 $Description:	Create the SMS editor window (display of the text of one SMS)
 
 $Returns:		window handler.

 $Arguments:	parent_window - current window handler
 				
*******************************************************************************/

static T_MFW_HND SmsRead_R_TEXTEDT2_create(MfwHnd parent_window)
{
    T_SMSREAD_R_TEXTEDT2      * data = (T_SMSREAD_R_TEXTEDT2 *)ALLOC_MEMORY (sizeof (T_SMSREAD_R_TEXTEDT2));
    T_MFW_WIN  * win;

    TRACE_FUNCTION ("SmsRead_R_TEXTEDT2_create()");

    /*
     * Create window handler
     */
	
    data->win = 
	win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)SmsRead_R_TEXTEDT2_win_cb);
    if (data->win EQ NULL)
	{
	    return NULL;
	}
    /* 
     * connect the dialog data to the MFW-window
     */

    data->mmi_control.dialog = (T_DIALOG_FUNC)SmsRead_R_TEXTEDT2_exec_cb;
    data->mmi_control.data   = data;
    win                      = ((T_MFW_HDR *)data->win)->data;
    win->user                = (void *)data;
    data->parent             = parent_window;

    /*
     * return window handle
     */
	winShow(data->win);
    return data->win;
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXTEDT2_destroy

 $Description:	Destroy the SMS editor window (display of the text of one SMS)
 
 $Returns:		none

 $Arguments:	own_window - current window handler
 				
*******************************************************************************/

static void SmsRead_R_TEXTEDT2_destroy(MfwHnd own_window)
{
    T_MFW_WIN * win_data;
    T_SMSREAD_R_TEXTEDT2     * data;

//	USHORT i;   // RAVI

    TRACE_FUNCTION ("SmsRead_R_TEXTEDT2_destroy()");

    if (own_window)
	{
	    win_data = ((T_MFW_HDR *)own_window)->data;
	    data = (T_SMSREAD_R_TEXTEDT2 *)win_data->user;

	    if (data)
		{
		    /*
		     * Delete WIN handler
		     */ 

			/* SPR#1428 - SH - New Editor changes */
#ifdef NEW_EDITOR
			AUI_edit_Destroy(data->editor_win);
#else /* NEW_EDITOR */
			editor_destroy(data->editor_win);
#endif /* NEW_EDITOR */

		    win_delete (data->win);

			
	        
			FREE_MEMORY ((void *)data->sms_editor_data->sms_info, sizeof (T_MFW_SMS_PARA));

		    FREE_MEMORY ((void *)data, sizeof (T_SMSREAD_R_TEXTEDT2));
		
		message_win = 0; /*SPR2132, make sure window pointer is reset*/
		}
	    else
		{
		    TRACE_EVENT ("SmsRead_R_TEXTEDT2_destroy() called twice");
		}
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXT_editor_cb

 $Description:	Callback function for the text editor
 
 $Returns:		none

 $Arguments:	win - current window handler
 				Identifier -Unique identifier.
 				reason - event 
*******************************************************************************/

static void SmsRead_R_TEXT_editor_cb (T_MFW_HND win, USHORT Identifier, SHORT reason)
{
	T_MFW_PHB_ENTRY  pb_data;

	T_MFW_WIN   * win_data = ((T_MFW_HDR *) win)->data;
	T_SMSREAD_R_TEXTEDT2      * data     = (T_SMSREAD_R_TEXTEDT2 *)win_data->user;

	T_MFW_HDR    * parent      =  data->parent;
    T_MFW_WIN    * win_data2   =  ((T_MFW_HDR *)parent)->data;    
//    T_SMSREAD_R_TEXTEDT2  * parent_data =  (T_SMSREAD_R_TEXTEDT2 *)win_data2->user;  // RAVI

 //   T_MFW_SMS_STAT  sms_list_type = MFW_SMS_ALL;  // RAVI


	TRACE_FUNCTION ("SmsRead_R_TEXT_editor_cb()");

	switch (reason)
	{
	case INFO_KCD_LEFT:
		//x0pleela 08 Feb, 2006 DR: OMAPS00059261
		//Replacing MT_STATUS_RPT with MFW_SMS_STATRPT as MT_STATUS_RPT is removed
		//x0pleela 30 Jan, 2006 DR: OMAPS00059261
		//Displaying different options screen for normal MT text message. 
		//whereas, for staus report message, the message is deleted, since the option is "Delete" in LSK
		if( data->sms_editor_data->sms_info->sms_mt.sms_msg_type EQ MFW_SMS_STATRPT)
		{
			if(sms_msg_delete((UBYTE)data->sms_editor_data->sms_info->sms_mt.index/*SPR 2686*/)== MFW_SMS_OK)
			{
		       /* set the status that the user selected the delete item */
				if(deleting_win == 0)
					deleting_win= mmi_dialog_information_screen_forever(0,TxtPleaseWait, NULL, COLOUR_STATUS_WAIT);

				SmsRead_R_TEXTEDT2_destroy(data->win);
			/*SPR 2530, Delete and recreate SMS list window to show updates*/
			 {	T_MFW_SMS_STAT  sms_list_type = MFW_SMS_ALL;

				listsDestroy(list_win);
				list_win=0;
			    SmsRead_R_destroy(sms_read_win);
				SmsRead_R_start(NULL, (MfwMnuAttr*)&sms_list_type);
			}

			}
			else
			{		   		
				
				/*SPR2530, don't delete option and display windows, just show failure*/
				mmi_dialog_information_screen(0,TxtFailed, NULL, NULL, COLOUR_STATUS_WAIT);
			}
		}
		//x0pleela 01 Feb, 2006 DR: OMAPS00059261
		//Made changes as per review comments
		else //MT_TEXT
		{
		// Present the user with an Options menu from the Read SMS text screen.:16/2/01
			SmsRead_R_READSMS_OPT_start(win, (MfwMnuAttr*)&data->sms_editor_data);
		}
		
		break;
	          
		case INFO_KCD_RIGHT:
		case INFO_KCD_HUP:
			SmsRead_R_TEXTEDT2_destroy(data->win);
			/*SPR 2530, Delete and recreate SMS list window to show updates*/
			{ T_MFW_SMS_STAT  sms_list_type = MFW_SMS_ALL;

				listsDestroy(list_win);
				list_win=0;
			    SmsRead_R_destroy(sms_read_win);
				SmsRead_R_start(NULL, (MfwMnuAttr*)&sms_list_type);
	    	}
			break;
		case INFO_KCD_DOWN:
			break;
		case INFO_KCD_CALL:
            /* Marcus: Issue 1041: 05/09/2002: Start */
            strcpy((char *)pb_data.number, (char *)SmsData.NumberBuffer);
            /* Marcus: Issue 1041: 05/09/2002: End */
        	TRACE_EVENT_P1("Number is = %d",(int)pb_data.number);
        	callNumber(pb_data.number);
		break;


		default:
			TRACE_EVENT("Err: Default No match found");
			break;
	}
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXTEDT2_exec_cb

 $Description:	Exec callback function of the SMS editor window (display of the 
 				text of one SMS)
 
 $Returns:		none

 $Arguments:	win - current window handler
 				event - event id
 				value - unique id
 				parameter - optional data. 
*******************************************************************************/

void SmsRead_R_TEXTEDT2_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter)
    /* callback handler for events sent to to trigger execution */
{	
    T_MFW_WIN      * win_data = ((T_MFW_HDR *) win)->data;
    T_SMSREAD_R_TEXTEDT2          * data = (T_SMSREAD_R_TEXTEDT2 *)win_data->user;
    T_MFW_HND      * l_parent;
    SHORT            l_id;
    T_MFW_SMS_MO *SmsMo;
    T_MFW_SMS_MT *SmsMt;
	T_MFW_SMS_CB *SmsCb;

	/* SPR#1428 - SH - New Editor changes */
#ifdef NEW_EDITOR
	T_AUI_EDITOR_DATA sms_editor_info;
	USHORT size;
/*SPR 2530*/
	T_ATB_TEXT main_text;
	T_ATB_TEXT temp_text;
//	T_ATB_DCS atb_dcs;  // RAVI
#else /* NEW_EDITOR */
	T_EDITOR_DATA sms_editor_info;
#endif /* NEW_EDITOR */

//	USHORT i, line_ret, line_nb;   // RAVI
	USHORT msg_len;
//	div_t result;     // RAVI
    /* JVJ SPR 1298 - Memory optimization. Converted to dynamic and size decreased*/
    char* sms_text_buffer = (char*)ALLOC_MEMORY(MAX_EDITOR_HEADER_LENGTH);
	T_MFW_PHB_ENTRY  pb_entry;
	USHORT index=0;
	T_MFW_SMS_IDX msg_info;/*SPR 2530*/
	
    TRACE_FUNCTION ("SmsRead_R_TEXTEDT2_exec_cb()");

    switch (event)
	{
	case E_INIT:
	{  UBYTE input_type;/*MC SPR1242*/
	    /* initialization of administrative data */
	    data->id = value;

		data->sms_editor_data = (T_SMS_EDITOR_DATA *)parameter;
		
		switch (data->sms_editor_data->sms_type)
		{
		case MMI_SMS_MO:
			
			/* where does we need that:
			   For editor when the user wants to editing the sms-message
			*/
			read_status = MMI_SMS_MO;

			SmsMo = (T_MFW_SMS_MO *)data->sms_editor_data->sms_info;
	
			sms_copy_idx(SmsMo->msg_ref, &msg_info);/*SPR 1830*/
			// API Clear the buffers before showing the MO message.
      		memset (sms_text_ascii, '\0', MAX_EDITOR_LEN);
      		memset (sms_text_buffer, '\0', MAX_EDITOR_HEADER_LENGTH);
/*SPR 2530, if new ediotr use nice string-handling functions*/
#ifdef NEW_EDITOR
			main_text.data = (UBYTE*)sms_text_ascii;
			/*if we are in chinese, then we need to display in Unicode, otherwise ASCII*/
			if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
				main_text.dcs = ATB_DCS_UNICODE;
			else
				main_text.dcs = ATB_DCS_ASCII;
		       ATB_string_Length(&main_text);  
			/*if this isn't an invalid message*/
			if (msg_info.stat != MFW_SMS_INVALID)
			{	/*set text string dcs, according to alphabet used for message*/
				if ( (SmsMo->dcs & 0x0c) == MFW_DCS_UCS2 || SmsMo->sms_msg[0] == 0x80)
				{
					temp_text.dcs = ATB_DCS_UNICODE;
					/* CQ 16780  15-01-04 MZ */
					/*copy message text to string*/
					temp_text.data = (UBYTE*)SmsMo->sms_msg;
				}
				else
				{
					temp_text.dcs = ATB_DCS_ASCII;
					/* CQ: 16780 Convert to Ascii format 15-01-04 MZ */
					ATB_convert_String(	SmsMo->sms_msg, MFW_DCS_8bits , SmsMo->msg_len,
										sms_text_ascii, MFW_ASCII,  MAX_MSG_LEN, TRUE);
					/*copy message text to string*/
					temp_text.data = (UBYTE*)sms_text_ascii;
				}
				
				ATB_string_Length(&temp_text);
				/*concat message text into display string*/
				ATB_string_Concat(&main_text, &temp_text);
				/*if this is an incomplete concat message, add "Incomplete Message" to end of display text*/
				if (msg_info.concat_status == MFW_SMS_CONC_PART)
				{	
				       ATB_string_SetChar(&main_text, ATB_string_Length(&main_text),(USHORT)":");
					if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
						temp_text.dcs = ATB_DCS_UNICODE;
					else
						temp_text.dcs = ATB_DCS_ASCII;
					temp_text.data = (UBYTE*)MmiRsrcGetText(TxtIncompleteMessage);
					ATB_string_Length(&temp_text);
					ATB_string_Concat(&main_text, &temp_text);
				}

			}
			else
			{/*set display text to "Invalid Message"*/
				if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
					temp_text.dcs = ATB_DCS_UNICODE;
				else
					temp_text.dcs = ATB_DCS_ASCII;
				temp_text.data = (UBYTE*)MmiRsrcGetText(TxtInvalidMessage);
				ATB_string_Length(&temp_text);
				ATB_string_Concat(&main_text, &temp_text);
			}
#else

					/* SH - convert from original dcs once more */

			/*MC,SPR1242 don't trust the DCS, check for Unicode tag*/
			if (SmsMo->sms_msg[0] == 0x80||SmsMo->dcs == MFW_DCS_UCS2)
			{	input_type = MFW_DCS_UCS2;}
			else
			{	input_type = MFW_DCS_8bits;}

			/*mc end*/
			if (input_type == MFW_DCS_UCS2/*MC SPR1242*/)
			{/*SPR2175, use new function for conversion*/

				ATB_convert_String(	SmsMo->sms_msg, /*SmsMo->dcs*/input_type/*MC SPR1242*/, SmsMo->msg_len,
										&sms_text_ascii[2], MFW_DCS_UCS2,  MAX_MSG_LEN-2, TRUE);
				sms_text_ascii[0] = 0x80;
				sms_text_ascii[1] = 0x7F;
			}
			else
			{/*SPR2175, use new function for conversion*/
			  
				ATB_convert_String(	SmsMo->sms_msg, /*SmsMo->dcs*/input_type/*MC SPR1242*/ , SmsMo->msg_len,
										sms_text_ascii, MFW_ASCII,  MAX_MSG_LEN, TRUE);
				
			}

#endif			
			break;

		case MMI_SMS_MT:
			/* where does we need that:
				For editor when the user wants to editing the sms-message
			 */
			read_status = MMI_SMS_MT;
			
			SmsMt = (T_MFW_SMS_MT *)data->sms_editor_data->sms_info;
			sms_copy_idx(SmsMt->index, &msg_info);/*SPR 2530*/
      		memset (sms_text_ascii, '\0', MAX_EDITOR_LEN);
      		memset (sms_text_buffer, '\0',MAX_EDITOR_HEADER_LENGTH);
/*SPR 2530, if new editor use nice string-handling functions*/
#ifdef NEW_EDITOR
			main_text.data = (UBYTE*)sms_text_ascii;
/*set up text data stucture for main display string*/
			if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
				main_text.dcs = ATB_DCS_UNICODE;
			else
				main_text.dcs = ATB_DCS_ASCII;
			ATB_string_Length(&main_text);  		
#endif
			if (msg_info.stat != MFW_SMS_INVALID)/*SPR 1830*/
			{	

            /* Marcus: Issue 1041: 05/09/2002: Start */
            // API - Copy number into buffer so when Call key is pressed in editor call is generated
        	strcpy((char *)SmsData.NumberBuffer,(char *)SmsMt->orig_addr.number);
            /* Marcus: Issue 1041: 05/09/2002: End */

            /* Marcus: Issue 1489: 13/12/2002: Start */
            /*API - 1053 - 09-09-02 Copy the number into this buffer so that when 
									a call is generated from the editor it is connected.
			*/
            if(SmsMt->orig_addr.ton == MFW_TON_INTERNATIONAL)
            {
     			if(SmsMt->orig_addr.number[0] == '+')
	    		{
		    		strcpy((char *)SmsData.NumberBuffer,(char *)SmsMt->orig_addr.number);
     			}
	    		else
    			{
	    			strcpy((char *)SmsData.NumberBuffer, "+");
    				strncat((char *)SmsData.NumberBuffer,(char *)SmsMt->orig_addr.number,sizeof(SmsData.NumberBuffer)-2);
    			}
            }
#ifndef NEW_EDITOR
							/* add the number or the name if he can find it in the phonebook*/
			if (bookFindNameInPhonebook((const char*)SmsMt->orig_addr.number, &pb_entry) !=0)
			{
#ifdef NO_ASCIIZ
				/*mc SPR 1257, unicode support*/
				memcpy(sms_text_ascii, (char*)pb_entry.name.data,pb_entry.name.len );
#else
				strcpy(sms_text_ascii, (char*)pb_entry.name);
#endif
			}
			else
			{
				
				strcpy(sms_text_ascii, (char *)SmsData.NumberBuffer);
                /* Marcus: Issue 1489: 13/12/2002: End */
			}
#else
/*SPR 2530, if new editor use nice string-handling functions*/
		/*see if the sender is in the phonebook*/
		if (bookFindNameInPhonebook((const char*)SmsMt->orig_addr.number, &pb_entry) !=0)
		{	char temp_string[PHB_MAX_LEN];

				memset(temp_string, '\0', PHB_MAX_LEN);
				/*copy name into a text data structure*/
				
				/* CQ: 16780 Check the phonebook string format by testing the dcs. NOT the dcs values are Enum types and not the true dcs 
				     values of the ADN store. 15-01-04 MZ */
				if (pb_entry.name.dcs == MFW_DCS_UCS2  ||pb_entry.name.data[0] == 0x80 )
					    temp_text.dcs = ATB_DCS_UNICODE;
				else
					temp_text.dcs = ATB_DCS_ASCII;
				
				if (temp_text.dcs != ATB_DCS_UNICODE)
				{	
					temp_text.data = (UBYTE*)pb_entry.name.data;	
				}
				
				else
				{
					/*  CQ:16780 Check for unicode string type 15-01-04 MZ*/ 
					if(pb_entry.name.data[0] == 0x80)
					{
					 	pb_entry.name.len-=2;
						memcpy(temp_string, &pb_entry.name.data[2], pb_entry.name.len);
					}
					else
					{
						memcpy(temp_string, &pb_entry.name.data[0], pb_entry.name.len);
					}
					
					temp_text.data = (UBYTE*)temp_string;
					
					
				}
				ATB_string_Length(&temp_text);
				/*add name text into main display string*/
				ATB_string_Concat(&main_text, &temp_text);

		}
			ATB_string_Length(&main_text);

#endif
#ifndef NEW_EDITOR
	/* SH - convert from original dcs once more */
				/*MC,SPR1242 don't trust the DCS, check for Unicode tag*/
			if (SmsMt->sms_msg[0] == 0x80||SmsMt->dcs == MFW_DCS_UCS2)
			{	input_type = MFW_DCS_UCS2;}
			else
			{	input_type = MFW_DCS_8bits;}

			/*mc end*/
			if (/*SmsMt->dcs*/input_type == MFW_DCS_UCS2)
			{	/*SPR2175, use new function for conversion*/
				ATB_convert_String(	SmsMt->sms_msg, input_type /*MC SPR1242*/, SmsMt->msg_len,
										&sms_text_ascii[2], MFW_DCS_UCS2,  MAX_MSG_LEN-2, TRUE);
				sms_text_ascii[0] = 0x80;
				sms_text_ascii[1] = 0x7F;
			}
			else
			{
		
#endif
					if(strlen(sms_text_ascii) != 14 ) // number of character that can be displayed on one line.
						sms_text_buffer[index++]='\n';
				
					sms_text_buffer[index++]='0'+SmsMt->sctp.day[0];
					sms_text_buffer[index++]='0'+SmsMt->sctp.day[1];
					sms_text_buffer[index++]='/';
					sms_text_buffer[index++]='0'+SmsMt->sctp.month[0];
					sms_text_buffer[index++]='0'+SmsMt->sctp.month[1];
					sms_text_buffer[index++]='/';
					sms_text_buffer[index++]='0'+SmsMt->sctp.year[0];
					sms_text_buffer[index++]='0'+SmsMt->sctp.year[1];
					sms_text_buffer[index++]=',';
					sms_text_buffer[index++]='\n';
					
					sms_text_buffer[index++] ='0'+SmsMt->sctp.hour[0];
					sms_text_buffer[index++]='0'+SmsMt->sctp.hour[1];
					sms_text_buffer[index++]=':';
					sms_text_buffer[index++]='0'+SmsMt->sctp.minute[0];
					sms_text_buffer[index++]='0'+SmsMt->sctp.minute[1];
					sms_text_buffer[index++]='\n';	
#ifndef NEW_EDITOR
		strcat(sms_text_ascii, sms_text_buffer);
				msg_len = strlen(sms_text_ascii);
				
				/*
					keep the length of the additional information (Date,Time & Number);
					need it later for editing the sms messages (user pressed-> EDIT)
				*/
				current_sms_len = msg_len;
				
				/* SH - convert from original dcs once more */
				/*SPR2175, use new function for conversion*/
				ATB_convert_String(	SmsMt->sms_msg, /*SmsMt->dcs*/input_type /*MC SPR1242*/, SmsMt->msg_len,
            		&sms_text_ascii[msg_len], MFW_ASCII /*SH*/,  MAX_EDITOR_LEN-(msg_len+1), TRUE);

			}

#else
/*SPR 2530, if new editor use nice string-handling functions*/
				/*Add date and time to main display string*/
				temp_text.dcs = ATB_DCS_ASCII;
				temp_text.data = (UBYTE*)sms_text_buffer;
				ATB_string_Length(&temp_text);
				ATB_string_Concat(&main_text, &temp_text);

				
				if ((SmsMt->dcs&0x0c) == MFW_DCS_UCS2)
				{
					temp_text.dcs = ATB_DCS_UNICODE;
					temp_text.data = (UBYTE*)SmsMt->sms_msg;
				}
				else
				{
					temp_text.dcs = ATB_DCS_ASCII;
					
					/* CQ 16780 Convert incoming SMS text to ASCIII 15-01-04 MZ */ 
					
					ATB_convert_String(	SmsMt->sms_msg, MFW_DCS_8bits , SmsMt->msg_len,
										(char*)temp_text.data, MFW_ASCII,  MAX_MSG_LEN, TRUE);
				}
				
				ATB_string_Length(&temp_text);
				ATB_string_Concat(&main_text, &temp_text);
				/*if the message is a fragment of a concat message*/
				if (msg_info.concat_status == MFW_SMS_CONC_PART)
				{	ATB_string_SetChar(&main_text, ATB_string_Length(&main_text),(USHORT)":");
					if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
						temp_text.dcs = ATB_DCS_UNICODE;
					else
						temp_text.dcs = ATB_DCS_ASCII;
					/*append "Incomplete Message" onto display string*/
					temp_text.data = (UBYTE*)MmiRsrcGetText(TxtIncompleteMessage);
					ATB_string_Length(&temp_text);
					ATB_string_Concat(&main_text, &temp_text);
				}
#endif
			}
			else
#ifdef NEW_EDITOR
			/*SPR 2530, if new editor use nice string-handling functions*/
			{	/*if invalid message just copy "Invalid message" into main display string*/
				if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
					temp_text.dcs = ATB_DCS_UNICODE;
				else
					temp_text.dcs = ATB_DCS_ASCII;
				temp_text.data = (UBYTE*)MmiRsrcGetText(TxtInvalidMessage);
				ATB_string_Length(&temp_text);
				ATB_string_Concat(&main_text, &temp_text);
			}
#endif
			sms_change_read_status(SmsMt->index);
			break;

		case MMI_SMS_CB:

			SmsCb = (T_MFW_SMS_CB *)data->sms_editor_data->sms_info;
			
			break;

		}

			/*
				Actually we have 2 different size of messages:
				1) SMS_MT with MAX_EDITOR_LEN because of the DATE,TIME,NUMBER
				2) SMS_MO with MAX_MSG_LEN, just the message itself
			*/

			/* SPR#1428 - SH - New Editor changes */
#ifdef NEW_EDITOR
			AUI_edit_SetDefault(&sms_editor_info);
			
			/* Include title for colour display */
#ifdef COLOURDISPLAY
			AUI_edit_SetDisplay(&sms_editor_info, ZONE_FULL_SK_TITLE_SCROLL, COLOUR_EDITOR, EDITOR_FONT);
#else /* COLOURDISPLAY */
			AUI_edit_SetDisplay(&sms_editor_info, ZONE_FULL_SK_SCROLL, COLOUR_EDITOR, EDITOR_FONT);
#endif /* COLOURDISPLAY */
			AUI_edit_SetMode(&sms_editor_info, ED_MODE_ALPHA | ED_MODE_READONLY, ED_CURSOR_NONE);
			AUI_edit_SetEvents(&sms_editor_info, 0, FALSE, FOREVER, (T_AUI_EDIT_CB)SmsRead_R_TEXT_editor_cb);

			//x0pleela 08 Feb, 2006 DR: OMAPS00059261
			//Replacing MT_STATUS_RPT with MFW_SMS_STATRPT as MT_STATUS_RPT is removed

			//x0pleela 01 Feb, 2006 DR: OMAPS00059261
			//Made changes as per review comments
			
			//x0pleela 30 Jan, 2006 DR: OMAPS00059261
			//Displaying the LSK as "Delete" for MT Staus report and "Options" for normal MT Text message 
			if (SmsMt->sms_msg_type EQ MFW_SMS_STATRPT) 
				AUI_edit_SetTextStr(&sms_editor_info, TxtDelete, TxtSoftBack, TxtMessage, NULL);
			else 
				AUI_edit_SetTextStr(&sms_editor_info, TxtSoftOptions, TxtSoftBack, TxtMessage, NULL);
			
			/* Check if concatenated sms is activated */
			
			if (read_status EQ MMI_SMS_MO)
      			size	= MAX_MSG_LEN;
			else
				size	= MAX_EDITOR_LEN;
/*SPR 2530, copy display screen to editor, alphabet depends on current lanaguage*/	
			if (Mmi_getCurrentLanguage() == CHINESE_LANGUAGE)
			{
				/* Unicode SMS message  */
				AUI_edit_SetBuffer(&sms_editor_info, ATB_DCS_UNICODE, (UBYTE *)&sms_text_ascii[0],size/2);
			}
			else
			{
				/* ASCII SMS message */
				AUI_edit_SetBuffer(&sms_editor_info, ATB_DCS_ASCII, (UBYTE *)&sms_text_ascii[0],size);
			}

			data->editor_win = AUI_edit_Start(win,&sms_editor_info);  /* start the editor */
			
		#else /* NEW_EDITOR */

			SmsSend_loadEditDefault(&sms_editor_info);			
			sms_editor_info.editor_attr.text	    = (char *)sms_text_ascii;

			if (read_status EQ MMI_SMS_MO)
      			sms_editor_info.editor_attr.size	= MAX_MSG_LEN;
			else
				sms_editor_info.editor_attr.size	= MAX_EDITOR_LEN;
			sms_editor_info.min_enter				= 0; 

			//x0pleela 08 Feb, 2006 DR: OMAPS00059261
			//Replacing MT_STATUS_RPT with MFW_SMS_STATRPT as MT_STATUS_RPT is removed
			
			//x0pleela 30 Jan, 2006 DR: OMAPS00059261
			//Displaying the LSK as "Delete" for MT Staus report and "Options" for normal MT Text message 
			if (SmsMt->sms_msg_type EQ MFW_SMS_STATRPT )
			{
				sms_editor_info.LeftSoftKey				= TxtDelete;
				sms_editor_info.AlternateLeftSoftKey	= TxtDelete;
			}
			//x0pleela 01 Feb, 2006 DR: OMAPS00059261
			//Made changes as per review comments
			else //if( SmsMt->sms_msg_type EQ MT_TEXT )
			{
				sms_editor_info.LeftSoftKey				= TxtSoftOptions;
				sms_editor_info.AlternateLeftSoftKey	= TxtSoftOptions;
			}	
			sms_editor_info.RightSoftKey			= TxtSoftBack;
			sms_editor_info.Identifier				= 0 ; 
			sms_editor_info.destroyEditor			= FALSE ;
			sms_editor_info.Callback				= (T_EDIT_CB)SmsRead_R_TEXT_editor_cb;
			sms_editor_info.mode					= READ_ONLY_MODE;

			data->editor_win = editor_start(win,&sms_editor_info);  /* start the editor */
		#endif /* NEW_EDITOR */


		if (info_win){
    	      SEND_EVENT(info_win,DIALOG_DESTROY,0,0 );
	          info_win = 0;
		}


		break;
	}
	case E_BACK:
	    l_parent = data->parent;
	    l_id = data->id;
	    /* The editor has sent an E_BACK event, we return to the previous window (E_RETURN) */
	    SEND_EVENT (l_parent, E_RETURN, l_id, NULL);
	    SmsRead_R_TEXTEDT2_destroy(data->win);
		break;
		
	case E_ABORT:
	case E_EXIT:
	    l_parent = data->parent;
	    l_id = data->id;
	    SEND_EVENT (l_parent, event, l_id, NULL); /* forward event to parent */
	    SmsRead_R_TEXTEDT2_destroy(data->win);
	    break;

	default:
    break;
	}

    FREE_MEMORY((void*)sms_text_buffer,MAX_EDITOR_HEADER_LENGTH);
    return;
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXTEDT2_win_cb

 $Description:	Window callback function of the SMS editor window (display of 
 				the text of one SMS).

 $Returns:		execution status

 $Arguments:	w - mfw window handle
 				e - event id
 				value - unique id
 				parameter - optional data. 
*******************************************************************************/

static int SmsRead_R_TEXTEDT2_win_cb (MfwEvt e, MfwWin *w)
    /* window event handler */
{
    TRACE_FUNCTION ("SmsRead_R_TEXTEDT2_win_cb()");

    switch (e)
	{
        case MfwWinVisible:  /* window is visible  */
//JVJE	    displaySoftKeys(TxtSoftSelect,TxtSoftBack);
	    break;
	case MfwWinFocussed: /* input focus / selected   */
	case MfwWinDelete:   /* window will be deleted   */
        default:
	    return MFW_EVENT_REJECTED;
	}
    return MFW_EVENT_CONSUMED;
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXTEDT2_smslist_cb

 $Description:	Callback function of the SMS editor window (editor itself).
 
 $Returns:		none
 
 $Arguments:	Parent - parent window.
 				ListData - Menu item list
*******************************************************************************/

void SmsRead_R_TEXTEDT2_smslist_cb(T_MFW_HND * Parent, ListMenuData * ListData)
{
    T_MFW_WIN       * win_data = ((T_MFW_HDR *)Parent)->data;
    T_SMSREAD_R * data     = (T_SMSREAD_R *)win_data->user;    
	  
	T_MFW_HND      * l_parent;
    SHORT            l_id;

	if ((ListData->Reason EQ LISTS_REASON_BACK) || (ListData->Reason EQ LISTS_REASON_CLEAR)
		|| (ListData->Reason EQ LISTS_REASON_HANGUP))
	{
	    l_parent = data->parent;
	    l_id = data->id;
	    SmsRead_R_destroy(data->win);
	    //The editor has sent an back event, we return to the previous window (E_RETURN)
	    SEND_EVENT (l_parent, E_RETURN, l_id, NULL);
	}
}

/*******************************************************************************

 $Function:    	check_assoc_name

 $Description:	This function search if a phone number corresponds to any name in phonebook
			 	or to the voice mailbox or to the SMS center
			 	BE CAREFUL it allocates memory for the name, that has to be freed by the caller
			 	It returns the length of the associated name if found, else length is 0 and name is NULL
			 
 $Returns:		string length
 
 $Arguments:	name - string
 				sms_addr - phonenumber string.
*******************************************************************************/

UBYTE check_assoc_name(char *name, T_MFW_SMS_ADDR sms_addr)
{
	// MZ T_MFW_SMS_STAT pb_entry;
	T_MFW_SMS_ADDR pb_entry;
	USHORT i;



	// TBD: add international numbers management

	// Voice, fax... mailboxes data
	
//	USHORT max_rcd;  // RAVI
	char mail_number[PHB_MAX_LEN + 1];
	char mail_alpha[10]; // size hard coded in pcm.h
	UBYTE nlen;

	name = NULL;

	// First: look in phonebook
	
	if (bookFindNameInPhonebook((const char*)&sms_addr.number[0], (T_MFW_PHB_ENTRY*)&pb_entry))
	{
		// A name has been found
		if ((name = (char*)ALLOC_MEMORY(strlen(pb_entry.tag) + 1)) != NULL)
		{
		/*Mc , unicode support*/
		#ifdef NO_ASCIIZ
				memcpy(name, pb_entry.tag, pb_entry.len);
				return pb_entry.len;
		#else
			strcpy(name, pb_entry.tag);
			return strlen(name);
		#endif
		}
	}
	
	// Then the different mailboxes (voice, fax, data...)
	for (i = MFW_MB_LINE1; i <= MFW_MB_DATA; i++)
	{

		{
			cmhPHB_getAdrStr(mail_number, PHB_MAX_LEN - 1, FFS_flashData.mbn_Num, FFS_flashData.mbn_len);
			
			if (strcmp(sms_addr.number, mail_number) EQ 0)
			{
				// If the same number then we get the alpha identifier
				cmhPHB_getMfwTagNt ( FFS_flashData.mbn_AlphId, 10, (UBYTE*)mail_alpha, &nlen );
				mail_alpha[nlen] = '\0';    

				if ((name = (char*)ALLOC_MEMORY(strlen(mail_alpha) + 1)) != NULL)
				{
/*MC, yet more unicode support*/
#ifdef NO_ASCIIZ
					memcpy(name, mail_alpha, nlen);
					return nlen;
#else
					strcpy(name, mail_alpha);
					return strlen(name);
#endif
				}
			}
		}
	}
	return 1;  // RAVI
}

/*******************************************************************************

 $Function:    	SmsRead_R_TEXTEDT2_editor_cb

 $Description:  Callback function for the  text editor.
			 
 $Returns:		void
 
 $Arguments:	win - current window.
 				Identifier - unique id
 				Reason - event id
*******************************************************************************/

void SmsRead_R_TEXTEDT2_editor_cb(T_MFW_HND win, USHORT Identifier, USHORT Reason)
{

    T_MFW_WIN     		* win_data = ((T_MFW_HDR *) win)->data;
    T_SMSREAD_R_TEXTEDT2 * data     = (T_SMSREAD_R_TEXTEDT2 *)win_data->user;

    TRACE_FUNCTION("SmsRead_R_TEXTEDT2_editor_cb");
	switch (Reason)
	{
	case INFO_KCD_LEFT:
	case INFO_KCD_RIGHT:
	case INFO_KCD_HUP:
	    SEND_EVENT (data->parent, E_RETURN, Identifier, NULL); /* forward event to parent */
	    break;
	default:
		break;
	}
}

/*******************************************************************************

 $Function:    	SmsRead_FindNextNumber_cb

 $Description:	Exec callback function for searching the SMS text message.
 
 $Returns:		none

 $Arguments:	win - window handler
 				event - mfw event
 				value -optional id
 				parameter - optional data.
 
*******************************************************************************/
void SmsRead_FindNextNumber_cb(T_MFW_HND win, USHORT Identifier, USHORT Reason)
{
    
	T_MFW_PHB_ENTRY  pb_data;

	switch (Reason)
	{
	case INFO_KCD_RIGHT:
	case INFO_KCD_CLEAR:
	
		break;
	case INFO_KCD_LEFT:
		
		// Check for numbers in SMS text, check for '+' .

		if(Search_forNextNumber(&SmsData))
		{
			
			if (bookFindNameInPhonebook((const char*)&SmsData.NumberBuffer[0], &pb_data) )
			{
				//Display the tag and number dialog.
#ifdef NO_ASCIIZ			
	/* SPR888 - SH - parent_data->parent changed to win */
				smsRead_NumberName_info_screen(win,(void *)&SmsData, (char*)pb_data.name.data);
#else
	/* SPR888 - SH - parent_data->parent changed to win */
				smsRead_NumberName_info_screen(win,(void *)&SmsData, (char*)pb_data.name);
#endif
			}
			else
			{
				/* SPR888 - SH - parent_data->parent changed to win */
				smsRead_NumberName_info_screen(win,(void *)&SmsData,NULL);
			}			
		}
		break;
	case INFO_KCD_OFFHOOK:
		callNumber(SmsData.NumberBuffer); 
		break;
		
	default:
			TRACE_EVENT(" >>> INFO Default   ");
		//return MFW_EVENT_REJECTED;
		break;
	}
	
}

/*******************************************************************************

 $Function:    	smsRead_NumberName_info_screen

 $Description:    Display the number and name of numbers found in the received SMS text.
			 
 $Returns:		window handle
 
 $Arguments:	win - current window.
 				UserData - Sms data info
*******************************************************************************/

static MfwHnd smsRead_NumberName_info_screen(MfwHnd win,T_SmsUserData *UserData, char* nameTag)
{

	T_DISPLAY_DATA DisplayInfo;
	TRACE_FUNCTION("smsRead_NumberName_info_screen() ");
	
	dlg_initDisplayData_TextStr( &DisplayInfo, TxtSoftNext, TxtSoftBack, nameTag,  (char*)UserData->NumberBuffer, COLOUR_STATUS);
	dlg_initDisplayData_events( &DisplayInfo, (T_VOID_FUNC)SmsRead_FindNextNumber_cb, FOREVER, KEY_ALL );

	TRACE_EVENT(">>>>> Display Information Screen ");
   return info_dialog(win, &DisplayInfo);

}

/*******************************************************************************

 $Function:    	Search_forNextNumber

 $Description:    Search through the SMS text and find a telephone number, the number 
 				may start with the '+' prefix.
			 
 $Returns:		Boolean
 
 $Arguments:	UserData - SMS data info
*******************************************************************************/
static BOOL Search_forNextNumber(T_SmsUserData *UserData)
{
		/* SPR888 - SH - Rewritten, old function below */
	/* Use search_index so we can start looking where we left off last time.
	Set to 0 in SMSRead_R_OPTExeStoreNumber */
	
	int sms_length;
	int number_index;
	char number_buffer[NUMBER_LENGTH*2+4];
	char *sms_buffer;
	char character;
	UBYTE found_status;

	TRACE_FUNCTION("Search_forNextNumber()");
	sms_buffer = (char*)UserData->TextBuffer;
	#ifdef NO_ASCIIZ
	if (sms_buffer[0] == 0x80)
	{
#ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes - new function to calculate length of unicode string */
		sms_length = ATB_string_UCLength((U16*)sms_buffer)*sizeof(USHORT);
#else /* NEW_EDITOR */
		sms_length = strlenUnicode((U16*)sms_buffer);
#endif /* NEW_EDITOR */
	}
	else
	{
		sms_length = strlen(sms_buffer);
	}
	#else /* NO_ASCIIZ */
	sms_length = strlen(sms_buffer);
	#endif /* NO_ASCIIZ */
	
	number_index = 0;
	found_status = 0;

	memset (number_buffer, '\0', NUMBER_LENGTH*2+4);

	
	while (search_index<sms_length && found_status<2 && number_index<NUMBER_LENGTH*2+4)
	{
		character = sms_buffer[search_index];

		search_index++;
#ifdef NO_ASCIIZ
		if (character=='+' ||  ( character>='0' && character<='9' ) || (character==0))
#else
		if (character=='+' ||  ( character>='0' && character<='9' ) )
#endif
		{	if (character != 0) /*MC, only copy non-Null chars*/
				number_buffer[number_index++] = character;
			if (found_status==0)
			{
				found_status = 1;		/* Found start of number */
			}
		}
		else
		{
			if (found_status==1)
				found_status = 2;		/* Have reached end of number */
		}
		TRACE_EVENT_P1("Extract number string:%s", number_buffer);
	}

	if(strlen(number_buffer) > 10)

	{

	   memcpy((char*)UserData->NumberBuffer, number_buffer, sizeof(UserData->NumberBuffer));
	   return TRUE;
	}

	return FALSE;
}
	

/* api Store number for calling when reading SMS - 04/03/2002
*/

/*******************************************************************************

 $Function:    	Search_forNextNumber

 $Description:    Search through the SMS text and find a telephone number, the number 
 				may start with the '+' prefix.
			 
 $Returns:		Boolean
 
 $Arguments:	UserData - SMS data info
*******************************************************************************/
void SmsRead_StoreNumber(void)
{
    T_MFW_HND       win  = mfwParent(mfw_header());
    T_MFW_WIN     * win_data = ((T_MFW_HDR *)win)->data;
    T_SMSREAD_R_OPT         * data = (T_SMSREAD_R_OPT *)win_data->user;

	T_MFW_HDR    * parent      =  data->parent;
    T_MFW_WIN    * win_data2   =  ((T_MFW_HDR *)parent)->data;
    T_SMSREAD_R_TEXTEDT2  * parent_data =  (T_SMSREAD_R_TEXTEDT2 *)win_data2->user;
	T_MFW_PHB_ENTRY  pb_data;
	
	TRACE_FUNCTION("SmsRead_StoreNumber");

	TRACE_EVENT_P1("TON = %d",parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.ton);
	/* Marcus: Issue 1489: 13/12/2002: Start */
	if(parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.ton == MFW_TON_INTERNATIONAL)
	{
		if(parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number[0] == '+')
		{
			strcpy((char *)SmsData.NumberBuffer,(char *)parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number); 
		}
		else
		{
			strcpy((char *)SmsData.NumberBuffer,"+");
			strncat((char *)SmsData.NumberBuffer,(char *)parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number,sizeof(SmsData.NumberBuffer)-2); 
		}
	}
	else
	{
	
		TRACE_EVENT_P1("Number = %s",parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number);
		strcpy((char *)SmsData.NumberBuffer,(char *)parent_data->sms_editor_data->sms_info->sms_mt.orig_addr.number); 
	}
	/* Marcus: Issue 1489: 13/12/2002: End */
	/*MC, unicode support*/
	memcpy((char*)pb_data.number, (char*)SmsData.NumberBuffer, sizeof(pb_data.number)); 


	    SmsRead_R_TEXTEDT2_destroy(message_win);
		/* Destroy the Options Menu and text editor.before starting the Send Editor.*/
		SmsRead_R_OPT_destroy(option_mnu_win);

		/*SPR 2686 destroy the SMS read window to free memory*/
		/*destroy the built list window*/
		listsDestroy(list_win);
		list_win=0;
		/*destroy the main control window*/
		if (sms_read_win)/*check window exists before destroying it*/
		{
			SmsRead_R_destroy(sms_read_win);
			sms_read_win = NULL;
		}

	callNumber(pb_data.number);
	
}

//x0035544 Mar 23, 2006 DR:OMAPS00047813 
/*******************************************************************************

 $Function:    	Search_forNumberInSMS

 $Description:    Search through the SMS text and find the numbers
			 
 $Returns:		void
 
 $Arguments:	UserData - SMS data info
*******************************************************************************/
void Search_forNumberInSMS(T_SmsUserData *UserData)
{
  int num_row, num_col, i;
  int len, sms_length = 0;
  char character;
  char *sms_buffer, *sender_num;
  BOOL mesg_end=FALSE;  
    
  TRACE_FUNCTION("Search_forNumberInSMS()");

  sms_buffer = (char*)UserData->TextBuffer;
  sender_num = (char*)UserData->NumberBuffer;
  
#ifdef NO_ASCIIZ
  if (sms_buffer[0] == 0x80)
  {
  #ifdef NEW_EDITOR /* SPR#1428 - SH - New Editor changes - new function to calculate length of unicode string */
      sms_length = ATB_string_UCLength((U16*)sms_buffer)*sizeof(USHORT);
  #else /* NEW_EDITOR */
      sms_length = strlenUnicode((U16*)sms_buffer);
  #endif /* NEW_EDITOR */
  }
  else
  {
    sms_length = strlen(sms_buffer);
  }
#else /* NO_ASCIIZ */
  sms_length = strlen(sms_buffer);
#endif /* NO_ASCIIZ */
  sms_length--;
  len= num_row=num_col=0;
  smsread_num_ctr =0;  
  num_buffer = (char**)ALLOC_MEMORY(sizeof(char*)*MAX_NUMBER_SIZE);
  if (num_buffer == NULL)
	{	
		TRACE_EVENT("sms number list alloc failed");
		return;
	}
  
  for(i=0; i<MAX_NUMBER_SIZE; i++)
  	num_buffer[i] = (char*)ALLOC_MEMORY(sizeof(char)*NUMBER_LENGTH);
		if (num_buffer[i] == NULL)
		{	
			TRACE_EVENT(" sms number string alloc failed");
			return; 
		}
  
      
    while (len <= sms_length)
  {
    character = sms_buffer[len];
	
	if(len == sms_length)
	 {
	    mesg_end = TRUE;
  	 }
	
#ifdef NO_ASCIIZ
		if (character=='+' ||  ( character>='0' && character<='9' ) || (character==0))
#else
		if (character=='+' ||  ( character>='0' && character<='9' ) )
#endif
    {	
      if (character != 0) /*MC, only copy non-Null chars*/
      {      
      if(num_col <= NUMBER_LENGTH)
      	{
         	num_buffer[num_row][num_col] = character;		
        	num_col++;
      	}
		if(mesg_end && (strlen(num_buffer[num_row]) >= MIN_NUM_LENGTH))//copy if number is at end of the message
		 {			 	
			smsread_num_ctr++;
			num_row++;
		 }		
      }
    }
    else
    {
      if(num_col != 0 )
      {
        num_buffer[num_row][num_col] = '\0';		
        if(strlen(num_buffer[num_row]) < MIN_NUM_LENGTH )
        {
          num_col=0;
        }  
        else
        {
          smsread_num_ctr++;
          num_row++;
          if( num_row >= MAX_NUMBER_SIZE)
            break;
          num_col = 0;
        }
      }
    }
	len++;
  } 	
		
  if( num_row < 10 )//copy the sender number
   {
    	memcpy((char*)num_buffer[num_row], (char*)sender_num, NUMBER_LENGTH);
	smsread_num_ctr++;
   }
   
  return ;
}

//Mar 23, 2006 DR:OMAPS00047813 x0035544
/*******************************************************************************

 $Function:     smsread_numlist_win_cb

 $Description: Window event handler

 $Returns:	MFW_EVENT_REJECTED: 
 			MFW_EVENT_CONSUMED:

 $Arguments:	

*******************************************************************************/
static int smsread_numlist_win_cb (MfwEvt e, MfwWin *w)    
{
  	TRACE_FUNCTION ("smsread_numlist_win_cb()");
  	switch (e)
  	{
    		case MfwWinVisible:  /* window is visible  */
    		break;
    		case MfwWinFocussed: /* input focus / selected   */
    		case MfwWinDelete:   /* window will be deleted   */

    		default:
      		return MFW_EVENT_REJECTED;
  	}
  	return MFW_EVENT_CONSUMED;
}

//Mar 23, 2006 DR:OMAPS00047813 x0035544
/*******************************************************************************

 $Function:     SmsRead_BuildNumList_Menu

 $Description: creates dynamic menu

 $Returns:

 $Arguments:

*******************************************************************************/
static T_MFW_HND SmsRead_BuildNumList_Menu(T_MFW_HND parent_window)
{
  T_SMSREAD_R *  data = (T_SMSREAD_R *)mfwAlloc(sizeof (T_SMSREAD_R));
  T_MFW_WIN  * win;
  
  TRACE_FUNCTION ("SmsRead_BuildNumList_Menu");
  
  /*
  	* Create window handler
  	*/
  
  data->win = win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)smsread_numlist_win_cb);
  if (data->win EQ NULL)
  {
  FREE_MEMORY( (void *)data, sizeof( T_SMSREAD_R ) );
  		return NULL; 
  }
  
  TRACE_EVENT("list holder window created: " );
  /*
  	* connect the dialog data to the MFW-window
  	*/
  
  data->mmi_control.dialog = (T_DIALOG_FUNC)smsread_numlist_exec_cb;
  data->mmi_control.data   = data;
  win                      = ((T_MFW_HDR *)data->win)->data;
  win->user                = (void *)data;
  data->parent             = parent_window;
  winShow(data->win);
  /*
  	* return window handle
  	*/
  
  	return data->win;
}

//Mar 23, 2006 DR:OMAPS00047813 x0035544
/*******************************************************************************

 $Function:     smsread_numlist_exec_cb

 $Description: callback function

 $Returns:

 $Arguments:

*******************************************************************************/
void smsread_numlist_exec_cb (T_MFW_HND win, USHORT event)
{
  T_MFW_WIN       * win_data;
  T_SMSREAD_R * data;    

  /* List is complete so present menu. */
  USHORT i;
  
  TRACE_FUNCTION("smsread_numlist_exec_cb");
 
		
  win_data = ((T_MFW_HDR *) win)->data; 
  data = (T_SMSREAD_R *)win_data->user;

 switch (event)
	{
	case E_INIT:				
  data->menu_list_data = (ListMenuData *)ALLOC_MEMORY(sizeof(ListMenuData));
  
  if(data->menu_list_data == 0)
  {
    TRACE_EVENT("Failed memory alloc 1 ");
    return;
  }
  /*SPR 2686, only allocate memory for the number of messages displayed*/	
  data->menu_list_data->List = (T_MFW_MNU_ITEM *)ALLOC_MEMORY( smsread_num_ctr * sizeof(T_MFW_MNU_ITEM) );//JVJE

  if(data->menu_list_data->List == 0)
  {
    TRACE_EVENT("Failed memory alloc 2");
    return;
  }
  
  for (i = 0; i < smsread_num_ctr; i++)
  {
    mnuInitDataItem(&data->menu_list_data->List[i]);
    data->menu_list_data->List[i].str  = (char *)num_buffer[i];
    TRACE_EVENT_P1("Menu Tags:%s", data->menu_list_data->List[i].str);
    data->menu_list_data->List[i].flagFunc = item_flag_none; 
  } 	
	
  data->menu_list_data->ListLength =smsread_num_ctr;
  data->menu_list_data->ListPosition = 1;
  data->menu_list_data->CursorPosition = 1;
  data->menu_list_data->SnapshotSize =smsread_num_ctr;
  data->menu_list_data->Font = 0;
  data->menu_list_data->LeftSoftKey = TxtSoftSelect;
  /*NM p032*/
  if(test_sim EQ TRUE)
    data->menu_list_data->RightSoftKey = TxtNull;
  else
    data->menu_list_data->RightSoftKey = TxtSoftBack;
  	
  data->menu_list_data->KeyEvents = KEY_ALL;
  data->menu_list_data->Reason = 0;
  data->menu_list_data->Strings = TRUE;
  data->menu_list_data->Attr   = (MfwMnuAttr*)&menuSearchNumListAttr;
  data->menu_list_data->autoDestroy    = FALSE;  
 	
  /* Create the dynamic menu window */
  listDisplayListMenu(win, data->menu_list_data, (ListCbFunc_t)SmsRead_numlist_cb ,0);
  break;
  default:
  	break;
 	}
  
  }

//Mar 23, 2006 DR:OMAPS00047813 x0035544
/*******************************************************************************

 $Function:     SmsRead_numlist_cb

 $Description: destroy lists and menu in case of back softkey or menu exit

 $Returns:

 $Arguments:

*******************************************************************************/
static void SmsRead_numlist_cb(T_MFW_HND Parent, ListMenuData * ListData)
{
	T_MFW_WIN			*win_data	= ((T_MFW_HDR *)Parent)->data;
	T_SMSREAD_R	*data		= (T_SMSREAD_R *)win_data->user;
	char *pb_number;
	int i;

	TRACE_FUNCTION ("SmsRead_numlist_cb()");


	if ((ListData->Reason EQ LISTS_REASON_BACK) ||
	     (ListData->Reason EQ LISTS_REASON_CLEAR) ||
	     (ListData->Reason EQ LISTS_REASON_HANGUP))
	{
		/*
		** Destroy the window --- Not sure if this is required! ... leave it out for now
		*/
		listsDestroy(ListData->win);

		/*
		** Free the memory set aside for ALL the devices to be listed.
		*/
		for(i=0; i<MAX_NUMBER_SIZE;i++)
  		 {  
  			FREE_MEMORY((U8*)num_buffer[i], sizeof(char)*NUMBER_LENGTH);
			num_buffer[i] = NULL;  		 	
		 }
	
		/*deallocate memory for the array of pointer to numbers*/
  			FREE_MEMORY((U8*)num_buffer, sizeof(char*)*MAX_NUMBER_SIZE);
	
		if (data->menu_list_data->List != NULL)
			{
			FREE_MEMORY ((void *)data->menu_list_data->List, (U16)((data->menu_list_data->ListLength) * 
						sizeof(T_MFW_MNU_ITEM)));
			}
		if (data->menu_list_data != NULL)
			{
			FREE_MEMORY ((void *)data->menu_list_data, sizeof (ListMenuData));
			}
	 	
		SmsRead_numlist_destroy(data->win);
		
		

	}
	 
	else if(ListData->Reason EQ LISTS_REASON_SELECT)
	  {			
		pb_number = ListData->List[ListData->ListPosition].str;		
		callNumber((UBYTE*)pb_number);		
		
	  }

	return;
}

//Mar 23, 2006 DR:OMAPS00047813 x0035544
/*******************************************************************************

 $Function:    	SmsRead_numlist_destroy

 $Description:	Destroy the Extr Number window.
 
 $Returns:		none

 $Arguments:	own_window - window handler
 
*******************************************************************************/

static void SmsRead_numlist_destroy(MfwHnd own_window)
{
	T_MFW_WIN     * win_data  = ((T_MFW_HDR *)own_window)->data;
	T_SMSREAD_R   * data = (T_SMSREAD_R *)win_data->user;

	TRACE_FUNCTION ("SmsRead_numlist_destroy");

	if (own_window == NULL)
	{
		return;
	}

	if (data)
	{
		win_delete(data->win);
		
		/*
		** Free Memory
		*/
		mfwFree((void *)data, sizeof (T_SMSREAD_R));
	}
}
#undef MMI_SMSREAD_C