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