Rocksolid Light

News from da outaworlds

mail  files  register  groups  login

Message-ID:  

BOFH excuse #241: _Rosin_ core solder? But...


comp / comp.unix.shell / ksh93: pipelines vs. job control

SubjectAuthor
* ksh93: pipelines vs. job controlChristian Weisgerber
`- Re: ksh93: pipelines vs. job controlMartijn Dekker

1
Subject: ksh93: pipelines vs. job control
From: Christian Weisgerber
Newsgroups: comp.unix.shell
Date: Mon, 13 May 2024 14:35 UTC
Path: eternal-september.org!news.eternal-september.org!feeder3.eternal-september.org!news.szaf.org!inka.de!mips.inka.de!.POSTED.localhost!not-for-mail
From: naddy@mips.inka.de (Christian Weisgerber)
Newsgroups: comp.unix.shell
Subject: ksh93: pipelines vs. job control
Date: Mon, 13 May 2024 14:35:32 -0000 (UTC)
Message-ID: <slrnv4499k.30g3.naddy@lorvorc.mips.inka.de>
Injection-Date: Mon, 13 May 2024 14:35:32 -0000 (UTC)
Injection-Info: lorvorc.mips.inka.de; posting-host="localhost:::1";
logging-data="4483"; mail-complaints-to="usenet@mips.inka.de"
User-Agent: slrn/1.0.3 (FreeBSD)
View all headers

.... or "how to accidentally hang your ksh93 session".

Bash has this shell option:

lastpipe
If set, and job control is not active, the shell runs
the last command of a pipeline not executed in the
background in the current shell environment.

The bit about job control sounds like a weird stipulation, but makes
sense once you think about it. I wonder how ksh93 handles that.
Famously, the AT&T ksh executes the last command of a pipeline in
the current shell:

$ x=foo
$ { /bin/sleep 10; echo bar; } | read x
$ echo $x
bar

However, a background pipeline runs in a subshell, as documented
in the man page:

$ x=foo
$ { /bin/sleep 10; echo bar; } | read x &
[1] 78726
$
[1] + Done { /bin/sleep 10; echo bar; } | read x &
$ echo $x
foo

But we are in job control environment. I can start a pipeline in
the foreground, suspend it, and put it into the background. ksh93
can't know about that in advance.

$ { /bin/sleep 10; echo bar; } | read x
^Z

.... and now the pipeline is suspended...

PID PGID STAT COMMAND
71496 71496 S - ksh93 ksh93
62980 62980 T+ `-- ksh93 ksh93
3778 62980 T+p `-- /bin/sleep 10

.... and you're stuck. There's no shell prompt, so you can't bg or fg
anything, intr (^C) or quit (^\) don't help, and there's no tty
control character to continue a suspended process (group).

You need to take radical measures like hanging up, or sending a
SIGCONT or SIGKILL from a different terminal.

I can't quite tell if this behavior constitutes a bug, but it seems
to follow from the design decision to not run the last command of
a pipeline in a subshell. And it can trap the unwary.

A more minimal example:

$ /bin/sleep 10 | read
^Z

PID PGID STAT COMMAND
30796 30796 S - ksh93 ksh93
31981 31981 T+p `-- /bin/sleep 10

--
Christian "naddy" Weisgerber naddy@mips.inka.de

Subject: Re: ksh93: pipelines vs. job control
From: Martijn Dekker
Newsgroups: comp.unix.shell
Date: Sun, 19 May 2024 19:21 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!feeder3.eternal-september.org!fu-berlin.de!uni-berlin.de!individual.net!not-for-mail
From: martijn@inlv.demon.nl (Martijn Dekker)
Newsgroups: comp.unix.shell
Subject: Re: ksh93: pipelines vs. job control
Date: Sun, 19 May 2024 20:21:06 +0100
Lines: 32
Message-ID: <lav1p2Fjj13U1@mid.individual.net>
References: <slrnv4499k.30g3.naddy@lorvorc.mips.inka.de>
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
X-Trace: individual.net Sua4UX4HQhlvkHuaudiUNgp1gZBtECYV7N/J7Wr5aQoi85BFs=
Cancel-Lock: sha1:0vU1ol5xAqxKDe0hULHk/A0fVtY= sha256:7tkxbo+86LETplmybVt3u4Z/dKe57JVNnfrCubifSbM=
User-Agent: Mozilla Thunderbird
Content-Language: nl, en-GB
In-Reply-To: <slrnv4499k.30g3.naddy@lorvorc.mips.inka.de>
View all headers

Op 13-05-2024 om 15:35 schreef Christian Weisgerber:
> ... and you're stuck. There's no shell prompt, so you can't bg or fg
> anything, intr (^C) or quit (^\) don't help, and there's no tty
> control character to continue a suspended process (group).
>
> You need to take radical measures like hanging up, or sending a
> SIGCONT or SIGKILL from a different terminal.
>
> I can't quite tell if this behavior constitutes a bug, but it seems
> to follow from the design decision to not run the last command of
> a pipeline in a subshell. And it can trap the unwary.
>
>
> A more minimal example:
>
> $ /bin/sleep 10 | read
> ^Z

In my view, this is certainly a bug. The shell should not hang under any
circumstances. I've filed it under:

https://github.com/ksh93/ksh/issues/750

and we'll try to find a fix or workaround for it eventually.

--
|| modernish -- harness the shell
|| https://github.com/modernish/modernish
||
|| KornShell lives!
|| https://github.com/ksh93/ksh

1

rocksolid light 0.9.8
clearnet tor