X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FMEDCoupling%2FMEDCouplingFieldFloat.cxx;h=989897eb2054b621a99f4c13de5a6209ab909ca7;hb=b8616069f6667dcec3f90574a05bfc9e66d87fa5;hp=2e7c7ddefd9f7b628fc61e785f54e595857e75a4;hpb=c5f9a2bb5f775564b5bd81de58dfa708bcef020d;p=tools%2Fmedcoupling.git diff --git a/src/MEDCoupling/MEDCouplingFieldFloat.cxx b/src/MEDCoupling/MEDCouplingFieldFloat.cxx index 2e7c7ddef..989897eb2 100644 --- a/src/MEDCoupling/MEDCouplingFieldFloat.cxx +++ b/src/MEDCoupling/MEDCouplingFieldFloat.cxx @@ -1,4 +1,4 @@ -// Copyright (C) 2007-2017 CEA/DEN, EDF R&D +// Copyright (C) 2007-2021 CEA/DEN, EDF R&D // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -21,8 +21,11 @@ #include "MEDCouplingFieldFloat.hxx" #include "MEDCouplingFieldT.txx" #include "MEDCouplingFieldDouble.hxx" +#include "MEDCouplingFieldInt.hxx" +#include "MEDCouplingFieldInt64.hxx" #include "MEDCouplingFieldTemplate.hxx" #include "MEDCouplingMesh.hxx" +#include "MEDCouplingMemArray.txx" using namespace MEDCoupling; @@ -67,17 +70,33 @@ MEDCouplingFieldFloat *MEDCouplingFieldFloat::clone(bool recDeepCpy) const return new MEDCouplingFieldFloat(*this,recDeepCpy); } -MEDCouplingFieldDouble *MEDCouplingFieldFloat::convertToDblField() const +template +typename Traits::FieldType *ConvertToUField(const MEDCouplingFieldFloat *self) { - MCAuto tmp(MEDCouplingFieldTemplate::New(*this)); + MCAuto tmp(MEDCouplingFieldTemplate::New(*self)); int t1,t2; - double t0(getTime(t1,t2)); - MCAuto ret(MEDCouplingFieldDouble::New(*tmp,getTimeDiscretization())); + double t0(self->getTime(t1,t2)); + MCAuto::FieldType> ret(Traits::FieldType::New(*tmp,self->getTimeDiscretization())); ret->setTime(t0,t1,t2); - if(getArray()) + if(self->getArray()) { - MCAuto arr(getArray()->convertToDblArr()); + MCAuto::ArrayType> arr(self->getArray()->convertToOtherTypeOfArr()); ret->setArray(arr); } return ret.retn(); } + +MEDCouplingFieldDouble * MEDCouplingFieldFloat::convertToDblField() const +{ + return ConvertToUField(this); +} + +MEDCouplingFieldInt32 * MEDCouplingFieldFloat::convertToIntField() const +{ + return ConvertToUField(this); +} + +MEDCouplingFieldInt64 * MEDCouplingFieldFloat::convertToInt64Field() const +{ + return ConvertToUField(this); +}