Flag proposal

KennyTM~ kennytm at gmail.com
Tue Jun 14 06:18:28 PDT 2011


On Jun 14, 11 20:34, Michel Fortin wrote:
> On 2011-06-13 21:36:01 -0400, so <so at so.so> said:
>
>> IMO named arguments in D at least should do:
>>
>> - Reordering (since we got default parameters, even better)
>>
>> - It is enabled only if we have access to the function declaration.
>>
>> - In a function call we either use named arguments for all the
>> non-default arguments or call it with the usual syntax. No hybrid
>> stuff, no confusion.
>>
>> fun(int a, int b, int c=3)
>>
>> fun(1, 2, 3) // fine - current
>> fun(1, 2) // fine - current
>>
>> fun(a:1, b:3, c:5) // fine
>> fun(a:1, b:3) // fine
>> fun(b:1, c:3, a:5) // fine
>> fun(b:1, a:3) // fine
>> fun(b:1) // error
>> fun(c:1) // error
>> fun(2, b:1) // error
>> fun(2, c:1) // error
>> fun(2, c:2, 3) // error
>
> There's much more to named arguments as it first appears. Have you
> thought about:
>
> 1. variadic arguments?
> 2. named template arguments?

     partition!(ss:SwapStrategy.stable,
                predicate:"a>0")
               (r:[1,2,3,4]);

Variadic is a real problem though. IIRC C# doesn't allow it.

> 3. template variadic arguments (tuples) and how they expand as function
> parameters?
>
> Also, with reordering, if you have two overloaded functions of this form:
>
> void fun(int a, string b) {}
> void fun(string b, int a) {}
>
> which one does this calls:
>
> fun(a: 1, b: "hello");
>
> ? Does the call become ambiguous when using named arguments? It wouldn't
> be ambiguous if reordering wasn't allowed. What does C# does with this?
>
>

Looks like the last one get the precedence. At least for Mono (see 
http://ideone.com/REXC0). MSDN says

============================================
Use of named and optional arguments affects overload resolution in the 
following ways:

- A method, indexer, or constructor is a candidate for execution if each 
of its parameters either is optional or corresponds, by name or by 
position, to a single argument in the calling statement, and that 
argument can be converted to the type of the parameter.

- If more than one candidate is found, overload resolution rules for 
preferred conversions are applied to the arguments that are explicitly 
specified. Omitted arguments for optional parameters are ignored.

- If two candidates are judged to be equally good, preference goes to a 
candidate that does not have optional parameters for which arguments 
were omitted in the call. This is a consequence of a general preference 
in overload resolution for candidates that have fewer parameters.
============================================

It doesn't cover your case. Of course this is bad. But this isn't much 
different from another solved problem...

----------------------------------------
void f(float s){}
void f(double s){}

void main() {
     f(3);
}
----------------------------------------
x.d(5): Error: function x.f called with argument types:
	((int))
matches both:
	x.f(float s)
and:
	x.f(double s)
----------------------------------------

We could do the same for named arguments.

----------------------------------------
void fun(int a, string b) {}
void fun(string b, int a) {}

void main() {
     fun(a: 1, b: "hello");
}
----------------------------------------
x.d(5): Error: function x.fun called with argument names and types:
	((int a, string b))
matches both:
	x.f(int a, string b)
and:
	x.f(string b, int a)
----------------------------------------


More information about the Digitalmars-d mailing list