Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix clang analyzer warning about FilterGenerator in v2.x #2314

Merged
merged 2 commits into from
Nov 24, 2021

Conversation

GHF
Copy link

@GHF GHF commented Oct 27, 2021

PR #2313 backported to v2.x since that's the one I'm actually using.

@codecov
Copy link

codecov bot commented Oct 27, 2021

Codecov Report

Merging #2314 (93aa4dd) into v2.x (f2f0dcc) will increase coverage by 0.01%.
The diff coverage is 100.00%.

@@            Coverage Diff             @@
##             v2.x    #2314      +/-   ##
==========================================
+ Coverage   90.09%   90.10%   +0.01%     
==========================================
  Files         113      113              
  Lines        5035     5038       +3     
==========================================
+ Hits         4536     4539       +3     
  Misses        499      499              

@@ -51,7 +51,7 @@ namespace Generators {


template <typename T, typename Predicate>
class FilterGenerator : public IGenerator<T> {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is, very very hypothetically, an API breaking change.

I think it is very low risk, but there is a bit uglier but guaranteed non-breaking change that also fixes this: turn the current implementation of next into a private helper, e.g. nextImpl, and have both the constructor and the new next implementation call it directly, e.g.

bool next() override {
    return nextImpl();
}

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is, very very hypothetically, an API breaking change.

I think it is very low risk, but there is a bit uglier but guaranteed non-breaking change that also fixes this: turn the current implementation of next into a private helper, e.g. nextImpl, and have both the constructor and the new next implementation call it directly, e.g.

Thanks for pointing out that important consideration. I think this is your call. Would you like me to revise this PR for the nextImpl route?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, sorry for making it implicit only.

I would merge a PR that adds a test or two (e.g. the ones I added to devel recently) and goes the nextImpl route.

Refactor FilterGenerator to remove ctor call to overridden method next()
in order to address clang static analyzer diagnostic:

catch2-src/single_include/catch2/catch.hpp:4166:42: note: Call to virtual method 'FilterGenerator::next' during construction bypasses virtual dispatch
                auto has_initial_value = next();
                                         ^~~~~~
@horenmar horenmar merged commit 33794a2 into catchorg:v2.x Nov 24, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants