remove elm_win_resize_object_add() API except for conformant object
[apps/core/preloaded/settings.git] / setting-storage / src / setting-storage-main.c
index 93e0cad..f0a3956 100755 (executable)
  */
 #include <setting-storage-main.h>
 #include <Ecore_X.h>
-#include <sys/statvfs.h>
-#include <sys/stat.h>
-#include <sys/mount.h>
-#include <dirent.h>
-#include <glib.h>
-#include <glib/gprintf.h>
-#include <sysman.h>
+#include <package-manager.h>
+#include <ail.h>
 
 static int setting_storage_main_create(void *cb);
 static int setting_storage_main_destroy(void *cb);
@@ -43,6 +38,20 @@ setting_view setting_view_storage_main = {
        .cleanup = setting_storage_main_cleanup,
 };
 
+static Evas_Object *__setting_storage_main_image_add(Evas *evas, char *icon_path, int width, int height)
+{
+       Evas_Object *image = NULL;
+       image = evas_object_image_add(evas);
+       evas_object_size_hint_weight_set(image, 0.0, EVAS_HINT_EXPAND);
+       evas_object_image_load_size_set(image, width, height);
+       evas_object_image_file_set(image, icon_path, NULL);
+       evas_object_image_fill_set(image, 0, 0, width, height);
+       evas_object_size_hint_min_set(image, width, height);
+       evas_object_show(image);
+
+       return image;
+}
+
 static char *__gl_text_get(void *data, Evas_Object *obj, const char *part)
 {
        retv_if(!data, NULL);
@@ -62,12 +71,25 @@ static Evas_Object *__gl_content_get(void *data, Evas_Object *obj, const char *p
 
        int width = SETTING_STORAGE_ICON_WIDTH;
        int height = SETTING_STORAGE_ICON_HEIGHT;
+
+       app_device_orientation_e m = elm_win_rotation_get(ad->win_get);
+       if(APP_DEVICE_ORIENTATION_90 == m || APP_DEVICE_ORIENTATION_270 == m) {
+               width = SETTING_STORAGE_ICON_LANDSCAPE_WIDTH;
+       } else {
+               width = SETTING_STORAGE_ICON_WIDTH;
+       }
        float temp_size = 0.0;
 
+       /* use size (applications + picture/videos + audio + miscellaneous + available) as 100% */
+       double total_size = ad->apps_status.dTotal + ad->pics_videos_status.dTotal +
+                                + ad->audio_status.dTotal +
+                               ad->others_status.dTotal + ad->internal_status.dAvail;
+
        if (!safeStrCmp(part, "elm.icon")){
                Evas_Object *status_box = NULL;
                status_box = elm_box_add(obj);
                retvm_if(status_box == NULL, NULL, "Cannot get box");
+               item_data->eo_check = status_box;
                elm_box_horizontal_set(status_box, 1);
                evas_object_size_hint_align_set(status_box, 0.0, EVAS_HINT_FILL);
                evas_object_show(status_box);
@@ -76,121 +98,71 @@ static Evas_Object *__gl_content_get(void *data, Evas_Object *obj, const char *p
 
                /* apps */
                unsigned int apps_size = 0;
-               temp_size = ((float)ad->apps_status.dTotal / ad->internal_status.dTotal) * width;
+               temp_size = ((float)ad->apps_status.dTotal / total_size) * width;
                if (temp_size < 1 && temp_size > 0) {
                        apps_size = 1;
                } else {
                        apps_size = (unsigned int)temp_size;
                }
                if (apps_size > 0) {
-                       Evas_Object *apps = NULL;
-                       apps = evas_object_image_add(evas);
-                       evas_object_size_hint_weight_set(apps, 0.0, EVAS_HINT_EXPAND);
-                       evas_object_image_load_size_set(apps, apps_size, height);
-                       evas_object_image_file_set(apps, SETTING_STORAGE_APPS_ICON_PATH, NULL);
-                       evas_object_image_fill_set(apps, 0, 0, apps_size, height);
-                       evas_object_size_hint_min_set(apps, apps_size, height);
-                       evas_object_show(apps);
+                       Evas_Object *apps = __setting_storage_main_image_add(evas, SETTING_STORAGE_APPS_ICON_PATH, apps_size, height);
                        elm_box_pack_end(status_box, apps);
                }
 
                /* pictures, videos */
                unsigned int pics_videos_size = 0;
-               temp_size = ((float)ad->pics_videos_status.dTotal / ad->internal_status.dTotal) * width;
+               temp_size = ((float)ad->pics_videos_status.dTotal / total_size) * width;
                if (temp_size < 1 && temp_size > 0) {
                        pics_videos_size = 1;
                } else {
                        pics_videos_size = (unsigned int)temp_size;
                }
                if (pics_videos_size > 0) {
-                       Evas_Object *pics = NULL;
-                       pics = evas_object_image_add(evas);
-                       evas_object_size_hint_weight_set(pics, 0.0, EVAS_HINT_EXPAND);
-                       evas_object_image_load_size_set(pics, pics_videos_size, height);
-                       evas_object_image_file_set(pics, SETTING_STORAGE_PICS_ICON_PATH, NULL);
-                       evas_object_image_fill_set(pics, 0, 0, pics_videos_size, height);
-                       evas_object_size_hint_min_set(pics, pics_videos_size, height);
-                       evas_object_show(pics);
+                       Evas_Object *pics = __setting_storage_main_image_add(evas, SETTING_STORAGE_PICS_ICON_PATH, pics_videos_size, height);
                        elm_box_pack_end(status_box, pics);
                }
 
-               /* downloads */
-               unsigned int downloads_size = 0;
-               temp_size = ((float)ad->downloads_status.dTotal / ad->internal_status.dTotal) * width;
-               if (temp_size < 1 && temp_size > 0) {
-                       downloads_size = 1;
-               } else {
-                       downloads_size = (unsigned int)temp_size;
-               }
-               if (downloads_size > 0) {
-                       Evas_Object *downs = NULL;
-                       downs = evas_object_image_add(evas);
-                       evas_object_size_hint_weight_set(downs, 0.0, EVAS_HINT_EXPAND);
-                       evas_object_image_load_size_set(downs, downloads_size, height);
-                       evas_object_image_file_set(downs, SETTING_STORAGE_DOWNS_ICON_PATH, NULL);
-                       evas_object_image_fill_set(downs, 0, 0, downloads_size, height);
-                       evas_object_size_hint_min_set(downs, downloads_size, height);
-                       evas_object_show(downs);
-                       elm_box_pack_end(status_box, downs);
-               }
-
                /* audio */
                unsigned int audio_size = 0;
-               temp_size = ((float)ad->audio_status.dTotal / ad->internal_status.dTotal) * width;
+               temp_size = ((float)ad->audio_status.dTotal / total_size) * width;
                if (temp_size < 1 && temp_size > 0) {
                        audio_size = 1;
                } else {
                        audio_size = (unsigned int)temp_size;
                }
                if (audio_size > 0) {
-                       Evas_Object *audio = NULL;
-                       audio = evas_object_image_add(evas);
-                       evas_object_size_hint_weight_set(audio, 0.0, EVAS_HINT_EXPAND);
-                       evas_object_image_load_size_set(audio, audio_size, height);
-                       evas_object_image_file_set(audio, SETTING_STORAGE_AUDIO_ICON_PATH, NULL);
-                       evas_object_image_fill_set(audio, 0, 0, audio_size, height);
-                       evas_object_size_hint_min_set(audio, audio_size, height);
-                       evas_object_show(audio);
+                       Evas_Object *audio = __setting_storage_main_image_add(evas, SETTING_STORAGE_AUDIO_ICON_PATH, audio_size, height);
                        elm_box_pack_end(status_box, audio);
                }
 
                /* Miscellaneous files */
                unsigned int others_size = 0;
-               temp_size = ((float)ad->others_status.dTotal / ad->internal_status.dTotal) * width;
+               temp_size = ((float)ad->others_status.dTotal / total_size) * width;
                if (temp_size < 1 && temp_size > 0) {
                        others_size = 1;
                } else {
                        others_size = (unsigned int)temp_size;
                }
                if (others_size > 0) {
-                       Evas_Object *misc = NULL;
-                       misc = evas_object_image_add(evas);
-                       evas_object_size_hint_weight_set(misc, 0.0, EVAS_HINT_EXPAND);
-                       evas_object_image_load_size_set(misc, others_size, height);
-                       evas_object_image_file_set(misc, SETTING_STORAGE_MISCES_ICON_PATH, NULL);
-                       evas_object_image_fill_set(misc, 0, 0, others_size, height);
-                       evas_object_size_hint_min_set(misc, others_size, height);
-                       evas_object_show(misc);
+                       Evas_Object *misc = __setting_storage_main_image_add(evas, SETTING_STORAGE_MISCES_ICON_PATH, others_size, height);
                        elm_box_pack_end(status_box, misc);
                }
 
                /* available */
                unsigned int avail_size = 0;
-               temp_size = ((float)ad->internal_status.dAvail / ad->internal_status.dTotal) * width;
+               temp_size = ((float)ad->internal_status.dAvail / total_size) * width;
                if (temp_size < 1 && temp_size > 0) {
                        avail_size = 1;
                } else {
                        avail_size = (unsigned int)temp_size;
+
+                       int sum = apps_size + pics_videos_size + audio_size + others_size;
+                       if ((sum + avail_size) > width) {
+                               avail_size = width - sum;
+                       }
                }
                if (avail_size > 0) {
-                       Evas_Object *avail = NULL;
-                       avail = evas_object_image_add(evas);
-                       evas_object_size_hint_weight_set(avail, 0.0, EVAS_HINT_EXPAND);
-                       evas_object_image_load_size_set(avail, avail_size, height);
-                       evas_object_image_file_set(avail, SETTING_STORAGE_AVAIL_ICON_PATH, NULL);
-                       evas_object_image_fill_set(avail, 0, 0, avail_size, height);
-                       evas_object_size_hint_min_set(avail, avail_size, height);
-                       evas_object_show(avail);
+                       Evas_Object *avail = __setting_storage_main_image_add(evas, SETTING_STORAGE_AVAIL_ICON_PATH, avail_size, height);
                        elm_box_pack_end(status_box, avail);
                }
 
@@ -228,145 +200,10 @@ static int __setting_storage_main_fs_stat(double *total, double *avail, const ch
        return SETTING_RETURN_SUCCESS;
 }
 
-static int __setting_storage_main_file_stat_get(const char *filename, Node_Info **node)
-{
-       setting_retvm_if(!filename || !node, SETTING_RETURN_FAIL, "NULL input parameters");
-       struct stat statbuf;
-       if (stat(filename, &statbuf) == -1) {
-               SETTING_TRACE_ERROR("failed to call stat");
-               return SETTING_RETURN_FAIL;
-       }
-
-       if (*node == NULL) {
-               SETTING_TRACE_ERROR("node is NULL");
-               return SETTING_RETURN_FAIL;
-       }
-
-       (*node)->size = statbuf.st_size;
-
-       return SETTING_RETURN_SUCCESS;
-}
-
-static int __setting_storage_main_file_list_get(char *path, Eina_List **dir_list, Eina_List **file_list)
-{
-       SETTING_TRACE_BEGIN;
-       setting_retvm_if(NULL == path, SETTING_RETURN_FAIL, "path is NULL");
-
-       DIR *pDir = NULL;
-       struct dirent *ent = NULL;
-       char childpath[SETTING_STORAGE_CHILDPATH_LEN] = {0,};
-
-       pDir = opendir(path);
-       setting_retvm_if(NULL == pDir, SETTING_RETURN_FAIL, "pDir is NULL");
-
-       while ((ent = readdir(pDir)) != NULL) {
-               if (safeStrCmp(ent->d_name, ".") == 0 || safeStrCmp(ent->d_name, "..") == 0) {
-                       continue;
-               }
-               /*only deal with dirs and regular files*/
-               if ((ent->d_type & DT_DIR) == 0 && (ent->d_type & DT_REG) == 0) {
-                       continue;
-               }
-
-               Node_Info *pNode = (Node_Info *)malloc(sizeof(Node_Info));
-
-               if (pNode == NULL) {
-                       continue;
-               }
-
-               memset(pNode, 0, sizeof(Node_Info));
-               /*get path*/
-               g_strlcpy(pNode->path, path, (gsize) sizeof(pNode->path));
-
-               /*get name*/
-               g_strlcpy(pNode->name, ent->d_name, (gsize) sizeof(pNode->name));
-
-               /*get size*/
-               int copiednum = g_sprintf(childpath, "%s/%s", path, ent->d_name);
-               if (copiednum < 0) {
-                       FREE(pNode);
-                       continue;
-               }
-               if (__setting_storage_main_file_stat_get(childpath, &pNode) == SETTING_RETURN_FAIL) {
-                       FREE(pNode);
-                       continue;
-               }
-
-               if (ent->d_type & DT_DIR) {
-                       *dir_list = eina_list_append(*dir_list, pNode);
-               } else {
-                       *file_list = eina_list_append(*file_list, pNode);
-               }
-       }
-       closedir(pDir);
-
-       return SETTING_RETURN_SUCCESS;
-}
-
-static int __setting_storage_main_list_len_get(const Eina_List *list)
-{
-       if (list == NULL)
-               return 0;
-
-       return eina_list_count(list);
-}
-
-static long __setting_storage_main_folder_size_get(char *path)
-{
-       SETTING_TRACE_BEGIN;
-       setting_retvm_if(NULL == path, SETTING_RETURN_FAIL, "path is NULL");
-
-       unsigned long size = 0;
-       Eina_List *file_list = NULL;
-       Eina_List *dir_list = NULL;
-
-       if (ecore_file_is_dir(path)) {
-               int ret = SETTING_RETURN_FAIL;
-               ret = __setting_storage_main_file_list_get(path, &dir_list, &file_list);
-
-               if (ret == SETTING_RETURN_SUCCESS) {
-                       int i = 0;
-                       int dir_list_len =  __setting_storage_main_list_len_get(dir_list);
-                       int file_list_len = __setting_storage_main_list_len_get(file_list);
-                       SETTING_TRACE("dir_list_len is [%d] file_list_len is [%d]", dir_list_len, file_list_len);
-                       for (i = 0; i < file_list_len; i++) {
-                               Node_Info *pNode = NULL;
-                               pNode = (Node_Info *)eina_list_nth(file_list, i);
-                               if (pNode == NULL)
-                                       continue;
-                               size += pNode->size;
-                       }
-                       for (i = 0; i < dir_list_len; i++) {
-                               Node_Info *pNode = NULL;
-                               char *full_path = NULL;
-                               pNode = (Node_Info *)eina_list_nth(dir_list, i);
-                               if (pNode == NULL)
-                                       continue;
-                               full_path =  g_strconcat(pNode->path, "/", pNode->name, NULL);
-                               SETTING_TRACE("full_path is [%s]", full_path);
-                               size += (__setting_storage_main_folder_size_get(full_path));
-                               FREE(full_path);
-                       }
-               }
-       }
-
-       if (file_list) {
-               eina_list_free(file_list);
-               file_list = NULL;
-       }
-
-       if (dir_list) {
-               eina_list_free(dir_list);
-               dir_list = NULL;
-       }
-
-       return size;
-}
-
 static int __setting_storage_status_size_transition(double size, char *size_desc)
 {
-       SETTING_TRACE_BEGIN;
-       SETTING_TRACE("size = %f", size);
+       //SETTING_TRACE_BEGIN;
+       //SETTING_TRACE("size = %f", size);
        double tmp_size = 0.0;
        int ret = 0;
        if (size < SETTING_STORAGE_MEGABYTE_VALUE) {    // size < 1MB: show x.xKB
@@ -398,83 +235,214 @@ static void __setting_storage_main_internal_storage_status_get(void *data)
        int ret = SETTING_RETURN_SUCCESS;
        Setting_Storage_Status internal_status;
 
-       ret = __setting_storage_main_fs_stat(&dTotal, &dAvail, SETTING_STORAGE_OPT_PATH);
+       ret = __setting_storage_main_fs_stat(&dTotal, &dAvail, SETTING_STORAGE_OPT_USR_PATH);
        setting_retm_if(ret == SETTING_RETURN_FAIL, "get opt status failed");
        internal_status.dTotal = dTotal;
        internal_status.dAvail = dAvail;
 
-       dTotal = 0.0;
-       dAvail = 0.0;
-       ret = __setting_storage_main_fs_stat(&dTotal, &dAvail, SETTING_STORAGE_MEDIA_PATH);
-       setting_retm_if(ret == SETTING_RETURN_FAIL, "get media status failed");
-       internal_status.dTotal += dTotal;
-       internal_status.dAvail += dAvail;
-
        ad->internal_status = internal_status;
 }
 
-static void __setting_storage_main_pictures_videos_status_get(void *data)
+static bool __setting_storage_main_media_item_cb(media_info_h media, void *data)
+{
+       //SETTING_TRACE_BEGIN;
+       setting_retvm_if(media == NULL, true, "media is NULL");
+       setting_retvm_if(data == NULL, true, "Data parameter is NULL");
+       double *total_size = (double *) data;
+
+       unsigned long long size = 0;
+
+       char *file_path = NULL;
+       media_info_get_file_path(media, &file_path);
+
+       if (!ecore_file_exists(file_path)) {
+               FREE(file_path);
+               return true;
+       }
+       FREE(file_path);
+
+       media_info_get_size(media, &size);
+       //SETTING_TRACE("size : [%lld]", size);
+       *total_size += size;
+
+       return true;
+}
+
+static double __setting_storage_main_pictures_videos_status_get()
 {
        SETTING_TRACE_BEGIN;
-       setting_retm_if(data == NULL, "Data parameter is NULL");
-       SettingStorageUG *ad = (SettingStorageUG *) data;
+       double total_size = 0.0;
 
-       double dTotal = 0.0;
-       int ret = SETTING_RETURN_SUCCESS;
-       Setting_Storage_Status pics_videos_status;
+       int ret = MEDIA_CONTENT_ERROR_NONE;
+       filter_h filter = NULL;
 
-       dTotal = __setting_storage_main_folder_size_get(SETTING_STORAGE_PICTURES_PATH);
-       setting_retm_if(ret == SETTING_RETURN_FAIL, "get pictures status failed");
-       pics_videos_status.dTotal = dTotal;
-       //SETTING_TRACE("pics_videos_status = %f", dTotal);
+       /*Set Filter*/
+       char *condition = "(MEDIA_TYPE=0 OR MEDIA_TYPE=1) and MEDIA_PATH LIKE \'/opt/usr/%%\'"; /*0-image, 1-video, 2-sound, 3-music, 4-other*/
 
-       dTotal = 0.0;
-       dTotal = __setting_storage_main_folder_size_get(SETTING_STORAGE_VIDEOS_PATH);
-       setting_retm_if(ret == SETTING_RETURN_FAIL, "get video status failed");
-       //SETTING_TRACE("pics_videos_status = %f", dTotal);
-       pics_videos_status.dTotal += dTotal;
+       ret = media_filter_create(&filter);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               SETTING_TRACE_ERROR("Fail to create filter");
+               return total_size;
+       }
 
-       //SETTING_TRACE("pics_videos_status = %f", pics_videos_status.dTotal);
+       ret = media_filter_set_condition(filter, condition, MEDIA_CONTENT_COLLATE_DEFAULT);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               media_filter_destroy(filter);
+               SETTING_TRACE_ERROR("Fail to set condition");
+               return total_size;
+       }
 
-       ad->pics_videos_status = pics_videos_status;
+       ret = media_info_foreach_media_from_db(filter, __setting_storage_main_media_item_cb, &total_size);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               media_filter_destroy(filter);
+               SETTING_TRACE_ERROR("Fail to get media");
+               return total_size;
+       }
+
+       ret = media_filter_destroy(filter);
+       if (ret != MEDIA_CONTENT_ERROR_NONE) {
+               SETTING_TRACE_ERROR("destroy filter failed\n\n");
+               return total_size;
+       }
+
+       return total_size;
 }
 
-static void __setting_storage_main_downloads_status_get(void *data)
+static double __setting_storage_main_audio_status_get()
 {
        SETTING_TRACE_BEGIN;
-       setting_retm_if(data == NULL, "Data parameter is NULL");
-       SettingStorageUG *ad = (SettingStorageUG *) data;
 
-       double dTotal = 0.0;
-       int ret = SETTING_RETURN_SUCCESS;
-       Setting_Storage_Status downloads_status;
+       double total_size = 0.0;
+
+       int ret = MEDIA_CONTENT_ERROR_NONE;
+       filter_h filter = NULL;
+
+       /*Set Filter*/
+       char *condition = "MEDIA_TYPE=3 and MEDIA_PATH LIKE \'/opt/usr/%%\'";   /*0-image, 1-video, 2-sound, 3-music, 4-other*/
+
+       ret = media_filter_create(&filter);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               SETTING_TRACE("Fail to create filter");
+               return total_size;
+       }
+
+       ret = media_filter_set_condition(filter, condition, MEDIA_CONTENT_COLLATE_DEFAULT);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               media_filter_destroy(filter);
+               SETTING_TRACE("Fail to set condition");
+               return total_size;
+       }
+
+       ret = media_info_foreach_media_from_db(filter, __setting_storage_main_media_item_cb, &total_size);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               media_filter_destroy(filter);
+               SETTING_TRACE("Fail to get media");
+               return total_size;
+       }
 
