Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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 compile error in
binaryop/compiled/util.cpp
#10209Fix compile error in
binaryop/compiled/util.cpp
#10209Changes from 3 commits
07df129
758cc53
f21ebac
aea7b14
fbae4ea
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A default-constructed
std::optional
should be equivalent tostd::nullopt
from my reading of cppreference. This pattern is used several times in libcudf.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I found this: https://stackoverflow.com/questions/57964217/stdoptional-construct-empty-with-or-stdnullopt
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here is my reasoning:
return {}
will return a valid optional object with default-constructeddata_type
, not anullopt
.data_type
has a default constructor, and calling{}
will construct a defaultdata_type
object instead of an empty optional object.data_type
object" does not initialize its members. That's why we got the compile error.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think so, mate. (1) in the spec indicates otherwise. Here's a trivial godbolt example.
This sounds very much like a compiler bug that we're working around. That said, this change might still be worth having.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, the only thing I can think of is a compiler bug that causes
return {}
to return a valid optional object with default-constructeddata_type
.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We don't see this bug with GCC 9 or 11. There may be some confluence of issues here that cause it to only appear on GCC 10.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's warning treated as error. From the links above, I can see that such warning is issued with gcc-7 and 8 too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Guys, we have a very hot discussion. Thanks all for your attention 👍 😃
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Moving the function out of anonymous namespace does not help.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nothing to get us excited like a possible compiler bug! Appreciate all the voices here - I learned quite a bit. :)