FreeCalypso > hg > fc-magnetite
view src/aci2/bmi/mmiBookUtils.c @ 530:a6a0102cb95f
makefile-frags/m0-to-bin-{c139,std}: use local mokosrec2bin in helpers
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Thu, 25 Oct 2018 22:57:17 +0000 |
parents | 3c2acfa1a72f |
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 (6349) $Module: PhoneBook $File: MmiBookUtils.c $Revision: 1.0 $Author: Condat(UK) $Date: 25/10/00 ******************************************************************************** Description: This module provides utility function for use in the phone book application ******************************************************************************** $History: MmiBookUtils.c Feb 20, 2006 REF: OMAPS00061948 x0039928 Bug:PhoneBook-My number menu -failed. Fix: phb_read_entries is called with used entries as the no of entries if used entries are less than MAX_SEARCH_NAME. Jan 27, 2006 REF: OMAPS00061925 x0039928 Bug:Phonebook-Changing an entry and Immidiately deleting the entry failed. Fix: Phonebook is populated with phone numbers after some time and not immediately after deleting an entry. Jan 22, 2006 REF: OMAPS00061930 x0039928 Bug:PhoneBook -Change entry and view entry through Change option-failed Fix: Phonebook is populated with phone numbers after some time and not immediately while saving the changed entries. 25/10/00 Original Condat(UK) BMI version. $End // Issue Number : SPR#15671 on 24/03/04 by Ajith K.P *******************************************************************************/ /******************************************************************************* Include Files *******************************************************************************/ #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 "mfw_sys.h" #include "mfw_mfw.h" #include "mfw_win.h" #include "mfw_kbd.h" #include "mfw_lng.h" /* SPR#1428 - SH - New Editor changes */ #ifndef NEW_EDITOR #include "mfw_edt.h" #endif #include "mfw_icn.h" #include "mfw_mnu.h" #include "mfw_tim.h" #include "mfw_sim.h" #include "mfw_cm.h" #include "mfw_nm.h" #include "mfw_phb.h" #include "mfw_mme.h" #include "mfw_sat.h" #include "mfw_sms.h" #include "dspl.h" #include "ksd.h" #include "psa.h" #include "MmiMain.h" #include "MmiBookController.h" #include "MmiDummy.h" #include "MmiDialogs.h" #include "MmiLists.h" #include "MmiMenu.h" #include "mmiCall.h" #include "Mmiicons.h" #include "MmiIdle.h" #include "MmiSoftKeys.h" #include "MmiSounds.h" #include "MmiIdle.h" #include "MmiNetwork.h" #include "mmiSat_i.h" #include "MmiAoc.h" #include "gdi.h" #include "audio.h" #include "cus_aci.h" #include "mfw_ffs.h" #include "MmiTimers.h" #include "MmiBookShared.h" #include "mmiColours.h" #include "mmiSmsRead.h"/*MC , SPR 1242 */ // May 24, 2004 REF: CRR MMI-SPR-15813 Ajith K P // Issue description: Followup from 15623, this is the BMI part of this Issue. // At last, in the record "SSC09" the number is displayed with the "+" // character at the beginning of the number instead of "**21*+014543877989#". extern int menuFDN; extern T_call call_data; // Jan 27, 2006 REF: OMAPS00061925 x0039928 // Fix : Declare a extern phonebook timer handler extern T_MFW_HND PhbSearchTim; /******************************************************************************* Private data elements *******************************************************************************/ static T_MFW_UPN_LIST *upnList = NULL; /* SPR#1112 - SH - This is redundant */ //static T_phbk *GlobalPhoneBookHandle = NULL; /* SPR#1112 - SH - Internal phonebook flag */ #ifdef INT_PHONEBOOK static UBYTE ipbCopyIndex = 0; static UBYTE ipbMove = FALSE; static T_MFW_HND ipbWin = NULL; #endif // ADDED BY RAVI - 28-11-2005 EXTERN T_MFW mfw_Ucs2SIMStr(T_MFW_DCS outMode, U16 *inUcsStr, UBYTE maxOutSize, UBYTE *outMfwStr, UBYTE *outLen); EXTERN T_MFW mfw_Gsm2SIMStr(T_MFW_DCS outMode, UBYTE *inGsmStr, UBYTE maxOutSize, UBYTE *outMfwStr,UBYTE *outLen); // END RAVI - 28-11-2005 /******************************************************************************* Private Methods *******************************************************************************/ /******************************************************************************* $Function: changeName $Description: Change a phone book entry if we have a valid book selected $Returns: status of change, or MWB_PHB_FAIL if an error occurs $Arguments: book, to be updated entry, to update currentStatus, pointer to status word *******************************************************************************/ static UBYTE changeName( UBYTE book, T_MFW_PHB_ENTRY *entry, T_MFW_PHB_STATUS *currentStatus ) { TRACE_FUNCTION( "changeName()" ); if ( book == PHB_SDN ) return MFW_PHB_FAIL; return phb_store_entry( book, entry, currentStatus ); } /******************************************************************************* $Function: deleteName $Description: Delete a phone book entry $Returns: status of delete, or MWB_PHB_FAIL if an error occurs $Arguments: book, to be updated index, index of entry to delete currentStatus, pointer to status word *******************************************************************************/ static UBYTE deleteName( UBYTE book, UBYTE index, T_MFW_PHB_STATUS *currentStatus ) { TRACE_FUNCTION( "deleteName()" ); if ( book == PHB_SDN ) return MFW_PHB_FAIL; return phb_delete_entry( book, index, currentStatus ); } /******************************************************************************* $Function: addName $Description: Add a new name to the phone book $Returns: status of change, or MWB_PHB_FAIL if an error occurs $Arguments: book, to be updated entry, to update currentStatus, pointer to status word *******************************************************************************/ static UBYTE addName( UBYTE book, T_MFW_PHB_ENTRY *entry, T_MFW_PHB_STATUS *currentStatus ) { TRACE_FUNCTION( "addName()" ); //MC-- Commented out UPN-specific code as it causes the name string in a UPN //entry to be stored incorrectly and doesn't seem to be neccessary. //Generic code here seems to work fine for UPN { /* normal store operation */ { char temp[120]; memset(temp,'\0',100); #ifdef NO_ASCIIZ { T_MFW_PHB_TEXT buf; /*SPR 1752 check for unicode*/ if (entry->name.data[0] ==0x80) { /*MC, don't do any conversions!!*/ TRACE_EVENT("Converting Unicode 2 SIM"); sprintf(temp,"Book: %d Name %s Number %s", book, (char*)buf.data,(char*)entry->number); } else { // convert from GSM to Alpha characters bookGsm2Alpha( (UBYTE *) entry->name.data ); sprintf(temp,"Book: %d Name %s Number %s", book, (char*)entry->name.data,(char*)entry->number); } } #else sprintf(temp,"Book: %d Name %s Number %s", book, (char*)entry->name,(char*)entry->number); #endif TRACE_EVENT(temp); } entry->index = 0; return phb_store_entry( book, entry, currentStatus ); } } /******************************************************************************* File Handling Utilities *******************************************************************************/ /******************************************************************************* $Function: storeInFile $Description: Converts the name to a storeable format and stores it in the phone book $Returns: None $Arguments: phbk, pointer to phonebook structure *******************************************************************************/ void storeInFile( T_phbk *phbk ) { int i; UBYTE actual_length = 0; char debug[20]; TRACE_FUNCTION( "storeInFile()" ); /* Convert the name */ #ifdef NO_ASCIIZ /* if the pattern is GSM default format, use the function mfw_Gsm2SIMStr() here */ if (phbk->edt_buf_name[0] == 0x80)//if unicode { for (i =0; i < PHB_MAX_LEN; i+=2) //work out string length { if (phbk->edt_buf_name[i] == 0 && phbk->edt_buf_name[i+1] == 0) { if (i== 0) actual_length =0; else actual_length = i -2; break; } } phbk->edt_buf_name[0] = (UBYTE)(actual_length/2);//add string length to beginning of string phbk->edt_buf_name[1] = 0x00; /*MC SPR 1257, replacing PHB_MAX_LEN with MAX_ALPHA_LEN*/ memset(phbk->newEntry.name.data, 0,MAX_ALPHA_LEN); //convert to SIM string mfw_Ucs2SIMStr( MFW_DCS_UCS2 , (U16*)phbk->edt_buf_name, MAX_ALPHA_LEN, phbk->newEntry.name.data, &phbk->newEntry.name.len ); TRACE_EVENT( (char*)phbk->newEntry.name.data); sprintf(debug, "length:%d", phbk->newEntry.name.len); TRACE_EVENT(debug); } else { mfw_Gsm2SIMStr( MFW_DCS_7bits, (U8*)phbk->edt_buf_name, MAX_ALPHA_LEN, phbk->newEntry.name.data, &phbk->newEntry.name.len ); } #else /*MC SPR 1257, replacing PHB_MAX_LEN with MAX_ALPHA_LEN*/ strncpy( (char *)phbk->newEntry.name, (char *)phbk->edt_buf_name, MAX_ALPHA_LEN ); #endif /* update the number */ strncpy( (char *) phbk->newEntry.number, (char *) phbk->edt_buf_number, PHB_MAX_LEN ); /*SPR 1327, copy current phonebook type to new entry*/ phbk->newEntry.book = phbk->current.status.book; /*If current phonebook UPN, don't overwrite phonebook type*/ // Feb 20, 2006 REF: OMAPS00061948 x0039928 // Fix : A check is made with enum PHB_UPN of MFW instead of UPN of ACI if( phbk->newEntry.book != PHB_UPN) phbk->newEntry.book = bookActiveBook(WRITE); phbk->newEntry.index = 0; /* Add the name/number combination to the phone book and setup the current text status string */ switch ( addName( phbk->newEntry.book, &phbk->newEntry, &phbk->current.status ) ) { case MFW_PHB_OK : { /* Entry saved okay */ MmiBookSetCurrentText( TxtSaved ); } break; case MFW_PHB_FULL : { /* Phone book full */ MmiBookSetCurrentText( TxtPhbkFull ); } break; case MFW_PHB_FAIL : { /* Write failure */ MmiBookSetCurrentText( TxtWriteError ); } break; default: { /* No other returns possible */ } break; } } /******************************************************************************* $Function: changeInFile $Description: change the phone book entry $Returns: none $Arguments: phbk, pointer to phonebook structure *******************************************************************************/ void changeInFile( T_phbk *phbk ) { int i; int actual_length; TRACE_FUNCTION( "changeInFile()" ); if(phbk->current.status.book == PHB_ADN_FDN) phbk->current.status.book = PHB_ADN; //JVJE We can only store in ADN/FDN else phbk->current.status.book = phbk->current.status.book; TRACE_EVENT_P1("Current Book = %d", phbk->current.status.book); TRACE_EVENT_P1("Current Name = %s", phbk->current.selectedName); TRACE_EVENT_P1("Current Buf Name = %s", phbk->edt_buf_name); /* Convert the name */ #ifdef NO_ASCIIZ /*MC SPR 1257, replacing PHB_MAX_LEN with MAX_ALPHA_LEN for name strings*/ if (phbk->edt_buf_name[0] == 0x80)//if unicode { for (i =0; i < MAX_ALPHA_LEN; i+=2) //work out string length { if (phbk->edt_buf_name[i] == 0 && phbk->edt_buf_name[i+1] == 0) { if (i== 0) actual_length =0; else actual_length = i -2; break; } } phbk->edt_buf_name[0] = (UBYTE)(actual_length/2);//add string length to beginning of string phbk->edt_buf_name[1] = 0x00; memset(phbk->current.entry[phbk->current.selectedName].name.data, 0, MAX_ALPHA_LEN); //convert to SIM string mfw_Ucs2SIMStr( MFW_DCS_UCS2, (U16*)phbk->edt_buf_name, MAX_ALPHA_LEN, phbk->current.entry[phbk->current.selectedName].name.data, &phbk->current.entry[phbk->current.selectedName].name.len ); } else { mfw_Gsm2SIMStr( MFW_DCS_7bits, (U8*)phbk->edt_buf_name, MAX_ALPHA_LEN, phbk->current.entry[phbk->current.selectedName].name.data, &phbk->current.entry[phbk->current.selectedName].name.len ); } #else strncpy( (char *) phbk->current.entry[ phbk->current.selectedName ].name, (char *) phbk->edt_buf_name, MAX_ALPHA_LEN ); #endif /* update the number */ strncpy( (char *) phbk->current.entry[ phbk->current.selectedName ].number, (char *) phbk->edt_buf_number, PHB_MAX_LEN ); /* Add the name/number combination to the phone book and setup the current text status string */ switch ( changeName( phbk->current.status.book, &phbk->current.entry[ phbk->current.selectedName ], &phbk->current.status ) ) { case MFW_PHB_OK : { /* Entry saved okay */ MmiBookSetCurrentText( TxtSaved ); } break; case MFW_PHB_FAIL : { /* Write failure */ MmiBookSetCurrentText( TxtWriteError ); } break; default: { /* No other returns possible */ } break; } } /******************************************************************************* $Function: deleteFromFile $Description: delete an entry from a phone book $Returns: None $Arguments: phbk, phone book handle, book, book to update, *******************************************************************************/ void deleteFromFile( T_phbk *phbk, UBYTE book ) { int index; TRACE_FUNCTION( "deleteFromFile()" ); index = phbk->current.selectedName - phbk->current.missedCallsOffset; switch ( deleteName( book, phbk->current.entry[index].index, &phbk->current.status ) ) { case MFW_PHB_OK : { /* Entry saved okay */ MmiBookSetCurrentText( TxtEntryDeleted ); #ifdef NO_ASCIIZ phbk->current.entry[index].name.len = 0; memset((char*)phbk->current.entry[index].number, '\0', PHB_MAX_LEN); #else /*MC SPR 1257, replacing PHB_MAX_LEN with MAX_ALPHA_LEN for name strings*/ memset((char*)phbk->current.entry[index].name, '\0', MAX_ALPHA_LEN); memset((char*)phbk->current.entry[index].number, '\0', PHB_MAX_LEN); #endif /* Move the current index to the next valid entry */ if(phbk->current.selectedName > 0) phbk->current.selectedName --; else phbk->current.selectedName = 0; if(phbk->current.index > 1) phbk->current.index--; else phbk->current.index = 1; /* And if we have a search window, perform the search to update the current valid entry */ if ( phbk->search_win ) { bookGetCurrentStatus( &phbk->current.status ); if ( ! phbk->current.status.used_entries ) { /* empty phone book */ bookSearchDestroy( phbk->search_win ); phbk->search_win = 0; } else { /* perform the search */ //Jan 27, 2006 REF: OMAPS00061925 x0039928 // Fix : Start the phonebook timer for populating the list timStart(PhbSearchTim); } } } break; case MFW_PHB_FAIL : { /* Write failure */ MmiBookSetCurrentText( TxtWriteError ); } break; default: { /* No other action required */ } break; } } /* SPR#1112 - SH - Internal phonebook use */ #ifdef INT_PHONEBOOK /******************************************************************************* $Function: bookChangePB $Description: Change the phonebook $Returns: None $Arguments: None. *******************************************************************************/ void bookChangePB(T_MFW_HND win, UBYTE identifier, UBYTE reason) { T_MFW_WIN *win_data = ( (T_MFW_HDR *) win )->data; T_phbk *Phbk = (T_phbk *) win_data->user; GI_pb_SetPhonebook(identifier); bookShowInfoScreen( Phbk->win, TxtPhonebook, TxtChanged, NULL, NULL, 3000); return; } /******************************************************************************* $Function: bookCopy $Description: Copy or move a phonebook entry from one book to another $Returns: status of change, or MWB_PHB_FAIL if an error occurs $Arguments: entry - the entry to be moved or copied srcStatus - Status information about the source phonebook destStatus - Status information about the destination phonebook move - TRUE if the original record is to be deleted *******************************************************************************/ UBYTE bookCopy( T_MFW_PHB_ENTRY *entry, T_MFW_PHB_STATUS *destStatus, T_MFW_PHB_STATUS *srcStatus, UBYTE move ) { T_MFW ret; UBYTE srcIndex; UBYTE srcBook; TRACE_FUNCTION("bookCopy"); if (!destStatus->avail_entries) { /* There's no room in the destination phonebook to add the entry */ TRACE_EVENT("bookCopy: dest phonebook full"); return MFW_PHB_FULL; } srcIndex = entry->index; entry->index = 0; if (entry->name.len>destStatus->tag_len) { TRACE_EVENT("bookCopy: Alpha tag cropped"); entry->name.len = destStatus->tag_len; entry->name.data[entry->name.len] = NULL; } ret = phb_store_entry( destStatus->book, entry, destStatus ); TRACE_EVENT_P2("bookCopy: phb_store_entry book %d result %d", destStatus->book, ret); if (ret!=MFW_PHB_OK) return ret; /* Only try to delete the entry if we are moving an entry from one book * to another. Don't try if it is an FDN entry */ TRACE_EVENT_P2("move %d, entry->book %d", move, entry->book); if (move && entry->book!=PHB_FDN) { if (( srcStatus->book == PHB_UPN) || (srcStatus->book == PHB_FDN )) srcBook = srcStatus->book; else srcBook = bookActiveBook(WRITE); ret = phb_delete_entry(srcBook, srcIndex, srcStatus); TRACE_EVENT_P3("bookCopy: phb_delete_entry book %d index %d result %d", srcStatus->book, srcIndex, ret); } TRACE_EVENT("bookCopy: leaving function"); return ret; } /******************************************************************************* $Function: bookCopySingle $Description: Copy or move a single phonebook entry $Returns: None $Arguments: None. *******************************************************************************/ void bookCopySingle(T_MFW_HND win, UBYTE identifier, UBYTE reason) { T_MFW_WIN *win_data = ( (T_MFW_HDR *) win )->data; T_phbk *Phbk = (T_phbk *) win_data->user; BOOL oldBook; int txtId; T_MFW_PHB_STATUS destStatus; tMmiPhbData *current = &Phbk->phbk->current; TRACE_FUNCTION("bookCopySingle"); oldBook = bookGetBookSelected(); // May 3, 2004 REF: CRR MMI-SPR-18555 Rashmi C N(Sasken) // While doing a copy from the FDN menu the destination should always be internal phonebook if(menuFDN && (call_data.calls.numCalls==0)) { destStatus.book = PHB_IPB; } else { bookSetBookSelected(!oldBook); destStatus.book = bookActiveBook(WRITE); } bookGetCurrentStatus( &destStatus ); bookSetBookSelected(oldBook); txtId = TxtStored; if (destStatus.avail_entries) { switch (bookCopy(¤t->entry[current->selectedName], &destStatus, ¤t->status, identifier)) { case MFW_PHB_OK: txtId = TxtStored; break; case MFW_PHB_FULL: txtId = TxtPhbkFull; break; default: txtId = TxtFailed; break; } } else { txtId = TxtPhbkFull; } bookShowInformation( win, txtId, NULL, NULL ); if (identifier) { /* Destroy options menu and regenerate address list */ bookMenuDestroy(Phbk->menu_options_win); if(Phbk->current.status.used_entries > 0) SEND_EVENT(Phbk->search_win, SEARCH_SCROLL_UP, 0, 0 ); SEND_EVENT(Phbk->search_win, SEARCH_UPDATE, 0, (void*)Phbk->current.status.book ); } return; } /******************************************************************************* $Function: bookCopyMultiple $Description: Copy or move multiple phonebook entries $Returns: None $Arguments: None. *******************************************************************************/ void bookCopyMultiple(T_MFW_HND win, UBYTE move, UBYTE reason) { T_MFW_WIN *win_data = ( (T_MFW_HDR *) win )->data; T_phbk *Phbk = (T_phbk *) win_data->user; UBYTE oldBook; T_MFW_PHB_STATUS destStatus; T_MFW_PHB_STATUS srcStatus; T_MFW_PHB_LIST entries; T_MFW_PHB_ENTRY entry; UBYTE readIndex; int txtId; // T_MFW_HND info_win; // RAVI static T_MFW_HND waitWin = NULL; /* Set up some data */ TRACE_FUNCTION("bookCopyMultiple"); entries.entry = &entry; srcStatus.book = bookActiveBook(WRITE); bookGetCurrentStatus( &srcStatus ); oldBook = bookGetBookSelected(); bookSetBookSelected(!oldBook); destStatus.book = bookActiveBook(WRITE); bookGetCurrentStatus( &destStatus ); bookSetBookSelected(oldBook); /* First time entering function, set up values. * Store information so this function can be called again * when the phonebook is ready */ if (ipbCopyIndex==0) { ipbCopyIndex = srcStatus.used_entries; ipbWin = win; ipbMove = move; if (!bookGetBookSelected() && !move) { /* We need to drop out of this function briefly in order to get the dialog to display * for this particular case! Show info screen very briefly, which calls this function as * a callback. The info screen remains until we drop out of this function a second * time */ waitWin = NULL; bookShowInfoScreen( Phbk->win, TxtPleaseWait, NULL, (T_VOID_FUNC)bookCopyMultiple, NULL, 100); return; } waitWin = bookShowInfoScreen( Phbk->win, TxtPleaseWait, NULL, NULL, NULL, FOREVER); } TRACE_EVENT_P1("Entries in list: %d", srcStatus.used_entries); /* For special case where SIM will give no E_PHB_READY response, the * do...while operates as a loop below. Otherwise, it will only go through * once, and this function will be called repeatedly every E_PHB_READY */ do { txtId = TxtStored; if (!destStatus.avail_entries) { txtId = TxtPhbkFull; } else if (ipbCopyIndex==0) { txtId = TxtEmpty; } else { /* For moving, always delete first entry alphabetically, list moves down. * For copying, move through the list */ if (move) readIndex = 1; else readIndex = ipbCopyIndex; TRACE_EVENT_P1("Moving entry %d", readIndex); /* Read in entry and copy/move it */ phb_read_entries(srcStatus.book, readIndex, MFW_PHB_ALPHA, 1, &entries); switch (bookCopy(entries.entry, &destStatus, &srcStatus, move)) { case MFW_PHB_OK: txtId = TxtStored; break; case MFW_PHB_FULL: txtId = TxtPhbkFull; break; default: txtId = TxtFailed; break; } ipbCopyIndex--; } }/* Is a loop in special case - see above */ while (!bookGetBookSelected() && !move && txtId==TxtStored && ipbCopyIndex>0); /* If we've finished, or an error has occurred, show info dialog */ if (ipbCopyIndex==0 || txtId!=TxtStored) { ipbCopyIndex = 0; /* Destroy the Please Wait window and show the result message */ bookShowInformation( win, txtId, NULL, NULL ); if (waitWin) { SEND_EVENT(waitWin, DIALOG_DESTROY,0,0); } if (move) { /* Destroy options menu and regenerate address list */ bookMenuDestroy(Phbk->menu_options_win); bookGetCurrentStatus( &Phbk->current.status ); if(Phbk->current.status.used_entries > 0) { SEND_EVENT(Phbk->search_win, SEARCH_SCROLL_UP, 0, 0 ); SEND_EVENT(Phbk->search_win, SEARCH_UPDATE, 0, (void*)Phbk->current.status.book ); } else bookSearchDestroy(Phbk->search_win); } } return; } #endif /******************************************************************************* Public Methods *******************************************************************************/ /******************************************************************************* $Function: bookCurrentWindow $Description: This returns the window handle associated with the current MFW element $Returns: window handle of current MFW item $Arguments: none. *******************************************************************************/ tBookMfwHnd bookCurrentWindow( void ) { return mfwParent( mfwHeader() ); } /******************************************************************************* $Function: bookDefaultCallBack $Description: This is a simple call back function which is invoked when a not implemented dialog is displayed. We don't want anyone outside of this module using it so define it as static, this will still be callable from the info dialogs as it will use the reference we set up. $Returns: zero, always $Arguments: win, parent window identifier, of the window reason, for the window *******************************************************************************/ static tBookStatus bookDefaultCallBack( tBookMfwHnd win, UBYTE identifier, UBYTE reason ) { if ( win ) winShow( win ); return 0; } /******************************************************************************* $Function: bookWindowData $Description: This routine is designed to be invoked from within a menu handler or call back function and will return a pointer to the window data associated with the current MFW element. $Returns: pointer to the data area $Arguments: none. *******************************************************************************/ void *bookWindowData( void ) { tBookMfwHnd WinPtr; if ( ( WinPtr = bookCurrentWindow() ) == NULL ) return (void *) NULL; return (void *)((tBookMfwHdr *) WinPtr)->data; } /******************************************************************************* $Function: bookMenuSelectedNumber $Description: This will return the currently selected entry in the phone book, when the routine is being called from a menu handler $Returns: pointer to the selected number buffer $Arguments: none. *******************************************************************************/ char *bookMenuSelectedNumber( void ) { tBookMfwHnd WinData; /* Have we got a valid window ? */ if ( ( WinData = (tBookMfwHnd) bookWindowData() ) == NULL ) return NULL; return NULL; } /******************************************************************************* $Function: bookPhoneBookLoading $Description: access routine for the local static menu area Utility functions to determine if the phone book is still in the loading state $Returns: BOOK_FAILURE if loading, otherwise BOOK_SUCCESS $Arguments: none. *******************************************************************************/ tBookStatus bookPhoneBookLoading( void ) { int temp; char tempst[20]; TRACE_FUNCTION("bookPhoneBookLoading"); temp = phb_get_mode(); sprintf(tempst,"phb_get_mode %d",temp); TRACE_EVENT(tempst); return ( (phb_get_mode() == PHB_LOADING)||(phb_get_mode() == MFW_PHB_FAIL) ) ? BOOK_FAILURE : BOOK_SUCCESS; } /******************************************************************************* $Function: bookInfoDialog $Description: Utility functions just to throw a string onto the screen primarily for debug purposes, the modal version will wait for a user input before removing the message, the non-modal will clear after three seconds $Returns: One. $Arguments: String1, String2, character strings to be displayed. *******************************************************************************/ tBookStatus bookInfoDialog( char *String1, char *String2 ) { tBookMfwHnd Win = bookCurrentWindow(); tBookDialogData Dialog; /* Initialise the dialog control block with default information */ dlg_initDisplayData_TextStr( &Dialog, TxtNull, TxtNull, String1, String2, COLOUR_STATUS); dlg_initDisplayData_events( &Dialog, (T_VOID_FUNC)bookDefaultCallBack, THREE_SECS, KEY_CLEAR); /* Show the dialog */ info_dialog( Win, &Dialog ); return 1; } /******************************************************************************* $Function: bookNotImplemented $Description: This will present an information dialog indicating the current feature is still under development. This routine will use the current MFW element to detect the handle of the parent window if the incoming window handle is NULL. $Returns: One $Arguments: Parent, window, can be NULL *******************************************************************************/ tBookStatus bookNotImplemented( tBookMfwHnd Parent ) { tBookMfwHnd Win = ( Parent ) ? Parent : bookCurrentWindow(); tBookDialogData Dialog; /* Initialise the dialog control block with default information */ dlg_initDisplayData_TextStr( &Dialog, TxtNull, TxtNull, MmiRsrcGetText( TxtNotImplemented ), NULL, COLOUR_STATUS); dlg_initDisplayData_events( &Dialog, (T_VOID_FUNC)bookDefaultCallBack, THREE_SECS, KEY_CLEAR); /* Show the dialog */ info_dialog( Win, &Dialog ); return 1; } /* Menu handler to invoke the routine above */ tBookStatus bookMenuNotImplemented( tBookMfwMenu *Menu, tBookMfwMenuItem *Item ) { return bookNotImplemented( NULL ); } /* SPR#1428 - SH - New Editor changes: No longer required */ #ifndef NEW_EDITOR /******************************************************************************* $Function: set_edt_attr $Description: Sets up the edit attribute structure with the provided parameters $Returns: None $Arguments: winPx, winPy, winSx, winSy, positioning information fgColor, colour for foreground font, mode, controls, pretty much what they say *text, initial text to be edited size, of the text (in bytes) attr, the block to be set up with the other parameters GW - Changed colour from 8 bits (foreground) to 2x32bits fgd and bgd For the colour display we pass a 32 bit word that defines the size and position of the editor. This can be either a specific size or a more generic ('middle of the screen'/full width of display) *******************************************************************************/ void bookSetEditAttributes( int zone_id, U32 colIndex, U8 font, U8 mode, U8 *controls, char *text, U16 size, MfwEdtAttr* attr) { /* Populate the structure with the parameters */ calculateWindow(attr, zone_id ); attr->edtCol = colIndex; attr->font = font; attr->mode = mode; attr->controls = controls; attr->text = text; attr->size = size; } #endif /* NEW_EDITOR */ /******************************************************************************* Name Handling Functions *******************************************************************************/ /******************************************************************************* $Function: bookGetCurrentStatus $Description: Determines the current status of the phone book $Returns: status byte $Arguments: currentStatus, pointer to structure to be populated with status information *******************************************************************************/ UBYTE bookGetCurrentStatus( T_MFW_PHB_STATUS *currentStatus ) { UBYTE temp; TRACE_FUNCTION( "bookGetCurrentStatus()" ); temp = phb_get_status( currentStatus ); { char temp[255]; sprintf(temp,"book %d max_entries %d used_entries %d aval_entries %d", currentStatus->book,currentStatus->max_entries, currentStatus->used_entries, currentStatus->avail_entries); TRACE_EVENT(temp); } return temp; } /******************************************************************************* $Function: bookFindNames $Description: Fine name in phone book $Returns: status of search $Arguments: number, number of entries to search, current, pointer to structure containing search context *******************************************************************************/ UBYTE bookFindName( UBYTE number, tMmiPhbData *current ) { UBYTE ret; int index; // , Count = 0; // RAVI UBYTE l_name[MAX_ALPHA_LEN];/*MC SPR 1257, name strings should use MAX_ALPHA_LEN*/ UBYTE book_type, index_type; int i; char debug[22]; // May 24, 2004 REF: CRR MMI-SPR-15813 Ajith K P // Added these variables to Fix the Issue MMI-SPR-15813 // nondigitindex => index after which '+' sign to be added // numlength = lenght of the number array. // nondigitFound = Checks whether nondigit is present in the number array or not. int nondigitindex = -1,j,numlength = 0, nondigitFound = -1; TRACE_FUNCTION( "bookFindName()" ); /* Firstly, check for an empty book */ bookGetCurrentStatus( ¤t->status ); if ( current->status.used_entries < 1 ) { current->index = 0; return MFW_PHB_OK; } // Feb 20, 2006 REF: OMAPS00061948 x0039928 // Fix : If used entries are less than MAX_SARCH_NAME then no. of entries // passed to the phb_read_entries is used entries. if(current->status.used_entries < MAX_SEARCH_NAME) number = current->status.used_entries; /* Okay, we have some entries to search, so initialise the current entry buffer to empty */ memset( current->entry, 0, MAX_SEARCH_CALL_LIST * sizeof( T_MFW_PHB_ENTRY ) ); current->list.entry = current->entry; current->list.num_entries = number; /* Sort out how we index the information */ book_type = current->status.book; index_type = MFW_PHB_INDEX; if ( ( book_type == bookActiveBook(WRITE) ) || ( book_type == PHB_SDN ) ) index_type = MFW_PHB_ALPHA; /* Sort out the type of search we are performing */ if ((book_type == PHB_LDN) || (book_type == PHB_LRN)|| (book_type == PHB_LMN)) index_type = MFW_PHB_INDEX; else { if ( current->KindOfSearch == SEARCH_BY_NAME ) index_type = MFW_PHB_ALPHA; else if ( current->KindOfSearch == SEARCH_BY_NUMBER ) index_type = MFW_PHB_NUMBER; else if ( current->KindOfSearch == SEARCH_BY_LOCATION ) index_type = MFW_PHB_INDEX; } /* read the appropriate entries from the phone book */ { char temp[255]; sprintf(temp,"book %d index %d indextype %d number %d", book_type,current->index,index_type,number); TRACE_EVENT(temp); } // May 3, 2004 REF: CRR MMI-SPR-18555 Rashmi C N(Sasken) //When book is ADN, we need to read only ADN entries. no need to display ADN and FDN together if (book_type == PHB_ADN) /*Quick test */ { TRACE_EVENT("book_type == PHB_ADN"); ret = phb_read_entries( PHB_ADN, current->index, index_type, number, ¤t->list ); } else { TRACE_EVENT("book_type == OTHER"); ret = phb_read_entries( book_type, current->index, index_type, number, ¤t->list ); } /* Populate the output structures */ if (current->list.result == MFW_NO_ENTRY) current->index = 0; for ( index = 0; index < number; index++ ) #ifdef NO_ASCIIZ #ifdef EASY_TEXT_ENABLED {/*MC , SPR 1242 merged in this section from b-sample build*/ /* GSM character sets */ TRACE_EVENT( (char*)current->entry[index].name.data); TRACE_EVENT("Convert from SIM to UCS2"); TRACE_EVENT_P1("length of name string: %d", current->entry[index].name.len); /*MC SPR 1257, replacing PHB_MAX_LEN with MAX_ALPHA_LEN for name strings*/ if (current->entry[index].name.data[0] == 0x80 ) { for (i=1; i<MAX_ALPHA_LEN; i+=1) { l_name[i+1] = current->entry[index].name.data[i]; } l_name[0] = current->entry[index].name.data[0]; l_name[1] = MAX_ALPHA_LEN; memcpy( current->entry[index].name.data, (char*)l_name, MAX_ALPHA_LEN ); /*MC, we'll just use the length provided by the MFW*/ if (current->entry[index].name.len%2 == 1)/*if length of string odd*/ current->entry[index].name.len++;/* INCREASE LENGTH BY 1*/ /*make sure all chars after length are 0*/ for (i=current->entry[index].name.len; i<MAX_ALPHA_LEN; i++) { current->entry[index].name.data[i] = 0; } for (i=0; i < MAX_ALPHA_LEN;i++) { if ( current->entry[index].name.data[i]== 0 && current->entry[index].name.data[i+1] != 0) debug[i] = '0'; else debug[i] = (char)current->entry[index].name.data[i]; } TRACE_EVENT("Decoded entry"); TRACE_EVENT(debug); } else { /*SPR2175, use new function to convert from GSM to ASCII*/ { ATB_convert_String((char*)current->entry[index].name.data, MFW_DCS_8bits, current->entry[index].name.len, (char*)l_name, MFW_ASCII, PHB_MAX_LEN, FALSE); current->entry[index].name.dcs = MFW_ASCII; memcpy( current->entry[index].name.data, (char*)l_name, MAX_ALPHA_LEN ); } } } #endif /*MC end*/ #else { TRACE_EVENT_P1("length of name string: %d", current->entry[index].name.len); /*SPR2175, use new function to convert from GSM to ASCII*/ { ATB_convert_String((char*)current->entry[index].name.data, MFW_DCS_8bits, current->entry[index].name.data.len, l_name.data, MFW_ASCII, PHB_MAX_LEN); current->entry[index].name.dcs = MFW_ASCII; memcpy( current->entry[index].name.data, (char*)l_name, MAX_ALPHA_LEN ); } } #endif /* Needed to make international calls from the phonebook */ for ( index = 0; index < number; index++ ) { if ( current->entry[index].ton ) { // May 24, 2004 REF: CRR MMI-SPR-15813 Ajith K P // Issue description: Followup from 15623, this is the BMI part of this Issue. // At last, in the record "SSC09" the number is displayed with the "+" // character at the beginning of the number instead of "**21*+014543877989#" // Solution: Find the location of nondigit(e.g:*, #) in the number array // and put '+' to next position if the index is less than numlength-8. This is done // as there can be ss strings(like *11*20#) attached to the number in the end. // For eg: **61#+9844093515*11*20# // If the total length is less than 8 assign this index to nondigitindex. // This solution is based on special sequences we have encountered till now. // Finds the length of the number array. numlength = strlen((char*)current->entry[ index ].number); //checks whether the length is within the limit. if(numlength <=PHB_MAX_LEN) { for( j=0; j< numlength ; j++) { if( !isdigit((char*)current->entry[ index ].number[j]) ) { // Found a nondigit can be */# nondigitFound = j; // Checking , whether the nondigit index is not at the end // part of the number array. if(j < (numlength-8)) { // Current index is less than numlength-8 nondigitindex = j; } else { if(numlength <8) { // If lenght of the number array is less than 8 // assign the index to nondigitindex // This condition might occur when the user // presses invalid short sequence nondigitindex = j; } } } } if((nondigitindex == -1) && (nondigitFound> -1) && (nondigitFound < 4)) { // Nondigit is existing and it's position is less than 4 and not met // any of the above conditions. nondigitindex = nondigitFound; } // Move the contents accordingly. memmove((char *) &(current->entry[ index ].number[ nondigitindex+2]), (char *) &(current->entry[ index ].number[nondigitindex+1]), numlength - nondigitindex+1); // Add the '+' sign after the appropriate nondigit character, if any. current->entry[index].number[nondigitindex+1] = '+'; } } } return current->result = ret; } /******************************************************************************* $Function: bookEvent $Description: Event handler for a phone book event $Returns: MFW_EVENT_CONSUMED if recognised message, otherwise MFW_EVENT_PASSED $Arguments: e, event, para, general parameter giving context of call *******************************************************************************/ int bookEvent( MfwEvt e, void *para ) { T_MFW_PHB_STATUS *status; TRACE_FUNCTION( "bookEvent" ); /* deal with the incoming event */ switch( e ) { case E_PHB_UPN_LIST : { upnList = (T_MFW_UPN_LIST *)para; /* tbd */ } break; case E_PHB_STATUS: { status = (T_MFW_PHB_STATUS *)para; if ( ( status->book == PHB_FDN ) || ( status->book == PHB_ADN ) ) { if ( pinsSetIsFocussed() == FOCUSSED_PINS ) backpinFDNactdeact(); } } break; case E_PHB_ERROR: { /* tbd */ } break; /* SPR#1112 - SH - New events to indicate status of phonebook */ case E_PHB_READY: { TRACE_EVENT("E_PHB_READY"); #ifdef INT_PHONEBOOK /* SPR#1112 - SH - If we're copying or moving a list, * the current operation has been successful - keep copying. */ if (ipbCopyIndex) { TRACE_EVENT("Copying/moving in progress."); bookCopyMultiple(ipbWin, ipbMove, 0); } #endif } break; case E_PHB_BUSY: { TRACE_EVENT("E_PHB_BUSY"); } break; /* end SPR#1112 */ default: { /* indicate we haven't dealt with event */ return MFW_EVENT_PASSED; } // break; // RAVI } /* got to here, we have dealt with the event */ return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: bookCopyPhbName $Description: Copiers a phonebook name structure (for NO_ASCII set or cleared) $Returns: None $Arguments: destEntry - destination phonebook entry structure srcEntry - source phonebook entry structure maxLen - max number oc chars to be copied *******************************************************************************/ //GW Created function to copy name (and length when required). void bookCopyPhbName( T_MFW_PHB_ENTRY* destEntry, T_MFW_PHB_ENTRY* srcEntry, int maxLen ) { int len; //length of string to be copied if ((destEntry==NULL) || (srcEntry==NULL)) return; #ifdef NO_ASCIIZ //Ensure we do not copy more than the PHB array can hold. if ((maxLen < PHB_MAX_LEN) && (maxLen >0)) len = maxLen; else len = PHB_MAX_LEN; #else /*MC SPR1319, name string is only up to MAX_ALPHA_LEN in length*/ //Ensure we do not copy more than the PHB array can hold. if ((maxLen < MAX_ALPHA_LEN) && (maxLen >0)) len = maxLen; else len = MAX_ALPHA_LEN; #endif #ifdef NO_ASCIIZ memset (destEntry->name.data, 0, PHB_MAX_LEN); memcpy( destEntry->name.data, srcEntry->name.data, len); if (srcEntry->name.len < len) destEntry->name.len = srcEntry->name.len; else { //we have truncated the name - add termination (if possible) destEntry->name.len = len; if (len < PHB_MAX_LEN) { // there is space in array for termination - add it. destEntry->name.data[len] = 0x00; } } #else memcpy( destEntry->name, srcEntry->name, maxLen); #endif } /******************************************************************************* End of File *******************************************************************************/