g_ptr_array_free(path_list, TRUE);
}
+static void __file_info_free(gpointer data)
+{
+ SAFE_FREE(*(media_svc_file_s **)data);
+}
+
int media_svc_update_item_meta(sqlite3 *handle, uid_t uid)
{
int ret = MS_MEDIA_ERR_NONE;
+ int i = 0;
/* NOTICE : After 6.0, change 'media_view' to 'media', add 'AND validity=1', and no need storage id */
char *sql = NULL;
media_svc_content_info_s content_info;
path_list = g_array_new(FALSE, FALSE, sizeof(media_svc_file_s *));
media_svc_retvm_if(!path_list, MS_MEDIA_ERR_OUT_OF_MEMORY, "Allocation failed");
+ g_array_set_clear_func(path_list, __file_info_free);
sql = sqlite3_mprintf("SELECT media_path, storage_uuid FROM %q WHERE media_type=3", MEDIA_SVC_DB_VIEW_MEDIA);
ret = _media_svc_get_media(handle, sql, &path_list);
if (ret != MS_MEDIA_ERR_NONE) {
media_svc_error("Fail to get media list");
- g_array_free(path_list, false);
+ g_array_free(path_list, TRUE);
return ret;
}
- while (path_list->len != 0) {
- file_info = g_array_index(path_list, media_svc_file_s *, 0);
- g_array_remove_index(path_list, 0);
+ for (i = 0; i < path_list->len; i++) {
+ file_info = g_array_index(path_list, media_svc_file_s *, i);
memset(&content_info, 0, sizeof(media_svc_content_info_s));
ret = _media_svc_extract_music_metadata_for_update(&content_info, file_info->storage_id, file_info->path);
if (ret != MS_MEDIA_ERR_NONE) {
media_svc_error("Fail to extract metadata");
_media_svc_destroy_content_info(&content_info);
- SAFE_FREE(file_info);
continue;
}
media_svc_error("Fail to append item[%s]", content_info.path);
_media_svc_destroy_content_info(&content_info);
- SAFE_FREE(file_info);
}
- g_array_free(path_list, false);
+ g_array_free(path_list, TRUE);
ret = _media_svc_list_query_do(MEDIA_SVC_QUERY_UPDATE_ITEM, uid);
media_svc_retvm_if(ret != MS_MEDIA_ERR_NONE, ret, "_media_svc_list_query_do failed");