-       dTotal = __setting_storage_main_folder_size_get(SETTING_STORAGE_DOWNLOADS_PATH);
-       setting_retm_if(ret == SETTING_RETURN_FAIL, "get pictures status failed");
-       downloads_status.dTotal = dTotal;
+       ret = media_filter_destroy(filter);
+       if (ret != MEDIA_CONTENT_ERROR_NONE) {
+               SETTING_TRACE_ERROR("destroy filter failed\n\n");
+               return total_size;
+       }
 
-       //SETTING_TRACE("downloads_status = %f", dTotal);
+       return total_size;
+}
 
-       ad->downloads_status = downloads_status;
+static bool __setting_storage_main_other_item_cb(media_info_h media, void *data)
+{
+       //SETTING_TRACE_BEGIN;
+       setting_retvm_if(media == NULL, true, "media is NULL");
+       setting_retvm_if(data == NULL, true, "Data parameter is NULL");
+       double *total_size = (double *) data;
+
+       unsigned long long size = 0;
+
+       char *file_path = NULL;
+       media_info_get_file_path(media, &file_path);
+
+       if (!ecore_file_exists(file_path)) {
+               FREE(file_path);
+               return true;
+       }
+
+       if (!safeStrNCmp(file_path, PATH1, sizeof(PATH1)) ||
+               !safeStrNCmp(file_path, PATH2, sizeof(PATH2)) ||
+               !safeStrNCmp(file_path, PATH3, sizeof(PATH3)) ||
+               !safeStrNCmp(file_path, PATH4, sizeof(PATH4)) ||
+               !safeStrNCmp(file_path, PATH5, sizeof(PATH5)) ||
+               !safeStrNCmp(file_path, PATH6, sizeof(PATH6)) ||
+               !safeStrNCmp(file_path, PATH7, sizeof(PATH7)) ||
+               !safeStrNCmp(file_path, PATH8, sizeof(PATH8)) ||
+               !safeStrNCmp(file_path, PATH9, sizeof(PATH9)))
+       {
+               FREE(file_path);
+               return true;
+       }
+               
+       media_info_get_size(media, &size);
+       //SETTING_TRACE("size : [%lld]", size);
+       *total_size += size;
+       FREE(file_path);
+       return true;
 }
 
