From 503ceec33800a751d67eaa72b7d6670a2a20718f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cezary=20Skrzy=C5=84ski?= Date: Mon, 9 May 2022 10:34:58 +0200 Subject: [PATCH] #1782: don't pass primitive types by reference --- src/vt/group/region/group_list.cc | 12 ++++++------ src/vt/group/region/group_list.h | 4 +++- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/src/vt/group/region/group_list.cc b/src/vt/group/region/group_list.cc index 3d2b2d5618..bf197b3810 100644 --- a/src/vt/group/region/group_list.cc +++ b/src/vt/group/region/group_list.cc @@ -97,7 +97,7 @@ List::List(List const& in_other, BoundType in_remove_extent) { } List::List( - BoundType const* const list, SizeType const& size, bool const& is_sorted + BoundType const* const list, SizeType const size, bool const is_sorted ) { ListType new_list; for (SizeType elm = 0; elm < size; elm++) { @@ -128,7 +128,7 @@ List::List( } /*virtual*/ List::SplitRegionType List::split() const { - auto const& size = getSize(); + auto const size = getSize(); vtAssert( size >= 2, "Size must be at least 2 to split" ); @@ -153,12 +153,12 @@ List::List( } /*virtual*/ void List::splitN(int nsplits, ApplyFnType apply) const { - auto const& size = static_cast(getSize()); - auto const& num_splits = std::min(nsplits, size); + auto const size = static_cast(getSize()); + auto const num_splits = std::min(nsplits, size); int cur_idx = 0; for (auto split = 0; split < num_splits; split++) { - auto const& child_size = size / num_splits; - auto const& cur_max = split == num_splits - 1 ? + auto const child_size = size / num_splits; + auto const cur_max = split == num_splits - 1 ? size : std::min(size, cur_idx + child_size); ListType list; for (int i = cur_idx; i < cur_max; i++) { diff --git a/src/vt/group/region/group_list.h b/src/vt/group/region/group_list.h index f8661e9596..88b56ede5e 100644 --- a/src/vt/group/region/group_list.h +++ b/src/vt/group/region/group_list.h @@ -44,13 +44,15 @@ #if !defined INCLUDED_VT_GROUP_REGION_GROUP_LIST_H #define INCLUDED_VT_GROUP_REGION_GROUP_LIST_H +#include "vt/group/region/group_region.h" + namespace vt { namespace group { namespace region { struct List : Region { explicit List(ListType const& in_list); explicit List(ListType&& in_list); List(List const& in_other, BoundType in_remove_extent); - List(BoundType const* const list, SizeType const& size, bool const& is_sorted); + List(BoundType const* const list, SizeType const size, bool const is_sorted); List(List const&) = default; List(List&&) = default;