FreeCalypso > hg > fc-magnetite
view src/aci2/bmi/mmiFileViewer.c @ 516:1ed9de6c90bd
src/g23m-gsm/sms/sms_for.c: bogus malloc removed
The new error handling code that was not present in TCS211 blob version
contains a malloc call that is bogus for 3 reasons:
1) The memory allocation in question is not needed in the first place;
2) libc malloc is used instead of one of the firmware's proper ways;
3) The memory allocation is made inside a function and then never freed,
i.e., a memory leak.
This bug was caught in gcc-built FreeCalypso fw projects (Citrine
and Selenite) because our gcc environment does not allow any use of
libc malloc (any reference to malloc produces a link failure),
but this code from TCS3.2 is wrong even for Magnetite: if this code
path is executed repeatedly over a long time, the many small allocations
made by this malloc call without a subsequent free will eventually
exhaust the malloc heap provided by the TMS470 environment, malloc will
start returning NULL, and the bogus code will treat it as an error.
Because the memory allocation in question is not needed at all,
the fix entails simply removing it.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 22 Jul 2018 06:04:49 +0000 |
parents | 3c2acfa1a72f |
children |
line wrap: on
line source
/******************************************************************************* Texas Instruments ******************************************************************************** This software product is the property of Texas Instruments and may not be disclosed to any third party without the express permission of the owner. ******************************************************************************** $Project name: File Viewer $Module: File Viewer $File: MmiFileViewer.c $Revision: 1.0 $Author: xdeepadh - sasken India $Date: 11/05/05 ******************************************************************************** Description: This module contains the functionality of File Viewer Application. ******************************************************************************** $History: MmiFileViewer.c Jan 03, 2006 REF: SPR OMAPS00060036 xdeepadh Description:In file viewer, the user is not allowed to retain the old name once he/she goes to the rename file option. Solution:While renaming the file,if the name already exists, display a proper error message Aug 31, 2005 REF: SPR 34050 xdeepadh Description: The application hangs if while renaming a saved file a special character such as '?', '!' etc is used Solution: Error message will be displayed when ffs_rename() fails Aug 30, 2005 REF:SPR 34049 xdeepadh Description: FileViewer: Not able to delete a file that is too big to display Solution: When the file was too big to display, the file handle was closed. Aug 22, 2005 REF: ENH 31154 xdeepadh Description: Application to Test Camera Solution: Implemeted the Fileviewer to view the jpeg images.Camera Application to preview,capture and save image has been implemented. $End *******************************************************************************/ #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" #include "prim.h" #else #include "stddefs.h" #include "custom.h" #include "gsm.h" #include "Vsi.h" #endif #include "message.h" /* included for aci_cmh.h .... */ #include "aci_cmh.h" /* included for mfw_sat.h, included for MmiDummy.h, included for MmiMenu.h */ #include "mfw_mfw.h" #include "mfw_win.h" #include "mfw_icn.h" /* included for mfw_mnu.h */ #include "mfw_mnu.h" #include "mfw_tim.h" #include "mfw_kbd.h" #include "mfw_sat.h" /* included for MmiDummy.h, included for MmiMenu.h */ #include "mfw_fv.h" //Will be enabled once the IMGIL APIS are provided. #include "ffs/ffs_api.h" #include "MmiBlkLangDB.h" #include "mmiColours.h" #include "MmiDialogs.h" #include "MmiDummy.h" /* included for MmiMenu.h */ #include "MmiLists.h" #include "MmiMenu.h" #include "MmiSoftKeys.h" #include "AUIEditor.h" #include "MmiFileViewer.h" #include "MmiMain.h" #include "Mmibookshared.h" /*local defines*/ //Events for windows #define FV_INIT 1 #define FV_RETURN 2 #define FV_ABORT 3 #define FV_EXIT 4 //Events for editor #define FV_EDITOR_CANCEL 5 #define FV_EDITOR_SELECT 6 #define FV_EDITOR_ERROR 7 //Aug 31, 2005 REF: SPR 34050 xdeepadh //Ids for diffrent functionalities. #define FV_OPT_ID 100 #define FV_EDT_ID 101 #define FV_DEL_ID 102 #define FV_INFO_SCRN_TIMEOUT 1500 //Aug 31, 2005 REF: SPR 34050 xdeepadh #define FV_FILE_NAME_LENGTH 20 #define FV_DIR_PATH_LENGTH (10 + FV_FILE_NAME_LENGTH) #define FV_DIR_NAME "/mmi/jpeg/" #define FV_MAX_NUM_FILES 10 #define FV_MAX_JPEG_SIZE (64 * 1024) //Variable defines UINT8 qcif_yuv_lum[FV_DSPL_VOLUME]; //decoded and Scaled lum buffer UINT8 qcif_yuv_cb[FV_SCALE_VOLUME]; //decoded and Scaled cb buffer UINT8 qcif_yuv_cr[FV_SCALE_VOLUME]; //decoded and Scaled cr buffer UINT8 qcif_rgb_array[ FV_DSPL_VOLUME * 2]; //Color converted buffer to view UINT8 rgb_img_process_array[FV_DSPL_VOLUME * 2]; //Color converted buffer for zoom/rotate UINT8 qcif_yuv_process_lum[FV_DSPL_VOLUME ]; //lum buffer for rotate and zoom UINT8 qcif_yuv_process_cb[FV_SCALE_VOLUME]; //cb buffer for rotate and zoom UINT8 qcif_yuv_process_cr[FV_SCALE_VOLUME]; //cr buffer for rotate and zoom /*menu data structure definition*/ typedef struct { T_MMI_CONTROL mmi_control; T_MFW_HND win; T_MFW_HND kbd; T_MFW_HND kbd_long; T_MFW_HND fv_menu; T_MFW_HND fv_option_win; T_MFW_HND parent; ListMenuData fv_list_data; UBYTE fv_file_count; ListCbFunc fv_list_cb; UBYTE fv_list_idx; }T_fv_menu; typedef struct { /* administrative data */ T_MMI_CONTROL mmi_control; T_MFW_HND win; SHORT id; T_MFW_HND parent; /* associated handlers */ T_MFW_HND kbd; T_MFW_HND kbd_long; T_MFW_HND menu; T_fv_menu * parent_data; } T_fv_opt; /*editor data structure*/ typedef struct{ T_MMI_CONTROL mmi_control; MfwHnd win; MfwHnd fv_win_editor; UBYTE fv_buffer[FV_FILE_NAME_LENGTH]; } T_FV_Editor_Data; /*default static menu*/ static MfwMnuAttr menuFvSearchListAttr = { &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 */ TxtNull, /* Hdr Id */ NULL, /* Background */ MNUATTRSPARE /* unused */ }; static const MfwMnuItem Mmi_fv_OPTItems [] = { {0,0,0,(char *)TxtView,0,(MenuFunc)mmi_fv_view_image_start,item_flag_none}, {0,0,0,(char *)TxtDelete,0,(MenuFunc)mmi_fv_delete_start,item_flag_none}, {0,0,0,(char *)TxtRename,0,(MenuFunc)mmi_fv_reame_edit,item_flag_none} }; static const MfwMnuAttr Mmi_fv_OPTAttrib = { &SmsSend_R_OPTArea, MNU_LEFT | MNU_LIST | MNU_CUR_LINE, /* centered page menu */ -1, /* use default font */ (MfwMnuItem*)Mmi_fv_OPTItems, /* with these items */ sizeof(Mmi_fv_OPTItems)/sizeof(MfwMnuItem), /* number of items */ COLOUR_LIST_SMS, TxtNull, NULL, MNUATTRSPARE }; //Variable definition T_fv_menu fv_menu_data = {0}; //Variable to store the max jpeg file count. int file_count = 0; //Array to store the Jpeg filenames. UBYTE jpegFiles[FV_MAX_NUM_FILES][FV_FILE_NAME_LENGTH] = {0}; //Buffer to store the jpeg image from FFS. static UBYTE jpeg_test_array[FV_MAX_JPEG_SIZE] = {0}; T_MFW_HND fv_optwin; UBYTE zoom_flag,rotate_flag = 0; //Flag to identify the rotate and zooming //Function prototypes static int mmi_fv_list_files_win_cb (MfwEvt e, MfwWin *w); static void mmi_fv_menu_listmnu_cb(T_MFW_HND Parent, ListMenuData * ListData); void mmi_fv_list_files_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter); static T_MFW_HND mmi_fv_list_files_create(T_MFW_HND parent_window, void* callfun); static T_MFW_HND mmi_fv_test_select_file (T_MFW_HND parent_win); static int mmi_fv_opt_mnu_cb (MfwEvt e, MfwMnu *m); static int mmi_fv_opt_kbd_cb (MfwEvt e, MfwKbd *k); static int mmi_fv_opt_win_cb (MfwEvt e, MfwWin *w); void mmi_fv_opt_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter); static void mmi_fv_delete_cb (T_MFW_HND win, USHORT Identifier, SHORT reason); static void mmi_rename_editor_cb(T_MFW_HND win, USHORT identifier, SHORT reason); MfwRes mmi_fv_editor_destroy(T_MFW_HND win); void mmi_fv_editor_cntrl (T_MFW_HND win, USHORT event, SHORT value, void * parameter); T_MFW_HND mmi_fv_editor_create(T_MFW_HND parent); static int mmi_fv_view_kbd_cb (MfwEvt e, MfwKbd *k); static int mmi_fv_view_win_cb (MfwEvt e, MfwWin w); static T_MFW_HND mmi_fv_view_image_create(MfwHnd parent_window); static void mmi_fv_view_exec_cb(T_MFW_HND win, USHORT event, void *parameter); static int mmi_fv_rotate_win_cb (MfwEvt e, MfwWin w); static int mmi_fv_rotate_kbd_cb (MfwEvt e, MfwKbd *k); static void mmi_fv_rotate_exec_cb(T_MFW_HND win, USHORT event, void *parameter); static int mmi_fv_zoom_win_cb (MfwEvt e, MfwWin w); static int mmi_fv_zoom_kbd_cb (MfwEvt e, MfwKbd *k); static void mmi_fv_zoom_exec_cb(T_MFW_HND win, USHORT event, void *parameter); static MfwHnd mmi_fv_test_show_info(T_MFW_HND parent,int lsk, int rsk, int str1, int str2, T_VOID_FUNC callback); static int mmi_fv_item_mnu_cb(MfwMnu * mnu, MfwMnuItem * item); static void mmi_fv_menu_destroy(MfwHnd window); static T_MFW_HND mmi_fv_opt_create(MfwHnd parent_window); GLOBAL int mmi_fv_delete_jpeg_file(UBYTE index); static T_MFW_HND mmi_fv_rotate_image_create(MfwHnd parent_window); int mmi_fv_zoom_image_start(T_MFW_HND parent) ; static T_MFW_HND mmi_fv_zoom_image_create(MfwHnd parent_window); /******************************************************************************* $Function: mmi_fv_get_file_count $Description: returns the count of jpeg files $Returns: The file count of the files in JPG folder. $Arguments:None *******************************************************************************/ UBYTE mmi_fv_get_file_count() { return file_count; } /******************************************************************************* $Function: LaunchFileViewer $Description: Initiates the creation of the jpeg file list window and post init event $Returns: Execution status $Arguments: m - pointer to current menu i - pointer to current menu item *******************************************************************************/ GLOBAL int LaunchFileViewer( MfwMnu *m, MfwMnuItem *i ) { T_MFW_HND win; T_MFW_HND parent_win = mfw_parent(mfw_header()); TRACE_FUNCTION ("LaunchFileViewer()"); mfw_fv_init(); win = mmi_fv_list_files_create(parent_win,(void*)mmi_fv_list_files_exec_cb); if (win NEQ NULL) { SEND_EVENT (win, FV_INIT, 0, 0); } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fileviewer_list_files_create $Description: Creates the window and dialog handler for the window that holds the list window $Returns: Window Handler $Arguments:parent_window - Parent Window callfun- Callback function *******************************************************************************/ static T_MFW_HND mmi_fv_list_files_create(T_MFW_HND parent_window, void* callfun) { T_fv_menu * data = (T_fv_menu *)mfwAlloc(sizeof (T_fv_menu)); T_MFW_WIN * win; TRACE_FUNCTION ("mmi_fileviewer_list_files_create"); /* Create window handler */ data->win = win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)mmi_fv_list_files_win_cb); if (data->win EQ NULL) { return NULL; } TRACE_EVENT("list holder window created: " ); /* connect the dialog data to the MFW-window */ data->mmi_control.dialog = (T_DIALOG_FUNC)callfun; 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; } /******************************************************************************* $Function: mmi_fv_list_files_exec_cb $Description: handler for the window that holds the list window $Returns:None $Arguments: win : The pointer to the window handler, so the function can reference the dynamic user data, if any. event : The incoming event value : Generic incoming Parameter, it will be 'event' dependant parameter : Generic incoming Parameter, it will be 'event' dependant *******************************************************************************/ void mmi_fv_list_files_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_fv_menu * data = (T_fv_menu *)win_data->user; TRACE_FUNCTION ("mmi_fv_list_files_exec_cb"); switch (event) { case FV_INIT: data->fv_menu = mmi_fv_test_select_file(win); if(data->fv_menu == NULL) mmi_fv_menu_destroy((MfwHnd)data->win); break; case FV_RETURN: default: break; } } /******************************************************************************* $Function: mmi_fv_list_files_win_cb $Description: window callback for the window that holds the list window $Returns:Status $Arguments: e - window handle event w - window *******************************************************************************/ static int mmi_fv_list_files_win_cb (MfwEvt e, MfwWin *w) { TRACE_FUNCTION ("mmi_fv_list_files_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: mmi_fv_test_select_file $Description: browse jpeg files and enable to select them $Returns: T_MFW_HND : Window Handle to the New Window, Null if failed. $Arguments: parent : pointer to the parent window. *******************************************************************************/ static T_MFW_HND mmi_fv_test_select_file (T_MFW_HND parent_win) { int j; T_fv_menu *data; T_MFW_HND win = parent_win; T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; TRACE_FUNCTION ("mmi_fv_test_select_file()"); //Populate the jpeg files from ffs mmi_fv_init(&file_count); data = (T_fv_menu *)win_data->user; if (data->win EQ NULL) { return NULL; } //set count to 0 data->fv_file_count = 0; //In case no files are present in ffs return info message if(file_count == 0) { mmi_fv_test_show_info(0,TxtNull,TxtNull, TxtFileNotLoaded, TxtNull, NULL); return NULL; } else { /* Create the list menu to display the results */ /* initialization of the dialog data */ data->fv_list_data.ListPosition = 1;/* True cursor position in list menu. */ data->fv_list_data.Font = 0; data->fv_list_data.LeftSoftKey = TxtSoftOptions; data->fv_list_data.RightSoftKey = TxtSoftBack; data->fv_list_data.KeyEvents = KEY_CLEAR | KEY_RIGHT | KEY_LEFT | KEY_MNUUP | KEY_MNUDOWN |KEY_HUP; data->fv_list_data.Reason = 0; data->fv_list_data.Strings = TRUE; data->fv_list_data.autoDestroy = TRUE; data->fv_list_data.Attr = (MfwMnuAttr *)&menuFvSearchListAttr; data->fv_list_data.Attr->hdrId = TxtFileViewer; data->fv_list_data.Attr->nItems = file_count; data->fv_list_cb = (ListCbFunc)mmi_fv_menu_listmnu_cb; data->fv_list_data.ListLength = file_count; /* actual number of entries in list menu. */ data->fv_list_data.List = (MfwMnuItem *)mfwAlloc(data->fv_list_data.ListLength * sizeof (MfwMnuItem)); if (data->fv_list_data.List != (MfwMnuItem *)0) { MfwMnuItem *listItem; /* Initialise the memory to 0x00 */ memset(data->fv_list_data.List, 0x00, data->fv_list_data.ListLength * sizeof (MfwMnuItem)); for (j = 0; j <data->fv_list_data.ListLength; j++) { listItem = &data->fv_list_data.List[j]; listItem->str = (char*)jpegFiles[data->fv_file_count++]; listItem->func = (MenuFunc)mmi_fv_item_mnu_cb; listItem->flagFunc = (FlagFunc)item_flag_none; } /* Recreate the menu with the new details */ if (listDisplayListMenu(data->win, &data->fv_list_data, data->fv_list_cb, FALSE) != LISTS_FAIL) return data->fv_list_data.win; } return data->win; } } /******************************************************************************* $Function: mmi_fv_test_show_info $Description: This function displays a information screen with the textId's $Returns: Dialog Window $Arguments:parent- parent win lsk- Left Softkey rsk-Right Softkey str1-String str2-String callback- Callback function *******************************************************************************/ static MfwHnd mmi_fv_test_show_info(T_MFW_HND parent,int lsk, int rsk, int str1, int str2, T_VOID_FUNC callback) { T_DISPLAY_DATA display_info; TRACE_FUNCTION ("mmi_fv_test_show_info()"); /* ** Create a timed dialog to display the Message */ dlg_initDisplayData_TextId( &display_info, lsk, rsk, str1, str2, COLOUR_STATUS); dlg_initDisplayData_events( &display_info, callback, FV_INFO_SCRN_TIMEOUT, KEY_LEFT | KEY_CLEAR | KEY_HUP); return info_dialog(parent, &display_info); } /******************************************************************************* $Function: mmi_fv_init $Description: Function retrieves the files present under the /JPG directory $Returns: None $Arguments: Filecount- count of files in FFS. *******************************************************************************/ void mmi_fv_init(int* fileCount) { T_FFS_FD fd = 0; char dir_name_p[] = FV_DIR_NAME; T_FFS_DIR dir = {0}; char dest_name_p[FV_FILE_NAME_LENGTH] = ""; int i, max_files_count = 0; char *fileExt; TRACE_FUNCTION("mmi_fv_init()"); i = strlen(dir_name_p); dir_name_p[i-1] = '\0'; TRACE_EVENT_P1("the dir name = %s",dir_name_p); if ((max_files_count = ffs_opendir (dir_name_p, &dir)) <= 0) { return; } //Display only 10 files if(max_files_count > FV_MAX_NUM_FILES) max_files_count = FV_MAX_NUM_FILES; *fileCount = max_files_count; TRACE_EVENT_P1("Number of files = %d",*fileCount); //read maximum of 10 file names for (i = 0; (ffs_readdir (&dir, dest_name_p, 100) > 0x0) && (i<max_files_count); i++) { if(i >= FV_MAX_NUM_FILES) break; //retrieve file extension fileExt = mmi_fv_GetExtension(dest_name_p); //Store only jpeg file names in array if ( (strcmp(fileExt, "jpg") == 0)) { strcpy ((char*)jpegFiles[i], dest_name_p); } memset(dest_name_p,0,FV_FILE_NAME_LENGTH); } TRACE_EVENT_P1("Number of files after read = %d",*fileCount); } /******************************************************************************* $Function: mmi_fv_item_mnu_cb $Description: save index of currently selected file $Returns: $Arguments: m - pointer to current menu i - pointer to current menu item *******************************************************************************/ static int mmi_fv_item_mnu_cb(MfwMnu * mnu, MfwMnuItem * item) { T_MFW_HND win = mfw_parent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_fv_menu *data = (T_fv_menu *)win_data->user; TRACE_FUNCTION ("mmi_fv_item_mnu_cb()"); if (data EQ NULL) { return NULL; } data->fv_list_idx = fv_menu_data.fv_list_idx = mnu->lCursor[mnu->level]; data->fv_option_win = mmi_fv_opt_start(data->win,(MfwMnuAttr*)&Mmi_fv_OPTAttrib); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_menu_listmnu_cb $Description: destroy lists and menu in case of back softkey or menu exit $Returns:None $Arguments:parent- Listadata- *******************************************************************************/ static void mmi_fv_menu_listmnu_cb(T_MFW_HND Parent, ListMenuData * ListData) { T_MFW_WIN *win_data = ((T_MFW_HDR *)Parent)->data; T_fv_menu *data = (T_fv_menu *)win_data->user; TRACE_FUNCTION ("mmi_fv_menu_listmnu_cb()"); if ((ListData->Reason EQ LISTS_REASON_BACK) || (ListData->Reason EQ LISTS_REASON_CLEAR) || (ListData->Reason EQ LISTS_REASON_HANGUP)) { /* Free the memory set aside for ALL the devices to be listed.*/ mfwFree((U8 *)data->fv_list_data.List, (U16)(ListData->ListLength* sizeof(MfwMnuItem))); listsDestroy(ListData->win); data->fv_list_data.List = NULL; mmi_fv_menu_destroy((MfwHnd)data->win); } return; } /******************************************************************************* $Function: mmi_fv_menu_destroy $Description: destroy menu window $Returns:None $Arguments: window : pointer to the parent window. *******************************************************************************/ static void mmi_fv_menu_destroy(MfwHnd window) { T_MFW_WIN * win_data = ((T_MFW_HDR *)window)->data; T_fv_menu * data = (T_fv_menu *)win_data->user; TRACE_FUNCTION ("mmi_fv_menu_destroy()"); if (window == NULL) { return; } if (data) { win_delete(data->win); /* Free Memory */ mfwFree((void *)data, sizeof (T_fv_menu)); } } /******************************************************************************* $Function: mmi_fv_set_rotate_90degree $Description: Rotates the selected image by 90 degree. $Returns: Status $Arguments:m - pointer to current menu i - pointer to current menu item *******************************************************************************/ GLOBAL int mmi_fv_set_rotate_90degree (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); TRACE_FUNCTION ("mmi_fv_set_rotate_90degree()"); rotate_flag = FV_ROTATE_90; mmi_fv_rotate_image_start(win); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_set_rotate_180degree $Description: Rotates the selected image by 180 degree. $Returns: Status $Arguments:m - pointer to current menu i - pointer to current menu item *******************************************************************************/ GLOBAL int mmi_fv_set_rotate_180degree (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); TRACE_FUNCTION ("mmi_fv_set_rotate_180degree()"); rotate_flag = FV_ROTATE_180; mmi_fv_rotate_image_start(win); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_set_rotate_270degree $Description: Rotates the selected image anti-clockwise. $Returns: $Arguments: m - pointer to current menu i - pointer to current menu item *******************************************************************************/ GLOBAL int mmi_fv_set_rotate_270degree (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); TRACE_FUNCTION ("mmi_fv_set_rotate_270degree()"); rotate_flag = FV_ROTATE_270; mmi_fv_rotate_image_start(win); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_set_zoom_out $Description: Zooms out the selected image $Returns: $Arguments: m - pointer to current menu i - pointer to current menu item *******************************************************************************/ GLOBAL int mmi_fv_set_zoom_out (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); TRACE_FUNCTION ("mmi_fv_set_zoom_out()"); zoom_flag = FV_ZOOM_OUT; mmi_fv_zoom_image_start(win); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_set_zoom_in $Description: Zooms in the selected image $Returns: $Arguments: m - pointer to current menu i - pointer to current menu item *******************************************************************************/ GLOBAL int mmi_fv_set_zoom_in (MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); TRACE_FUNCTION ("mmi_fv_set_zoom_in()"); zoom_flag = FV_ZOOM_IN; mmi_fv_zoom_image_start(win); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_view_image_start $Description: Create editor for viewing the image. $Returns: none $Arguments: m - menu handler i - menu item selected. *******************************************************************************/ int mmi_fv_view_image_start(MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win; T_MFW_HND parent_win = mfw_parent(mfw_header()); win = mmi_fv_view_image_create(parent_win); TRACE_FUNCTION ("mmi_fv_view_image_start"); SEND_EVENT(win,FV_INIT,FV_OPT_ID,0); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_view_image_create $Description: Create a window for viewing the image. $Returns: window handle $Arguments: parent_window - parent window. *******************************************************************************/ static T_MFW_HND mmi_fv_view_image_create(MfwHnd parent_window) { T_fv_opt* data = (T_fv_opt *)ALLOC_MEMORY (sizeof (T_fv_opt)); T_MFW_WIN * win; TRACE_FUNCTION ("mmi_fv_view_image_create()"); // Create window handler data->win = win_create (parent_window, 0, E_WIN_VISIBLE,(MfwCb)mmi_fv_view_win_cb); if (data->win EQ NULL) { return NULL; } // connect the dialog data to the MFW-window data->mmi_control.dialog = (T_DIALOG_FUNC)mmi_fv_view_exec_cb; data->mmi_control.data = data; win = ((T_MFW_HDR *)data->win)->data; win->user = (MfwUserDataPtr)data; data->parent = parent_window; //Create keyboard handler data->kbd = kbd_create (data->win,KEY_ALL,(T_MFW_CB)mmi_fv_view_kbd_cb); return data->win; } /******************************************************************************* $Function: mmi_fv_view_exec_cb $Description: Callback handler for events sent by the images editor $Returns: none $Arguments: win - current window event - event id parameter - optional data. *******************************************************************************/ static void mmi_fv_view_exec_cb(T_MFW_HND win, USHORT event, void *parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; int status; TRACE_FUNCTION ("mmi_fv_view_exec_cb()"); switch (event) { case FV_INIT: TRACE_EVENT("init"); status = mmi_fv_read_jpeg_file(fv_menu_data.fv_list_idx); //Display the decoded jpeg image in QCIF-RGB565 format on LCD. if(status == 1) winShow(data->win); else mmi_fv_test_show_info(0,TxtNull,TxtNull, TxtFileTooBig, TxtNull, NULL); break; case FV_RETURN: break; default: TRACE_EVENT("Err: Default"); return; } } /******************************************************************************* $Function: mmi_fv_opt_start $Description: called when the user press the Option menu $Returns: execution status $Arguments: parent_window -parent window handle menuAttr - Menu attributes. *******************************************************************************/ T_MFW_HND mmi_fv_opt_start(T_MFW_HND parent_window, MfwMnuAttr *menuAttr) { T_MFW_HND win; TRACE_FUNCTION ("mmi_fv_opt_start()"); fv_optwin = (T_MFW_HND)mmi_fv_opt_create ((MfwHnd)parent_window); if (fv_optwin NEQ NULL) { SEND_EVENT (fv_optwin, FV_INIT, NULL, (void *)menuAttr); } return fv_optwin; } /******************************************************************************* $Function: mmi_fv_opt_create $Description: Create the Option window $Returns: mfw window handle $Arguments: parent_window -parent window handle *******************************************************************************/ static T_MFW_HND mmi_fv_opt_create(MfwHnd parent_window) { T_fv_opt * data = (T_fv_opt *)ALLOC_MEMORY (sizeof (T_fv_opt)); T_MFW_WIN * win; TRACE_FUNCTION ("mmi_fv_opt_create()"); /* * Create window handler */ data->win = win_create (parent_window, 0, E_WIN_VISIBLE, (T_MFW_CB)mmi_fv_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)mmi_fv_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: mmi_fv_opt_destroy $Description: Destroy the Option window $Returns: mfw window handle $Arguments: own_window - current window *******************************************************************************/ static void mmi_fv_opt_destroy(MfwHnd own_window) { T_MFW_WIN * win_data; T_fv_opt * data; TRACE_FUNCTION ("mmi_fv_opt_destroy()"); if (own_window) { win_data = ((T_MFW_HDR *)own_window)->data; data = (T_fv_opt *)win_data->user; if (data) { /* * Delete WIN handler */ if (data->kbd) { kbd_delete(data->kbd); data->kbd = NULL; } if (data->kbd_long) { kbd_delete(data->kbd_long); data->kbd_long = NULL; } if (data->menu) { mnuDelete(data->menu); data->menu=NULL; } win_delete (data->win); /* * Free Memory */ FREE_MEMORY ((void *)data, sizeof (T_fv_opt)); } else { TRACE_EVENT ("mmi_fv_opt_destroy() called twice"); } } } /******************************************************************************* $Function: mmi_fv_opt_win_cb $Description: Window callback function for the Option window $Returns: execution status $Arguments: e - event id w - window handle *******************************************************************************/ static int mmi_fv_opt_win_cb (MfwEvt e, MfwWin *w) { TRACE_FUNCTION ("mmi_fv_opt_win_cb()"); switch (e) { case MfwWinVisible: /* window is visible */ dspl_ClearAll(); 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: mmi_fv_view_win_cb $Description: Window callback function for the Option window $Returns: execution status $Arguments: e - event id w - window handle *******************************************************************************/ static int mmi_fv_view_win_cb (MfwEvt e, MfwWin w) { TRACE_FUNCTION ("mmi_fv_view_win_cb()"); switch (e) { case MfwWinVisible: /* window is visible */ dspl_ClearAll(); displaySoftKeys(TxtSoftOptions,TxtSoftBack); //Display the image now. mmi_fv_display_image(); break; case MfwWinFocussed: /* input focus / selected */ case MfwWinDelete: /* window will be deleted */ default: return MFW_EVENT_REJECTED; } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_opt_exec_cb $Description: Exec callback function for the Option window $Returns: none $Arguments: win - current window event - event id value - unique id parameter - optional data. *******************************************************************************/ void mmi_fv_opt_exec_cb (T_MFW_HND win, USHORT event, SHORT value, void * parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; T_MFW_HDR * parent = data->parent; T_MFW_WIN * win_data2 = ((T_MFW_HDR *)parent)->data; T_fv_menu* parent_data = (T_fv_menu *)win_data2->user; TRACE_FUNCTION ("mmi_fv_opt_exec_cb()"); switch (event) { case FV_INIT: TRACE_EVENT("mmi_fv_opt_exec_cb() Event:5.FV_INIT"); /* initialization of administrative data */ data->parent_data = parent_data; data->id = value; data->kbd = kbdCreate(data->win,KEY_ALL, (MfwCb)mmi_fv_opt_kbd_cb); data->kbd_long = kbdCreate(data->win,KEY_ALL|KEY_LONG,(MfwCb)mmi_fv_opt_kbd_cb); data->menu = mnuCreate(data->win,(MfwMnuAttr*)parameter, E_MNU_ESCAPE, (MfwCb)mmi_fv_opt_mnu_cb); mnuLang(data->menu,mainMmiLng); /* put the (new) dialog window on top of the window stack */ mnuUnhide(data->menu); winShow(win); break; default: return; } } /******************************************************************************* $Function: mmi_fv_opt_kbd_cb $Description: Exec callback function for the Option window $Returns: execution status $Arguments: e - event id k - keyboard info *******************************************************************************/ static int mmi_fv_opt_kbd_cb (MfwEvt e, MfwKbd *k) { T_MFW_HND win = mfwParent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; TRACE_FUNCTION ("mmi_fv_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: mmi_fv_view_kbd_cb $Description: Exec callback function for the view window $Returns: execution status $Arguments: e - event id k - keyboard info *******************************************************************************/ static int mmi_fv_view_kbd_cb (MfwEvt e, MfwKbd *k) { T_MFW_HND win = mfwParent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; TRACE_FUNCTION ("mmi_fv_view_kbd_cb()"); switch (k->code) { case KCD_LEFT: TRACE_EVENT("mmi_fv_view_kbd_cb,INFO_KCD_LEFT "); bookMenuStart(data->win, ViewOptionsMenuAttributes(),0); break; case KCD_RIGHT: case KCD_HUP: TRACE_EVENT("mmi_fv_view_kbd_cb,INFO_KCD_RIGHT "); mmi_fv_opt_destroy(data->win); break; default: break; } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_opt_mnu_cb $Description: Menu callback function for the Option window $Returns: none $Arguments: e - event id m - menu handle *******************************************************************************/ static int mmi_fv_opt_mnu_cb (MfwEvt e, MfwMnu *m) { T_MFW_HND win = mfwParent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; TRACE_FUNCTION ("mmi_fv_opt_mnu_cb()"); switch (e) { case E_MNU_ESCAPE: /* back to previous menu */ mmi_fv_opt_destroy(data->win); break; default: /* in mnuCreate() only E_MNU_ESCAPE has been enabled! */ return MFW_EVENT_REJECTED; } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_rotate_start $Description: This function creates and displays the Roate menu . $Returns: Execution status $Arguments: m - menu handler i - Menu item selected *******************************************************************************/ int mmi_fv_rotate_start(MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; TRACE_FUNCTION("mmi_fv_rotate_start"); if (data->win EQ NULL) { return NULL; } /* Create the Rotate menu*/ bookMenuStart(data->win, rotateMenuAttributes(),0); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_zoom_start $Description: This function creates and displays the Zoom menu . $Returns: Execution status $Arguments: m - menu handler i - Menu item selected *******************************************************************************/ int mmi_fv_zoom_start(MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; TRACE_FUNCTION("mmi_fv_zoom_start"); if (data->win EQ NULL) { return NULL; } /* Create the Zoom menu*/ bookMenuStart(data->win, zoomMenuAttributes(),0); return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_GetExtension $Description: public function to retrieve the extension of a file $Returns:Extention of the filename $Arguments: scr- Filename *******************************************************************************/ char *mmi_fv_GetExtension(char *src) { int i; TRACE_FUNCTION("mmi_fv_GetExtension"); for(i = 0; i < strlen(src); i++){ if(src[i] == '.'){ return (src+i+1); } } return (src+i); } /******************************************************************************* $Function: mmi_fv_delete_start $Description: This function is called when the user press Delete . $Returns: Execution status $Arguments: m - menu handler i - Menu item selected *******************************************************************************/ int mmi_fv_delete_start(MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfwParent(mfw_header()); T_DISPLAY_DATA display_info; TRACE_FUNCTION("mmi_fv_delete_start"); //Check whether files are present if ( mmi_fv_get_file_count() == 0) { /*tell user*/ mmi_fv_test_show_info(0,TxtNull,TxtNull, TxtEmptyList, TxtNull, NULL); } else { TRACE_EVENT("files are present"); TRACE_EVENT_P1("delete_index is %d",fv_menu_data.fv_list_idx); TRACE_EVENT_P1("The selected file = %s",jpegFiles[fv_menu_data.fv_list_idx]); dlg_initDisplayData_TextId( &display_info, TxtSoftOK, TxtSoftBack, TxtDeleteConfirm, TxtNull, COLOUR_STATUS); dlg_initDisplayData_events( &display_info, (T_VOID_FUNC)mmi_fv_delete_cb, FOREVER, KEY_LEFT |KEY_RIGHT|KEY_CLEAR|KEY_HUP); info_dialog (win, &display_info); } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_delete_cb $Description: Exec callback function for the delete window $Returns: none $Arguments: win - current win Identifier- reason- *******************************************************************************/ static void mmi_fv_delete_cb (T_MFW_HND win, USHORT Identifier, SHORT reason) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; int status; TRACE_FUNCTION ("mmi_fv_delete_cb()"); switch (reason) { case INFO_KCD_LEFT: TRACE_EVENT("file has been left"); //Delete the selected file from FFS. status=mmi_fv_delete_jpeg_file((UBYTE)fv_menu_data.fv_list_idx); if(status>0) { mmi_fv_test_show_info(0, TxtNull,TxtNull,TxtDeleted, TxtNull, NULL); } SEND_EVENT(data->parent, FV_INIT, Identifier, NULL); break; case INFO_KCD_RIGHT: case INFO_KCD_HUP: TRACE_EVENT("file has been back"); break; default: break; } mmi_fv_opt_destroy(fv_optwin); } /******************************************************************************* $Function: mmi_fv_read_jpeg_file $Description: reads the contents of the file into the buffer . $Returns: Status $Arguments:index: Index of the file to be read from FFS. *******************************************************************************/ GLOBAL int mmi_fv_read_jpeg_file(UBYTE index) { T_FFS_FD file_handle = 0; SHORT readStatus = 1; //Aug 31, 2005 REF: SPR 34050 xdeepadh //The filename will have the full path details char file_name[FV_DIR_PATH_LENGTH]; TRACE_FUNCTION ("mmi_fv_read_jpeg_file()"); strcpy((char*)file_name,FV_DIR_NAME); strcat((char*)file_name, (const char*)jpegFiles[index]); TRACE_EVENT_P1("The selected file = %s",jpegFiles[index]); file_handle = ffs_open(file_name,FFS_O_RDONLY); if(file_handle <0) { readStatus = -1; mmi_fv_test_show_info(0,TxtNull,TxtNull, TxtFileNotLoaded, TxtNull, NULL); } else { UINT16 Ffs_stat; struct stat_s stat; Ffs_stat = ffs_stat(file_name,&stat); TRACE_EVENT_P1("read jpg size: %d", stat.size); if (Ffs_stat != 0) TRACE_EVENT_P1("read jpg size: %d", stat.size); if(stat.size >= FV_MAX_JPEG_SIZE ) { TRACE_EVENT_P1("File zise too big: %d", stat.size); readStatus = -1; //Aug 30, 2005 REF:SPR 34049 xdeepadh //Close the file handle ffs_close(file_handle); return readStatus; } memset(jpeg_test_array,0,FV_MAX_JPEG_SIZE); Ffs_stat = ffs_read(file_handle, (UBYTE *)jpeg_test_array, stat.size); TRACE_EVENT_P1("read jpg file size: %d", Ffs_stat); ffs_close(file_handle); } return readStatus; } /******************************************************************************* $Function: mmi_fv_delete_jpeg_file $Description: delete the selected file from FFS. $Returns:Status $Arguments: index: Index of the file to be read from FFS. *******************************************************************************/ GLOBAL int mmi_fv_delete_jpeg_file(UBYTE index) { //Aug 31, 2005 REF: SPR 34050 xdeepadh //The filename will have the full path details char file_name[FV_DIR_PATH_LENGTH]; T_FFS_RET status; TRACE_FUNCTION ("mmi_fv_delete_jpeg_file()"); strcpy((char*)file_name,FV_DIR_NAME); strcat((char*)file_name, (const char*)jpegFiles[index]); TRACE_EVENT_P1("The selected file = %s",jpegFiles[index]); TRACE_EVENT_P1("The deleted file = %s",file_name); status = ffs_remove(file_name); if (status == EFFS_OK) { //Populate the list again file_count = 0; mmi_fv_init(&file_count); } return status; } /******************************************************************************* $Function: mmi_fv_display_image $Description: The decoded and color converted image is displayed onto the screen. $Returns:Status $Arguments:None *******************************************************************************/ GLOBAL int mmi_fv_display_image() { UBYTE status = 0; TRACE_FUNCTION("mmi_fv_display_image()"); status = mfw_fv_decode_image(jpeg_test_array,sizeof(jpeg_test_array)); if(status) { TRACE_FUNCTION("mmi_fv_display_image()--OK"); //return MFW_EVENT_CONSUMED; } else { TRACE_FUNCTION("mmi_fv_display_image()--Fail"); //return MFW_EVENT_REJECTED; } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_reame_edit $Description: This function is called when the user press rename . $Returns: Execution status $Arguments: m - menu handler i - Menu item selected *******************************************************************************/ GLOBAL int mmi_fv_reame_edit(MfwMnu* m, MfwMnuItem* i) { T_MFW_HND win = mfw_parent(mfw_header()); //T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_MFW_HND win_temp; //T_FV_Editor_Data * data = (T_FV_Editor_Data *)(win_data->user); TRACE_FUNCTION ("mmi_fv_reame_edit()"); win_temp = mmi_fv_editor_create(win); if (win_temp != NULL) { SEND_EVENT(win_temp, FV_INIT, 0, (void *)NULL); } else { TRACE_FUNCTION ("mmi_fv_reame_edit() : Unable to create Editor Win!"); } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_editor_create $Description: Create a window for renaming the image file name $Returns: window handle $Arguments: parent - parent window. *******************************************************************************/ T_MFW_HND mmi_fv_editor_create(T_MFW_HND parent) { T_FV_Editor_Data *data; T_MFW_WIN * win; TRACE_FUNCTION ("mmi_fv_editor_create"); data = (T_FV_Editor_Data *)mfwAlloc((U16)sizeof(T_FV_Editor_Data)); if (data == NULL) return data; data->win = winCreate(parent, 0, E_WIN_VISIBLE, NULL); if (data->win == NULL) { /* ** Failed to start : Free Memory, and exit */ mfwFree((U8 *)data, (U16)sizeof(T_FV_Editor_Data)); data = NULL; return data; } else { /* ** Setup the Dialog control functions */ data->mmi_control.dialog = (T_DIALOG_FUNC)mmi_fv_editor_cntrl; data->mmi_control.data = data; win = ((T_MFW_HDR *)data->win)->data; win->user = (void *)data; } return data->win; } /******************************************************************************* $Function: mmi_fv_editor_cntrl $Description: Exec callback function for the rename window $Returns: none $Arguments: win - current window event - event id value - unique id parameter - optional data. *******************************************************************************/ void mmi_fv_editor_cntrl (T_MFW_HND win, USHORT event, SHORT value, void * parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_FV_Editor_Data * data = (T_FV_Editor_Data *)win_data->user; T_AUI_EDITOR_DATA editor_data; //Aug 31, 2005 REF: SPR 34050 xdeepadh //The filename will have the full path details char new_filename[FV_DIR_PATH_LENGTH]; char selected_file[FV_DIR_PATH_LENGTH]; int status = 0; switch (event) { case FV_INIT: #ifdef NEW_EDITOR //Clear the editor buffer memset(&editor_data,'\0',sizeof(editor_data)); // Get the name from FFS TRACE_EVENT_P1("The file to be renamed file = %s",jpegFiles[fv_menu_data.fv_list_idx]); strcpy((char *)data->fv_buffer, (const char*)jpegFiles[fv_menu_data.fv_list_idx]); /* ** Initialise the editor */ AUI_edit_SetDefault(&editor_data); AUI_edit_SetBuffer(&editor_data, ATB_DCS_ASCII, data->fv_buffer, FV_FILE_NAME_LENGTH); AUI_edit_SetTextStr(&editor_data, TxtSoftOK, TxtDelete, TxtRename, NULL); AUI_edit_SetAltTextStr(&editor_data, 1, TxtNull, TRUE, TxtSoftBack); AUI_edit_SetEvents(&editor_data, 0, TRUE, FOREVER, (T_AUI_EDIT_CB)mmi_rename_editor_cb); data->fv_win_editor = AUI_edit_Start(data->win, &editor_data); #endif break; case FV_EDITOR_CANCEL: /* ** The editor will have been destroyed. Reset the Window handler */ data->fv_win_editor = NULL; /* ** Destroy the editor Window */ TRACE_FUNCTION ("mmi_fv_editor_cntrl cancel"); mmi_fv_editor_destroy(data->win); mmi_fv_opt_destroy(fv_optwin); break; case FV_EDITOR_ERROR: //Aug 31, 2005 REF: SPR 34050 xdeepadh //Display the error message to the user mmi_fv_test_show_info(0, TxtNull,TxtNull,TxtNoExtension, TxtNull, NULL); /* ** The editor will have been destroyed. Reset the Window handler */ data->fv_win_editor = NULL; /* ** Destroy the editor Window */ TRACE_FUNCTION ("mmi_fv_editor_cntrl cancel"); mmi_fv_editor_destroy(data->win); mmi_fv_opt_destroy(fv_optwin); break; case FV_EDITOR_SELECT: //copy the file name from the editor strcpy(new_filename,FV_DIR_NAME); strcat(new_filename,(char *)data->fv_buffer); TRACE_EVENT_P1("new_filename %s",new_filename); strcpy(selected_file,FV_DIR_NAME); strcat(selected_file,(char*)jpegFiles[fv_menu_data.fv_list_idx]); TRACE_EVENT_P1("selected_file %s",selected_file); // Rename the file in FFS. status = ffs_rename(selected_file,new_filename); TRACE_EVENT_P1("status is %d",status); //Jan 03, 2006 REF: SPR OMAPS00060036 xdeepadh //While renaming the file,if the name already exists, display a proper error message. switch(status) { case EFFS_OK: //Populate the list again file_count = 0; mmi_fv_init(&file_count); break; case EFFS_EXISTS: mmi_fv_test_show_info(0, TxtNull,TxtNull,TxtFileExists, TxtNull, NULL); break; default: //Display the error message to the user mmi_fv_test_show_info(0, TxtNull,TxtNull,TxtWrongFilename, TxtNull, NULL); } /* ** Destroy the Editor Window */ mmi_fv_editor_destroy(data->win); mmi_fv_opt_destroy(fv_optwin); break; default: TRACE_FUNCTION ("mmi_fv_editor_cntrl(), Unexpected Event!"); break; } } /******************************************************************************* $Function: mmi_fv_editor_destroy $Description: Destroy the rename editor window $Returns: mfw window handle $Arguments: own_window - current window *******************************************************************************/ MfwRes mmi_fv_editor_destroy(T_MFW_HND win) { T_MFW_WIN * win_data; T_FV_Editor_Data * data; TRACE_FUNCTION ("mmi_fv_editor_destroy"); if (win == NULL) return MfwResIllHnd; win_data = ((T_MFW_HDR *) win)->data; data = (T_FV_Editor_Data *)win_data->user; /* ** Destroy the Window */ win_delete(data->win); /* ** Free the dynamically allocated memory */ mfwFree((U8 *)data, (U16)sizeof(T_FV_Editor_Data)); return MfwResOk; } /******************************************************************************* $Function: mmi_rename_editor_cb $Description: This function provides the callback functionality to an editor for file viewer $Returns: None $Arguments: win - current window identifier - reason - *******************************************************************************/ static void mmi_rename_editor_cb(T_MFW_HND win, USHORT identifier, SHORT reason) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_FV_Editor_Data* dev_name_data = (T_FV_Editor_Data *)win_data->user; UBYTE * editor_buffer = NULL; SHORT max_edit_size = 0; T_MFW_HND editor_win; T_MFW_HND parent; char * fileExt; TRACE_FUNCTION ("mmi_rename_editor_cb()"); editor_buffer = dev_name_data->fv_buffer; max_edit_size = FV_FILE_NAME_LENGTH - 1; editor_win = dev_name_data->fv_win_editor; parent = dev_name_data->win; switch (reason) { case INFO_KCD_LEFT: { /* ** If there is no string entered, treat this as if it was a "Cancel" */ if (editor_buffer[0] == NULL) { /* ** Send a "Cancel" to the window */ SEND_EVENT(parent, FV_EDITOR_CANCEL, identifier, NULL); } else { //If the file extn is not jpg, send cancel event fileExt = (char *)mmi_fv_GetExtension((char *)editor_buffer); if ( (strcmp(fileExt, "jpg") != 0)) { //Aug 31, 2005 REF: SPR 34050 xdeepadh /* ** Send a "Error" to the window */ SEND_EVENT(parent, FV_EDITOR_ERROR, identifier, NULL); } else { /* ** Send a "Select" to the window */ SEND_EVENT(parent, FV_EDITOR_SELECT, identifier, NULL); } } } break; case INFO_KCD_RIGHT: if (strlen((char *)editor_buffer) == NULL) { /* ** Send a "Cancel" to the window */ SEND_EVENT(parent, FV_EDITOR_CANCEL, identifier, NULL); } break; case INFO_KCD_HUP: /* ** Set the buffer to NULLS */ memset(editor_buffer, NULL, max_edit_size); /* ** Send a "Cancel" to the window */ SEND_EVENT(parent, FV_EDITOR_CANCEL, identifier, NULL); break; default: /* otherwise no action to be performed */ break; } } /******************************************************************************* $Function: mmi_fv_rotate_image_start $Description: Create window for displaying the rotated image. $Returns: none $Arguments: m - menu handler i - menu item selected. *******************************************************************************/ int mmi_fv_rotate_image_start(T_MFW_HND parent) { T_MFW_HND win; win = (T_MFW_HND)mmi_fv_rotate_image_create((MfwHnd)parent); TRACE_FUNCTION ("mmi_fv_rotate_image_start"); if (win NEQ NULL) { SEND_EVENT(win,FV_INIT,FV_OPT_ID,0); } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_rotate_image_create $Description: Create a window for rotating the image. $Returns: window handle $Arguments: parent_window - parent window. *******************************************************************************/ static T_MFW_HND mmi_fv_rotate_image_create(MfwHnd parent_window) { T_fv_opt* data = (T_fv_opt *)ALLOC_MEMORY (sizeof (T_fv_opt)); T_MFW_WIN * win; TRACE_FUNCTION ("mmi_fv_rotate_image_create()"); // Create window handler data->win = win_create (parent_window, 0, E_WIN_VISIBLE,(MfwCb)mmi_fv_rotate_win_cb); if (data->win EQ NULL) { return NULL; } // connect the dialog data to the MFW-window data->mmi_control.dialog = (T_DIALOG_FUNC)mmi_fv_rotate_exec_cb; data->mmi_control.data = data; win = ((T_MFW_HDR *)data->win)->data; win->user = (MfwUserDataPtr)data; data->parent = parent_window; //Create keyboard handler data->kbd = kbd_create (data->win,KEY_ALL,(T_MFW_CB)mmi_fv_rotate_kbd_cb); winShow(data->win); return data->win; } /******************************************************************************* $Function: mmi_fv_rotate_exec_cb $Description: Callback handler for events sent by the images editor $Returns: none $Arguments: win - current window event - event id parameter - optional data. *******************************************************************************/ static void mmi_fv_rotate_exec_cb(T_MFW_HND win, USHORT event, void *parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; int status; TRACE_FUNCTION ("mmi_fv_rotate_exec_cb()"); switch (event) { case FV_INIT: TRACE_EVENT("init"); status = mfw_fv_rotate_image(); if(!status) { mmi_fv_test_show_info(0,TxtNull,TxtNull, TxtError, TxtNull, NULL); } break; case FV_RETURN: break; default: TRACE_EVENT("Err: Default"); return; } } /******************************************************************************* $Function: mmi_fv_rotate_win_cb $Description: Window callback function for the rotate window $Returns: execution status $Arguments: e - event id w - window handle *******************************************************************************/ static int mmi_fv_rotate_win_cb (MfwEvt e, MfwWin w) { TRACE_FUNCTION ("mmi_fv_rotate_win_cb()"); switch (e) { case MfwWinVisible: /* window is visible */ dspl_ClearAll(); displaySoftKeys(TxtNull,TxtSoftBack); break; case MfwWinFocussed: /* input focus / selected */ case MfwWinDelete: /* window will be deleted */ default: return MFW_EVENT_REJECTED; } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_rotate_kbd_cb $Description: Exec callback function for the rotate window $Returns: execution status $Arguments: e - event id k - keyboard info *******************************************************************************/ static int mmi_fv_rotate_kbd_cb (MfwEvt e, MfwKbd *k) { T_MFW_HND win = mfwParent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; TRACE_FUNCTION ("mmi_fv_rotate_kbd_cb()"); switch (k->code) { case KCD_LEFT: TRACE_EVENT("mmi_fv_rotate_kbd_cb,INFO_KCD_LEFT "); break; case KCD_RIGHT: case KCD_HUP: TRACE_EVENT("mmi_fv_rotate_kbd_cb,INFO_KCD_RIGHT "); mmi_fv_opt_destroy(data->win); break; default: break; } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_zoom_image_start $Description: Create window for displaying the zoomed image. $Returns: none $Arguments: m - menu handler i - menu item selected. *******************************************************************************/ int mmi_fv_zoom_image_start(T_MFW_HND parent) { T_MFW_HND win; win = (T_MFW_HND)mmi_fv_zoom_image_create((MfwHnd)parent); TRACE_FUNCTION ("mmi_fv_zoom_image_start"); if (win NEQ NULL) { SEND_EVENT(win,FV_INIT,FV_OPT_ID,0); } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_zoom_image_create $Description: Create a window for zooming the image. $Returns: window handle $Arguments: parent_window - parent window. *******************************************************************************/ static T_MFW_HND mmi_fv_zoom_image_create(MfwHnd parent_window) { T_fv_opt* data = (T_fv_opt *)ALLOC_MEMORY (sizeof (T_fv_opt)); T_MFW_WIN * win; TRACE_FUNCTION ("mmi_fv_zoom_image_create()"); // Create window handler data->win = win_create (parent_window, 0, E_WIN_VISIBLE,(MfwCb)mmi_fv_zoom_win_cb); if (data->win EQ NULL) { return NULL; } // connect the dialog data to the MFW-window data->mmi_control.dialog = (T_DIALOG_FUNC)mmi_fv_zoom_exec_cb; data->mmi_control.data = data; win = ((T_MFW_HDR *)data->win)->data; win->user = (MfwUserDataPtr)data; data->parent = parent_window; //Create keyboard handler data->kbd = kbd_create (data->win,KEY_ALL,(T_MFW_CB)mmi_fv_zoom_kbd_cb); winShow(data->win); return data->win; } /******************************************************************************* $Function: mmi_fv_zoom_exec_cb $Description: Callback handler for events sent by the images editor $Returns: none $Arguments: win - current window event - event id parameter - optional data. *******************************************************************************/ static void mmi_fv_zoom_exec_cb(T_MFW_HND win, USHORT event, void *parameter) { T_MFW_WIN * win_data = ((T_MFW_HDR *) win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; int status; TRACE_FUNCTION ("mmi_fv_zoom_exec_cb()"); switch (event) { case FV_INIT: TRACE_EVENT("init"); status = mfw_fv_zoom_image(); if(!status) { mmi_fv_test_show_info(0,TxtNull,TxtNull, TxtError, TxtNull, NULL); } break; case FV_RETURN: break; default: TRACE_EVENT("Err: Default"); return; } } /******************************************************************************* $Function: mmi_fv_zoom_win_cb $Description: Window callback function for the Option window $Returns: execution status $Arguments: e - event id w - window handle *******************************************************************************/ static int mmi_fv_zoom_win_cb (MfwEvt e, MfwWin w) { TRACE_FUNCTION ("mmi_fv_zoom_win_cb()"); switch (e) { case MfwWinVisible: /* window is visible */ dspl_ClearAll(); displaySoftKeys(TxtNull,TxtSoftBack); break; case MfwWinFocussed: /* input focus / selected */ case MfwWinDelete: /* window will be deleted */ default: return MFW_EVENT_REJECTED; } return MFW_EVENT_CONSUMED; } /******************************************************************************* $Function: mmi_fv_zoom_kbd_cb $Description: Exec callback function for the zoom window $Returns: execution status $Arguments: e - event id k - keyboard info *******************************************************************************/ static int mmi_fv_zoom_kbd_cb (MfwEvt e, MfwKbd *k) { T_MFW_HND win = mfwParent(mfw_header()); T_MFW_WIN * win_data = ((T_MFW_HDR *)win)->data; T_fv_opt * data = (T_fv_opt *)win_data->user; TRACE_FUNCTION ("mmi_fv_zoom_kbd_cb()"); switch (k->code) { case KCD_LEFT: TRACE_EVENT("mmi_fv_zoom_kbd_cb,INFO_KCD_LEFT "); break; case KCD_RIGHT: case KCD_HUP: TRACE_EVENT("mmi_fv_zoom_kbd_cb,INFO_KCD_RIGHT "); mmi_fv_opt_destroy(data->win); break; default: break; } return MFW_EVENT_CONSUMED; }