// Created on: 1992-05-07 // Created by: Jacques GOUSSARD // Copyright (c) 1992-1999 Matra Datavision // Copyright (c) 1999-2014 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #include #include #include inline Standard_Boolean IntPatch_ImpImpIntersection::IsDone () const { return (GetStatus() != IntStatus_Fail); } inline IntPatch_ImpImpIntersection::IntStatus IntPatch_ImpImpIntersection::GetStatus() const { return myDone; } inline Standard_Boolean IntPatch_ImpImpIntersection::IsEmpty () const { if (!IsDone ()) { throw StdFail_NotDone(); } return empt; } inline Standard_Boolean IntPatch_ImpImpIntersection::TangentFaces () const { if (!IsDone ()) { throw StdFail_NotDone(); } return tgte; } inline Standard_Boolean IntPatch_ImpImpIntersection::OppositeFaces () const { if (!IsDone ()) { throw StdFail_NotDone(); } if (!tgte) {throw Standard_DomainError();} return oppo; } inline Standard_Integer IntPatch_ImpImpIntersection::NbPnts () const { if (!IsDone ()) { throw StdFail_NotDone(); } return spnt.Length(); } inline const IntPatch_Point& IntPatch_ImpImpIntersection::Point (const Standard_Integer Index) const { if (!IsDone ()) { throw StdFail_NotDone(); } return spnt(Index); } inline Standard_Integer IntPatch_ImpImpIntersection::NbLines () const { if (!IsDone ()) { throw StdFail_NotDone(); } return slin.Length(); } inline const Handle(IntPatch_Line)& IntPatch_ImpImpIntersection::Line (const Standard_Integer Index) const { if (!IsDone ()) { throw StdFail_NotDone(); } return slin(Index); }