devel@ where you _can_ ask
 help / color / mirror / Atom feed
* Re: [newbies] Bash and POSIX - local variables
  @ 2025-11-20 21:44 ` Leonid Krivoshein
  2025-11-21  9:32   ` Alexander Lubyagin
  0 siblings, 1 reply; 3+ messages in thread
From: Leonid Krivoshein @ 2025-11-20 21:44 UTC (permalink / raw)
  To: devel-newbies

Добрый день!


On 11/20/25 18:28, Alexander Lubyagin wrote:
>
> Вот такой скрипт:
> x=42
> echo $x
> foo() {
>  local x=43
>  echo $x
> }
> foo
> echo $x
>
> Интерпретатор Bash:
> $ /bin/bash4 script
> 42
> 43
> 42
>
> Интерпретатор Bash в режиме POSIX:
> $ /bin/bash4 --posix script
> 42
> 43
> 42
>
> То есть, в POSIX-режиме тоже поддерживаются локальные для функций 
> переменные.
>
> Как же писать скрипт, после shebang в котором указан /bin/sh?
>
> Полагаться ли на поддержку локальных переменных?
>

Зависит от целеполагания. Поддержка local появилась давно. Во многих 
системах /bin/sh является симлинком на что-то, что совершенно не обязано 
быть POSIX-compliant shell. Например, даже в старых альтах это был bash3 
с поддержкой local. Проверяйте ash, используйте subshell ( ... ), если 
так важна переносимость. По-моему, все, кто за неё радел, уже давно 
забили на это дело и пользуются всеми прелестями башизмов. :-) Куда 
важнее для правильного скриптования использовать shellcheck.


-- 
WBR, Leonid Krivoshein.



^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [newbies] Bash and POSIX - local variables
  2025-11-20 21:44 ` [newbies] Bash and POSIX - local variables Leonid Krivoshein
@ 2025-11-21  9:32   ` Alexander Lubyagin
  2025-11-21 23:25     ` Leonid Krivoshein
  0 siblings, 1 reply; 3+ messages in thread
From: Alexander Lubyagin @ 2025-11-21  9:32 UTC (permalink / raw)
  To: devel-newbies

21.11.2025 00:44, Leonid Krivoshein пишет:
>> [ ... ]
>>
>> Полагаться ли на поддержку локальных переменных?
>
> Зависит от целеполагания. Поддержка local появилась давно. Во многих 
> системах /bin/sh является симлинком на что-то, что совершенно не 
> обязано быть POSIX-compliant shell. Например, даже в старых альтах это 
> был bash3 с поддержкой local. Проверяйте ash, используйте subshell ( 
> ... ), если так важна переносимость. По-моему, все, кто за неё радел, 
> уже давно забили на это дело и пользуются всеми прелестями башизмов. 
> :-) Куда важнее для правильного скриптования использовать shellcheck.

Да, по-моему, переносимость между shell-ами в соответствии со стандартом 
является реликтом.

Будет ли нормальным заменить shebang-строки в модулях Альтератора на 
/bin/bash ?

Там полно локальных переменных.

Хотя в ash и pdksh локальные переменные и поддерживаются.

$ ls -l /bin/sh
lrwxrwxrwx 1 root root 3 фев 19  2019 /bin/sh-> sh4

-- 


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [newbies] Bash and POSIX - local variables
  2025-11-21  9:32   ` Alexander Lubyagin
@ 2025-11-21 23:25     ` Leonid Krivoshein
  0 siblings, 0 replies; 3+ messages in thread
From: Leonid Krivoshein @ 2025-11-21 23:25 UTC (permalink / raw)
  To: devel-newbies


On 11/21/25 12:32, Alexander Lubyagin wrote:
> 21.11.2025 00:44, Leonid Krivoshein пишет:
>>> [ ... ]
>>>
>>> Полагаться ли на поддержку локальных переменных?
>>
>> Зависит от целеполагания. Поддержка local появилась давно. Во многих 
>> системах /bin/sh является симлинком на что-то, что совершенно не 
>> обязано быть POSIX-compliant shell. Например, даже в старых альтах 
>> это был bash3 с поддержкой local. Проверяйте ash, используйте 
>> subshell ( ... ), если так важна переносимость. По-моему, все, кто за 
>> неё радел, уже давно забили на это дело и пользуются всеми прелестями 
>> башизмов. :-) Куда важнее для правильного скриптования использовать 
>> shellcheck.
>
> Да, по-моему, переносимость между shell-ами в соответствии со 
> стандартом является реликтом.
>
> Будет ли нормальным заменить shebang-строки в модулях Альтератора на 
> /bin/bash ?
>

Нет, потому что нет оснований для такой замены. В те времена, когда 
писалось большинство его модулей, это было фактически bash3. Под 
сложившиеся стили проектов необходимо подстраиваться.


> Там полно локальных переменных.
>

Конечно, они давно поддерживаются практически везде.


> Хотя в ash и pdksh локальные переменные и поддерживаются.
>
> $ ls -l /bin/sh
> lrwxrwxrwx 1 root root 3 фев 19  2019 /bin/sh-> sh4
>

Это вообще ни о чём не говорит. У данного симлинка в репо много провайдсов.
https://packages.altlinux.org/ru/sisyphus/files/?q=%2Fbin%2Fsh


-- 
WBR, Leonid Krivoshein.



^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2025-11-21 23:25 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-11-20 21:44 ` [newbies] Bash and POSIX - local variables Leonid Krivoshein
2025-11-21  9:32   ` Alexander Lubyagin
2025-11-21 23:25     ` Leonid Krivoshein

devel@ where you _can_ ask

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel-newbies/0 devel-newbies/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel-newbies devel-newbies/ http://lore.altlinux.org/devel-newbies \
		devel-newbies@lists.altlinux.org devel-newbies@lists.altlinux.ru devel-newbies@lists.altlinux.com
	public-inbox-index devel-newbies

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel-newbies


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git