An issue with templates with non-existant symbols
Timon Gehr
timon.gehr at gmx.ch
Mon Aug 22 12:50:44 PDT 2011
On 08/22/2011 04:16 AM, Andrej Mitrovic wrote:
> void foo(T)(T t) if(is(X == struct)) { }
>
> void main()
> {
> foo(4);
> }
>
> This prints out:
>
> test.d(9): Error: template test.foo(T) if (is(X == struct)) does not
> match any function template declaration
> test.d(9): Error: template test.foo(T) if (is(X == struct)) cannot
> deduce template function
> from argument types !()(int)
>
> which is your typical template instantiation error. The real issue is
> that the symbol "X" doesn't actually exist.
>
> I've had a template I was refactoring and I've accidentally mistyped
> the name of the type, e.g.:
>
> void foo(T)(T r) if (is(T == struct) || is(t == class)) // t should have been T
>
> I was hoping for a better error message here. Can the compiler check
> that `is` has an expression with valid symbols in it?
No, because that would defeat the main purpose of 'is'. 'is' is to a
large extent there to allow you to check for conditions that are not
necessarily semantically valid.
However, the compiler could catch that the result of some parts of the
constraint does not actually depend on any template arguments to improve
the error message. Maybe you could write an enhancement request for this.
More information about the Digitalmars-d-learn
mailing list