-static void __setting_storage_main_audio_status_get(void *data)
+/**
+  * Miscellaneous files is all directories files under /opt/usr/media/ except below default directories:
+  * ++++++++++++++++++++++++++++++++++++++++++++++++
+  *  -sh-4.1# ls -all
+  *  total 56
+  *  drwxrwxrwx 11 app  app   4096 Jan  4 12:42 .
+  *  drwxr-xr-x 20 root root  4096 Jan  7 10:09 ..
+  *  drwxr-xr-x  2 root root  4096 Jan  4 08:46 .tmp_download
+  *  drwxr-xr-x  2 app  app   4096 Jan  4 08:47 .video-hub
+  *  drwxrwxrwx  2 app  app   4096 Oct  5      2012 Camera
+  *  drwxrwxrwx  3 app  app   4096 Jan  4 08:46 Downloads
+  *  drwxrwxrwx  2 app  app   4096 Oct  5      2012 Images
+  *  drwxrwxrwx  2 app  app   4096 Oct  5      2012 Others
+  *  drwxrwxrwx  3 app  app   4096 Oct  5      2012 Sounds
+  *  drwxrwxrwx  2 app  app   4096 Oct  5      2012 Videos
+  *  drwxrwxrwx  2 app  app  16384 Oct  5      2012 lost+found
+  * ++++++++++++++++++++++++++++++++++++++++++++++++
+  */
+static double __setting_storage_main_miscellaneous_size_get()
 {
        SETTING_TRACE_BEGIN;
-       setting_retm_if(data == NULL, "Data parameter is NULL");
-       SettingStorageUG *ad = (SettingStorageUG *) data;
+       double total_size = 0.0;
 
-       double dTotal = 0.0;
-       int ret = SETTING_RETURN_SUCCESS;
-       Setting_Storage_Status audio_status;
+       int ret = MEDIA_CONTENT_ERROR_NONE;
+       filter_h filter = NULL;
 
-       dTotal = __setting_storage_main_folder_size_get(SETTING_STORAGE_AUDIO_PATH);
-       setting_retm_if(ret == SETTING_RETURN_FAIL, "get audio status failed");
-       audio_status.dTotal = dTotal;
+       /*Set Filter*/
+       char *condition = "(MEDIA_TYPE=4) and MEDIA_PATH LIKE \'/opt/usr/media/%%\'";
 
-       //SETTING_TRACE("audio_status = %f", dTotal);
+       ret = media_filter_create(&filter);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               SETTING_TRACE_ERROR("Fail to create filter");
+               return total_size;
+       }
 
