]> granicus.if.org Git - graphviz/commitdiff
pack pccomps: use cgraph wrappers for allocation
authorMatthew Fernandez <matthew.fernandez@gmail.com>
Wed, 21 Sep 2022 02:31:18 +0000 (19:31 -0700)
committerMatthew Fernandez <matthew.fernandez@gmail.com>
Thu, 22 Sep 2022 00:00:18 +0000 (17:00 -0700)
The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

lib/pack/ccomps.c

index 3cffd593750a842119e2a3a5f3c547493b832929..403897024d8b03891703520b2c3ece17b003a51d 100644 (file)
@@ -153,7 +153,6 @@ Agraph_t **pccomps(Agraph_t * g, int *ncc, char *pfx, bool *pinned)
     char *name;
     Agraph_t *out = NULL;
     Agnode_t *n;
-    Agraph_t **ccs;
     size_t len;
     size_t bnd = 10;
     bool pin = false;
@@ -166,7 +165,7 @@ Agraph_t **pccomps(Agraph_t * g, int *ncc, char *pfx, bool *pinned)
     }
     name = setPrefix (pfx, &len, buffer, SMALLBUF);
 
-    ccs = N_GNEW(bnd, Agraph_t *);
+    Agraph_t **ccs = gv_calloc(bnd, sizeof(Agraph_t*));
 
     initStk(&stk, insertFn, markFn);
     for (n = agfstnode(g); n; n = agnxtnode(g, n))
@@ -202,8 +201,8 @@ Agraph_t **pccomps(Agraph_t * g, int *ncc, char *pfx, bool *pinned)
            goto packerror;
        }
        if (c_cnt == bnd) {
+           ccs = gv_recalloc(ccs, bnd, bnd * 2, sizeof(Agraph_t*));
            bnd *= 2;
-           ccs = RALLOC(bnd, ccs, Agraph_t *);
        }
        ccs[c_cnt] = out;
        c_cnt++;
@@ -221,7 +220,7 @@ packerror:
        ccs = NULL;
     }
     else {
-       ccs = RALLOC(c_cnt, ccs, Agraph_t *);
+       ccs = gv_recalloc(ccs, bnd, c_cnt, sizeof(Agraph_t*));
        *ncc = (int) c_cnt;
        *pinned = pin;
     }