diff options
author | Don Bright <hugh.m.bright@gmail.com> | 2013-12-14 23:20:35 (GMT) |
---|---|---|
committer | Don Bright <hugh.m.bright@gmail.com> | 2013-12-14 23:20:35 (GMT) |
commit | 0a2b7ca0d4d7fb1acda9996d69b25ff6b5495856 (patch) | |
tree | 465fb326c433297bb88182de7f215ff21925cf5f /src/CGAL_Nef_polyhedron.cc | |
parent | f175bae46a8f15823780c5a9c89b11476acb3107 (diff) |
FIXME leaking polyset by altering functions signatures
Diffstat (limited to 'src/CGAL_Nef_polyhedron.cc')
-rw-r--r-- | src/CGAL_Nef_polyhedron.cc | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/CGAL_Nef_polyhedron.cc b/src/CGAL_Nef_polyhedron.cc index 440f4ed..2d5bba5 100644 --- a/src/CGAL_Nef_polyhedron.cc +++ b/src/CGAL_Nef_polyhedron.cc @@ -97,11 +97,14 @@ PolySet *CGAL_Nef_polyhedron::convertToPolyset() else if (this->dim == 3) { CGAL::Failure_behaviour old_behaviour = CGAL::set_error_behaviour(CGAL::THROW_EXCEPTION); try { + ps = new PolySet(); CGAL_Polyhedron P; this->p3->convert_to_Polyhedron(P); - ps = createPolySetFromPolyhedron(P); + bool err = createPolySetFromPolyhedron(P, ps); + if (err) delete ps; } catch (const CGAL::Precondition_exception &e) { + delete ps; PRINTB("CGAL error in CGAL_Nef_polyhedron::convertToPolyset(): %s", e.what()); } CGAL::set_error_behaviour(old_behaviour); |