Today I was reading the C++17 support page of clang. I've notice something odd. The feature Matching template template parameters to compatible arguments (P0522R0) is marked as partial, because it must be activate through a switch. Their note says:
Despite being the the resolution to a Defect Report, this feature is disabled by default in all language versions, and can be enabled explicitly with the flag -frelaxed-template-template-args in Clang 4. The change to the standard lacks a corresponding change for template partial ordering, resulting in ambiguity errors for reasonable and previously-valid code. This issue is expected to be rectified soon.
What kind of constructs breaks when this feature is activated? Why can it break code and how?
You can have code like this:
Without the defect resolution,
unused
would be ill-formed, becausefoo
takes a template with only one template parameter, and not two. If you relied on this (maybe for SFINAE):Then the call would fail! The problem is that there was no corresponding change to partial ordering, and so both candidate functions have the same viability, and the call is ambiguous.
A more common scenario is when some code wants to inspect the template arguments with a set of partial specializations, e.g.:
Foo<std::vector<int>>
is now ill-formed without an appropriate partial ordering fix.