Robert Jacques wrote:
On Sat, 17 Jul 2010 00:58:58 -0400, dsimcha <dsim...@yahoo.com> wrote:

== Quote from Chad J (chadj...@__spam.is.bad__gmail.com)'s article
On 07/15/2010 09:16 AM, dsimcha wrote:
> Once property syntax is fully enforced (not necessarily recommended) will it > be possible to overload properties against non-properties? My use case is > that I'm thinking about API improvements for my dflplot lib and one thing that > I would really like is to give a fluent interface to everything to further cut > back on the amount of boilerplate needed to generate simple plots. For example:
>
> Histogram(someData, 10)
>     .barColor(getColor(255, 0, 0))
>     .histType(HistType.Probability)
>     .toFigure.title("A Histogram")
>     .xLabel("Stuff").showAsMain();
>
> The problem is that I also want things like barColor and title to be settable > via normal property syntax, using the equals sign. Right now, this "just > works" because D's current non-analness about enforcing @property-ness is > awesome 99% of the time even if it leads to a few weird corner cases. Will > there be a way to express such an interface to be provided (calling a setter > as either a member function or a property at the user's choice) once @property
> is fully implemented?
>
Wasn't this going to be handled by normal n...@property functions?
I was under the impression that normal functions/methods with no
arguments would still allow omission of parentheses and the assignments
would still be rewritten to 1-arg calls.  As long as the semantics of it
are handled correctly then that syntax will be safe; it just has to do
what the programmer /expects/.
The @property syntax can resolve some ambiguities, so they are quite
useful if you want to say, return a zero-argument delegate from a
property.

You're impression is correct with regard to D as it currently stands and the final @property proposal compromise.

This is what I'd vote for, but it's not what TDPL says.  Page 156:

"In particular 'property' is recognized by the compiler and signals the fact that the function bearing such an attribute must be called without the trailing ()."

Technically, TDPL simply doesn't mention Methods-as-Properties as they are currently implemented in D.

In the event of a difference between TDPL and DMD, TDPL always wins. The compiler will have to change.

Reply via email to