problem with template arguments deduction
Zhenya
zheny at list.ru
Fri Jun 1 07:28:13 PDT 2012
On Friday, 1 June 2012 at 12:53:16 UTC, Zhenya wrote:
>
>> ну как же map, filter и тд работают )
>> ну передавай свой delegate как
>> параметр времени компиляции
>> через !(...)
>> все будет ок ...
> нууу так не прикольно.
> А это часом не бага у DMD?
кстати если я заменяю
template bind(alias indeces)
{
static if(is(typeof(indeces) : int[]))
{
auto bind(D,V...)(D dg,V values)
{
static if(is(D d : R delegate(U), R, U...) &&
is(V == Combination!(indeces,ParameterTypeTuple!D)))
{
static if(indeces.length > 1)
return
bind!(update!(indeces,indeces[0])[1..$]).bind(Curry!(indeces[0])(dg,values[0]),values[1..$]);
else static if(indeces.length == 1)
return Curry!(indeces[0])(dg,values[0]);
}
}
}
}
на
class Bind(alias indeces)
{
static auto opCall(D,V...)(D dg,V values)
{
static if(is(D d : R delegate(U), R, U...) &&
is(V == Combination!(indeces,ParameterTypeTuple!D)))
{
static if(indeces.length > 1)
return
Bind!(update!(indeces,indeces[0])[1..$])(Curry!(indeces[0])(dg,values[0]),values[1..$]);
else
return Curry!(indeces[0])(dg,values[0]);
}
}
}
то вот так
Bind!([1,0,3])(&checker!(int,int,int,int),2,1,4)(3);
вполне спокойно работает
в чем же разница?
More information about the Digitalmars-d-learn
mailing list