-       ad->audio_status = audio_status;
+       ret = media_filter_set_condition(filter, condition, MEDIA_CONTENT_COLLATE_DEFAULT);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               media_filter_destroy(filter);
+               SETTING_TRACE_ERROR("Fail to set condition");
+               return total_size;
+       }
+
+       ret = media_info_foreach_media_from_db(filter, __setting_storage_main_other_item_cb, &total_size);
+       if(ret != MEDIA_CONTENT_ERROR_NONE) {
+               media_filter_destroy(filter);
+               SETTING_TRACE_ERROR("Fail to get media");
+               return total_size;
+       }
+
+       ret = media_filter_destroy(filter);
+       if (ret != MEDIA_CONTENT_ERROR_NONE) {
+               SETTING_TRACE_ERROR("destroy filter failed");
+               return total_size;
+       }
+
+       return total_size;
 }
 
 static void __setting_storage_main_launch_ug_destroy_cb(ui_gadget_h ug, void *priv)
@@ -493,6 +461,8 @@ static void __setting_storage_main_launch_ug_destroy_cb(ui_gadget_h ug, void *pr
        if (back_btn != NULL) {
                elm_object_style_set(back_btn, NAVI_BACK_BUTTON_STYLE); /* take into effect */
        }
+
+       setting_view_update(&setting_view_storage_main, ad);
 }
 
 static void __setting_storage_main_launch_ug_layout_cb(ui_gadget_h ug, enum ug_mode mode, void *priv)
