HeeksObj* CreateExtrusionOrRevolution(std::list<HeeksObj*> list, double height_or_angle, bool solid_if_possible, bool revolution_not_extrusion, double taper_angle_for_extrusion, bool add_new_objects) { std::list<TopoDS_Shape> faces_or_wires; ConvertToFaceOrWire(list, faces_or_wires, (fabs(taper_angle_for_extrusion) <= 0.0000001) && solid_if_possible); std::list<TopoDS_Shape> new_shapes; gp_Trsf trsf = wxGetApp().GetDrawMatrix(false); if(revolution_not_extrusion) { CreateRevolutions(faces_or_wires, new_shapes, gp_Ax1(gp_Pnt(0, 0, 0).Transformed(trsf), gp_Vec(1, 0, 0).Transformed(trsf)), height_or_angle); } else { CreateExtrusions(faces_or_wires, new_shapes, gp_Vec(0, 0, height_or_angle).Transformed(trsf), taper_angle_for_extrusion, solid_if_possible); } HeeksObj* new_object = 0; if(new_shapes.size() > 0) { for(std::list<TopoDS_Shape>::iterator It = new_shapes.begin(); It != new_shapes.end(); It++){ TopoDS_Shape& shape = *It; new_object = CShape::MakeObject(shape, revolution_not_extrusion ? _("Revolved Solid") : _("Extruded Solid"), SOLID_TYPE_UNKNOWN, wxGetApp().current_color, 1.0f); if(add_new_objects) wxGetApp().AddUndoably(new_object, NULL, NULL); else break; } } for(std::list<TopoDS_Shape>::iterator It = faces_or_wires.begin(); It != faces_or_wires.end(); It++) { TopoDS_Shape shape = *It; shape.Free(); } return new_object; }