Skip to content

Commit

Permalink
Fix bugprone and modernize clang-tidy findings
Browse files Browse the repository at this point in the history
  • Loading branch information
Neverlord committed Sep 30, 2024
1 parent 0358821 commit 66b9acf
Show file tree
Hide file tree
Showing 8 changed files with 24 additions and 21 deletions.
2 changes: 1 addition & 1 deletion libbroker/broker/detail/memory_backend.cc
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,7 @@ expected<expirables> memory_backend::expiries() const {

for (auto& p : store_) {
if (p.second.second)
rval.emplace_back(expirable(p.first, *p.second.second));
rval.emplace_back(p.first, *p.second.second);
}

return {std::move(rval)};
Expand Down
7 changes: 4 additions & 3 deletions libbroker/broker/error.cc
Original file line number Diff line number Diff line change
Expand Up @@ -216,7 +216,8 @@ bool convertible_to_ec(uint8_t src) noexcept {
}

template <class List>
bool convertible_to_error_impl(const List& xs) noexcept {
bool convertible_to_error_impl(const List& xs) noexcept(
std::is_same_v<List, variant_list>) {
if (!contains<std::string, ec, any_type>(xs)) {
// There is one special case: default errors with enum value "none" fail to
// convert to ec but are still legal.
Expand All @@ -234,11 +235,11 @@ bool convertible_to_error_impl(const List& xs) noexcept {
|| contains<endpoint_info, std::string>(args);
}

bool convertible_to_error(const vector& xs) noexcept {
bool convertible_to_error(const vector& xs) {
return convertible_to_error_impl(xs);
}

bool convertible_to_error(const data& src) noexcept {
bool convertible_to_error(const data& src) {
return convertible_to_error_impl(src.to_list());
}

Expand Down
12 changes: 6 additions & 6 deletions libbroker/broker/error.hh
Original file line number Diff line number Diff line change
Expand Up @@ -276,22 +276,22 @@ struct can_convert_predicate<ec> {

/// Checks whethter `src` is convertible to a `caf::error` with
/// `category() == caf::atom("broker")`.
bool convertible_to_error(const data& src) noexcept;
bool convertible_to_error(const data& src);

/// @copydoc convertible_to_error
bool convertible_to_error(const vector& xs);

/// Checks whethter `src` is convertible to a `caf::error` with
/// `category() == caf::atom("broker")`.
bool convertible_to_error(const variant& src) noexcept;

/// @copydoc convertible_to_error
bool convertible_to_error(const vector& xs) noexcept;

template <>
struct can_convert_predicate<error> {
static bool check(const data& src) noexcept {
static bool check(const data& src) {
return convertible_to_error(src);
}

static bool check(const vector& src) noexcept {
static bool check(const vector& src) {
return convertible_to_error(src);
}

Expand Down
6 changes: 3 additions & 3 deletions libbroker/broker/format/bin.hh
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,7 @@ std::enable_if_t<std::is_arithmetic_v<T>, OutIter> encode(T value,
} else if constexpr (std::is_unsigned_v<T>) {
return write_unsigned(value, out);
} else {
static_assert(std::is_signed<T>::value);
static_assert(std::is_signed_v<T>);
using unsigned_t = std::make_unsigned_t<T>;
return write_unsigned(static_cast<unsigned_t>(value), out);
}
Expand Down Expand Up @@ -435,8 +435,8 @@ public:
}

template <class T>
const T& field(std::string_view, const T& value) {
return value;
decltype(auto) field(std::string_view, T&& value) {
return std::forward<T>(value);
}

bool fields() {
Expand Down
10 changes: 6 additions & 4 deletions libbroker/broker/internal/channel.hh
Original file line number Diff line number Diff line change
Expand Up @@ -198,9 +198,10 @@ public:
}

void shipped(int64_t num) {
auto dbl_num = static_cast<double>(num);
if (unacknowledged) {
unacknowledged->Decrement(num);
processed->Increment(num);
unacknowledged->Decrement(dbl_num);
processed->Increment(dbl_num);
}
}
};
Expand Down Expand Up @@ -844,8 +845,9 @@ public:
void try_consume_buffer() {
auto i = buf_.begin();
for (; i != buf_.end() && i->seq == next_seq_; ++i) {
if (i->content) {
backend_->consume(this, *i->content);
auto& content = i->content;
if (content) {
backend_->consume(this, *content);
} else {
if (auto err = backend_->consume_nil(this)) {
buf_.erase(buf_.begin(), i);
Expand Down
2 changes: 1 addition & 1 deletion libbroker/broker/internal/flow_scope.hh
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ public:
if (deregister_cb_) {
try {
deregister_cb_(stats_);
} catch (...) {
} catch (...) { // NOLINT
// The callbacks may not throw. However, we can't specify them noexcept
// because std::function does not support noexcept signatures. Hence,
// this catch-all to silence tool warnings.
Expand Down
2 changes: 1 addition & 1 deletion libbroker/broker/internal/master_actor.cc
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ master_state::master_state(
detail::die("failed to get master expiries while initializing");
}
if (auto entries = backend->size(); entries && *entries > 0) {
metrics.entries->Set(*entries);
metrics.entries->Set(static_cast<double>(*entries));
}
BROKER_INFO("attached master" << id << "to" << store_name);
}
Expand Down
4 changes: 2 additions & 2 deletions libbroker/broker/subnet.cc
Original file line number Diff line number Diff line change
Expand Up @@ -78,8 +78,8 @@ bool convert(const std::string& str, subnet& sn) {
sn = subnet{addr, static_cast<uint8_t>(len)};
return true;
}
} catch (std::exception&) {
// nop
} catch (const std::exception&) {
return false;
}
}
return false;
Expand Down

0 comments on commit 66b9acf

Please sign in to comment.