2c1eff165c8247afe190f47c6d1a4a31caed7fd4
[occt.git] / src / IntSurf / IntSurf_LineOn2S.cxx
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
19 #include <IntSurf_LineOn2S.ixx>
20
21
22 IntSurf_LineOn2S::IntSurf_LineOn2S ()
23 {}
24
25
26 Handle(IntSurf_LineOn2S) IntSurf_LineOn2S::Split (const Standard_Integer Index)
27 {
28   IntSurf_SequenceOfPntOn2S SS;
29   mySeq.Split(Index,SS);
30   Handle(IntSurf_LineOn2S) NS = new IntSurf_LineOn2S ();
31   Standard_Integer i;
32   Standard_Integer leng = SS.Length();
33   for (i=1; i<=leng; i++) {
34     NS->Add(SS(i));
35   }
36   return NS;
37 }
38
39
40 void IntSurf_LineOn2S::InsertBefore(const Standard_Integer index, const IntSurf_PntOn2S& P) { 
41   if(index>mySeq.Length()) { 
42     mySeq.Append(P);
43   }
44   else { 
45     mySeq.InsertBefore(index,P);
46   }
47 }
48
49 void IntSurf_LineOn2S::RemovePoint(const Standard_Integer index) { 
50   mySeq.Remove(index);
51 }