Fix leaks in MEANS command
authorJohn Darrington <john@darrington.wattle.id.au>
Mon, 13 Aug 2012 19:13:56 +0000 (21:13 +0200)
committerJohn Darrington <john@darrington.wattle.id.au>
Mon, 13 Aug 2012 19:13:56 +0000 (21:13 +0200)
src/language/stats/means.c
src/language/stats/oneway.c
src/math/categoricals.c
src/math/categoricals.h

index c67d75002f75c28716f9b52528d81fe344a4dd29..888a6a75836707f71564816ab6a15da2b8db8835 100644 (file)
@@ -1,4 +1,3 @@
-
 /* PSPP - a program for statistical analysis.
    Copyright (C) 2011, 2012 Free Software Foundation, Inc.
 
@@ -828,6 +827,22 @@ struct per_cat_data
   bool warn;
 };
 
+
+static void 
+destroy_n (const void *aux1 UNUSED, void *aux2, void *user_data)
+{
+  struct mtable *table = aux2;
+  int v;
+  struct per_cat_data *per_cat_data = user_data;
+  struct per_var_data *pvd = per_cat_data->pvd;
+
+  for (v = 0; v < table->n_dep_vars; ++v)
+    {
+      struct per_var_data *pp = &pvd[v];
+      moments1_destroy (pp->mom);
+    }
+}
+
 static void *
 create_n (const void *aux1, void *aux2)
 {
@@ -940,7 +955,7 @@ run_means (struct means *cmd, struct casereader *input,
   payload.create = create_n;
   payload.update = update_n;
   payload.calculate = calculate_n;
-  payload.destroy = NULL;
+  payload.destroy = destroy_n;
   
   for (t = 0; t < cmd->n_tables; ++t)
   {
index 13c1625be1fbc273a5b9325b86bab196be5c1353..735c6d441cc8eda8c956b70ba4d487c5a6d1e754 100644 (file)
@@ -637,7 +637,7 @@ makeit (const void *aux1, void *aux2 UNUSED)
 }
 
 static void 
-killit (const void *aux1 UNUSED, void *user_data)
+killit (const void *aux1 UNUSED, void *aux2 UNUSED, void *user_data)
 {
   struct descriptive_data *dd = user_data;
 
index 43edd048dc5324a8306133453096a0d079625708..b9748c759ed8f114969728743c84d3880ce033df 100644 (file)
@@ -254,7 +254,7 @@ categoricals_destroy (struct categoricals *cat)
       HMAP_FOR_EACH (iv, struct interaction_value, node, &cat->iap[i].ivmap)
        {
          if (cat->payload && cat->payload->destroy)
-           cat->payload->destroy (cat->aux1, iv->user_data);
+           cat->payload->destroy (cat->aux1, cat->aux2, iv->user_data);
          case_unref (iv->ccase);
        }
 
index 3fa6c36d906a3d337a54e33de5a6806608007acb..53e309ed62eaf76d9b7cc808a4443cae070ec3d1 100644 (file)
@@ -107,7 +107,7 @@ struct payload
   void* (*create)  (const void *aux1, void *aux2);
   void (*update)  (const void *aux1, void *aux2, void *user_data, const struct ccase *, double weight);
   void (*calculate) (const void *aux1, void *aux2, void *user_data);
-  void (*destroy) (const void *aux1, void *user_data);
+  void (*destroy) (const void *aux1, void *aux2, void *user_data);
 };