Back to index

salome-med  6.5.0
DataArrayIntClient.cxx
Go to the documentation of this file.
00001 // Copyright (C) 2007-2012  CEA/DEN, EDF R&D
00002 //
00003 // This library is free software; you can redistribute it and/or
00004 // modify it under the terms of the GNU Lesser General Public
00005 // License as published by the Free Software Foundation; either
00006 // version 2.1 of the License.
00007 //
00008 // This library is distributed in the hope that it will be useful,
00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00011 // Lesser General Public License for more details.
00012 //
00013 // You should have received a copy of the GNU Lesser General Public
00014 // License along with this library; if not, write to the Free Software
00015 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
00016 //
00017 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
00018 //
00019 
00020 #include "DataArrayIntClient.hxx"
00021 #include "MEDCouplingMemArray.hxx"
00022 
00023 #include <vector>
00024 
00025 using namespace ParaMEDMEM;
00026 
00027 DataArrayInt *DataArrayIntClient::New(SALOME_MED::DataArrayIntCorbaInterface_ptr dadPtr)
00028 {
00029   SALOME_TYPES::ListOfLong *tinyL=0;
00030   SALOME_TYPES::ListOfString *tinyS=0;
00031   //
00032   dadPtr->Register();
00033   dadPtr->getTinyInfo(tinyL,tinyS);
00034   DataArrayInt *ret=DataArrayInt::New();
00035   int tinyLgth=tinyL->length();
00036   std::vector<int> v1(tinyLgth);
00037   for(int j=0;j<tinyLgth;j++)
00038     v1[j]=(*tinyL)[j];
00039   delete tinyL; tinyL=0;
00040   //
00041   tinyLgth=tinyS->length();
00042   std::vector<std::string> v3(tinyLgth);
00043   for(int j=0;j<tinyLgth;j++)
00044     v3[j]=(*tinyS)[j];
00045   delete tinyS; tinyS=0;
00046   if(ret->resizeForUnserialization(v1))
00047     {
00048       int *pt=ret->getPointer();
00049       dadPtr->getSerialisationData(tinyL);
00050       int lgth=tinyL->length();
00051       for(int j=0;j<lgth;j++)
00052         pt[j]=(*tinyL)[j];
00053       delete tinyL; tinyL=0;
00054     }
00055   dadPtr->UnRegister();
00056   ret->finishUnserialization(v1,v3);
00057   return ret;
00058 }