@@ -507,7 +477,7 @@ static void __setting_storage_main_launch_ug_layout_cb(ui_gadget_h ug, enum ug_m
        switch (mode) {
        case UG_MODE_FULLVIEW:
                evas_object_size_hint_weight_set(base, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-               elm_win_resize_object_add(ad->win_get, base);
+               //elm_win_resize_object_add(ad->win_get, base);
                evas_object_show(base);
                break;
        default:
@@ -557,17 +527,7 @@ static void __setting_storage_main_app_launch(char *app_name)
        SETTING_TRACE_BEGIN;
        setting_retm_if(app_name == NULL, "app_name is NULL");
 
-       #if 0
-       if(aul_app_is_running((const char *)app_name)) {
-               SETTING_TRACE_DEBUG("%s is already launched.", app_name);
-               aul_open_app((const char *)app_name);
-       } else {
-               SETTING_TRACE_DEBUG("%s will be launched. ", app_name);
-               aul_launch_app((const char *)app_name, NULL);
-       }
-       #else
-               app_launcher(app_name);
-       #endif
+       app_launcher(app_name);
 }
 
 static void __setting_storage_main_Gendial_mouse_up_cb(void *data, Evas_Object *obj, void *event_info)
@@ -583,22 +543,32 @@ static void __setting_storage_main_Gendial_mouse_up_cb(void *data, Evas_Object *
 
        SETTING_TRACE("clicking item[%s]", _(list_item->keyStr));
 
-       if (!safeStrCmp("IDS_ST_BODY_APPLICATIONS", list_item->keyStr)) {
-               __setting_storage_main_launch_manage_app_ug(ad);
-       } else if (!safeStrCmp(SETTING_STORAGE_DEFAULT_STORAGE_STR, list_item->keyStr)) {
-               setting_view_change(&setting_view_storage_main,
-                                   &setting_view_storage_default_storage, ad);
-       } else if (!safeStrCmp(SETTING_STORAGE_PICS_STR, list_item->keyStr)) {
-               __setting_storage_main_app_launch("org.tizen.gallery");
-       } else if (!safeStrCmp(SETTING_STORAGE_DOWNS_STR, list_item->keyStr)) {
-               __setting_storage_main_app_launch("org.tizen.download-manager");
-       } else if (!safeStrCmp(SETTING_STORAGE_AUDIO_STR, list_item->keyStr)) {
-               __setting_storage_main_app_launch("org.tizen.music-player");
-       } else if (!safeStrCmp(SETTING_STORAGE_MISCES_STR, list_item->keyStr)) {
-               setting_view_change(&setting_view_storage_main,
-                                   &setting_view_storage_miscellaneous_files, ad);
+       if (isEmulBin()) {
+               if (!safeStrCmp(SETTING_STORAGE_DEFAULT_STORAGE_STR, list_item->keyStr)) {
+                       setting_view_change(&setting_view_storage_main,
+                                           &setting_view_storage_default_storage, ad);
+               } else if (!safeStrCmp(SETTING_STORAGE_MISCES_STR, list_item->keyStr)) {
+                       setting_view_change(&setting_view_storage_main,
+                                           &setting_view_storage_miscellaneous_files, ad);
+               } else {
+                       // do nothing now
+               }
        } else {
-               // do nothing now
+               if (!safeStrCmp("IDS_ST_BODY_APPLICATIONS", list_item->keyStr)) {
+                       __setting_storage_main_launch_manage_app_ug(ad);
+               } else if (!safeStrCmp(SETTING_STORAGE_DEFAULT_STORAGE_STR, list_item->keyStr)) {
+                       setting_view_change(&setting_view_storage_main,
+                                           &setting_view_storage_default_storage, ad);
+               } else if (!safeStrCmp(SETTING_STORAGE_PICS_STR, list_item->keyStr)) {
+                       __setting_storage_main_app_launch("org.tizen.gallery");
+               } else if (!safeStrCmp(SETTING_STORAGE_AUDIO_STR, list_item->keyStr)) {
+                       __setting_storage_main_app_launch("org.tizen.music-player");
+               } else if (!safeStrCmp(SETTING_STORAGE_MISCES_STR, list_item->keyStr)) {
+                       setting_view_change(&setting_view_storage_main,
+                                           &setting_view_storage_miscellaneous_files, ad);
+               } else {
+                       // do nothing now
+               }
        }
 }
 
@@ -668,6 +638,7 @@ static int __setting_storage_main_mmc_content_init(void *data, setting_storage_m
        return SETTING_RETURN_SUCCESS;
 }
 
+#if SUPPORT_SD_CARD_FORMAT
 static void __setting_storage_status_sd_card_popup_format_response_cb(void *data,
                                                         Evas_Object *obj, void *event_info)
 {
@@ -697,6 +668,7 @@ static void __setting_storage_status_sd_card_popup_format_response_cb(void *data
                elm_genlist_item_update(ad->sd_available->item);
        }
 }
+#endif
 
 static void __setting_storage_status_sd_card_popup_response_cb(void *data,
                                                         Evas_Object *obj, void *event_info)
@@ -837,19 +809,21 @@ static void __setting_storage_main_sd_card_mount_unmount(void *data)
        }
 }
 
-
-static void __setting_storage_main_sd_card_format_cb(int val, void *data)
+#if SUPPORT_SD_CARD_FORMAT
+static void __setting_storage_main_sd_card_scan_cb(media_content_error_e err, void *data)
 {
        SETTING_TRACE_BEGIN;
        setting_retm_if(data == NULL, "Data parameter is NULL");
        SettingStorageUG *ad = (SettingStorageUG *) data;
 
+       SETTING_TRACE("scan_cb result = %d", err);
+
        if (ad->popup) {
                evas_object_del(ad->popup);
                ad->popup = NULL;
        }
 
-       if (val == SETTING_STORAGE_SYSMAN_REQUEST_SUCCESS) {
+       if (err == MEDIA_CONTENT_ERROR_NONE) {
                ad->popup = setting_create_popup_without_btn(ad, ad->win_get, NULL, _("IDS_COM_POP_SUCCESS"),
                                         __setting_storage_status_sd_card_popup_format_response_cb,
                                         SETTING_STORAGE_POPUP_TIMER, FALSE, FALSE);
@@ -861,6 +835,30 @@ static void __setting_storage_main_sd_card_format_cb(int val, void *data)
        }
 }
 
+static void __setting_storage_main_sd_card_format_cb(int val, void *data)
+{
+       SETTING_TRACE_BEGIN;
+       setting_retm_if(data == NULL, "Data parameter is NULL");
+       SettingStorageUG *ad = (SettingStorageUG *) data;
+
+       if (val == SETTING_STORAGE_SYSMAN_REQUEST_SUCCESS) {
+               int ret = media_content_scan_folder(SETTING_STORAGE_MMC_PATH, __setting_storage_main_sd_card_scan_cb, ad);
+
+               if(ret != MEDIA_CONTENT_ERROR_NONE) {
+                       SETTING_TRACE_ERROR("Fail to media_content_scan_file : %d", ret);
+                       return;
+               }
+       } else {
+               if (ad->popup) {
+                       evas_object_del(ad->popup);
+                       ad->popup = NULL;
+               }
+               ad->popup = setting_create_popup_without_btn(ad, ad->win_get, NULL, _("IDS_COM_POP_FAILED"),
+                                        __setting_storage_status_sd_card_popup_response_cb,
+                                        SETTING_STORAGE_POPUP_TIMER, FALSE, FALSE);
+       }
+}
+
 static void __setting_storage_main_sd_card_format_popup_yes(void *data)
 {
        SETTING_TRACE_BEGIN;
@@ -874,9 +872,9 @@ static void __setting_storage_main_sd_card_format_popup_yes(void *data)
 
        /* Show Formatting..... popup */
        ad->popup = setting_create_popup_with_progressbar(ad, ad->win_get,
-                                                "list_process", _("IDS_ST_POP_MSG_FORMATTING"),
-                                                NULL, __setting_storage_status_sd_card_popup_response_cb,
-                                                SETTING_STORAGE_PROGRESSBAR_TIMEOUT, TRUE, TRUE);
+                                                "pending_list", NULL,
+                                                NULL, NULL,
+                                                0, TRUE, TRUE);
 
        int ret = __setting_storage_main_mmc_content_init(ad, __setting_storage_main_sd_card_format_cb);
        if (ret == SETTING_RETURN_FAIL) {
@@ -947,6 +945,7 @@ static void __setting_storage_main_sd_card_format_popup_create(void *data)
                                         __setting_storage_main_sd_card_ask_format_resp_cb, 0,
                                         2, _("IDS_COM_SK_YES"),_("IDS_COM_SK_NO"));
 }
+#endif
 
 static void __setting_storage_main_mouse_up_Gendial_list_cb(void *data, Evas_Object *obj,
                                               void *event_info)
@@ -961,11 +960,32 @@ static void __setting_storage_main_mouse_up_Gendial_list_cb(void *data, Evas_Obj
        Setting_GenGroupItem_Data *list_item = (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
 
        SETTING_TRACE("clicking item[%s]", _(list_item->keyStr));
+
+       int db_status = 0;
+       int ret = vconf_get_int(VCONFKEY_FILEMANAGER_DB_STATUS, &db_status);
+       setting_retm_if(ret != 0, "fail to get vconf");
+
+       /* if SD card is busy, show popup */
+       if (db_status != VCONFKEY_FILEMANAGER_DB_UPDATED) {
+               if (ad->popup) {
+                       evas_object_del(ad->popup);
+                       ad->popup = NULL;
+               }
+               ad->popup = setting_create_popup_without_btn(ad, ad->win_get,
+                                        NULL, _("IDS_ST_BODY_SORRY_YOUR_SD_CARD_IS_BUSY"),
+                                        __setting_storage_status_sd_card_popup_response_cb,
+                                        SETTING_STORAGE_POPUP_TIMER, FALSE, FALSE);
+               return;
+       }
+
        if (list_item == ad->sd_mount) {
                __setting_storage_main_sd_card_mount_unmount(ad);
-       } else if (list_item == ad->sd_format) {
+       }
+#if SUPPORT_SD_CARD_FORMAT
+       else if (list_item == ad->sd_format) {
                __setting_storage_main_sd_card_format_popup_create(ad);
        }
+#endif
 }
 
 static void __setting_storage_main_sd_card_info_append(void* data)
@@ -987,11 +1007,12 @@ static void __setting_storage_main_sd_card_info_append(void* data)
                elm_object_item_del(ad->sd_available->item);
                ad->sd_available = NULL;
        }
+#if SUPPORT_SD_CARD_FORMAT
        if (ad->sd_format) {
                elm_object_item_del(ad->sd_format->item);
                ad->sd_format = NULL;
        }
-
+#endif
        int mmc_mode = VCONFKEY_SYSMAN_MMC_REMOVED;
        int ret = vconf_get_int(VCONFKEY_SYSMAN_MMC_STATUS, &mmc_mode);
        setting_retm_if(ret != 0, "Get vconf failed");
@@ -1052,6 +1073,7 @@ static void __setting_storage_main_sd_card_info_append(void* data)
                        SETTING_TRACE_ERROR("ad->sd_mount is NULL");
                }
 
+#if SUPPORT_SD_CARD_FORMAT
                ad->sd_format = setting_create_Gendial_field_def(ad->genlist, &(ad->itc_1text),
                                                     __setting_storage_main_mouse_up_Gendial_list_cb,
                                                     ad, SWALLOW_Type_INVALID, NULL,
@@ -1063,6 +1085,7 @@ static void __setting_storage_main_sd_card_info_append(void* data)
                } else {
                        SETTING_TRACE_ERROR("ad->sd_format is NULL");
                }
+#endif
        } else {
                SETTING_TRACE_ERROR("error status of sd card");
        }
@@ -1094,6 +1117,322 @@ static void __setting_storage_vconf_change_cb(keynode_t *key, void *data)
        }
 }
 
