0024002: Overall code and build procedure refactoring -- automatic
[occt.git] / src / BinMDataStd / BinMDataStd_ByteArrayDriver.cxx
1 // Created on: 2007-05-29
2 // Created by: Vlad Romashko
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
17 #include <BinMDataStd.hxx>
18 #include <BinMDataStd_ByteArrayDriver.hxx>
19 #include <BinObjMgt_Persistent.hxx>
20 #include <CDM_MessageDriver.hxx>
21 #include <Standard_Type.hxx>
22 #include <TColStd_Array1OfInteger.hxx>
23 #include <TColStd_HArray1OfByte.hxx>
24 #include <TDataStd_ByteArray.hxx>
25 #include <TDF_Attribute.hxx>
26
27 //=======================================================================
28 //function : BinMDataStd_ByteArrayDriver
29 //purpose  : Constructor
30 //=======================================================================
31 BinMDataStd_ByteArrayDriver::BinMDataStd_ByteArrayDriver(const Handle(CDM_MessageDriver)& theMsgDriver)
32      : BinMDF_ADriver (theMsgDriver, STANDARD_TYPE(TDataStd_ByteArray)->Name())
33 {
34
35 }
36
37 //=======================================================================
38 //function : NewEmpty
39 //purpose  : 
40 //=======================================================================
41 Handle(TDF_Attribute) BinMDataStd_ByteArrayDriver::NewEmpty() const
42 {
43   return new TDataStd_ByteArray();
44 }
45
46 //=======================================================================
47 //function : Paste
48 //purpose  : persistent -> transient (retrieve)
49 //=======================================================================
50 Standard_Boolean BinMDataStd_ByteArrayDriver::Paste(const BinObjMgt_Persistent&  theSource,
51                                                     const Handle(TDF_Attribute)& theTarget,
52                                                     BinObjMgt_RRelocationTable&  ) const
53 {
54   Standard_Integer aFirstInd, aLastInd;
55   if (! (theSource >> aFirstInd >> aLastInd))
56     return Standard_False;
57   if (aLastInd < aFirstInd)
58     return Standard_False;
59
60   TColStd_Array1OfByte aTargetArray(aFirstInd, aLastInd);
61   theSource.GetByteArray (&aTargetArray(aFirstInd), aTargetArray.Length());
62
63   Handle(TDataStd_ByteArray) anAtt = Handle(TDataStd_ByteArray)::DownCast(theTarget);
64   Handle(TColStd_HArray1OfByte) bytes = new TColStd_HArray1OfByte(aFirstInd, aLastInd);
65   for (Standard_Integer i = aFirstInd; i <= aLastInd; i++)
66   {
67     bytes->SetValue(i, aTargetArray.Value(i));
68   }
69   anAtt->ChangeArray(bytes);
70
71   Standard_Boolean aDelta(Standard_False); 
72   if(BinMDataStd::DocumentVersion() > 2) {
73     Standard_Byte aDeltaValue;
74     if (! (theSource >> aDeltaValue))
75       return Standard_False;
76     else
77       aDelta = (Standard_Boolean)aDeltaValue;
78   }
79   anAtt->SetDelta(aDelta);
80   return Standard_True;
81 }
82
83 //=======================================================================
84 //function : Paste
85 //purpose  : transient -> persistent (store)
86 //=======================================================================
87 void BinMDataStd_ByteArrayDriver::Paste(const Handle(TDF_Attribute)& theSource,
88                                         BinObjMgt_Persistent&        theTarget,
89                                         BinObjMgt_SRelocationTable&  ) const
90 {
91   Handle(TDataStd_ByteArray) anAtt = Handle(TDataStd_ByteArray)::DownCast(theSource);
92   const Standard_Integer aFirstInd = anAtt->Lower();
93   const Standard_Integer aLastInd  = anAtt->Upper();
94   if (aLastInd < aFirstInd)
95     return;
96   theTarget << aFirstInd << aLastInd;
97
98   const Handle(TColStd_HArray1OfByte)& bytes = anAtt->InternalArray();
99   Standard_Integer lower = bytes->Lower(), i = lower, upper = bytes->Upper();
100   TColStd_Array1OfByte aSourceArray(lower, upper);
101   for (; i <= upper; i++)
102   {
103     aSourceArray.SetValue(i, bytes->Value(i));
104   }
105   Standard_Byte *aPtr = (Standard_Byte *) &aSourceArray(lower);
106   theTarget.PutByteArray(aPtr, bytes->Length());
107   theTarget << (Standard_Byte)anAtt->GetDelta();
108 }