Template constructor instantiation syntax remains unresolved

Nicholas Wilson iamthewilsonator at hotmail.com
Sun Jan 27 04:11:00 UTC 2019


On Sunday, 27 January 2019 at 01:22:09 UTC, James Blachly wrote:
> I ran in to this bug from 2013 tonight:
>
> https://issues.dlang.org/show_bug.cgi?id=10689
>
> Briefly, templated (and overloaded) constructor syntax is 
> supported:
>
>     this(int MAX_UNPACK = BCF_UN_ALL, T)(T *h, bcf1_t *b)
>     if(is(T == VCFHeader) || is(T == bcf_hdr_t))
>     {
> ...
>     }
>     this(SS)(VCFHeader *vcfhdr, string chrom, int pos, string 
> id, string _ref, string alt, float qual, SS filter, )
>     if (isSomeString!SS || is(SS == string[]))
>     {
> ...
>     }
>     this(int MAX_UNPACK = BCF_UN_ALL)(VCFHeader *vcfhdr, string 
> line)
>     {
> ...
>     }
>
>
> But there is no way (?) to instantiate these with specific 
> template value parameters. (Deduction works just fine)
>
>     auto rr = new VCFRecord!BCF_UN_STR(vw.vcfhdr, "...");
>
> for example, returns the same error it did in 2013:
>
> Error: template instance `VCFRecord!BCF_UN_STR` VCFRecord is 
> not a template declaration, it is a class
>
>
>
> Suggestions given in past threads include templating the class, 
> but in this, and other posters' examples, the constructor is 
> overloaded with several ways to construct the object.  Too, I 
> am not sure how templating the class would work with template 
> value parameters (vice type params).
>
> Given that templating the constructor is well-supported 
> syntactically, the suggestion to use a factory function seems 
> inelegant.
>
> Thanks for listening and suggestions.
> James

This works fro the struct case:

struct A {
	string s;
	int n;
	this( string s) { this.s = s; }
	this( int k)( int n) { this.n = n - k; }
}
void main()
{
     A a = void;
     a.__ctor!3(42);
}

Not sure about the class case but you can probably concoct 
something similar.



More information about the Digitalmars-d mailing list