X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FMEDCoupling%2FMEDCouplingRefCountObject.cxx;h=a0c28d56134e6cd9cb0c5f33c1b2db4eddde3a77;hb=8f2a28585bcf231a8f976f36b7fb1d2eed8801c2;hp=c75f7934ad79213aabc0eb24fe86c403f470faec;hpb=e69d39395db60a1edc0caad7a76c769f1b34628d;p=tools%2Fmedcoupling.git diff --git a/src/MEDCoupling/MEDCouplingRefCountObject.cxx b/src/MEDCoupling/MEDCouplingRefCountObject.cxx index c75f7934a..a0c28d561 100644 --- a/src/MEDCoupling/MEDCouplingRefCountObject.cxx +++ b/src/MEDCoupling/MEDCouplingRefCountObject.cxx @@ -1,4 +1,4 @@ -// Copyright (C) 2007-2016 CEA/DEN, EDF R&D +// Copyright (C) 2007-2020 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 @@ -20,6 +20,7 @@ #include "MEDCouplingRefCountObject.hxx" #include "MEDCoupling_version.h" +#include "MCType.hxx" #include "InterpKernelException.hxx" @@ -53,6 +54,11 @@ int MEDCoupling::MEDCouplingSizeOfVoidStar() return 8*sizeof(std::size_t); } +std::size_t MEDCoupling::MEDCouplingSizeOfIDs() +{ + return 8*sizeof(mcIdType); +} + /*! * If true is returned it is a LittleEndian machine. * If false it is a BigEndian machine. @@ -75,8 +81,42 @@ const char *MEDCoupling::MEDCouplingByteOrderStr() return BIGENDIAN_STR; } +bool MEDCoupling::IsCXX11Compiled() +{ + return true; +} + //= +std::string BigMemoryObject::debugHeapMemorySize() const +{ + std::size_t ret(getHeapMemorySizeWithoutChildren()),sum(ret); + std::ostringstream oss; + std::vector s2(getDirectChildren()); + std::set s1; + oss << "this (" << this->getClassName() << ") -> " << ret << std::endl; + while(!s2.empty()) + { + std::vector s3; + for(auto it : s2) + { + if(s1.find(it)==s1.end()) + { + ret = it->getHeapMemorySizeWithoutChildren(); sum+=ret; + oss << it->getClassName() << " -> " << ret << std::endl; + s1.insert(it); + std::vector v2(it->getDirectChildren()); + for(auto it2 : v2) + if(s1.find(it2)==s1.end()) + s3.push_back(it2); + } + } + s2=s3; + } + oss << "sum = " << sum << std::endl; + return oss.str(); +} + std::size_t BigMemoryObject::getHeapMemorySize() const { std::size_t ret(getHeapMemorySizeWithoutChildren()); @@ -330,7 +370,7 @@ void GlobalDict::clear() _my_map.clear(); } -void GlobalDict::setKeyValue(const std::string& key, const std::string& value) +void GlobalDict::setKeyValue(const std::string& key, const std::string& val) { std::map::const_iterator it(_my_map.find(key)); if(it!=_my_map.end()) @@ -339,12 +379,12 @@ void GlobalDict::setKeyValue(const std::string& key, const std::string& value) oss << "GlobalDict::setKeyValue : key \"" << key << "\" already exists !"; throw INTERP_KERNEL::Exception(oss.str().c_str()); } - _my_map[key]=value; + _my_map[key]=val; } -void GlobalDict::setKeyValueForce(const std::string& key, const std::string& value) +void GlobalDict::setKeyValueForce(const std::string& key, const std::string& val) { - _my_map[key]=value; + _my_map[key]=val; } std::string GlobalDict::printSelf() const