summary refs log tree commit diff
path: root/src/mksignames.c
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2010-11-28 15:17:45 +0800
committerHerbert Xu <herbert@gondor.apana.org.au>2010-11-28 15:17:45 +0800
commitfaefce1ebe585366b1458031f2c1f723dc630def (patch)
tree88907858585ca340ad9bd560c319c8635f687a99 /src/mksignames.c
parent[EXPAND] Fix ifsfirst/ifslastp leak in casematch (diff)
downloaddash-faefce1ebe585366b1458031f2c1f723dc630def.tar.gz
dash-faefce1ebe585366b1458031f2c1f723dc630def.zip
[EVAL] Fixed trap/return regression due to SKIPEVAL removal
On Wed, Aug 11, 2010 at 08:06:16AM +0000, Guido Berhoerster wrote:
> 
> with the latest git version of dash trap actions are not
> evaluated in the context of a function.
> 
> The following script demonstrates the bug:
> ----8<----
> read_timeout () {
>     saved_traps="$(trap)"
>     trap 'printf "timed out\n"; eval "${saved_traps}"; return' TERM
>     ( sleep $1; kill -TERM $$ ) >/dev/null 2>&1 &
>     timer_pid=$!
>     read $2
>     kill $timer_pid 2>/dev/null
> }
> 
> read_timeout 5 value
> printf "read \"%s\"\n" "${value:=default}"
> 
> ---->8----
> The return statement in the trap inside the read_timeout function
> does not return from the function but rather exits the script.
> 
> With dash 0.5.5.1 it works as expected.

This bug was caused by the SKIPEVAL removal.  When the SKIPEVAL
hack was added to improve set -e support in traps, dotrap was
changed to return whether set -e was detected.  After the removal
of SKIPEVAL, set -e is now handled through exraise.

However, dotrap still returned a value which is now incorrectly
used to trigger an exraise.

This patch removes the vestigial link between dotrap and exraise.

Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'src/mksignames.c')
0 files changed, 0 insertions, 0 deletions
odeJune McEnroe And add warnings to configOpen, since that's the only way to be accurate if a weird error occurs. 2020-02-10Leave a blank line after loaded bufferJune McEnroe 2020-02-10Add -s to save and load buffersJune McEnroe 2020-02-10Show heat and other unread in titleJune McEnroe 2020-02-10Eliminate array in hashJune McEnroe I expected to have to remove some arbitrary colors, but it seems like just the range 2-75 works fine. 2020-02-10Add -HJune McEnroe 2020-02-10Hash to colors in the range 2-75June McEnroe Colors 76-87 seem too light, some almost appearing white. Colors 88-98 are shades of gray. 2020-02-10Improve color fudgingJune McEnroe Prevent fudged colors from ever being pure black. Distribute fudged colors between normal and bold if COLORS is 8. Fudge colors before checking if it's a pre-allocated pair. 2020-02-10Support all 99 IRC colorsJune McEnroe Corresponding ANSI colors from the table on ircdocs. 2020-02-10Avoid coloring mentions if there are control codesJune McEnroe This was breaking leading color codes. 2020-02-10Recalculate unreadLines on reflowJune McEnroe 2020-02-10Only make windows hotterJune McEnroe A warm message shouldn't clear a window's hotness. 2020-02-10Always increase unreadLinesJune McEnroe So that if you switch to a window and some new activity happens before you press M-u, it'll still jump to the right place. 2020-02-10Move scroll marker on resizeJune McEnroe 2020-02-10Update line count for words longer than linesJune McEnroe 2020-02-10Simplify mark, heat, unread trackingJune McEnroe 2020-02-10Update prompt when own nick changesJune McEnroe 2020-02-10Match URLs surrounded by parenthesesJune McEnroe But include a pair of parentheses in the URL itself. 2020-02-10Fix M-a so it properly cycles back to where it startedJune McEnroe 2020-02-09Add M-lJune McEnroe 2020-02-09Add /whoisJune McEnroe 2020-02-09Add /msgJune McEnroe