0023948: Wrong intersection between a surface of revolution and a plane.
[occt.git] / src / IntAna2d / IntAna2d_AnaIntersection.lxx
1 // Copyright (c) 1995-1999 Matra Datavision
2 // Copyright (c) 1999-2014 OPEN CASCADE SAS
3 //
4 // This file is part of Open CASCADE Technology software library.
5 //
6 // This library is free software; you can redistribute it and/or modify it under
7 // the terms of the GNU Lesser General Public License version 2.1 as published
8 // by the Free Software Foundation, with special exception defined in the file
9 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
10 // distribution for complete text of the license and disclaimer of any warranty.
11 //
12 // Alternatively, this file may be used under the terms of Open CASCADE
13 // commercial license or contractual agreement.
14
15 #include <StdFail_NotDone.hxx>
16 #include <Standard_OutOfRange.hxx>
17
18 inline Standard_Boolean IntAna2d_AnaIntersection::IsDone () const {
19   return done;
20 }
21
22 inline Standard_Boolean IntAna2d_AnaIntersection::IsEmpty () const {
23   
24   if (!done) {
25     StdFail_NotDone::Raise();
26   }
27   return ((nbp==0)&&(!iden));
28 }
29
30 inline Standard_Boolean IntAna2d_AnaIntersection::IdenticalElements () const {
31   
32   if (!done) {
33     StdFail_NotDone::Raise();
34   }
35   return iden ;
36 }
37
38 inline Standard_Boolean IntAna2d_AnaIntersection::ParallelElements () const {
39   
40   if (!done) {
41     StdFail_NotDone::Raise();
42   }
43   return para ;
44 }
45
46 inline Standard_Integer IntAna2d_AnaIntersection::NbPoints () const {
47   
48   if (!done) {
49     StdFail_NotDone::Raise();
50   }
51   return nbp ;
52 }
53
54 inline const IntAna2d_IntPoint& IntAna2d_AnaIntersection::Point (const Standard_Integer N) const {
55   
56   if (!done) {
57     StdFail_NotDone::Raise();
58     return lpnt[0];
59   }
60   else {
61     if ((N<=0)||(N>nbp)) {
62       Standard_OutOfRange::Raise();
63       return lpnt[0];
64     }
65     else {
66       return lpnt[N-1];
67     }
68   }
69 }
70