0024927: Getting rid of "Persistent" functionality -- Code
[occt.git] / src / MDataStd / MDataStd_NamedDataRetrievalDriver.cxx
1 // Created on: 2007-06-27
2 // Created by: Sergey ZARITCHNY
3 // Copyright (c) 2007-2014 OPEN CASCADE SAS
4 //
5 // This file is part of Open CASCADE Technology software library.
6 //
7 // This library is free software; you can redistribute it and/or modify it under
8 // the terms of the GNU Lesser General Public License version 2.1 as published
9 // by the Free Software Foundation, with special exception defined in the file
10 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
11 // distribution for complete text of the license and disclaimer of any warranty.
12 //
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
15
16 #include <MDataStd_NamedDataRetrievalDriver.ixx>
17 #include <PDataStd_NamedData.hxx>
18 #include <TDataStd_NamedData.hxx>
19 #include <MDataStd.hxx>
20 #include <CDM_MessageDriver.hxx>
21 #include <PCollection_HExtendedString.hxx>
22 #include <TColStd_DataMapOfStringInteger.hxx>
23 #include <TDataStd_DataMapOfStringReal.hxx>
24 #include <TDataStd_DataMapOfStringByte.hxx>
25 #include <TDataStd_DataMapOfStringString.hxx>
26 #include <TDataStd_DataMapOfStringHArray1OfInteger.hxx>
27 #include <TDataStd_DataMapOfStringHArray1OfReal.hxx>
28 #include <TColStd_HArray1OfInteger.hxx>
29 #include <TColStd_HArray1OfReal.hxx>
30 #include <PColStd_HArray1OfInteger.hxx>
31 #include <PColStd_HArray1OfReal.hxx>
32
33 //=======================================================================
34 //function : MDataStd_NamedDataRetrievalDriver
35 //purpose  : 
36 //=======================================================================
37 MDataStd_NamedDataRetrievalDriver::MDataStd_NamedDataRetrievalDriver(const Handle(CDM_MessageDriver)& theMsgDriver):MDF_ARDriver(theMsgDriver)
38 {
39
40 }
41
42 //=======================================================================
43 //function : VersionNumber
44 //purpose  : 
45 //=======================================================================
46 Standard_Integer MDataStd_NamedDataRetrievalDriver::VersionNumber() const
47
48   return 0; 
49 }
50
51 //=======================================================================
52 //function : SourceType
53 //purpose  : 
54 //=======================================================================
55 Handle(Standard_Type) MDataStd_NamedDataRetrievalDriver::SourceType() const
56 {
57   static Handle(Standard_Type) sourceType = STANDARD_TYPE(PDataStd_NamedData);
58   return sourceType;
59 }
60
61 //=======================================================================
62 //function : NewEmpty
63 //purpose  : 
64 //=======================================================================
65 Handle(TDF_Attribute) MDataStd_NamedDataRetrievalDriver::NewEmpty () const 
66 {
67   return new TDataStd_NamedData();
68 }
69
70 //=======================================================================
71 //function : Paste
72 //purpose  : 
73 //=======================================================================
74 void MDataStd_NamedDataRetrievalDriver::Paste(const Handle(PDF_Attribute)& Source,
75                                                    const Handle(TDF_Attribute)& Target,
76                                                    const Handle(MDF_RRelocationTable)& ) const
77 {
78   Handle(PDataStd_NamedData) S = Handle(PDataStd_NamedData)::DownCast (Source);
79   Handle(TDataStd_NamedData) T = Handle(TDataStd_NamedData)::DownCast (Target);
80   if(S.IsNull() || T.IsNull()) return;
81   Standard_Integer i;
82 #ifdef OCCT_DEBUG
83   cout << "Start: " <<S->LowerI() << " " <<S->UpperI()<<"\t"<<S->LowerR() << " " <<S->UpperR();
84   cout << "\t"<<S->LowerS() << " " <<S->UpperS()<< "\t"<<S->LowerB() << " " <<S->UpperB();
85   cout << "\t"<<S->LowerAI() << " " <<S->UpperAI()<<"\t"<<S->LowerAR() << " " <<S->UpperAR()<<endl;
86 #endif
87   if(S->HasIntegers()) {
88     TColStd_DataMapOfStringInteger aMap;
89     for(i=S->LowerI();i<=S->UpperI();i++) {
90       Handle(PCollection_HExtendedString) aPKey;
91       Standard_Integer aValue = S->IntDataItemValue(i, aPKey);
92       const TCollection_ExtendedString& aKey = aPKey->Convert();
93       aMap.Bind(aKey, aValue);
94     }
95     T->ChangeIntegers(aMap);
96     }
97
98   if(S->HasReals()) {
99     TDataStd_DataMapOfStringReal aMap;
100     for(i=S->LowerR();i<=S->UpperR();i++) {
101       Handle(PCollection_HExtendedString) aPKey;
102       Standard_Real aValue = S->RealDataItemValue(i, aPKey);
103       const TCollection_ExtendedString& aKey = aPKey->Convert();
104       aMap.Bind(aKey, aValue);
105     }
106     T->ChangeReals(aMap);
107   }
108   if(S->HasStrings()) {
109     TDataStd_DataMapOfStringString aMap;
110     for(i=S->LowerS();i<=S->UpperS();i++) {
111       Handle(PCollection_HExtendedString) aPKey;
112       const Handle(PCollection_HExtendedString)& aPValue = S->StrDataItemValue(i, aPKey);
113       const TCollection_ExtendedString& aKey = aPKey->Convert();
114       const TCollection_ExtendedString& aValue = aPValue->Convert();
115       aMap.Bind(aKey, aValue);
116     }
117     T->ChangeStrings(aMap);
118   }
119   if(S->HasBytes()) {
120     TDataStd_DataMapOfStringByte aMap;
121     for(i=S->LowerB();i<=S->UpperB();i++) {
122       Handle(PCollection_HExtendedString) aPKey;
123       Standard_Byte aValue = S->ByteDataItemValue(i, aPKey);
124       const TCollection_ExtendedString& aKey = aPKey->Convert();
125       aMap.Bind(aKey, aValue);
126     }
127     T->ChangeBytes(aMap);
128   }
129   if(S->HasArraysOfIntegers()) {
130     TDataStd_DataMapOfStringHArray1OfInteger aMap;
131     for(i=S->LowerAI();i<=S->UpperAI();i++) {
132       Handle(PCollection_HExtendedString) aPKey;
133       Handle(PColStd_HArray1OfInteger) aPValue = S->ArrIntDataItemValue(i, aPKey);
134       const TCollection_ExtendedString& aKey = aPKey->Convert();
135       Handle(TColStd_HArray1OfInteger) anAr;
136       if (aPValue.IsNull()) continue;
137       Standard_Integer lower = aPValue->Lower(), upper = aPValue->Upper();
138       anAr = new TColStd_HArray1OfInteger(lower, upper);
139       for (Standard_Integer j = lower; j <= upper; j++)
140         anAr->SetValue(j, aPValue->Value(j));
141       aMap.Bind(aKey, anAr);
142     }
143     T->ChangeArraysOfIntegers(aMap);
144   }
145   if(S->HasArraysOfReals()) {
146     TDataStd_DataMapOfStringHArray1OfReal aMap;
147     for(i=S->LowerAR();i<=S->UpperAR();i++) {
148       Handle(PCollection_HExtendedString) aPKey;
149       Handle(PColStd_HArray1OfReal) aPValue = S->ArrRealDataItemValue(i, aPKey);
150       const TCollection_ExtendedString& aKey = aPKey->Convert();
151       Handle(TColStd_HArray1OfReal) anAr;
152       if (aPValue.IsNull()) continue;
153       Standard_Integer lower = aPValue->Lower(), upper = aPValue->Upper();
154       anAr = new TColStd_HArray1OfReal(lower, upper);
155       for (Standard_Integer j = lower; j <= upper; j++)
156         anAr->SetValue(j, aPValue->Value(j));
157       aMap.Bind(aKey, anAr);
158     }
159     T->ChangeArraysOfReals(aMap);
160   }
161 }