Skip to content

Commit

Permalink
Merge pull request #44718 from hoontee/fix-44713
Browse files Browse the repository at this point in the history
Properly handle empty CSGShapes
  • Loading branch information
akien-mga authored Dec 27, 2020
2 parents 1f7d6ba + 24a6aac commit d55e335
Showing 1 changed file with 11 additions and 11 deletions.
22 changes: 11 additions & 11 deletions modules/csg/csg_shape.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -701,7 +701,7 @@ CSGPrimitive3D::CSGPrimitive3D() {

CSGBrush *CSGMesh3D::_build_brush() {
if (!mesh.is_valid()) {
return nullptr;
return memnew(CSGBrush);
}

Vector<Vector3> vertices;
Expand All @@ -719,7 +719,7 @@ CSGBrush *CSGMesh3D::_build_brush() {

if (arrays.size() == 0) {
_make_dirty();
ERR_FAIL_COND_V(arrays.size() == 0, nullptr);
ERR_FAIL_COND_V(arrays.size() == 0, memnew(CSGBrush));
}

Vector<Vector3> avertices = arrays[Mesh::ARRAY_VERTEX];
Expand Down Expand Up @@ -840,7 +840,7 @@ CSGBrush *CSGMesh3D::_build_brush() {
}

if (vertices.size() == 0) {
return nullptr;
return memnew(CSGBrush);
}

return _create_brush_from_arrays(vertices, uvs, smooth, materials);
Expand Down Expand Up @@ -1502,7 +1502,7 @@ CSGBrush *CSGTorus3D::_build_brush() {
float max_radius = outer_radius;

if (min_radius == max_radius) {
return nullptr; //sorry, can't
return memnew(CSGBrush); //sorry, can't
}

if (min_radius > max_radius) {
Expand Down Expand Up @@ -1721,7 +1721,7 @@ CSGBrush *CSGPolygon3D::_build_brush() {
// set our bounding box

if (polygon.size() < 3) {
return nullptr;
return memnew(CSGBrush);
}

Vector<Point2> final_polygon = polygon;
Expand All @@ -1733,7 +1733,7 @@ CSGBrush *CSGPolygon3D::_build_brush() {
Vector<int> triangles = Geometry2D::triangulate_polygon(final_polygon);

if (triangles.size() < 3) {
return nullptr;
return memnew(CSGBrush);
}

Path3D *path = nullptr;
Expand Down Expand Up @@ -1767,15 +1767,15 @@ CSGBrush *CSGPolygon3D::_build_brush() {

if (mode == MODE_PATH) {
if (!has_node(path_node)) {
return nullptr;
return memnew(CSGBrush);
}
Node *n = get_node(path_node);
if (!n) {
return nullptr;
return memnew(CSGBrush);
}
path = Object::cast_to<Path3D>(n);
if (!path) {
return nullptr;
return memnew(CSGBrush);
}

if (path != path_cache) {
Expand All @@ -1793,10 +1793,10 @@ CSGBrush *CSGPolygon3D::_build_brush() {
}
curve = path->get_curve();
if (curve.is_null()) {
return nullptr;
return memnew(CSGBrush);
}
if (curve->get_baked_length() <= 0) {
return nullptr;
return memnew(CSGBrush);
}
}
CSGBrush *brush = memnew(CSGBrush);
Expand Down

0 comments on commit d55e335

Please sign in to comment.