From c8839ec5cd81ba9ae88081747c49ecc758973dd1 Mon Sep 17 00:00:00 2001 From: Martin Leitner-Ankerl Date: Wed, 2 Aug 2023 19:49:40 +0200 Subject: [PATCH] refactor: use "if constexpr" in prevector's Serialize() This gets rid of unnecessarily creating a temporary object T() to call the right function. --- src/serialize.h | 28 +++++++++------------------- 1 file changed, 9 insertions(+), 19 deletions(-) diff --git a/src/serialize.h b/src/serialize.h index aa9f8346540..cfbbd1e9405 100644 --- a/src/serialize.h +++ b/src/serialize.h @@ -642,8 +642,6 @@ template void Unserialize(Stream& is, std::basic_st * prevector * prevectors of unsigned char are a special case and are intended to be serialized as a single opaque blob. */ -template void Serialize_impl(Stream& os, const prevector& v, const unsigned char&); -template void Serialize_impl(Stream& os, const prevector& v, const V&); template inline void Serialize(Stream& os, const prevector& v); template void Unserialize_impl(Stream& is, prevector& v, const unsigned char&); template void Unserialize_impl(Stream& is, prevector& v, const V&); @@ -751,24 +749,16 @@ void Unserialize(Stream& is, std::basic_string& str) /** * prevector */ -template -void Serialize_impl(Stream& os, const prevector& v, const unsigned char&) +template +void Serialize(Stream& os, const prevector& v) { - WriteCompactSize(os, v.size()); - if (!v.empty()) - os.write(MakeByteSpan(v)); -} - -template -void Serialize_impl(Stream& os, const prevector& v, const V&) -{ - Serialize(os, Using>(v)); -} - -template -inline void Serialize(Stream& os, const prevector& v) -{ - Serialize_impl(os, v, T()); + if constexpr (std::is_same_v) { + WriteCompactSize(os, v.size()); + if (!v.empty()) + os.write(MakeByteSpan(v)); + } else { + Serialize(os, Using>(v)); + } }