On 28 March 2013 09:39, Dean Rasheed <dean.a.rasheed@gmail.com> wrote:
> On 27 March 2013 17:14, Brendan Jurd <direvus@gmail.com> wrote:
>> Well the fix is primarily about 1-D empty arrays, and in that respect
>> it is much less confusing than what we have now.
>
> Maybe. But even in 1-D, it's still jumping from having one empty array
> to infinitely many starting at different indexes, e.g., '{}'::int[] !=
> '[4:3]={}'::int[]. There may be a certain logic to that, but I'm not
> convinced about its usefulness.
We already have the ability to define lower bounds other than 1 on
arrays, and it would be inconsistent to allow that for arrays with
elements, but not for arrays without.  I could imagine somebody
wanting to create an empty zero-based array, and then iteratively
append elements to it.
> Also, it is incompatible with the choice made for empty ranges,
To me it doesn't make sense to try to draw parallels between arrays
and ranges, they really are completely different things.
Cheers,
BJ