mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0023903: Invalid result of pipe operation on closed path
Add test case for this fix
This commit is contained in:
parent
244587f413
commit
cf3327f417
@ -849,15 +849,9 @@ TopoDS_Shape BRepFill_Pipe::ShareFaces
|
||||
anExp.Init(myFaces->Value(ii, jj), TopAbs_EDGE);
|
||||
|
||||
for (; anExp.More(); anExp.Next()) {
|
||||
if (aMapBndEdgeIndex.IsBound(anExp.Current())) {
|
||||
// This is not boundary edge. Remove it.
|
||||
aMapBndEdgeIndex.UnBind(anExp.Current());
|
||||
} else {
|
||||
// Add boundary edge.
|
||||
aMapBndEdgeIndex.Bind(anExp.Current(), ii);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Check if edges of newly created faces are shared with old ones.
|
||||
for (ii = theInitialFacesLen + 1; ii <= myFaces->ColLength(); ii++) {
|
||||
|
@ -2065,7 +2065,6 @@ BRepFill_Sweep::BRepFill_Sweep(const Handle(BRepFill_SectionLaw)& Section,
|
||||
Standard_Boolean exuv, singu, singv;
|
||||
Handle(Geom_Surface) S;
|
||||
|
||||
if (! vclose) {
|
||||
// (2.0) return preexisting Edges and vertices
|
||||
TopoDS_Edge E;
|
||||
if (! FirstShape.IsNull() && (IFirst==1)) {
|
||||
@ -2203,7 +2202,6 @@ BRepFill_Sweep::BRepFill_Sweep(const Handle(BRepFill_SectionLaw)& Section,
|
||||
mySec->VertexTol(isec-1, Vi(NbPath+1)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ---------- Creation of Vertex and edge ------------
|
||||
|
24
tests/bugs/modalg_5/bug23903
Executable file
24
tests/bugs/modalg_5/bug23903
Executable file
@ -0,0 +1,24 @@
|
||||
puts "============"
|
||||
puts "OCC23903"
|
||||
puts "============"
|
||||
puts ""
|
||||
#######################################################################
|
||||
# Invalid result of pipe operation on closed path
|
||||
#######################################################################
|
||||
|
||||
restore [locate_data_file bug23903_base.brep] sh
|
||||
restore [locate_data_file bug23903_path.brep] w
|
||||
|
||||
pipe result w sh
|
||||
|
||||
set nb_v_good 2
|
||||
set nb_e_good 5
|
||||
set nb_w_good 3
|
||||
set nb_f_good 3
|
||||
set nb_sh_good 2
|
||||
set nb_sol_good 2
|
||||
set nb_compsol_good 0
|
||||
set nb_compound_good 1
|
||||
set nb_shape_good 18
|
||||
|
||||
set 2dviewer 1
|
Loading…
x
Reference in New Issue
Block a user