set makeprg=make\ test
"set tw=100
-au FileType valgrind syn match gritsFile "\v<(grits-\w+|roam|elev|env|map|sat|test|radar)\.c>" containedin=valgrindSrc
+au FileType valgrind syn match gritsFile "\v<(grits-\w+|roam|elev|env|map|sat|test|radar|alert)\.c>" containedin=valgrindSrc
au FileType valgrind hi link gritsFile Error
--num-callers=50 \
--suppressions=gtk.suppression \
--suppressions=/usr/lib/valgrind/default.supp \
- ./grits-test \
+ .libs/grits-test \
2> valgrind.out
/* Close file */
fclose(fp);
- if (path != part && SOUP_STATUS_IS_SUCCESSFUL(message->status_code)) {
- g_rename(part, path);
+ if (path != part) {
+ if (SOUP_STATUS_IS_SUCCESSFUL(message->status_code))
+ g_rename(part, path);
g_free(part);
}
/* Finished */
- if (message->status_code == SOUP_STATUS_CANCELLED) {
+ guint status = message->status_code;
+ g_object_unref(message);
+ if (status == SOUP_STATUS_CANCELLED) {
return NULL;
- } else if (message->status_code == SOUP_STATUS_REQUESTED_RANGE_NOT_SATISFIABLE) {
+ } else if (status == SOUP_STATUS_REQUESTED_RANGE_NOT_SATISFIABLE) {
/* Range unsatisfiable, file already complete */
- } else if (!SOUP_STATUS_IS_SUCCESSFUL(message->status_code)) {
+ } else if (!SOUP_STATUS_IS_SUCCESSFUL(status)) {
g_warning("GritsHttp: done_cb - error copying file, status=%d\n"
"\tsrc=%s\n"
"\tdst=%s",
- message->status_code, uri, path);
+ status, uri, path);
return NULL;
}
}
-
/* TODO: free everything.. */
return path;
}
gdk_threads_leave();
gdk_display_close(gdk_display_get_default());
+
+ prefs = NULL;
+ plugins = NULL;
+ viewer = NULL;
+ window = vbox = config = NULL;
return 0;
}
fun:g_module_symbol
fun:g_module_open
}
+{
+ g_class_ref__leak
+ Memcheck:Leak
+ fun:malloc
+ fun:g_malloc
+ fun:g_memdup
+ fun:type_iface_vtable_base_init_Wm
+ fun:g_type_class_ref
+}
# GTK+
{
glPopAttrib();
}
+static gboolean grits_poly_delete(gpointer list)
+{
+ glDeleteLists((guint)list, 1);
+ return FALSE;
+}
+
/**
* grits_poly_new:
* @points: TODO
return poly;
}
+static void _free_points(gdouble (**points)[3])
+{
+ for (int i = 0; points[i]; i++)
+ g_free(points[i]);
+ g_free(points);
+}
+
GritsPoly *grits_poly_parse(const gchar *str,
const gchar *poly_sep, const gchar *point_sep, const gchar *coord_sep)
{
polys[pi] = coords;
g_strfreev(scoords);
}
+ g_strfreev(spolys);
/* Create GritsPoly */
GritsPoly *poly = grits_poly_new(polys);
GRITS_OBJECT(poly)->center.lon = lon_avg(bounds.e, bounds.w);
GRITS_OBJECT(poly)->center.elev = 0;
GRITS_OBJECT(poly)->skip = GRITS_SKIP_CENTER;
+ g_object_weak_ref(G_OBJECT(poly), (GWeakNotify)_free_points, polys);
return poly;
}
static void grits_poly_finalize(GObject *_poly)
{
- g_debug("GritsPoly: finalize");
+ //g_debug("GritsPoly: finalize");
GritsPoly *poly = GRITS_POLY(_poly);
- (void)poly;
- // TODO: free points
+ if (poly->list[0]) g_idle_add(grits_poly_delete, (gpointer)poly->list[0]);
+ if (poly->list[1]) g_idle_add(grits_poly_delete, (gpointer)poly->list[1]);
}
static void grits_poly_class_init(GritsPolyClass *klass)