+static void __setting_storage_main_genlist_update(Setting_GenGroupItem_Data *data, Setting_Storage_Status status)
+{
+       //SETTING_TRACE_BEGIN;
+       setting_retm_if(data == NULL, "Data parameter is NULL");
+       Setting_GenGroupItem_Data *item_data = (Setting_GenGroupItem_Data *) data;
+
+       char desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
+       int ret = __setting_storage_status_size_transition(status.dTotal, desc);
+       setting_retm_if(ret == SETTING_RETURN_FAIL, "failed to transform")
+
+       G_FREE(item_data->sub_desc);
+       item_data->sub_desc = (char *)g_strdup(desc);
+       elm_object_item_data_set(item_data->item, item_data);
+       elm_genlist_item_update(item_data->item);
+}
+
+static ail_cb_ret_e __setting_storage_main_appinfo_func_cb(const ail_appinfo_h ail_info, void *data)
+{
+       Eina_List **apps_list = (Eina_List **) data;
+
+       char *pkg_name = NULL;
+       char *pkg_type = NULL;
+
+       ail_appinfo_get_str(ail_info, AIL_PROP_PACKAGE_STR, &pkg_name);
+       setting_retvm_if(pkg_name == NULL, AIL_CB_RET_CONTINUE, "get pkg_name failed");
+
+       ail_appinfo_get_str(ail_info, AIL_PROP_X_SLP_PACKAGETYPE_STR, &pkg_type);
+       setting_retvm_if(pkg_type == NULL, AIL_CB_RET_CONTINUE, "get pkg_type failed");
+
+       App_Info *app_info = (App_Info*)calloc(1, sizeof(App_Info));
+       setting_retvm_if(app_info == NULL, AIL_CB_RET_CONTINUE, "failed to calloc");
+
+       app_info->pkg_name = (char *)g_strdup(pkg_name);
+       app_info->pkg_type = (char *)g_strdup(pkg_type);
+       *apps_list = eina_list_append(*apps_list, app_info);
+       return AIL_CB_RET_CONTINUE;
+}
+
+static void __setting_storage_main_applications_list_get(Eina_List **apps_list)
+{
+       SETTING_TRACE_BEGIN;
+       /* get app_info from AIL */
+       ail_filter_h filter_rpm = NULL;
+       ail_filter_h filter_wrt = NULL;
+       ail_filter_h filter_tpk = NULL;
+
+       ail_filter_new(&filter_rpm);
+       ail_filter_new(&filter_wrt);
+       ail_filter_new(&filter_tpk);
+
+       ail_filter_add_str(filter_rpm, AIL_PROP_X_SLP_PACKAGETYPE_STR, RPM_PREFIX);
+       ail_filter_add_str(filter_wrt, AIL_PROP_X_SLP_PACKAGETYPE_STR, WRT_PREFIX);
+       ail_filter_add_str(filter_tpk, AIL_PROP_X_SLP_PACKAGETYPE_STR, TPK_PREFIX);
+
+       ail_filter_list_appinfo_foreach(filter_rpm, __setting_storage_main_appinfo_func_cb, (void*)apps_list);
+       ail_filter_list_appinfo_foreach(filter_wrt, __setting_storage_main_appinfo_func_cb, (void*)apps_list);
+       ail_filter_list_appinfo_foreach(filter_tpk, __setting_storage_main_appinfo_func_cb, (void*)apps_list);
+
+       ail_filter_destroy(filter_rpm);
+       ail_filter_destroy(filter_wrt);
+       ail_filter_destroy(filter_tpk);
+}
+
+static double __setting_storage_main_applications_status_get(void *data)
+{
+       SETTING_TRACE_BEGIN;
+       setting_retvm_if(data == NULL, 0.0, "Data parameter is NULL");
+       SettingStorageUG *ad = (SettingStorageUG *)data;
+
+       Eina_List *apps_list = NULL;
+       __setting_storage_main_applications_list_get(&apps_list);
+
+       SETTING_TRACE("count = %d", eina_list_count(apps_list));
+
+       double total_size = 0.0;
+
+       Eina_List *l = NULL;
+       App_Info *app_info = NULL;
+       EINA_LIST_FOREACH (apps_list, l, app_info)
+       {
+               int exit_flag = 0;
+               pthread_mutex_lock(&ad->exit_mutex);
+               exit_flag = ad->exit_flag;
+               pthread_mutex_unlock(&ad->exit_mutex);
+
+               if (exit_flag == 1) {
+                       SETTING_TRACE("exit_flag is 1");
+                       break;
+               }
+
+               //SETTING_TRACE("pkg_name: %s ", app_info->pkg_name);
+               //SETTING_TRACE("pkg_type: %s", app_info->pkg_type);
+               pkgmgr_info *pkg_info = pkgmgr_info_new(app_info->pkg_type, app_info->pkg_name);
+               if (!pkg_info) {
+                       //SETTING_TRACE("pkg_info is null, couldn't get the sizes");
+                       app_info->total_size = 0;
+               } else {
+                       char *buf = NULL;
+                       buf = pkgmgr_info_get_string(pkg_info, STR_INSTALLED_SIZE);
+                       if (buf) {
+                               //SETTING_TRACE("size : %s", buf);
+                               app_info->total_size = atoi(buf);
+                               G_FREE(buf);
+                       } else {
+                               app_info->total_size = 0;
+                       }
+                       pkgmgr_info_free(pkg_info);
+               }
+
+               total_size += app_info->total_size;
+       }
+
+       /* free the list */
+       Eina_List *tmp = NULL;
+       app_info = NULL;
+       EINA_LIST_FOREACH(apps_list, tmp, app_info)
+       {
+               G_FREE(app_info->pkg_name);
+               G_FREE(app_info->pkg_type);
+               FREE(app_info);
+       }
+       eina_list_free(apps_list);
+       apps_list = NULL;
+
+       return total_size;
+}
+
+void __setting_storage_main_pipe_cb(void *data, void *buffer, unsigned int nbyte)
+{
+       SETTING_TRACE_BEGIN;
+       setting_retm_if(data == NULL, "Data parameter is NULL");
+       setting_retm_if(buffer == NULL, "buffer parameter is NULL");
+       SettingStorageUG *ad = (SettingStorageUG *)data;
+
+       Update_Info *update_info = (Update_Info *) buffer;
+
+       SETTING_TRACE("update_info : %d", update_info->type);
+
+       switch (update_info->type) {
+       case SETTING_STORAGE_APPLICATIONS:
+               {
+                       ad->apps_status.dTotal = update_info->total_size;
+                       __setting_storage_main_genlist_update(ad->apps, ad->apps_status);
+               }
+               break;
+       case SETTING_STORAGE_PICTURES_VIDEO:
+               {
+                       ad->pics_videos_status.dTotal = update_info->total_size;
+                       __setting_storage_main_genlist_update(ad->pics_videos, ad->pics_videos_status);
+               }
+               break;
+       case SETTING_STORAGE_AUDIO:
+               {
+                       ad->audio_status.dTotal = update_info->total_size;
+                       __setting_storage_main_genlist_update(ad->audio, ad->audio_status);
+               }
+               break;
+       case SETTING_STORAGE_MISCELLANEOUS:
+               {
+                       ad->others_status.dTotal = update_info->total_size;
+                       __setting_storage_main_genlist_update(ad->others, ad->others_status);
+               }
+               break;
+       default:
+               /* do nothing*/
+               SETTING_TRACE_ERROR("wrong update type");
+               break;
+       }
+
+       __setting_storage_main_genlist_update(ad->internal, ad->internal_status);
+
+       SETTING_TRACE_END;
+}
+
+static void *__setting_storage_main_thread_start_routine(void *data)
+{
+       SETTING_TRACE("==== sub thread id = %d =====", (int)pthread_self());
+       SETTING_TRACE_BEGIN;
+       setting_retvm_if(data == NULL, NULL, "Data parameter is NULL");
+       SettingStorageUG *ad = (SettingStorageUG *)data;
+
+       //Ecore_Pipe *pipe = ad->pipe;
+       update_type type = SETTING_STORAGE_PICTURES_VIDEO;
+       while (1) {
+               pthread_mutex_lock(&ad->update_mutex);
+               while (ad->type == SETTING_STORAGE_SLEEP) {
+                       /* wait to be waked up*/
+                       pthread_cond_wait(&ad->wait_cond, &ad->update_mutex);
+               }
+               type = ad->type;
+               pthread_mutex_unlock(&ad->update_mutex);
+
+               SETTING_TRACE("thread start to work, update type = %d", type);
+
+               int exit_flag = 0;
+
+               pthread_mutex_lock(&ad->exit_mutex);
+               exit_flag = ad->exit_flag;
+               pthread_mutex_unlock(&ad->exit_mutex);
+
+               if (exit_flag == 1) {
+                       SETTING_TRACE("exit_flag is 1");
+                       break;
+               }
+
+               if (type >= SETTING_STORAGE_MAX) {
+                       SETTING_TRACE("work is done, thread will sleep");
+                       pthread_mutex_lock(&ad->update_mutex);
+                       ad->type = SETTING_STORAGE_SLEEP;
+                       pthread_mutex_unlock(&ad->update_mutex);
+                       continue;
+               }
+
+               switch (type) {
+               case SETTING_STORAGE_PICTURES_VIDEO:
+               {
+                       /* get pictures and videos info */
+                       double pics_videos_size = __setting_storage_main_pictures_videos_status_get();
+                       SETTING_TRACE("pics_videos_size = %f", pics_videos_size);
+
+                       Update_Info pics_videos_info;
+                       memset(&pics_videos_info, 0, sizeof(Update_Info));
+                       pics_videos_info.type = SETTING_STORAGE_PICTURES_VIDEO;
+                       pics_videos_info.total_size = pics_videos_size;
+                       if (ad->pipe)
+                               ecore_pipe_write(ad->pipe, &pics_videos_info, sizeof(pics_videos_info));
+               }
+               break;
+               case SETTING_STORAGE_AUDIO:
+               {
+                       /* get audio info */
+                       double audio_size = __setting_storage_main_audio_status_get();
+                       SETTING_TRACE("audio_size = %f", audio_size);
+
+                       Update_Info audio_info;
+                       memset(&audio_info, 0, sizeof(Update_Info));
+                       audio_info.type = SETTING_STORAGE_AUDIO;
+                       audio_info.total_size = audio_size;
+                       if (ad->pipe)
+                               ecore_pipe_write(ad->pipe, &audio_info, sizeof(audio_info));
+               }
+               break;
+               case SETTING_STORAGE_MISCELLANEOUS:
+               {
+                       /* get miscellaneous files info */
+                       double misc_size = __setting_storage_main_miscellaneous_size_get();
+                       SETTING_TRACE("misc_size = %f", misc_size);
+
+                       Update_Info misc_info;
+                       memset(&misc_info, 0, sizeof(Update_Info));
+                       misc_info.type = SETTING_STORAGE_MISCELLANEOUS;
+                       misc_info.total_size = misc_size;
+                       if (ad->pipe)
+                               ecore_pipe_write(ad->pipe, &misc_info, sizeof(misc_info));
+               }
+               break;
+               case SETTING_STORAGE_APPLICATIONS:
+               {
+                       /* get apps info */
+                       double apps_size = __setting_storage_main_applications_status_get(ad);
+                       SETTING_TRACE("apps_size = %f", apps_size);
+
+                       Update_Info apps_info;
+                       memset(&apps_info, 0, sizeof(Update_Info));
+                       apps_info.type = SETTING_STORAGE_APPLICATIONS;
+                       apps_info.total_size = apps_size;
+                       if (ad->pipe)
+                               ecore_pipe_write(ad->pipe, &apps_info, sizeof(apps_info));
+               }
+               break;
+               default:
+               {
+                       SETTING_TRACE("type = %d", type);
+                       break;
+               }
+               }
+
+               pthread_mutex_lock(&ad->update_mutex);
+               ad->type++;
+               SETTING_TRACE("ad->type = %d", ad->type);
+               pthread_mutex_unlock(&ad->update_mutex);
+       }
+       SETTING_TRACE_END;
+       pthread_exit((void *) 0);
+       ad->tid = 0;
+}
+
+static void __setting_storage_main_init(void *data)
+{
+       SETTING_TRACE_BEGIN;
+       setting_retm_if(data == NULL, "Data parameter is NULL");
+       SettingStorageUG *ad = (SettingStorageUG *)data;
+
+       pthread_mutex_init(&ad->exit_mutex, NULL);
+       pthread_mutex_init(&ad->update_mutex, NULL);
+       pthread_cond_init(&ad->wait_cond, NULL);
+
+       ad->exit_flag = EINA_FALSE;
+       ad->type = SETTING_STORAGE_PICTURES_VIDEO;
+
+       ad->internal_status.dAvail = 0.0;
+       ad->internal_status.dTotal= 0.0;
+
+       ad->apps_status.dAvail = 0.0;
+       ad->apps_status.dTotal= 0.0;
+
+       ad->pics_videos_status.dAvail = 0.0;
+       ad->pics_videos_status.dTotal= 0.0;
+
+       ad->audio_status.dAvail = 0.0;
+       ad->audio_status.dTotal= 0.0;
+
+       ad->others_status.dAvail = 0.0;
+       ad->others_status.dTotal= 0.0;
+}
+
 /* ***************************************************
  *
  *basic func
@@ -1107,11 +1446,13 @@ static int setting_storage_main_create(void *cb)
 
        SettingStorageUG *ad = (SettingStorageUG *) cb;
 
-       retvm_if(ad->win_main_layout == NULL, SETTING_DRAW_ERR_FAIL_LOAD_EDJ,
-                "win_main_layout is NULL");
+       __setting_storage_main_init(ad);
 
        int ret = SETTING_RETURN_SUCCESS;
 
+       retvm_if(ad->win_main_layout == NULL, SETTING_DRAW_ERR_FAIL_LOAD_EDJ,
+                "win_main_layout is NULL");
+
        ad->ly_main =
            setting_create_layout_navi_bar_genlist(ad->win_main_layout,
                                                   ad->win_get,
@@ -1130,15 +1471,11 @@ static int setting_storage_main_create(void *cb)
 
        __setting_storage_main_internal_storage_status_get(ad);
 
-       __setting_storage_main_pictures_videos_status_get(ad);
-
-       __setting_storage_main_downloads_status_get(ad);
-
-       __setting_storage_main_audio_status_get(ad);
-
        Elm_Object_Item *item = NULL;
 
-       if (!isEmulBin()) {
+       bool is_emulator = isEmulBin();
+
+       if (!is_emulator) {
                item = elm_genlist_item_append(ad->genlist, &itc_seperator, NULL, NULL,
                                        ELM_GENLIST_ITEM_NONE, NULL, NULL);
                elm_genlist_item_select_mode_set(item, ELM_OBJECT_SELECT_MODE_DISPLAY_ONLY);
@@ -1176,87 +1513,60 @@ static int setting_storage_main_create(void *cb)
        }
 
        /* Applications */
