diff options
| author | Ken VanDine <ken.vandine@canonical.com> | 2011-09-28 11:52:31 -0400 | 
|---|---|---|
| committer | Ken VanDine <ken.vandine@canonical.com> | 2011-09-28 11:52:31 -0400 | 
| commit | f4999fe698f8c6bc7d5cccf642f82465b6a08d18 (patch) | |
| tree | ba911006d3b6b381062569a444e058db1afe3e88 /src | |
| parent | 256899d059d635d64f43d97d46bf0e559116854c (diff) | |
| parent | 749e1fca116849bc9e8cde0f3ac34ff98ce1c199 (diff) | |
| download | ayatana-indicator-application-f4999fe698f8c6bc7d5cccf642f82465b6a08d18.tar.gz ayatana-indicator-application-f4999fe698f8c6bc7d5cccf642f82465b6a08d18.tar.bz2 ayatana-indicator-application-f4999fe698f8c6bc7d5cccf642f82465b6a08d18.zip | |
* New upstream release.
  * Fix memory leak (LP: #829961)
Diffstat (limited to 'src')
| -rw-r--r-- | src/application-service-appstore.c | 33 | 
1 files changed, 33 insertions, 0 deletions
| diff --git a/src/application-service-appstore.c b/src/application-service-appstore.c index d59cfe9..edc517f 100644 --- a/src/application-service-appstore.c +++ b/src/application-service-appstore.c @@ -508,6 +508,14 @@ got_all_properties (GObject * source_object, GAsyncResult * res,  	else {  		app->validated = TRUE; +		/* It is possible we're coming through a second time and +		   getting the properties.  So we need to ensure we don't +		   already have them stored */ +		g_free(app->id); +		g_free(app->category); +		g_free(app->icon); +		g_free(app->menu); +  		app->id = g_variant_dup_string(id, NULL);  		app->category = g_variant_dup_string(category, NULL);  		app->status = string_to_status(g_variant_get_string(status, NULL)); @@ -516,10 +524,30 @@ got_all_properties (GObject * source_object, GAsyncResult * res,  		/* Now the optional properties */ +		g_free(app->icon_desc); +		if (icon_desc != NULL) { +			app->icon_desc = g_variant_dup_string(icon_desc, NULL); +		} +		else { +			app->icon_desc = g_strdup(""); +		} + +		g_free(app->aicon);  		if (aicon_name != NULL) {  			app->aicon = g_variant_dup_string(aicon_name, NULL); +		} else { +			app->aicon = g_strdup(""); +		} + +		g_free(app->aicon_desc); +		if (aicon_desc != NULL) { +			app->aicon_desc = g_variant_dup_string(aicon_desc, NULL); +		} +		else { +			app->aicon_desc = g_strdup("");  		} +		g_free(app->icon_theme_path);  		if (icon_theme_path != NULL) {  			app->icon_theme_path = g_variant_dup_string(icon_theme_path, NULL);  		} else { @@ -539,12 +567,14 @@ got_all_properties (GObject * source_object, GAsyncResult * res,  		g_debug("'%s' ordering index is '%X'", app->id, app->ordering_index);  		app->appstore->priv->applications = g_list_sort_with_data(app->appstore->priv->applications, app_sort_func, NULL); +		g_free(app->label);  		if (label != NULL) {  			app->label = g_variant_dup_string(label, NULL);  		} else {  			app->label = g_strdup("");  		} +		g_free(app->guide);  		if (guide != NULL) {  			app->guide = g_variant_dup_string(guide, NULL);  		} else { @@ -736,6 +766,9 @@ application_free (Application * app)  	if (app->icon_desc != NULL) {  		g_free(app->icon_desc);  	} +	if (app->aicon != NULL) { +		g_free(app->aicon); +	}  	if (app->aicon_desc != NULL) {  		g_free(app->aicon_desc);  	} | 
