aboutsummaryrefslogtreecommitdiffstats
path: root/smime/gui/e-cert-selector.c
diff options
context:
space:
mode:
Diffstat (limited to 'smime/gui/e-cert-selector.c')
-rw-r--r--smime/gui/e-cert-selector.c28
1 files changed, 15 insertions, 13 deletions
diff --git a/smime/gui/e-cert-selector.c b/smime/gui/e-cert-selector.c
index b3fcabdc43..9c64ebb37e 100644
--- a/smime/gui/e-cert-selector.c
+++ b/smime/gui/e-cert-selector.c
@@ -176,19 +176,21 @@ e_cert_selector_new(int type, const char *currentid)
certlist = CERT_FindUserCertsByUsage(CERT_GetDefaultCertDB(), usage, FALSE, TRUE, NULL);
ecs->priv->certlist = certlist;
- node = CERT_LIST_HEAD(certlist);
- while (!CERT_LIST_END(node, certlist)) {
- w = gtk_menu_item_new_with_label(node->cert->nickname);
- gtk_menu_shell_append((GtkMenuShell *)menu, w);
- gtk_widget_show(w);
-
- if (currentid != NULL
- && (strcmp(node->cert->nickname, currentid) == 0
- || strcmp(node->cert->emailAddr, currentid) == 0))
- active = n;
-
- n++;
- node = CERT_LIST_NEXT(node);
+ if (certlist != NULL) {
+ node = CERT_LIST_HEAD(certlist);
+ while (!CERT_LIST_END(node, certlist)) {
+ w = gtk_menu_item_new_with_label(node->cert->nickname);
+ gtk_menu_shell_append((GtkMenuShell *)menu, w);
+ gtk_widget_show(w);
+
+ if (currentid != NULL
+ && (strcmp(node->cert->nickname, currentid) == 0
+ || strcmp(node->cert->emailAddr, currentid) == 0))
+ active = n;
+
+ n++;
+ node = CERT_LIST_NEXT(node);
+ }
}
gtk_option_menu_set_menu((GtkOptionMenu *)p->menu, menu);