in reply to Using ternary operator as lvalue in push

This problem is due to the prototype of the push function.

The prototype for push is \@@ and this means that perl needs to check that the first argument to push is an array.

You can make your own function that will give the same errors with

sub tst_push(\@@) { }
Also note that the code below works, as perl can optimize out the ternary.
push(1 ? @a : @b, 'asdf'); push(1 == 0 ? @a : @b, 'asdf');
The code above make it pretty clear to me that precedence is not the problem. If you don't like the push(@{$x ? \@a : \@b}.. syntax you could do this:
sub apush($@) { my $a = shift; push @$a, @_; }
and use
apush($cond>0 ? \@a : \@b, $elem);
But to answer the question you pose: the push @{$x ? \@a : \@b}, $elem; code is portable over all perl versions.
-- gam3
A picture is worth a thousand words, but takes 200K.