On 2012-01-18 09:30, sclytrack wrote:


Is it practical or realistic to throw it out at this stage? I don't
know. But there are reasons to.


I hope we are not dropping properties
regardless of the syntax of how to call them.

Keep @property
Keep methods-as-properties

---------------------------------
(a) No ()

obj.property = "test";
string str = obj.property;

obj.method = "string";
obj.method("first");
string str = obj.method;
obj.method("first", "second");

---------------------------------
(b) Optional () for methods

obj.property = "test";
string str = obj.property;

obj.method = "string";
obj.method("first");
string str = obj.method;
string str = obj.method();
obj.method("first", "second");

---------------------------------
(c) Mandatory () for methods

obj.property = "test";
string str = obj.property;

obj.method = "string";
obj.method("first");
string str = obj.method();
obj.method("first", "second");

---------------------------------
(d) Property and Method separated. (Is this the goal for -property?)

obj.property = "test";
string str = obj.property;

string str = obj.method();
obj.method("first");
obj.method("first", "second");

---------------------------------

Who likes (a) ?

Also I think that the @property opDispatch() looks weird.

I would like this:

property:
        getter - parentheses are not allowed
        setter:
                * equal sign is required
                * parentheses are not allowed

method:
        no parameters - parentheses are optional
        parameters:
                * parentheses are required
                * equal sign is not allowed

Examples:

obj.property; // legal
obj.property = 1; // legal
obj.property(); // error
obj.property(1); // error

obj.method; // legal
obj.method(); // legal
obj.method(1); // legal
obj.method = 1; // error

--
/Jacob Carlborg

Reply via email to