Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > gnu.bash.bug > #14045 > unrolled thread

Re: [BUG] RETURN trap with -o functrace: infinite recursion on 'eval return'

Started byChet Ramey <chet.ramey@case.edu>
First post2018-04-13 21:49 -0400
Last post2018-04-13 21:49 -0400
Articles 1 — 1 participant

Back to article view | Back to gnu.bash.bug

This discussion starts older than the indexed window; earlier articles aren't shown. The article labeled Started by below is the oldest one visible, not the original post.


Contents

  Re: [BUG] RETURN trap with -o functrace: infinite recursion on 'eval return' Chet Ramey <chet.ramey@case.edu> - 2018-04-13 21:49 -0400

#14045 — Re: [BUG] RETURN trap with -o functrace: infinite recursion on 'eval return'

FromChet Ramey <chet.ramey@case.edu>
Date2018-04-13 21:49 -0400
SubjectRe: [BUG] RETURN trap with -o functrace: infinite recursion on 'eval return'
Message-ID<mailman.12340.1523670609.27995.bug-bash@gnu.org>
On 4/10/18 5:56 AM, Martijn Dekker wrote:
> $ bash -o functrace -c 'fn() { eval "return"; }; trap "fn" RETURN; fn'
> 
> Result: segfault due to infinite recursion.

Thanks for the report; I'll fix this.

 __________
> 
> Even apart from this bug with 'eval return', the effect of '-o functrace'
> is a bit strange:
> 
> $ bash -o functrace -c 'fn() { printf foo; fn2; };
>     fn2() { printf bar; fn3; };
>     fn3() { printf baz\\n; };
>     trap fn RETURN; fn'
> foobarbaz
> foobarbaz
> foobarbaz
> foobarbaz
> 
> (I'd expect one 'foobarbaz', not four)
> 
> It seems odd that the RETURN trap would be triggered while a RETURN trap
> action is still being executed. Might it be better to temporarily
> deactivate the effect of '-o functrace' while a RETURN trap action is being
> executed?

Well, trap handlers are recursive, in the sense that you can execute a trap
on signal X from a signal X trap handler. If the RETURN trap is inherited
by functions, and traps are recursive, wouldn't the bash behavior be the
logical thing to do? (Yes, I know there are problems with recursive signal
handler invocations in bash-4.4.)

Chet
-- 
``The lyf so short, the craft so long to lerne.'' - Chaucer
		 ``Ars longa, vita brevis'' - Hippocrates
Chet Ramey, UTech, CWRU    chet@case.edu    http://tiswww.cwru.edu/~chet/

[toc] | [standalone]


Back to top | Article view | gnu.bash.bug


csiph-web