mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-06 18:26:22 +03:00
0029673: Exception while Face-Face intersection
If 2D-curves are requested in intersection result but they cannot be created (by some reason) then the full set of curves (3D and two 2D) is rejected from the intersection result.
This commit is contained in:
parent
a6ebe9fc7c
commit
e28b8c6218
@ -819,11 +819,14 @@ void IntTools_FaceFace::MakeCurve(const Standard_Integer Index,
|
||||
aCurve.SetTolerance(aTolC);
|
||||
}
|
||||
//
|
||||
aCurve.SetCurve(new Geom_TrimmedCurve(newc, fprm, lprm));
|
||||
if(myApprox1) {
|
||||
Handle (Geom2d_Curve) C2d;
|
||||
GeomInt_IntSS::BuildPCurves(fprm, lprm, Tolpc,
|
||||
myHS1->ChangeSurface().Surface(), newc, C2d);
|
||||
|
||||
if (C2d.IsNull())
|
||||
continue;
|
||||
|
||||
aCurve.SetFirstCurve2d(new Geom2d_TrimmedCurve(C2d, fprm, lprm));
|
||||
}
|
||||
//
|
||||
@ -831,6 +834,10 @@ void IntTools_FaceFace::MakeCurve(const Standard_Integer Index,
|
||||
Handle (Geom2d_Curve) C2d;
|
||||
GeomInt_IntSS::BuildPCurves(fprm, lprm, Tolpc,
|
||||
myHS2->ChangeSurface().Surface(), newc, C2d);
|
||||
|
||||
if (C2d.IsNull())
|
||||
continue;
|
||||
|
||||
aCurve.SetSecondCurve2d(new Geom2d_TrimmedCurve(C2d, fprm, lprm));
|
||||
}
|
||||
//
|
||||
|
17
tests/lowalgos/intss/bug29673
Normal file
17
tests/lowalgos/intss/bug29673
Normal file
@ -0,0 +1,17 @@
|
||||
puts "========"
|
||||
puts "0029673: Ex-ception while Face-Face intersection"
|
||||
puts "========"
|
||||
puts ""
|
||||
|
||||
restore [locate_data_file bug29673_f1.brep] f1
|
||||
restore [locate_data_file bug29673_f2.brep] f2
|
||||
|
||||
regexp {Tolerance Reached=+([-0-9.+eE]+)\n+([-0-9.+eE]+)} [bopcurves f1 f2 -2d] full Toler NbCurv
|
||||
|
||||
if {$Toler > 1.0e-7} {
|
||||
puts "Error: too big tolerance"
|
||||
}
|
||||
|
||||
if {$NbCurv != 1} {
|
||||
puts "Error: Please check NbCurves for intersector"
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user