At 2003-11-05 09:59 +0100, Michael Walter wrote:
>Very cool.
>
>How about supporting .. syntax, btw. as in [1..3] or ["a".."z"]? Might no be the 
>worth, just thinking out loud ;)

I'm also in favor of a shorter notation for array() and list().

In fact this also helps to ease the problem I have
with 'foreach ($A as $I=>$d)', because it would
then be possible to write: while ([$i,$d]=each($A)).
It's still not as short as I'd like it to be:
'while ($i=>$d in $A)', but it's already a lot
better.

I'd also like to see ranges supported and propose
to add notations for inclusive and non-inclusive
ranges as:
1..3 inclusive at both ends so equal to 1,2,3
1.<3 non inclusive at the end so equal to 1,2
1>.3 non inclusive at the beginning so equal to 2,3
1><3 non inclusive at both ends so equal to 2

Of course generally only the first two variations
are being used.

(Please note that this syntax conflicts slightly
with the syntax of floating point numbers and
compares. Perhaps it's solvable by scanning '..',
'.<', '>.' and '><' as tokens first and not
allowing ranges with floating point numbers
anyway.)

By the way, Python has three 'group' notations:
[] for a list
{} for a dictionary
() for a tuple

Very confusing (and one of the reasons I prefer PHP
over Python ;-), and I agree with Rasmus that at least
here the symbols no longer make clear what is being
meant, but I think that just [] for the values in an
array is very intuitive because the same symbols are
being used to add the index of an array. (But {}
from the set notion in mathematics would be fine too,
I think).

By the way, don't forget to allow a comma at the end
of a list: 1,2,3,

This especially makes sense when the elements are
listed each on a seperate line:
1,
2,
3,

Greetings,
Jaap


>Christian Schneider wrote:
>>I propose to add an alternative (backward compatible) short array creation syntax:
>>$a = [ 1, 2, 3 ]; and $a = [ 'a' => 42, 'b' => "foo" ];
>>It can also be used in function calls:
>>img(['src' => "logo.gif", 'alt' => "Logo"]);
>>Reason behind this change: Arrays are used a lot and should therefore have as little 
>>syntactic overhead as possible. And I think the short syntax is also easier to read 
>>and write.
>>A patch for the parser is trivial and is attached for Zend2.
>>Note: I checked the newsgroup archive but couldn't find a discussion about this. 
>>After not hearing back about my proposed enhancement to debug_backtrace() and the 
>>dangling comma for function call parameters being rejected I wonder if I'm using the 
>>right mailing list for this :-)
>>- Chris
>>
>>------------------------------------------------------------------------
>>Index: Zend/zend_language_parser.y
>>===================================================================
>>RCS file: /repository/ZendEngine2/zend_language_parser.y,v
>>retrieving revision 1.127
>>diff -u -r1.127 zend_language_parser.y
>>--- Zend/zend_language_parser.y 19 Oct 2003 08:38:48 -0000      1.127
>>+++ Zend/zend_language_parser.y 4 Nov 2003 23:32:12 -0000
>>@@ -581,6 +581,7 @@
>>        |       '@' { zend_do_begin_silence(&$1 TSRMLS_CC); } expr { 
>> zend_do_end_silence(&$1 TSRMLS_CC); $$ = $3; }
>>        |       scalar                          { $$ = $1; }
>>        |       T_ARRAY '(' array_pair_list ')' { $$ = $3; }
>>+       |       '[' array_pair_list ']' { $$ = $2; }
>>        |       '`' encaps_list '`'             { zend_do_shell_exec(&$$, &$2 
>> TSRMLS_CC); }
>>        |       T_PRINT expr  { zend_do_print(&$$, &$2 TSRMLS_CC); }
>> ;
>
>-- 
>PHP Internals - PHP Runtime Development Mailing List
>To unsubscribe, visit: http://www.php.net/unsub.php

-- 
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to