Comments (9)
In your example, the call can never be constexpr
, so clang is wrong.
The type_safe::strong_typedef_op
s, however, are templated. This means that calling them in non-constant expressions should not fail just because they can't be evaluated in constant expressions.
from type_safe.
I had a discussion with on the C++ slack: MSVC is - surprisingly - correct by rejecting it.
I have to create free templated functions that are disabled unless a type inherits from the appropriate strong_typedef_op.
from type_safe.
Do you mean that MSVC is correct in the given example, or in the described case of a user-defined type with non-constexpr operators? Or both (and I have given wrong information :()? If its the second case, could you elaborate?
from type_safe.
If I understand the slack discussion correctly:
- The mixins are templated classes, but the friend functions defined in them are not, so MSVC is correct in rejecting it.
- clang is not wrong in accepting it, as no diagnostic is required.
from type_safe.
@JohelEGP If you have a non-template constexpr function it must only use constexpr functions/types/..., so MSVC correctly rejects it as the called operator== is not constexpr.
from type_safe.
- That's right. What I said about not failing only applies to function templates. See [dcl.constexpr]/6 (emphasis mine):
If the instantiated template specialization of a constexpr function template or member function of a class template would fail to satisfy the requirements for a constexpr function or constexpr constructor, that specialization is still a constexpr function or constexpr constructor, even though a call to such a function cannot appear in a constant expression. If no specialization of the template would satisfy the requirements for a constexpr function or constexpr constructor when considered as a non-template function or constructor, the template is ill-formed; no diagnostic required.
- You're right. I should have used C++ terminology, rather than ambiguous words such as failing or wrong.
@foonathan Given the above, it should be okay to leave the strong_typedef_op
s in the structs and template them on the StrongTypedef
template argument and disable if they're not the same type. I don't have much experience with it, but I've read that having free template functions can cause some noise.
from type_safe.
Regarding 7c963a8, I think you need to switch the StrongTypedef
parameters with T
so that it becomes dependent, if it isn't already.
from type_safe.
Can't get that too work, complains about duplicate definitions.
Have to do the "write free template functions, enable_if derived" trickery. Working on that, I hope I can finally fix it together, but probably with some breaking changes.
from type_safe.
Alright, I finally got something that seems to work.
from type_safe.
Related Issues (20)
- Add custom views of C++ objects in the debugger using the Natvis framework HOT 1
- abs() shouldn't change type (or handle min correctly) HOT 3
- Converting copy constructor SFINAE test seems broken HOT 1
- TYPE_SAFE_BUILD_TEST_EXAMPLE=OFF still results in building tests / examples
- README.md blog links are dead HOT 1
- How to constraint a semantic type? HOT 9
- Failed to compile with MSVC HOT 1
- Linker error in specific circumstances with Doctest HOT 6
- Create a New Release HOT 1
- Add __declspec(empty_bases) to integer_arithmetic and floating_point_arithmetic HOT 2
- strong_typedef is not structural
- Allow implicit narrowing conversion if constexpr is known to fit HOT 5
- strong_typedef: numeric_limits HOT 1
- Make is_strong_typedef public HOT 3
- Bitwise operations for integer_ops HOT 5
- CMake installation is not architecture independent HOT 2
- Clashes with type like uint8_t HOT 1
- Standard library module HOT 2
- Fix or work around a probable MS compiler bug when using C++ 20 or above HOT 1
- std::aligned_storage_t are deprecated in C++23 HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from type_safe.