Merge pull request #5716 from akva2/c++20_stuff

Quell c++-20 warnings
This commit is contained in:
Bård Skaflestad 2024-11-06 11:17:44 +01:00 committed by GitHub
commit c8366e96ac
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
11 changed files with 28 additions and 22 deletions

View File

@ -212,8 +212,8 @@ class Co2InjectionProblem : public GetPropType<TypeTag, Properties::BaseProblem>
enum { liquidPhaseIdx = FluidSystem::liquidPhaseIdx }; enum { liquidPhaseIdx = FluidSystem::liquidPhaseIdx };
enum { CO2Idx = FluidSystem::CO2Idx }; enum { CO2Idx = FluidSystem::CO2Idx };
enum { BrineIdx = FluidSystem::BrineIdx }; enum { BrineIdx = FluidSystem::BrineIdx };
enum { conti0EqIdx = Indices::conti0EqIdx }; static constexpr int conti0EqIdx = Indices::conti0EqIdx;
enum { contiCO2EqIdx = conti0EqIdx + CO2Idx }; static constexpr int contiCO2EqIdx = conti0EqIdx + CO2Idx;
using PrimaryVariables = GetPropType<TypeTag, Properties::PrimaryVariables>; using PrimaryVariables = GetPropType<TypeTag, Properties::PrimaryVariables>;
using RateVector = GetPropType<TypeTag, Properties::RateVector>; using RateVector = GetPropType<TypeTag, Properties::RateVector>;

View File

@ -591,7 +591,9 @@ public:
const Scalar& maxAdsorbtion = PolymerModule::plyrockMaxAdsorbtion(elemCtx, dofIdx, timeIdx); const Scalar& maxAdsorbtion = PolymerModule::plyrockMaxAdsorbtion(elemCtx, dofIdx, timeIdx);
const auto& plyadsAdsorbedPolymer = PolymerModule::plyadsAdsorbedPolymer(elemCtx, dofIdx, timeIdx); const auto& plyadsAdsorbedPolymer = PolymerModule::plyadsAdsorbedPolymer(elemCtx, dofIdx, timeIdx);
polymerAdsorption_ = plyadsAdsorbedPolymer.eval(polymerConcentration_, /*extrapolate=*/true); polymerAdsorption_ = plyadsAdsorbedPolymer.eval(polymerConcentration_, /*extrapolate=*/true);
if (PolymerModule::plyrockAdsorbtionIndex(elemCtx, dofIdx, timeIdx) == BlackOilPolymerParams<Scalar>::NoDesorption) { if (static_cast<int>(PolymerModule::plyrockAdsorbtionIndex(elemCtx, dofIdx, timeIdx)) ==
BlackOilPolymerParams<Scalar>::NoDesorption)
{
const Scalar& maxPolymerAdsorption = elemCtx.problem().maxPolymerAdsorption(elemCtx, dofIdx, timeIdx); const Scalar& maxPolymerAdsorption = elemCtx.problem().maxPolymerAdsorption(elemCtx, dofIdx, timeIdx);
polymerAdsorption_ = std::max(Evaluation(maxPolymerAdsorption) , polymerAdsorption_); polymerAdsorption_ = std::max(Evaluation(maxPolymerAdsorption) , polymerAdsorption_);
} }

View File

@ -45,7 +45,7 @@ class FlashIndices
: public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumComponents>(), : public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumComponents>(),
getPropValue<TypeTag, Properties::EnableEnergy>()> getPropValue<TypeTag, Properties::EnableEnergy>()>
{ {
enum { numComponents = getPropValue<TypeTag, Properties::NumComponents>() }; static constexpr int numComponents = getPropValue<TypeTag, Properties::NumComponents>();
enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() }; enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() };
using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents, enableEnergy>; using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents, enableEnergy>;

View File

