[devel] /bin/sh errexit semantics

Alexey Tourbin =?iso-8859-1?q?at_=CE=C1_altlinux=2Eru?=
Пт Апр 14 23:34:32 MSD 2006


On Fri, Apr 14, 2006 at 10:23:01PM +0400, Alexey Rusakov wrote:
> > Чего я интуитивно хочу: чтобы при вызове 'func || что-то' функция func
> > отвалила бы на команде false, т.е. вернула бы статус false, а часть
> > "after false" выполняться не должна.  Почему я этого интуитивно хочу?
> > Если бы функция func() была отдельным исполняемым файлом (который
> > выполняется в режиме errexit), поведение было бы именно таким
> Ну, в манах по этому поводу сказано, что если команда является частью 
> проверки условия, или её результат отрицается через !, или команда 
> является частью выражения с || или &&, то семантика errexit не 
> поддерживается. Я могу только посоветовать ставить хвосты "|| return $?" 
> везде в функции, где может быть неудачное выполнение команды.

Получается, что в errexit mode невозможно сделать wrapper для функции,
который проверяет код возврата этой функции.  Неконсистентно.  Напр. в
скрипте cmdcache используется такая конструкция:

	rc=0
	"$@" >out$$ || rc=$?
	if [ $rc -eq 0 ]; then
		сохранить в кеш out$$
	else
		удалить out$$
		return $rc
	fi

Поскольку errexit в таком случае не работает, "$@" скорее всего вернёт 0.
Если же убрать '|| rc=$?', то невозможно будет удалить out$$ в случае
ненулевого возврата.
----------- следующая часть -----------
Было удалено вложение не в текстовом формате...
Имя     : =?iso-8859-1?q?=CF=D4=D3=D5=D4=D3=D4=D7=D5=C5=D4?=
Тип     : application/pgp-signature
Размер  : 189 байтов
Описание: =?iso-8859-1?q?=CF=D4=D3=D5=D4=D3=D4=D7=D5=C5=D4?=
Url     : <http://lists.altlinux.org/pipermail/devel/attachments/20060414/efdb652d/attachment-0001.bin>


Подробная информация о списке рассылки Devel