X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;ds=inline;f=src%2Fmaemo%2Fmodest-platform.c;h=e16317a77016ed1c457623d0239ab0ead73922b0;hb=da42a65eeae3c5b8b80e1dbab10ec3ff1ca095de;hp=50718b9224a03f3994691ae82217d9e4bed6c54e;hpb=6b786cdfc551fec1606eb6f13432b4ba90f65357;p=modest diff --git a/src/maemo/modest-platform.c b/src/maemo/modest-platform.c index 50718b9..e16317a 100644 --- a/src/maemo/modest-platform.c +++ b/src/maemo/modest-platform.c @@ -50,6 +50,7 @@ #include #include #include "modest-tny-folder.h" +#include "modest-tny-account.h" #include #include @@ -92,12 +93,13 @@ check_required_files (void) return FALSE; } else fclose (mcc_file); - - if (access (MODEST_PROVIDERS_DATA_PATH, R_OK) != 0) { + + if (access(MODEST_PROVIDER_DATA_FILE, R_OK) != 0 && + access(MODEST_MAEMO_PROVIDER_DATA_FILE, R_OK) != 0) { g_printerr ("modest: cannot find providers data\n"); return FALSE; } - + return TRUE; } @@ -157,7 +159,7 @@ modest_platform_init (int argc, char *argv[]) /* Register hardware event dbus callback: */ hw_state.shutdown_ind = TRUE; - osso_hw_set_event_cb(osso_context, NULL,/*&hw_state*/ modest_osso_cb_hw_state_handler, NULL); + osso_hw_set_event_cb(osso_context, NULL, NULL, NULL); /* Register osso auto-save callbacks: */ result = osso_application_set_autosave_cb (osso_context, @@ -232,14 +234,15 @@ modest_platform_get_file_icon_name (const gchar* name, const gchar* mime_type, gchar *icon_name = NULL; gchar **icons, **cursor; - if (!mime_type || !g_ascii_strcasecmp (mime_type, "application/octet-stream")) + if (!mime_type || g_ascii_strcasecmp (mime_type, "application/octet-stream") == 0) mime_str = g_string_new (gnome_vfs_get_mime_type_for_name (name)); else { mime_str = g_string_new (mime_type); g_string_ascii_down (mime_str); } - + icons = hildon_mime_get_icon_names (mime_str->str, NULL); + for (cursor = icons; cursor; ++cursor) { if (!g_ascii_strcasecmp (*cursor, "gnome-mime-message") || !g_ascii_strcasecmp (*cursor, "gnome-mime-message-rfc822")) { @@ -256,7 +259,7 @@ modest_platform_get_file_icon_name (const gchar* name, const gchar* mime_type, *effective_mime_type = g_string_free (mime_str, FALSE); else g_string_free (mime_str, TRUE); - + return icon_name; } @@ -291,28 +294,34 @@ modest_platform_activate_uri (const gchar *uri) g_return_val_if_fail (uri, FALSE); if (!uri) return FALSE; - - actions = hildon_uri_get_actions_by_uri (uri, -1, NULL); - - for (iter = actions; iter; iter = g_slist_next (iter)) { - action = (HildonURIAction*) iter->data; - if (action && strcmp (hildon_uri_action_get_service (action), - "com.nokia.modest") == 0) { - result = checked_hildon_uri_open (uri, action); - break; + + /* don't try to activate file: uri's -- they might confuse the user, + * and/or might have security implications */ + if (!g_str_has_prefix (uri, "file:")) { + + actions = hildon_uri_get_actions_by_uri (uri, -1, NULL); + + for (iter = actions; iter; iter = g_slist_next (iter)) { + action = (HildonURIAction*) iter->data; + if (action && strcmp (hildon_uri_action_get_service (action), + "com.nokia.modest") == 0) { + result = checked_hildon_uri_open (uri, action); + break; + } } - } + + /* if we could not open it with email, try something else */ + if (!result) + result = checked_hildon_uri_open (uri, NULL); + } - /* if we could not open it with email, try something else */ - if (!result) - result = checked_hildon_uri_open (uri, NULL); - if (!result) { ModestWindow *parent = modest_window_mgr_get_main_window (modest_runtime_get_window_mgr(), FALSE); hildon_banner_show_information (parent ? GTK_WIDGET(parent): NULL, NULL, _("mcen_ib_unsupported_link")); - } + g_warning ("%s: cannot open uri '%s'", __FUNCTION__,uri); + } return result; } @@ -323,7 +332,7 @@ modest_platform_activate_file (const gchar *path, const gchar *mime_type) gint result = 0; DBusConnection *con; gchar *uri_path = NULL; - + uri_path = g_strconcat ("file://", path, NULL); con = osso_get_dbus_connection (modest_maemo_utils_get_osso_context()); @@ -404,38 +413,47 @@ modest_platform_show_uri_popup (const gchar *uri) if (uri == NULL) return FALSE; - + actions_list = hildon_uri_get_actions_by_uri (uri, -1, NULL); - if (actions_list != NULL) { - GSList *node; + if (actions_list) { + GtkWidget *menu = gtk_menu_new (); ModestPlatformPopupInfo *popup_info = g_new0 (ModestPlatformPopupInfo, 1); - popup_info->actions = actions_list; - popup_info->uri = g_strdup (uri); - - for (node = actions_list; node != NULL; node = g_slist_next (node)) { - GtkWidget *menu_item; - const gchar *action_name; - const gchar *translation_domain; - HildonURIAction *action = (HildonURIAction *) node->data; - action_name = hildon_uri_action_get_name (action); - translation_domain = hildon_uri_action_get_translation_domain (action); - menu_item = gtk_menu_item_new_with_label (dgettext(translation_domain, action_name)); - g_object_set_data (G_OBJECT(menu_item), HILDON_OSSO_URI_ACTION, (gpointer)action_name); /* hack */ - g_signal_connect (G_OBJECT (menu_item), "activate", G_CALLBACK (activate_uri_popup_item), - popup_info); - - if (hildon_uri_is_default_action (action, NULL)) { - gtk_menu_shell_prepend (GTK_MENU_SHELL (menu), menu_item); - } else { - gtk_menu_shell_append (GTK_MENU_SHELL (menu), menu_item); + /* don't add actions for file: uri's -- they might confuse the user, + * and/or might have security implications + * we still allow to copy the url though + */ + if (!g_str_has_prefix (uri, "file:")) { + + GSList *node; + popup_info->actions = actions_list; + popup_info->uri = g_strdup (uri); + + for (node = actions_list; node != NULL; node = g_slist_next (node)) { + GtkWidget *menu_item; + const gchar *action_name; + const gchar *translation_domain; + HildonURIAction *action = (HildonURIAction *) node->data; + action_name = hildon_uri_action_get_name (action); + translation_domain = hildon_uri_action_get_translation_domain (action); + menu_item = gtk_menu_item_new_with_label (dgettext(translation_domain, action_name)); + g_object_set_data (G_OBJECT(menu_item), HILDON_OSSO_URI_ACTION, (gpointer)action_name); /* hack */ + g_signal_connect (G_OBJECT (menu_item), "activate", G_CALLBACK (activate_uri_popup_item), + popup_info); + + if (hildon_uri_is_default_action (action, NULL)) { + gtk_menu_shell_prepend (GTK_MENU_SHELL (menu), menu_item); + } else { + gtk_menu_shell_append (GTK_MENU_SHELL (menu), menu_item); + } + gtk_widget_show (menu_item); } - gtk_widget_show (menu_item); } /* always add the copy item */ - GtkWidget* menu_item = gtk_menu_item_new_with_label (dgettext("osso-uri", "uri_link_copy_link_location")); + GtkWidget* menu_item = gtk_menu_item_new_with_label (dgettext("osso-uri", + "uri_link_copy_link_location")); g_object_set_data_full (G_OBJECT(menu_item), HILDON_OSSO_URI_ACTION, g_strconcat (URI_ACTION_COPY, uri, NULL), g_free); @@ -451,7 +469,7 @@ modest_platform_show_uri_popup (const gchar *uri) } else { hildon_banner_show_information (NULL, NULL, _("mcen_ib_unsupported_link")); } - + return TRUE; } @@ -569,6 +587,23 @@ entry_changed (GtkEditable *editable, g_free (chars); } +static guint +checked_hildon_sort_dialog_add_sort_key (HildonSortDialog *dialog, const gchar* key, guint max) +{ + gint sort_key; + + g_return_val_if_fail (dialog && HILDON_IS_SORT_DIALOG(dialog), 0); + g_return_val_if_fail (key, 0); + + sort_key = hildon_sort_dialog_add_sort_key (dialog, key); + if (sort_key < 0 || sort_key >= max) { + g_warning ("%s: out of range (%d) for %s", __FUNCTION__, sort_key, key); + return 0; + } else + return (guint)sort_key; +} + + static void launch_sort_headers_dialog (GtkWindow *parent_window, HildonSortDialog *dialog) @@ -596,15 +631,17 @@ launch_sort_headers_dialog (GtkWindow *parent_window, /* Add sorting keys */ cols = modest_header_view_get_columns (header_view); - if (cols == NULL) return; - int sort_model_ids[6]; - int sort_ids[6]; - + if (cols == NULL) + return; +#define SORT_ID_NUM 6 + int sort_model_ids[SORT_ID_NUM]; + int sort_ids[SORT_ID_NUM]; outgoing = (GPOINTER_TO_INT (g_object_get_data(G_OBJECT(cols->data), MODEST_HEADER_VIEW_COLUMN))== MODEST_HEADER_VIEW_COLUMN_COMPACT_HEADER_OUT); - sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_sender_recipient")); + sort_key = checked_hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_sender_recipient"), + SORT_ID_NUM - 1); if (outgoing) { sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_TO_COLUMN; sort_ids[sort_key] = MODEST_HEADER_VIEW_COLUMN_COMPACT_HEADER_OUT; @@ -613,7 +650,8 @@ launch_sort_headers_dialog (GtkWindow *parent_window, sort_ids[sort_key] = MODEST_HEADER_VIEW_COLUMN_COMPACT_HEADER_IN; } - sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_date")); + sort_key = checked_hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_date"), + SORT_ID_NUM - 1); if (outgoing) { sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_DATE_SENT_TIME_T_COLUMN; sort_ids[sort_key] = MODEST_HEADER_VIEW_COLUMN_COMPACT_SENT_DATE; @@ -623,23 +661,27 @@ launch_sort_headers_dialog (GtkWindow *parent_window, } default_key = sort_key; - sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_subject")); + sort_key = checked_hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_subject"), + SORT_ID_NUM -1); sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_SUBJECT_COLUMN; if (outgoing) sort_ids[sort_key] = MODEST_HEADER_VIEW_COLUMN_COMPACT_HEADER_OUT; else sort_ids[sort_key] = MODEST_HEADER_VIEW_COLUMN_COMPACT_HEADER_IN; - sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_attachment")); + sort_key = checked_hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_attachment"), + SORT_ID_NUM - 1); sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_FLAGS_COLUMN; sort_ids[sort_key] = TNY_HEADER_FLAG_ATTACHMENTS; attachments_sort_id = sort_key; - sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_size")); + sort_key = checked_hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_size"), + SORT_ID_NUM - 1); sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_MESSAGE_SIZE_COLUMN; sort_ids[sort_key] = 0; - sort_key = hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_priority")); + sort_key = checked_hildon_sort_dialog_add_sort_key (dialog, _("mcen_li_sort_priority"), + SORT_ID_NUM - 1); sort_model_ids[sort_key] = TNY_GTK_HEADER_LIST_MODEL_FLAGS_COLUMN; sort_ids[sort_key] = TNY_HEADER_FLAG_PRIORITY_MASK; priority_sort_id = sort_key; @@ -675,6 +717,11 @@ launch_sort_headers_dialog (GtkWindow *parent_window, result = gtk_dialog_run (GTK_DIALOG (dialog)); if (result == GTK_RESPONSE_OK) { sort_key = hildon_sort_dialog_get_sort_key (dialog); + if (sort_key < 0 || sort_key > SORT_ID_NUM -1) { + g_warning ("%s: out of range (%d)", __FUNCTION__, sort_key); + sort_key = 0; + } + sort_type = hildon_sort_dialog_get_sort_order (dialog); if (sort_model_ids[sort_key] == TNY_GTK_HEADER_LIST_MODEL_FLAGS_COLUMN) { g_object_set_data (G_OBJECT(cols->data), MODEST_HEADER_VIEW_FLAG_SORT, @@ -695,9 +742,6 @@ launch_sort_headers_dialog (GtkWindow *parent_window, modest_widget_memory_save (modest_runtime_get_conf (), G_OBJECT (header_view), MODEST_CONF_HEADER_VIEW_KEY); -/* while (gtk_events_pending ()) */ -/* gtk_main_iteration (); */ - /* free */ g_list_free(cols); } @@ -712,21 +756,40 @@ on_response (GtkDialog *dialog, GList *child_vbox, *child_hbox; GtkWidget *hbox, *entry; TnyFolderStore *parent; + const gchar *new_name; + gboolean exists; if (response != GTK_RESPONSE_ACCEPT) return; - + /* Get entry */ child_vbox = gtk_container_get_children (GTK_CONTAINER (dialog->vbox)); hbox = child_vbox->data; child_hbox = gtk_container_get_children (GTK_CONTAINER (hbox)); entry = child_hbox->next->data; - + parent = TNY_FOLDER_STORE (user_data); - + new_name = gtk_entry_get_text (GTK_ENTRY (entry)); + exists = FALSE; + /* Look for another folder with the same name */ if (modest_tny_folder_has_subfolder_with_name (parent, - gtk_entry_get_text (GTK_ENTRY (entry)))) { + new_name, + TRUE)) { + exists = TRUE; + } + + if (!exists) { + if (TNY_IS_ACCOUNT (parent) && + modest_tny_account_is_virtual_local_folders (TNY_ACCOUNT (parent)) && + modest_tny_local_folders_account_folder_name_in_use (MODEST_TNY_LOCAL_FOLDERS_ACCOUNT (parent), + new_name)) { + exists = TRUE; + } + } + + if (exists) { + /* Show an error */ hildon_banner_show_information (gtk_widget_get_parent (GTK_WIDGET (dialog)), NULL, _CS("ckdg_ib_folder_already_exists")); @@ -844,9 +907,9 @@ modest_platform_run_new_folder_dialog (GtkWindow *parent_window, else real_suggested_name = g_strdup_printf (_("mcen_ia_default_folder_name_s"), num_str); - exists = modest_tny_folder_has_subfolder_with_name (parent_folder, - real_suggested_name); + real_suggested_name, + TRUE); if (!exists) break; @@ -1026,16 +1089,22 @@ modest_platform_connect_and_wait (GtkWindow *parent_window, gboolean device_online; TnyDevice *device; TnyConnectionStatus conn_status; + gboolean user_requested; device = modest_runtime_get_device(); device_online = tny_device_is_online (device); + /* Whether the connection is user requested or automatically + requested, for example via D-Bus */ + user_requested = (parent_window) ? TRUE : FALSE; + /* If there is no account check only the device status */ if (!account) { if (device_online) return TRUE; else - return tny_maemo_conic_device_connect (TNY_MAEMO_CONIC_DEVICE (device), NULL); + return tny_maemo_conic_device_connect (TNY_MAEMO_CONIC_DEVICE (device), + NULL, user_requested); } /* Return if the account is already connected */ @@ -1055,7 +1124,8 @@ modest_platform_connect_and_wait (GtkWindow *parent_window, G_CALLBACK (on_connection_status_changed), data); /* Try to connect the device */ - device_online = tny_maemo_conic_device_connect (TNY_MAEMO_CONIC_DEVICE (device), NULL); + device_online = tny_maemo_conic_device_connect (TNY_MAEMO_CONIC_DEVICE (device), + NULL, user_requested); /* If the device connection failed then exit */ if (!device_online && data->handler) @@ -1069,7 +1139,7 @@ modest_platform_connect_and_wait (GtkWindow *parent_window, /* Wait until the callback is executed */ g_mutex_lock (data->mutex); if (!data->has_callback) { - data->wait_loop = g_main_loop_new (NULL, FALSE); + data->wait_loop = g_main_loop_new (g_main_context_new (), FALSE); gdk_threads_leave (); g_mutex_unlock (data->mutex); g_main_loop_run (data->wait_loop); @@ -1127,39 +1197,6 @@ modest_platform_connect_and_wait_if_network_folderstore (GtkWindow *parent_windo return result; } -gboolean -modest_platform_is_network_folderstore (TnyFolderStore *folder_store) -{ - TnyAccount *account = NULL; - gboolean result = TRUE; - - g_return_val_if_fail(TNY_IS_FOLDER_STORE(folder_store), FALSE); - - if (TNY_IS_FOLDER (folder_store)) { - /* Get the folder's parent account: */ - account = tny_folder_get_account(TNY_FOLDER(folder_store)); - } else if (TNY_IS_ACCOUNT (folder_store)) { - account = TNY_ACCOUNT(folder_store); - g_object_ref(account); - } - - if (account != NULL) { - if (tny_account_get_account_type (account) == TNY_ACCOUNT_TYPE_STORE) { - if (!TNY_IS_CAMEL_POP_STORE_ACCOUNT (account) && - !TNY_IS_CAMEL_IMAP_STORE_ACCOUNT (account)) { - /* This must be a maildir account, which does - * not require a connection: */ - result = FALSE; - } - } - g_object_unref (account); - } else { - result = FALSE; - } - - return result; -} - void modest_platform_run_sort_dialog (GtkWindow *parent_window, ModestSortDialogType type) @@ -1682,8 +1719,6 @@ modest_platform_run_certificate_confirmation_dialog (const gchar* server_name, return response == GTK_RESPONSE_OK; } - - gboolean modest_platform_run_alert_dialog (const gchar* prompt, @@ -1708,7 +1743,7 @@ modest_platform_run_alert_dialog (const gchar* prompt, * so we know what buttons to show. */ GtkWidget *dialog = GTK_WIDGET (hildon_note_new_confirmation (GTK_WINDOW (main_win), prompt)); - modest_window_mgr_set_modal (modest_runtime_get_window_mgr (), + modest_window_mgr_set_modal (modest_runtime_get_window_mgr (), GTK_WINDOW (dialog)); const int response = gtk_dialog_run (GTK_DIALOG (dialog)); @@ -1722,3 +1757,267 @@ modest_platform_run_alert_dialog (const gchar* prompt, } return retval; } + +/***************/ +typedef struct { + GtkWindow *parent_window; + ModestConnectedPerformer callback; + TnyAccount *account; + gpointer user_data; + gchar *iap; + TnyDevice *device; +} OnWentOnlineInfo; + +static void +on_went_online_info_free (OnWentOnlineInfo *info) +{ + /* And if we cleanup, we DO cleanup :-) */ + + if (info->device) + g_object_unref (info->device); + if (info->iap) + g_free (info->iap); + if (info->parent_window) + g_object_unref (info->parent_window); + if (info->account) + g_object_unref (info->account); + + g_slice_free (OnWentOnlineInfo, info); + + /* We're done ... */ + + return; +} + +static void +on_account_went_online (TnyCamelAccount *account, gboolean canceled, GError *err, gpointer user_data) +{ + OnWentOnlineInfo *info = (OnWentOnlineInfo *) user_data; + + /* Now it's really time to callback to the caller. If going online didn't succeed, + * err will be set. We don't free it, Tinymail does that! If a cancel happened, + * canceled will be set. Etcetera etcetera. */ + + if (info->callback) { + info->callback (canceled, err, info->parent_window, info->account, info->user_data); + } + + /* This is our last call, we must cleanup here if we didn't yet do that */ + on_went_online_info_free (info); + + return; +} + + +static void +on_conic_device_went_online (TnyMaemoConicDevice *device, const gchar* iap_id, gboolean canceled, GError *err, gpointer user_data) +{ + OnWentOnlineInfo *info = (OnWentOnlineInfo *) user_data; + info->iap = g_strdup (iap_id); + + if (canceled || err || !info->account) { + + /* If there's a problem or if there's no account (then that's it for us, we callback + * the caller's callback now. He'll have to handle err or canceled, of course. + * We are not really online, as the account is not really online here ... */ + + /* We'll use the err and the canceled of this cb. TnyMaemoConicDevice delivered us + * this info. We don't cleanup err, Tinymail does that! */ + + if (info->callback) { + + /* info->account can be NULL here, this means that the user did not + * provide a nice account instance. We'll assume that the user knows + * what he's doing and is happy with just the device going online. + * + * We can't do magic, we don't know what account the user wants to + * see going online. So just the device goes online, end of story */ + + info->callback (canceled, err, info->parent_window, info->account, info->user_data); + } + + } else if (info->account) { + + /* If there's no problem and if we have an account, we'll put the account + * online too. When done, the callback of bringing the account online + * will callback the caller's callback. This is the most normal case. */ + + info->device = TNY_DEVICE (g_object_ref (device)); + + tny_camel_account_set_online (TNY_CAMEL_ACCOUNT (info->account), TRUE, + on_account_went_online, info); + + /* The on_account_went_online cb frees up the info, go look if you + * don't believe me! (so we return here) */ + + return; + } + + /* We cleanup if we are not bringing the account online too */ + on_went_online_info_free (info); + + return; +} + +void +modest_platform_connect_and_perform (GtkWindow *parent_window, + TnyAccount *account, + ModestConnectedPerformer callback, + gpointer user_data) +{ + gboolean device_online; + TnyDevice *device; + TnyConnectionStatus conn_status; + OnWentOnlineInfo *info; + gboolean user_requested; + + device = modest_runtime_get_device(); + device_online = tny_device_is_online (device); + + /* Whether the connection is user requested or automatically + requested, for example via D-Bus */ + user_requested = (parent_window) ? TRUE : FALSE; + + /* If there is no account check only the device status */ + if (!account) { + + if (device_online) { + + /* We promise to instantly perform the callback, so ... */ + if (callback) { + callback (FALSE, NULL, parent_window, account, user_data); + } + + } else { + + info = g_slice_new0 (OnWentOnlineInfo); + + info->iap = NULL; + info->device = NULL; + info->account = NULL; + + if (parent_window) + info->parent_window = (GtkWindow *) g_object_ref (parent_window); + else + info->parent_window = NULL; + info->user_data = user_data; + info->callback = callback; + + tny_maemo_conic_device_connect_async (TNY_MAEMO_CONIC_DEVICE (device), NULL, + user_requested, on_conic_device_went_online, + info); + + /* We'll cleanup in on_conic_device_went_online */ + } + + /* The other code has no more reason to run. This is all that we can do for the + * caller (he should have given us a nice and clean account instance!). We + * can't do magic, we don't know what account he intends to bring online. So + * we'll just bring the device online (and await his false bug report). */ + + return; + } + + + /* Return if the account is already connected */ + + conn_status = tny_account_get_connection_status (account); + if (device_online && conn_status == TNY_CONNECTION_STATUS_CONNECTED) { + + /* We promise to instantly perform the callback, so ... */ + if (callback) { + callback (FALSE, NULL, parent_window, account, user_data); + } + + return; + } + + /* Else, we are in a state that requires that we go online before we + * call the caller's callback. */ + + info = g_slice_new0 (OnWentOnlineInfo); + + info->device = NULL; + info->iap = NULL; + info->account = TNY_ACCOUNT (g_object_ref (account)); + + if (parent_window) + info->parent_window = (GtkWindow *) g_object_ref (parent_window); + else + info->parent_window = NULL; + + /* So we'll put the callback away for later ... */ + + info->user_data = user_data; + info->callback = callback; + + if (!device_online) { + + /* If also the device is offline, then we connect both the device + * and the account */ + + tny_maemo_conic_device_connect_async (TNY_MAEMO_CONIC_DEVICE (device), NULL, + user_requested, on_conic_device_went_online, + info); + + } else { + + /* If the device is online, we'll just connect the account */ + + tny_camel_account_set_online (TNY_CAMEL_ACCOUNT (account), TRUE, + on_account_went_online, info); + } + + /* The info gets freed by on_account_went_online or on_conic_device_went_online + * in both situations, go look if you don't believe me! */ + + return; +} + +void +modest_platform_connect_if_remote_and_perform (GtkWindow *parent_window, + TnyFolderStore *folder_store, + ModestConnectedPerformer callback, + gpointer user_data) +{ + TnyAccount *account = NULL; + + if (!folder_store) { + /* We promise to instantly perform the callback, so ... */ + if (callback) { + callback (FALSE, NULL, parent_window, NULL, user_data); + } + return; + + /* Original comment: Maybe it is something local. */ + /* PVH's comment: maybe we should KNOW this in stead of assuming? */ + + } else if (TNY_IS_FOLDER (folder_store)) { + /* Get the folder's parent account: */ + account = tny_folder_get_account(TNY_FOLDER (folder_store)); + } else if (TNY_IS_ACCOUNT (folder_store)) { + /* Use the folder store as an account: */ + account = TNY_ACCOUNT (folder_store); + } + + if (tny_account_get_account_type (account) == TNY_ACCOUNT_TYPE_STORE) { + if (!TNY_IS_CAMEL_POP_STORE_ACCOUNT (account) && + !TNY_IS_CAMEL_IMAP_STORE_ACCOUNT (account)) { + + /* This IS a local account like a maildir account, which does not require + * a connection. (original comment had a vague assumption in its language + * usage. There's no assuming needed, this IS what it IS: a local account), */ + + /* We promise to instantly perform the callback, so ... */ + if (callback) { + callback (FALSE, NULL, parent_window, account, user_data); + } + + return; + } + } + + modest_platform_connect_and_perform (parent_window, account, callback, user_data); + + return; +}