@ -43,7 +43,7 @@ struct ImmiscibleIndices
: public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumPhases>(), : public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumPhases>(),
getPropValue<TypeTag, Properties::EnableEnergy>()> getPropValue<TypeTag, Properties::EnableEnergy>()>
{ {
enum { numPhases = getPropValue<TypeTag, Properties::NumPhases>() }; static constexpr int numPhases = getPropValue<TypeTag, Properties::NumPhases>();
enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() }; enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() };
using EnergyIndices = Opm::EnergyIndices<PVOffset + numPhases, enableEnergy>; using EnergyIndices = Opm::EnergyIndices<PVOffset + numPhases, enableEnergy>;

View File

@ -48,8 +48,8 @@ struct NcpIndices
{ {
private: private:
using FluidSystem = GetPropType<TypeTag, Properties::FluidSystem>; using FluidSystem = GetPropType<TypeTag, Properties::FluidSystem>;
enum { numPhases = FluidSystem::numPhases }; static constexpr int numPhases = FluidSystem::numPhases;
enum { numComponents = FluidSystem::numComponents }; static constexpr int numComponents = FluidSystem::numComponents;
enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() }; enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() };
using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents + numPhases, enableEnergy>; using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents + numPhases, enableEnergy>;

View File

@ -232,13 +232,13 @@ class NcpModel
using FluidSystem = GetPropType<TypeTag, Properties::FluidSystem>; using FluidSystem = GetPropType<TypeTag, Properties::FluidSystem>;
using Indices = GetPropType<TypeTag, Properties::Indices>; using Indices = GetPropType<TypeTag, Properties::Indices>;
enum { numPhases = FluidSystem::numPhases }; static constexpr int numPhases = FluidSystem::numPhases;
enum { numComponents = FluidSystem::numComponents }; static constexpr int numComponents = FluidSystem::numComponents;
enum { fugacity0Idx = Indices::fugacity0Idx }; static constexpr int fugacity0Idx = Indices::fugacity0Idx;
enum { pressure0Idx = Indices::pressure0Idx }; enum { pressure0Idx = Indices::pressure0Idx };
enum { saturation0Idx = Indices::saturation0Idx }; enum { saturation0Idx = Indices::saturation0Idx };
enum { conti0EqIdx = Indices::conti0EqIdx }; static constexpr int conti0EqIdx = Indices::conti0EqIdx;
enum { ncp0EqIdx = Indices::ncp0EqIdx }; static constexpr int ncp0EqIdx = Indices::ncp0EqIdx;
enum { enableDiffusion = getPropValue<TypeTag, Properties::EnableDiffusion>() }; enum { enableDiffusion = getPropValue<TypeTag, Properties::EnableDiffusion>() };
enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() }; enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() };

View File

@ -46,7 +46,7 @@ class FlashIndices
: public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumComponents>(), : public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumComponents>(),
getPropValue<TypeTag, Properties::EnableEnergy>()> getPropValue<TypeTag, Properties::EnableEnergy>()>
{ {
enum { numComponents = getPropValue<TypeTag, Properties::NumComponents>() }; static constexpr int numComponents = getPropValue<TypeTag, Properties::NumComponents>();
enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() }; enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() };
using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents, enableEnergy>; using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents, enableEnergy>;

View File

@ -46,7 +46,7 @@ class PvsIndices
: public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumComponents>(), : public EnergyIndices<PVOffset + getPropValue<TypeTag, Properties::NumComponents>(),
getPropValue<TypeTag, Properties::EnableEnergy>()> getPropValue<TypeTag, Properties::EnableEnergy>()>
{ {
enum { numComponents = getPropValue<TypeTag, Properties::NumComponents>() }; static constexpr int numComponents = getPropValue<TypeTag, Properties::NumComponents>();
enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() }; enum { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() };
using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents, enableEnergy>; using EnergyIndices = Opm::EnergyIndices<PVOffset + numComponents, enableEnergy>;

View File

@ -212,5 +212,6 @@ Opm::RegionPhasePoreVolAverage::valueArrayIndex(const Ix start,
const AvgType type, const AvgType type,
const Element element) const const Element element) const
{ {
return start + type*Element::NumElem + element; return start + static_cast<Ix>(type) * static_cast<Ix>(Element::NumElem)
+ static_cast<Ix>(element);
} }

View File

