Skip to content

Commit

Permalink
Prevent leak of binary_partition in choose_chunkdivision (NanoComp#1603)
Browse files Browse the repository at this point in the history
  • Loading branch information
ahoenselaar authored Jun 10, 2021
1 parent a85dd3d commit d47509a
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions src/structure.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
#include <stdlib.h>
#include <math.h>
#include <string.h>
#include <memory>

#include "meep.hpp"
#include "meep_internals.hpp"
Expand Down Expand Up @@ -112,13 +113,13 @@ void structure::choose_chunkdivision(const grid_volume &thegv, int desired_num_c
a = gv.a;
dt = Courant / a;

binary_partition *my_bp = NULL;
if (!bp) my_bp = meep::choose_chunkdivision(gv, v, desired_num_chunks, s);
std::unique_ptr<binary_partition> my_bp;
if (!bp) my_bp.reset(meep::choose_chunkdivision(gv, v, desired_num_chunks, s));

// create the chunks:
std::vector<grid_volume> chunk_volumes;
std::vector<int> ids;
split_by_binarytree(gv, chunk_volumes, ids, (!bp) ? my_bp : bp);
split_by_binarytree(gv, chunk_volumes, ids, (!bp) ? my_bp.get() : bp);

// initialize effort volumes
num_effort_volumes = 1;
Expand Down

0 comments on commit d47509a

Please sign in to comment.