8f560af82f7c99dc1316b29b664923f4316a6352
[occt.git] / src / BinMDataStd / BinMDataStd_BooleanArrayDriver.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_BooleanArrayDriver.hxx>
18 #include <BinObjMgt_Persistent.hxx>
19 #include <CDM_MessageDriver.hxx>
20 #include <Standard_Type.hxx>
21 #include <TColStd_Array1OfInteger.hxx>
22 #include <TColStd_HArray1OfByte.hxx>
23 #include <TDataStd_BooleanArray.hxx>
24 #include <TDF_Attribute.hxx>
25
26 //=======================================================================
27 //function : BinMDataStd_BooleanArrayDriver
28 //purpose  : Constructor
29 //=======================================================================
30 BinMDataStd_BooleanArrayDriver::BinMDataStd_BooleanArrayDriver(const Handle(CDM_MessageDriver)& theMsgDriver)
31      : BinMDF_ADriver (theMsgDriver, STANDARD_TYPE(TDataStd_BooleanArray)->Name())
32 {
33
34 }
35
36 //=======================================================================
37 //function : NewEmpty
38 //purpose  : 
39 //=======================================================================
40 Handle(TDF_Attribute) BinMDataStd_BooleanArrayDriver::NewEmpty() const
41 {
42   return new TDataStd_BooleanArray();
43 }
44
45 //=======================================================================
46 //function : Paste
47 //purpose  : persistent -> transient (retrieve)
48 //=======================================================================
49 Standard_Boolean BinMDataStd_BooleanArrayDriver::Paste(const BinObjMgt_Persistent&  theSource,
50                                                        const Handle(TDF_Attribute)& theTarget,
51                                                        BinObjMgt_RRelocationTable&  ) const
52 {
53   Standard_Integer aFirstInd, aLastInd;
54   if (! (theSource >> aFirstInd >> aLastInd))
55     return Standard_False;
56   if (aLastInd < aFirstInd)
57     return Standard_False;
58
59   TColStd_Array1OfByte aTargetArray(0, (aLastInd - aFirstInd + 1) >> 3);
60   theSource.GetByteArray (&aTargetArray(0), aTargetArray.Length());
61
62   Handle(TDataStd_BooleanArray) anAtt = Handle(TDataStd_BooleanArray)::DownCast(theTarget);
63   anAtt->Init(aFirstInd, aLastInd);
64   Handle(TColStd_HArray1OfByte) bytes = new TColStd_HArray1OfByte(aTargetArray.Lower(), aTargetArray.Upper());
65   Standard_Integer lower = bytes->Lower(), i = lower, upper = bytes->Upper();
66   for (; i <= upper; i++)
67   {
68     bytes->SetValue(i, aTargetArray.Value(i));
69   }
70   anAtt->SetInternalArray(bytes);
71   return Standard_True;
72 }
73
74 //=======================================================================
75 //function : Paste
76 //purpose  : transient -> persistent (store)
77 //=======================================================================
78 void BinMDataStd_BooleanArrayDriver::Paste(const Handle(TDF_Attribute)& theSource,
79                                            BinObjMgt_Persistent&        theTarget,
80                                            BinObjMgt_SRelocationTable&  ) const
81 {
82   Handle(TDataStd_BooleanArray) anAtt = Handle(TDataStd_BooleanArray)::DownCast(theSource);
83   const Standard_Integer aFirstInd = anAtt->Lower();
84   const Standard_Integer aLastInd  = anAtt->Upper();
85   if (aLastInd < aFirstInd)
86     return;
87   theTarget << aFirstInd << aLastInd;
88
89   const Handle(TColStd_HArray1OfByte)& bytes = anAtt->InternalArray();
90   TColStd_Array1OfByte aSourceArray(bytes->Lower(), bytes->Upper());
91   Standard_Integer lower = bytes->Lower(), i = lower, upper = bytes->Upper();
92   for (; i <= upper; i++)
93   {
94     aSourceArray.SetValue(i, bytes->Value(i));
95   }
96   Standard_Byte *aPtr = (Standard_Byte *) &aSourceArray(lower);
97   theTarget.PutByteArray(aPtr, upper - lower + 1);
98 }