0024023: Revamp the OCCT Handle -- general
[occt.git] / src / RWHeaderSection / RWHeaderSection_GeneralModule.cxx
1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
2 //
3 // This file is part of Open CASCADE Technology software library.
4 //
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
10 //
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
13
14 #include <RWHeaderSection_GeneralModule.ixx>
15
16 #include <Interface_Macros.hxx>
17
18 #include <Interface_GeneralLib.hxx>
19
20 #include <Interface_EntityIterator.hxx>
21
22 #include <HeaderSection.hxx>
23
24 #include <RWHeaderSection.hxx>
25
26 #include <Interface_HArray1OfHAsciiString.hxx>
27 #include <TCollection_HAsciiString.hxx>
28
29
30 #include <HeaderSection_FileName.hxx>
31 #include <HeaderSection_FileDescription.hxx>
32 #include <HeaderSection_FileSchema.hxx>
33 #include <HeaderSection_Protocol.hxx>
34
35 #include <StepData_UndefinedEntity.hxx>
36 #include <Interface_Macros.hxx>
37
38
39 RWHeaderSection_GeneralModule::RWHeaderSection_GeneralModule ()
40
41   Interface_GeneralLib::SetGlobal(this, HeaderSection::Protocol());
42 }
43
44 void RWHeaderSection_GeneralModule::FillSharedCase(const Standard_Integer CN, const Handle(Standard_Transient)& ent, Interface_EntityIterator& iter) const
45 {
46   if (CN != 4) return;
47
48   DeclareAndCast(StepData_UndefinedEntity,undf,ent);
49   undf->FillShared (iter);
50
51 }
52
53
54 void RWHeaderSection_GeneralModule::CheckCase(const Standard_Integer,
55                                               const Handle(Standard_Transient)&,
56                                               const Interface_ShareTool&,
57                                               Handle(Interface_Check)&) const
58 {
59 }
60
61
62 void RWHeaderSection_GeneralModule::CopyCase(const Standard_Integer CN, const Handle(Standard_Transient)& entfrom, const Handle(Standard_Transient)& entto, Interface_CopyTool& TC) const
63 {
64 //   ajout manuel
65   switch (CN) {
66
67     case 1 : {
68       Standard_Integer i;
69       DeclareAndCast(HeaderSection_FileName,enfr,entfrom);
70       DeclareAndCast(HeaderSection_FileName,ento,entto);
71       Handle(TCollection_HAsciiString) name =
72         new TCollection_HAsciiString (enfr->Name());
73       Handle(TCollection_HAsciiString) time =
74         new TCollection_HAsciiString (enfr->TimeStamp());
75       Standard_Integer nba = enfr->NbAuthor();
76       Handle(Interface_HArray1OfHAsciiString) auth =
77         new Interface_HArray1OfHAsciiString (1,nba);
78       for (i = 1; i <= nba; i ++) auth->SetValue
79         (i, new TCollection_HAsciiString (enfr->AuthorValue(i)) );
80       Standard_Integer nbo = enfr->NbOrganization();
81       Handle(Interface_HArray1OfHAsciiString) orga =
82         new Interface_HArray1OfHAsciiString (1,nbo);
83       for (i = 1; i <= nbo; i ++) orga->SetValue
84         (i, new TCollection_HAsciiString (enfr->OrganizationValue(i)) );
85       Handle(TCollection_HAsciiString) prep =
86         new TCollection_HAsciiString (enfr->PreprocessorVersion());
87       Handle(TCollection_HAsciiString) orig =
88         new TCollection_HAsciiString (enfr->OriginatingSystem());
89       Handle(TCollection_HAsciiString) autr =
90         new TCollection_HAsciiString (enfr->Authorisation());
91       ento->Init (name,time,auth,orga,prep,orig,autr);
92     }
93     break;
94
95     case 2 : {
96       Standard_Integer i;
97       DeclareAndCast(HeaderSection_FileDescription,enfr,entfrom);
98       DeclareAndCast(HeaderSection_FileDescription,ento,entto);
99       Standard_Integer nbd = enfr->NbDescription();
100       Handle(Interface_HArray1OfHAsciiString) desc =
101         new Interface_HArray1OfHAsciiString (1,nbd);
102       for (i = 1; i <= nbd; i ++) desc->SetValue
103         (i, new TCollection_HAsciiString (enfr->DescriptionValue(i)) );
104       Handle(TCollection_HAsciiString) impl =
105         new TCollection_HAsciiString (enfr->ImplementationLevel());
106       ento->Init (desc,impl);
107     }
108     break;
109
110     case 3 : {
111       Standard_Integer i;
112       DeclareAndCast(HeaderSection_FileSchema,enfr,entfrom);
113       DeclareAndCast(HeaderSection_FileSchema,ento,entto);
114       Standard_Integer nbs = enfr->NbSchemaIdentifiers();
115       Handle(Interface_HArray1OfHAsciiString) sche =
116         new Interface_HArray1OfHAsciiString (1,nbs);
117       for (i = 1; i <= nbs; i ++) sche->SetValue
118         (i, new TCollection_HAsciiString (enfr->SchemaIdentifiersValue(i)) );
119       ento->Init (sche);
120     }
121     break;
122
123     case 4 : {
124       DeclareAndCast(StepData_UndefinedEntity,undfrom,entfrom);
125       DeclareAndCast(StepData_UndefinedEntity,undto,entto);
126       undto->GetFromAnother(undfrom,TC);  //  On pourrait rapatrier cela
127     }
128     break;
129
130     default : break;
131   }
132 }
133         // --- Construction of empty class ---
134
135 Standard_Boolean RWHeaderSection_GeneralModule::NewVoid
136         (const Standard_Integer CN, Handle(Standard_Transient)& ent) const
137 {
138         if (CN == 0) return Standard_False;
139         switch (CN) {
140           case 1 : 
141             ent = new HeaderSection_FileName;
142             break;
143           case 2 : 
144             ent = new HeaderSection_FileDescription;
145             break;
146           case 3 : 
147             ent = new HeaderSection_FileSchema;
148             break;
149           case 4 : 
150             ent = new StepData_UndefinedEntity;
151             break;
152           default : return Standard_False;
153         }
154
155 return Standard_True;
156 }
157