0024157: Parallelization of assembly part of BO
[occt.git] / src / GCPnts / GCPnts_UniformDeflection.cxx
CommitLineData
b311480e 1// Copyright (c) 1995-1999 Matra Datavision
2// Copyright (c) 1999-2012 OPEN CASCADE SAS
3//
4// The content of this file is subject to the Open CASCADE Technology Public
5// License Version 6.5 (the "License"). You may not use the content of this file
6// except in compliance with the License. Please obtain a copy of the License
7// at http://www.opencascade.org and read it completely before using this file.
8//
9// The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
10// main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
11//
12// The Original Code and all software distributed under the License is
13// distributed on an "AS IS" basis, without warranty of any kind, and the
14// Initial Developer hereby disclaims all such warranties, including without
15// limitation, any warranties of merchantability, fitness for a particular
16// purpose or non-infringement. Please see the License for the specific terms
17// and conditions governing the rights and limitations under the License.
18
7fd59977 19#include <GCPnts_UniformDeflection.ixx>
20#include <StdFail_NotDone.hxx>
21#include <Standard_DomainError.hxx>
22#include <Standard_OutOfRange.hxx>
23#include <Standard_ConstructionError.hxx>
24#include <Standard_NotImplemented.hxx>
25#include <gp_Pnt2d.hxx>
7fd59977 26// mask the return of a Adaptor2d_Curve2d as a gp_Pnt
7fd59977 27static gp_Pnt Value(const Adaptor3d_Curve & C,
28 const Standard_Real Parameter)
29{
30 return C.Value(Parameter) ;
31}
32static gp_Pnt Value(const Adaptor2d_Curve2d & C,
33 const Standard_Real Parameter)
34{
35 gp_Pnt aPoint ;
36 gp_Pnt2d a2dPoint =
37 C.Value(Parameter) ;
38 aPoint.SetX ( a2dPoint.X()) ;
39 aPoint.SetY ( a2dPoint.Y()) ;
40 aPoint.SetZ ( 0.0e0) ;
41 return aPoint ;
42}
43//=======================================================================
44//function : Value
45//purpose :
46//=======================================================================
47
48gp_Pnt GCPnts_UniformDeflection::Value
49 (const Standard_Integer Index) const
50{
51 StdFail_NotDone_Raise_if(!myDone,
52 "GCPnts_UniformAbscissa::Parameter()");
53 return myPoints.Value(Index) ;
54}
55//=======================================================================
56//function : GCPnts_UniformDeflection
57//purpose :
58//=======================================================================
59
60GCPnts_UniformDeflection::GCPnts_UniformDeflection ()
61:myDone(Standard_False)
62{
63}
64
65#include <Geom_BezierCurve.hxx>
66#include <Geom_BSplineCurve.hxx>
67#define TheCurve Adaptor3d_Curve
68#define Handle_TheBezierCurve Handle(Geom_BezierCurve)
69#define Handle_TheBSplineCurve Handle(Geom_BSplineCurve)
70#include <GCPnts_UniformDeflection.gxx>
71#undef TheCurve
72#undef Handle_TheBezierCurve
73#undef Handle_TheBSplineCurve
74
75#include <Geom2d_BezierCurve.hxx>
76#include <Geom2d_BSplineCurve.hxx>
77#define TheCurve Adaptor2d_Curve2d
78#define Handle_TheBezierCurve Handle(Geom2d_BezierCurve)
79#define Handle_TheBSplineCurve Handle(Geom2d_BSplineCurve)
80#include <GCPnts_UniformDeflection.gxx>
81#undef TheCurve
82#undef Handle_TheBezierCurve
83#undef Handle_TheBSplineCurve
84
85
86
87
88
89