[evolution-exchange] Prevent using NULL in libical functions



commit e9562e1014c41b886e312e50216a29a4997d7b73
Author: Milan Crha <mcrha redhat com>
Date:   Mon Apr 27 12:22:31 2009 +0200

    Prevent using NULL in libical functions
    
    	** Fix for bug #577105
---
 ChangeLog                         |    8 ++++++++
 calendar/e-cal-backend-exchange.c |   21 +++++++++++++--------
 2 files changed, 21 insertions(+), 8 deletions(-)

diff --git a/ChangeLog b/ChangeLog
index 558cb94..7403f3a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2009-04-27  Milan Crha  <mcrha redhat com>
+
+	** Fix for bug #577105
+
+	* calendar/e-cal-backend-exchange.c: (save_object),
+	(e_cal_backend_exchange_modify_object),	(get_object),
+	(free_exchange_comp): Prevent using NULL in libical functions.
+
 2009-04-24  Milan Crha  <mcrha redhat com>
 
 	** Part of fix for bug #563954
diff --git a/calendar/e-cal-backend-exchange.c b/calendar/e-cal-backend-exchange.c
index 09630be..cdfda07 100644
--- a/calendar/e-cal-backend-exchange.c
+++ b/calendar/e-cal-backend-exchange.c
@@ -276,12 +276,16 @@ save_object (gpointer key, gpointer value, gpointer vcalcomp)
 	icalcomponent *icalcomp;
 	GList *l;
 
-	icalcomp = icalcomponent_new_clone (ecomp->icomp);
-	icalcomponent_add_component (vcalcomp, icalcomp);
+	if (ecomp->icomp) {
+		icalcomp = icalcomponent_new_clone (ecomp->icomp);
+		icalcomponent_add_component (vcalcomp, icalcomp);
+	}
 
 	for (l = ecomp->instances; l; l = l->next) {
-		icalcomp = icalcomponent_new_clone (l->data);
-		icalcomponent_add_component (vcalcomp, icalcomp);
+		if (l->data) {
+			icalcomp = icalcomponent_new_clone (l->data);
+			icalcomponent_add_component (vcalcomp, icalcomp);
+		}
 	}
 }
 
@@ -838,7 +842,8 @@ e_cal_backend_exchange_modify_object (ECalBackendExchange *cbex,
 		return FALSE;
 
 	if (mod == CALOBJ_MOD_ALL || icaltime_is_null_time (rid) || discard_detached) {
-		icalcomponent_free (ecomp->icomp);
+		if (ecomp->icomp)
+			icalcomponent_free (ecomp->icomp);
 		ecomp->icomp = icalcomponent_new_clone (comp);
 		if (discard_detached && !icaltime_is_null_time (rid))
 			discard_detached_instance (ecomp, rid);
@@ -1020,7 +1025,7 @@ get_object (ECalBackendSync *backend, EDataCal *cal,
 
 			*object = icalcomponent_as_ical_string_r (vcalcomp);
 			icalcomponent_free (vcalcomp);
-		} else {
+		} else if (ecomp->icomp) {
 			/* There are no detached instances. Send only the master object */
 			*object = icalcomponent_as_ical_string_r (ecomp->icomp);
 		}
@@ -1633,7 +1638,6 @@ check_change_type (gpointer key, gpointer value, gpointer data)
 	*/
 	if (!ecomp)
 		return;
-	icomp = ecomp->icomp;
 	l = ecomp->instances;
 	for (icomp = ecomp->icomp; l; icomp = l->data, l = l->next) {
 		if (!icomp)
@@ -2127,7 +2131,8 @@ free_exchange_comp (gpointer value)
 	g_free (ecomp->href);
 	g_free (ecomp->lastmod);
 
-	icalcomponent_free (ecomp->icomp);
+	if (ecomp->icomp)
+		icalcomponent_free (ecomp->icomp);
 
 	for (inst = ecomp->instances; inst; inst = inst->next)
 		icalcomponent_free (inst->data);



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]