diff options
author | Marius Kintel <marius@kintel.net> | 2013-12-01 16:36:50 (GMT) |
---|---|---|
committer | Marius Kintel <marius@kintel.net> | 2013-12-01 16:36:50 (GMT) |
commit | 89c21d07c46294e7c28f8852a89550b17d7a4402 (patch) | |
tree | e63eef1efa8ab7cbb19fc7b5a33c1e33af1c1931 /src/CGAL_Nef_polyhedron.cc | |
parent | f175bae46a8f15823780c5a9c89b11476acb3107 (diff) | |
parent | 791a49b9e8489818e41deae2b1d4ba2b6ff50e5f (diff) |
Merge pull request #554 from openscad/issue410x
Issue410x
Diffstat (limited to 'src/CGAL_Nef_polyhedron.cc')
-rw-r--r-- | src/CGAL_Nef_polyhedron.cc | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/src/CGAL_Nef_polyhedron.cc b/src/CGAL_Nef_polyhedron.cc index 440f4ed..49b9a53 100644 --- a/src/CGAL_Nef_polyhedron.cc +++ b/src/CGAL_Nef_polyhedron.cc @@ -96,13 +96,22 @@ PolySet *CGAL_Nef_polyhedron::convertToPolyset() } else if (this->dim == 3) { CGAL::Failure_behaviour old_behaviour = CGAL::set_error_behaviour(CGAL::THROW_EXCEPTION); + bool err = true; + std::string errmsg(""); + CGAL_Polyhedron P; try { - CGAL_Polyhedron P; - this->p3->convert_to_Polyhedron(P); - ps = createPolySetFromPolyhedron(P); + err = nefworkaround::convert_to_Polyhedron<CGAL_Kernel3>( *(this->p3), P ); + //this->p3->convert_to_Polyhedron(P); + } + catch (const CGAL::Failure_exception &e) { + err = true; + errmsg = std::string(e.what()); } - catch (const CGAL::Precondition_exception &e) { - PRINTB("CGAL error in CGAL_Nef_polyhedron::convertToPolyset(): %s", e.what()); + if (err) { + PRINT("ERROR: CGAL NefPolyhedron->Polyhedron conversion failed."); + if (errmsg!="") PRINTB("ERROR: %s",errmsg); + } else { + ps = createPolySetFromPolyhedron(P); } CGAL::set_error_behaviour(old_behaviour); } |