-       ad->apps_status.dTotal = 230.45 * 1024 * 1024; /* for test*/
-       char apps_desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
-       ret = __setting_storage_status_size_transition(ad->apps_status.dTotal, apps_desc);
-       setting_retvm_if(ret == SETTING_RETURN_FAIL, SETTING_RETURN_FAIL, "failed to transform")
-
        ad->apps = setting_create_Gendial_field_def(ad->genlist, &(ad->itc_2text_1icon_3),
                                             __setting_storage_main_Gendial_mouse_up_cb,
                                             ad, SWALLOW_Type_INVALID, SETTING_STORAGE_APPS_ICON_PATH,
                                             NULL, 0, "IDS_ST_BODY_APPLICATIONS",
-                                            apps_desc, NULL);
+                                            _("IDS_ST_HEADER_PLEASE_WAIT"), NULL);
        if (ad->apps) {
                ad->apps->userdata = ad;
+               if (is_emulator) {
+                       elm_genlist_item_select_mode_set(ad->apps->item, ELM_OBJECT_SELECT_MODE_DISPLAY_ONLY);
+               }
        } else {
                SETTING_TRACE_ERROR("ad->apps is NULL");
                return SETTING_RETURN_FAIL;
        }
 
        /* Pictures, Videos */
-       char pics_videos_desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
-       ret = __setting_storage_status_size_transition(ad->pics_videos_status.dTotal, pics_videos_desc);
-       setting_retvm_if(ret == SETTING_RETURN_FAIL, SETTING_RETURN_FAIL, "failed to transform")
        ad->pics_videos = setting_create_Gendial_field_def(ad->genlist, &(ad->itc_2text_1icon_3),
                                             __setting_storage_main_Gendial_mouse_up_cb,
                                             ad, SWALLOW_Type_INVALID, SETTING_STORAGE_PICS_ICON_PATH,
                                             NULL, 0, SETTING_STORAGE_PICS_STR,
-                                            pics_videos_desc, NULL);
+                                            _("IDS_ST_HEADER_PLEASE_WAIT"), NULL);
        if (ad->pics_videos) {
                ad->pics_videos->userdata = ad;
+               if (is_emulator) {
+                       elm_genlist_item_select_mode_set(ad->pics_videos->item, ELM_OBJECT_SELECT_MODE_DISPLAY_ONLY);
+               }
        } else {
                SETTING_TRACE_ERROR("ad->pics_videos is NULL");
                return SETTING_RETURN_FAIL;
        }
 
-       /* Downloads */
-       char downloads_desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
-       ret = __setting_storage_status_size_transition(ad->downloads_status.dTotal, downloads_desc);
-       setting_retvm_if(ret == SETTING_RETURN_FAIL, SETTING_RETURN_FAIL, "failed to transform")
-       ad->downloads = setting_create_Gendial_field_def(ad->genlist, &(ad->itc_2text_1icon_3),
-                                            __setting_storage_main_Gendial_mouse_up_cb,
-                                            ad, SWALLOW_Type_INVALID, SETTING_STORAGE_DOWNS_ICON_PATH,
-                                            NULL, 0, SETTING_STORAGE_DOWNS_STR,
-                                            downloads_desc,
-                                            NULL);
-       if (ad->downloads) {
-               ad->downloads->userdata = ad;
-       } else {
-               SETTING_TRACE_ERROR("ad->downloads is NULL");
-               return SETTING_RETURN_FAIL;
-       }
-
        /* Audio */
