From d6642e439baafa141608cfa0e6d38478f841f837 Mon Sep 17 00:00:00 2001 From: Father Chrysostomos Date: Wed, 28 Mar 2012 23:38:05 -0700 Subject: =?UTF-8?q?[perl=20#111864]=20Don=E2=80=99t=20leave=20obj=20on=20s?= =?UTF-8?q?tack=20for=20-x=20$overloaded?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Commit 8db8f6b697e changed the way filetest operators use the stack, in order to make stacked -t work. Filetest operators were changed to pop the argument off the stack for a standalone operator, but to leave it on the stack for a stacking op (so the next operator could use it). The code for handling overloaded objects, which was separate, was already doing something similar, by not popping the object off the stack. I made the mistake of changing overloaded objects’ return code to share code with regular filetest operators (the FT_RETURN_* macros), but without changing the way the overload code got the item from the stack to begin with. Hence, the returning code assumed that the argu- ment had been popped for non-stacking ops, which was not the case. This commit changes the way the overload case does it’s return, to account for the fact that the object must be left on the stack when initially fetched from it (in case the object turns out not to have -X overloading and the regular code has to kick in). --- t/op/filetest_stack_ok.t | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 't/op/filetest_stack_ok.t') diff --git a/t/op/filetest_stack_ok.t b/t/op/filetest_stack_ok.t index 6be383a947..4128612d6c 100644 --- a/t/op/filetest_stack_ok.t +++ b/t/op/filetest_stack_ok.t @@ -12,7 +12,10 @@ BEGIN { my @ops = split //, 'rwxoRWXOezsfdlpSbctugkTMBAC'; -plan( tests => @ops * 4 ); +plan( tests => @ops * 5 ); + +package o { use overload '-X' => sub { 1 } } +my $o = bless [], 'o'; for my $op (@ops) { ok( 1 == @{ [ eval "-$op 'TEST'" ] }, "-$op returns single value" ); @@ -40,4 +43,7 @@ for my $op (@ops) { } $count++; } + + my @foo = eval "-$op \$o"; + is @foo, 1, "-$op \$overld did not leave \$overld on the stack"; } -- cgit v1.2.1