@ -553,7 +553,7 @@ void registerAdaptiveParameters();
return serializationTestObject_<SimpleIterationCountTimeStepControl>(); return serializationTestObject_<SimpleIterationCountTimeStepControl>();
} }
bool operator==(const AdaptiveTimeStepping<TypeTag>& rhs) bool operator==(const AdaptiveTimeStepping<TypeTag>& rhs) const
{ {
if (timeStepControlType_ != rhs.timeStepControlType_ || if (timeStepControlType_ != rhs.timeStepControlType_ ||
(timeStepControl_ && !rhs.timeStepControl_) || (timeStepControl_ && !rhs.timeStepControl_) ||

View File

@ -34,6 +34,9 @@ namespace Opm::Mpi {
namespace detail { namespace detail {
template <typename T>
constexpr bool is_pod_v = std::is_standard_layout_v<T> && std::is_trivial_v<T>;
std::size_t mpi_buffer_size(const std::size_t bufsize, const std::size_t position); std::size_t mpi_buffer_size(const std::size_t bufsize, const std::size_t position);
//! \brief Abstract struct for packing which is (partially) specialized for specific types. //! \brief Abstract struct for packing which is (partially) specialized for specific types.
@ -199,7 +202,7 @@ struct Packer
template<class T> template<class T>
std::size_t packSize(const T& data) const std::size_t packSize(const T& data) const
{ {
return detail::Packing<std::is_pod_v<T>,T>::packSize(data, m_comm); return detail::Packing<detail::is_pod_v<T>,T>::packSize(data, m_comm);
} }
//! \brief Calculates the pack size for an array. //! \brief Calculates the pack size for an array.
@ -209,7 +212,7 @@ struct Packer
template<class T> template<class T>
std::size_t packSize(const T* data, std::size_t n) const std::size_t packSize(const T* data, std::size_t n) const
{ {
static_assert(std::is_pod_v<T>, "Array packing not supported for non-pod data"); static_assert(detail::is_pod_v<T>, "Array packing not supported for non-pod data");
return detail::Packing<true,T>::packSize(data, n, m_comm); return detail::Packing<true,T>::packSize(data, n, m_comm);
} }
@ -223,7 +226,7 @@ struct Packer
std::vector<char>& buffer, std::vector<char>& buffer,
std::size_t& position) const std::size_t& position) const
{ {
detail::Packing<std::is_pod_v<T>,T>::pack(data, buffer, position, m_comm); detail::Packing<detail::is_pod_v<T>,T>::pack(data, buffer, position, m_comm);
} }
//! \brief Pack an array. //! \brief Pack an array.
@ -238,7 +241,7 @@ struct Packer
std::vector<char>& buffer, std::vector<char>& buffer,
std::size_t& position) const std::size_t& position) const
{ {
static_assert(std::is_pod_v<T>, "Array packing not supported for non-pod data"); static_assert(detail::is_pod_v<T>, "Array packing not supported for non-pod data");
detail::Packing<true,T>::pack(data, n, buffer, position, m_comm); detail::Packing<true,T>::pack(data, n, buffer, position, m_comm);
} }
@ -252,7 +255,7 @@ struct Packer
const std::vector<char>& buffer, const std::vector<char>& buffer,
std::size_t& position) const std::size_t& position) const
{ {
detail::Packing<std::is_pod_v<T>,T>::unpack(data, buffer, position, m_comm); detail::Packing<detail::is_pod_v<T>,T>::unpack(data, buffer, position, m_comm);
} }
//! \brief Unpack an array. //! \brief Unpack an array.
@ -267,7 +270,7 @@ struct Packer
const std::vector<char>& buffer, const std::vector<char>& buffer,
std::size_t& position) const std::size_t& position) const
{ {
static_assert(std::is_pod_v<T>, "Array packing not supported for non-pod data"); static_assert(detail::is_pod_v<T>, "Array packing not supported for non-pod data");
detail::Packing<true,T>::unpack(data, n, buffer, position, m_comm); detail::Packing<true,T>::unpack(data, n, buffer, position, m_comm);
} }