diff options
| author | Richard Smith <richard-llvm@metafoo.co.uk> | 2016-12-31 21:41:23 +0000 | 
|---|---|---|
| committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2016-12-31 21:41:23 +0000 | 
| commit | 26b86ea8b1673229ed07e952783abe21b1d954d6 (patch) | |
| tree | 6b80ad071ea9856fa891884c6b658bb7feabbdf1 /llvm/lib/CodeGen/TargetFrameLoweringImpl.cpp | |
| parent | c8bf96182dc24439a097d24b158d1901eedf077a (diff) | |
| download | bcm5719-llvm-26b86ea8b1673229ed07e952783abe21b1d954d6.tar.gz bcm5719-llvm-26b86ea8b1673229ed07e952783abe21b1d954d6.zip | |
[c++17] Implement P0522R0 as written. This allows a template template argument
to be specified for a template template parameter whenever the parameter is at
least as specialized as the argument (when there's an obvious and correct
mapping from uses of the parameter to uses of the argument). For example, a
template with more parameters can be passed to a template template parameter
with fewer, if those trailing parameters have default arguments.
This is disabled by default, despite being a DR resolution, as it's fairly
broken in its current state: there are no partial ordering rules to cope with
template template parameters that have different parameter lists, meaning that
code that attempts to decompose template-ids based on arity can hit unavoidable
ambiguity issues.
The diagnostics produced on a non-matching argument are also pretty bad right
now, but I aim to improve them in a subsequent commit.
llvm-svn: 290792
Diffstat (limited to 'llvm/lib/CodeGen/TargetFrameLoweringImpl.cpp')
0 files changed, 0 insertions, 0 deletions

