diff options
author | Thomas White <taw@physics.org> | 2021-09-07 16:47:06 +0200 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2021-09-07 16:47:06 +0200 |
commit | c2e7ca233c0955cc5c326b1a60a548a20dcbd739 (patch) | |
tree | 66d9a1e576c569d8a1d91eea9c5669066d238c9f | |
parent | 2e86c91ddf1c976b6f5ad3ab8a5ef5b2cd8bacb8 (diff) |
partialator write_split: Handle zero crystals
The variable-sized array can't have zero size, so we need to check.
-rw-r--r-- | src/partialator.c | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/src/partialator.c b/src/partialator.c index 7d2cfd7b..20d46abb 100644 --- a/src/partialator.c +++ b/src/partialator.c @@ -175,12 +175,24 @@ static void write_split(Crystal **crystals, int n_crystals, const char *outfile, { char tmp[1024]; RefList *split; - Crystal *crystals1[n_crystals]; - Crystal *crystals2[n_crystals]; + Crystal **crystals1; + Crystal **crystals2; int n_crystals1 = 0; int n_crystals2 = 0; int i; + if ( n_crystals == 0 ) { + ERROR("No crystals for split!\n"); + return; + } + + crystals1 = malloc(n_crystals * sizeof(Crystal *)); + if ( crystals1 == NULL ) return; + + crystals2 = malloc(n_crystals * sizeof(Crystal *)); + if ( crystals2 == NULL ) return; + + for ( i=0; i<n_crystals; i++ ) { if ( i % 2 ) { crystals1[n_crystals1] = crystals[i]; @@ -196,6 +208,8 @@ static void write_split(Crystal **crystals, int n_crystals, const char *outfile, if ( split == NULL ) { ERROR("Not enough crystals for two way split!\n"); + free(crystals1); + free(crystals2); return; } @@ -210,6 +224,9 @@ static void write_split(Crystal **crystals, int n_crystals, const char *outfile, write_reflist_2(tmp, split, sym); free_contribs(split); reflist_free(split); + + free(crystals1); + free(crystals2); } |