-       char audio_desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
-       ret = __setting_storage_status_size_transition(ad->audio_status.dTotal, audio_desc);
-       setting_retvm_if(ret == SETTING_RETURN_FAIL, SETTING_RETURN_FAIL, "failed to transform")
        ad->audio = setting_create_Gendial_field_def(ad->genlist, &(ad->itc_2text_1icon_3),
                                             __setting_storage_main_Gendial_mouse_up_cb,
                                             ad, SWALLOW_Type_INVALID, SETTING_STORAGE_AUDIO_ICON_PATH,
                                             NULL, 0, SETTING_STORAGE_AUDIO_STR,
-                                            audio_desc,
-                                            NULL);
+                                            _("IDS_ST_HEADER_PLEASE_WAIT"), NULL);
        if (ad->audio) {
                ad->audio->userdata = ad;
+
+               if (is_emulator) {
+                       elm_genlist_item_select_mode_set(ad->audio->item, ELM_OBJECT_SELECT_MODE_DISPLAY_ONLY);
+               }
        } else {
                SETTING_TRACE_ERROR("ad->audio is NULL");
                return SETTING_RETURN_FAIL;
        }
 
        /* Miscellaneous files */
-       ad->others_status.dTotal = ad->internal_status.dTotal - ad->internal_status.dAvail
-                                - ad->apps_status.dTotal - ad->pics_videos_status.dTotal
-                                - ad->downloads_status.dTotal - ad->audio_status.dTotal;
-       ad->others_status.dAvail = 0.0;
-       char others_desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
-       ret = __setting_storage_status_size_transition(ad->others_status.dTotal, others_desc);
-       setting_retvm_if(ret == SETTING_RETURN_FAIL, SETTING_RETURN_FAIL, "failed to transform")
-
-       ad->others = setting_create_Gendial_field_def(ad->genlist, &(ad->itc_2text_1icon_3), 
+       ad->others = setting_create_Gendial_field_def(ad->genlist, &(ad->itc_2text_1icon_3),
                                             __setting_storage_main_Gendial_mouse_up_cb,
                                             ad, SWALLOW_Type_INVALID, SETTING_STORAGE_MISCES_ICON_PATH,
                                             NULL, 0, SETTING_STORAGE_MISCES_STR,
-                                            others_desc, NULL);
+                                            _("IDS_ST_HEADER_PLEASE_WAIT"), NULL);
        if (ad->others) {
                ad->others->userdata = ad;
        } else {
@@ -1281,7 +1591,8 @@ static int setting_storage_main_create(void *cb)
                return SETTING_RETURN_FAIL;
        }
 
-       if (!isEmulBin()) {
+       if (!is_emulator) {
+#if DISABLED_CODE
                /* Format USB storage */
                setting_create_Gendial_field_def(ad->genlist, &(ad->itc_1text), NULL,
                                                     ad, SWALLOW_Type_INVALID, NULL,
@@ -1293,10 +1604,11 @@ static int setting_storage_main_create(void *cb)
                                                 ad, SWALLOW_Type_LAYOUT_SPECIALIZTION_X,
                                                 NULL, NULL, 0, SETTING_STORAGE_FORMAT_DESC_STR, NULL,
                                                 NULL);
+#endif
 
                /* SD card info */
                setting_create_Gendial_field_titleItem(ad->genlist, &(ad->itc_group_item),
-                                              "IDS_ST_BODY_SD_CARD", NULL);            
+                                              "IDS_ST_BODY_SD_CARD", NULL);
                __setting_storage_main_sd_card_info_append(ad);
 
                ret = vconf_notify_key_changed(VCONFKEY_SYSMAN_MMC_STATUS,
@@ -1311,6 +1623,25 @@ static int setting_storage_main_create(void *cb)
        }
 
        setting_view_storage_main.is_create = 1;
+
+       if (ad->pipe) {
+               ecore_pipe_del(ad->pipe);
+               ad->pipe = NULL;
+       }
+       ad->pipe = ecore_pipe_add(__setting_storage_main_pipe_cb, ad);
+       if (ad->pipe)
+       {
+               ret = pthread_create(&ad->tid, NULL, __setting_storage_main_thread_start_routine, ad);
+               if (ret != 0) {
+                       SETTING_TRACE_ERROR("fail to pthread_create");
+               }
+               SETTING_TRACE("thread id = %d", ad->tid);
+       }
+       else
+       {
+               SETTING_TRACE_ERROR("fail to ecore_pipe_add");
+       }
+
        return SETTING_RETURN_SUCCESS;
 }
 
@@ -1321,8 +1652,39 @@ static int setting_storage_main_destroy(void *cb)
 
        SettingStorageUG *ad = (SettingStorageUG *) cb;
 
+       int ret = 0;
+
+       pthread_mutex_lock(&ad->exit_mutex);
+       ad->exit_flag = 1;
+       pthread_mutex_unlock(&ad->exit_mutex);
+
+       /* wake up thread */
+       pthread_mutex_lock(&ad->update_mutex);
+       ad->type = SETTING_STORAGE_REUPDATE;
+       pthread_cond_signal(&ad->wait_cond);
+       pthread_mutex_unlock(&ad->update_mutex);
+
+       if (ad->tid > 0)
+       {
+               void *thread_ret = NULL;
+               ret = pthread_join(ad->tid, &thread_ret);
+               if(ret != 0) {
+                       SETTING_TRACE_ERROR("fail to join with thread");
+               }
+               SETTING_TRACE("thread exit code %d", (int)thread_ret);
+       }
+
+       pthread_mutex_destroy(&ad->exit_mutex);
+       pthread_mutex_destroy(&ad->update_mutex);
+       pthread_cond_destroy(&ad->wait_cond);
+
+       if (ad->pipe) {
+               ecore_pipe_del(ad->pipe);
+               ad->pipe = NULL;
+       }
+
        if (!isEmulBin()) {
-               int ret = vconf_ignore_key_changed(VCONFKEY_SYSMAN_MMC_STATUS,
+               ret = vconf_ignore_key_changed(VCONFKEY_SYSMAN_MMC_STATUS,
                                __setting_storage_vconf_change_cb);
                if (ret != 0) {
                        SETTING_TRACE_ERROR("call vconf_ignore_key_changed failed");
@@ -1347,9 +1709,46 @@ static int setting_storage_main_update(void *cb)
        SETTING_TRACE_BEGIN;
        /* error check */
        retv_if(cb == NULL, SETTING_GENERAL_ERR_NULL_DATA_PARAMETER);
-
        SettingStorageUG *ad = (SettingStorageUG *) cb;
 
+       int ret = 0;
+
+       __setting_storage_main_internal_storage_status_get(ad);
+
+       /* update internal total size */
+       char total_desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
+       ret = __setting_storage_status_size_transition(ad->internal_status.dTotal, total_desc);
+       setting_retvm_if(ret == SETTING_RETURN_FAIL, SETTING_RETURN_FAIL, "failed to transform")
+
+       G_FREE(ad->internal->keyStr);
+       ad->internal->keyStr = (char *)g_strdup(total_desc);
+       elm_object_item_data_set(ad->internal->item, ad->internal);
+       elm_genlist_item_update(ad->internal->item);
+
+       /* update internal available size */
+       char avail_desc[SETTING_STORAGE_MAX_STR_LEN + 1] = {0,};
+       ret = __setting_storage_status_size_transition(ad->internal_status.dAvail, avail_desc);
+       setting_retvm_if(ret == SETTING_RETURN_FAIL, SETTING_RETURN_FAIL, "failed to transform")
+
+       G_FREE(ad->avail->sub_desc);
+       ad->avail->sub_desc = (char *)g_strdup(avail_desc);
+       elm_object_item_data_set(ad->avail->item, ad->avail);
+       elm_genlist_item_update(ad->avail->item);
+
+       /* update miscellaneous */
+       if (ad->back_from_misc) {
+               double misc_size = __setting_storage_main_miscellaneous_size_get();
+
+               ad->others_status.dTotal = misc_size;
+               __setting_storage_main_genlist_update(ad->others, ad->others_status);
+       }
+
+       /* wake up thread */
+       pthread_mutex_lock(&ad->update_mutex);
+       ad->type = SETTING_STORAGE_REUPDATE;
+       pthread_cond_signal(&ad->wait_cond);
+       pthread_mutex_unlock(&ad->update_mutex);
+
        if (ad->ly_main != NULL) {
                evas_object_show(ad->ly_main);
        }