Back to index

salome-med  6.5.0
DataArrayDoubleClient.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 "DataArrayDoubleClient.hxx"
00021 #include "MEDCouplingMemArray.hxx"
00022 
00023 #include <vector>
00024 
00025 using namespace ParaMEDMEM;
00026 
00027 DataArrayDouble *DataArrayDoubleClient::New(SALOME_MED::DataArrayDoubleCorbaInterface_ptr dadPtr)
00028 {
00029   SALOME_TYPES::ListOfLong *tinyL=0;
00030   SALOME_TYPES::ListOfDouble *tinyD=0;
00031   SALOME_TYPES::ListOfString *tinyS=0;
00032   //
00033   dadPtr->Register();
00034   dadPtr->getTinyInfo(tinyL,tinyS);
00035   DataArrayDouble *ret=DataArrayDouble::New();
00036   int tinyLgth=tinyL->length();
00037   std::vector<int> v1(tinyLgth);
00038   for(int j=0;j<tinyLgth;j++)
00039     v1[j]=(*tinyL)[j];
00040   delete tinyL; tinyL=0;
00041   //
00042   tinyLgth=tinyS->length();
00043   std::vector<std::string> v3(tinyLgth);
00044   for(int j=0;j<tinyLgth;j++)
00045     v3[j]=(*tinyS)[j];
00046   delete tinyS; tinyS=0;
00047   if(ret->resizeForUnserialization(v1))
00048     {
00049       double *pt=ret->getPointer();
00050       dadPtr->getSerialisationData(tinyD);
00051       int lgth=tinyD->length();
00052       for(int j=0;j<lgth;j++)
00053         pt[j]=(*tinyD)[j];
00054       delete tinyD; tinyD=0;
00055     }
00056   dadPtr->UnRegister();
00057   ret->finishUnserialization(v1,v3);
00058   return ret;
00059 }