シェルスクリプト総合 その37

レス数が1000を超えています。これ以上書き込みはできません。
2021/10/05(火) 22:49:30.91ID:KsbWuyFp
シェルスクリプトに関する総合スレッドです。

全般
・荒しは無視しましょう。
・丁寧な姿勢を心掛けましょう。
・ネチケット(死語)を意識しましょう。
・「○○(他の言語)でいいやん」は禁止。他のスレに行ってください。
・「POSIX原理主義」「ユニケージ」「USP研究所」はPOSIXとUnixを曲解し
間違ったシェルスクリプトを広めている宗教です。洗脳されないようにしてください。

前スレ: シェルスクリプト総合 その36
https://mevius.5ch.net/test/read.cgi/tech/1614212414/

関連スレ
・【Bash】Windows Subsystem for Linux【WSL】11
https://mao.5ch.net/test/read.cgi/linux/1627507889/
・Bashでプログラミング [転載禁止](c)2ch.net
https://mao.5ch.net/test/read.cgi/linux/1443885102/
・シェルスクリプト総合 その28
https://mevius.5ch.net/test/read.cgi/unix/1533154936/
・zsh その7
https://mevius.5ch.net/test/read.cgi/unix/1337844883/
・過去UNIXで使われていた ksh というシェルについて
https://mevius.5ch.net/test/read.cgi/unix/1582358403/
・【POSIX】UNIXプログラミング【BSD】 [転載禁止](c)2ch.net
https://mevius.5ch.net/test/read.cgi/unix/1443103705/
・おまえら! shell は何を使っているんですか?
https://mevius.5ch.net/test/read.cgi/unix/1012330865/
2022/12/15(木) 20:30:31.26ID:ckKyI6FD
Unix/Linuxは昔から実行中にファイルを書き換えられる
Windowsとは違う
2022/12/15(木) 21:57:10.51ID:RzHoZPr/
超Geekぐらいだろな、役立つように使おうとするのは
機能としてではなく限られたメモリ上でどうするかでそうなったんじゃね
>>943
バイナリの正当な(?)実行ファイルもそうなのか?
あり得ないけど=今時のUnix系OSはそうはならない
2022/12/15(木) 22:14:44.89ID:a9LNvh7S
UNIX/Linuxにはアドバイザリロックしかないんだから
実行中にファイルは書き換えられる
バイナリ実行ファイルは、スクリプト言語とは違って
最初にメモリに全部読み込むってだけ
2022/12/15(木) 23:02:40.00ID:DSr8QAEc
そもそも、シェルやしな。
インタラクティブが前提なら必要なとこまでしか読んどらんやろから、自然とそうなるんちゃうか。
2022/12/15(木) 23:11:24.42ID:a9LNvh7S
インタプリタっていうのは元々そういうもんだと思うけどね
一行ごとに解釈するものなんだから、必要ないところまで読み込む必要がない

最近のスクリプト言語は最初にファイル全体を解釈して
内部的にバイナリにしているような気がするけど
それもファイル単位で動的にファイルを読み込むこともあるし
2022/12/15(木) 23:16:12.82ID:5ZR90K1l
昨年末にHP(が作成したスクリプト)が京大のスパコンデータを吹き飛ばした事故があったけど、あれも原因は「実行中のシェルスクリプト書き換え」だったはず
2022/12/15(木) 23:19:14.14ID:a9LNvh7S
普通にバックアップ処理実行中に
プログラムアップデートするなって話だな
2022/12/16(金) 09:17:10.65ID:OmUfbGxN
>>947
opengroupはシェルスクリプトのコンパイルとか静的解析とか、なにやら不穏な事を考えているよう
One justification for ignoring the contents of IFS upon entry to the script, beyond security considerations, is to assist possible future shell compilers. Allowing IFS to be imported from the environment prevents many optimizations that might otherwise be performed via dataflow analysis of the script itself.
https://pubs.opengroup.org/onlinepubs/9699919799/utilities/sh.html

寡聞だが珍妙な事やってるシェルなんて知らないし、シェルスクリプトなんてロートルなのがむしろ魅力なのにな

ちなみに俺はexitの後に>>"$0"でデバッグ中のログ取りしてる、別にログファイル作るのめんどいしバッファ再読み込みでエディタにすぐフィードバックが得られる

他のビルトインの項を見ても珍妙な展望(?)が見られて面白い、誰が望むんだこれ
It is anticipated that a future implementation could take advantage of this and provide something like:

outofloop: for i in a b c d e
do
for j in 0 1 2 3 4 5 6 7 8 9
do
if test -r "${i}${j}"
then break outofloop
fi
done
done

and that this might be standardized after implementation experience is achieved.

実装に先走って舵取りまでやりたいのかこいつら、傲慢もいいとこ
2022/12/16(金) 09:26:55.18ID:OmUfbGxN
exitやexecの先まで読まれるとtclやperlのように頭だけシェルスクリプトとして読まれて、読まれない部分にコードを記述するインタプリタや、到達しない部分をデータ置き場として使ってるスクリプトが困るような

まあ展望されている実装が十分賢くて、そこでシンタックスエラー出さないなら問題無いんだけど
2022/12/16(金) 09:41:47.00ID:OmUfbGxN
source another-file
${exitcmd}
こんなもん解析できるわけねー
2022/12/16(金) 10:43:52.39ID:IL6/baQf
>>950
何言ってるの? opengroupはシェル開発者がやろうと思っていることを
妨げないようにしているだけ

シェルスクリプトのコンパイルであればBourne Shellの開発者がやろうとしたことだし
Korn Shellにはずっと前からシェルスクリプトのコンパイラがある

お前の意見を押し付けるな
傲慢はお前だろ
2022/12/16(金) 10:48:02.96ID:IL6/baQf
>>950
誰が望むんだって、それただのラベルを使ったループの脱出じゃん
そういった拡張シェルを作りたい人もいるだろうし
お前は、将来の目をつもうとしてるのか?
シェルが改良されたら困ることでもあるのか?

まああるんだろうな。
新しいシェルを勉強したくない
2022/12/16(金) 10:53:44.58ID:IL6/baQf
> ちなみに俺はexitの後に>>"$0"でデバッグ中のログ取りしてる、別にログファイル作るのめんどいしバッファ再読み込みでエディタにすぐフィードバックが得られる

珍妙な事やってるな(笑)
2022/12/16(金) 10:56:32.82ID:Z4pvnD7F
面倒がまた増えるのか
2022/12/16(金) 11:00:38.08ID:IL6/baQf
>>951
単純にシェルスクリプトにシェルスクリプトとして解析できないものを埋め込んだら
コンパイルできないってだけだろ

頭固いよ(笑)
なんでシェルスクリプトのコンパイラは
どんなシェルスクリプトにも対応できなきゃ駄目だって
思っちゃうの?

【注意】以下のようなコードを書いたらコンパイルできません

って注意書きを書くだけでいいんだよ?
もっと柔軟な頭を作ろうね(笑)
2022/12/16(金) 11:01:23.90ID:Z4pvnD7F
インタプリタを軽くした方が筋がいいと思うわ
dashもなだかんだでコマンドライン編集や規格に従いたくて対話機能落とせてないし
どうせスクリプティングにしか使われないんだから、規格なんて無視すればいいのにと思う
2022/12/16(金) 11:06:09.35ID:IL6/baQf
機能を削減したら互換性がなくなるだろ
規格準拠じゃなくて、互換性のためにやってる
2022/12/16(金) 12:14:08.72ID:uGaF/TrQ
>>950
vi編集モードの指定がやけに細かいな
dashはemacsもヒストリもサポートしてるしむしろ対話シェルとして十分使える方で、普段対話使いしてる人もまあ居るかも

シェルスクリプトエンジンとしては、ttyに見せかけてvi/emacs風キーバインドを送って間接的にコマンドバッファ弄ったり、ヒストリ検索活用するシェルスクリプトが多いなら互換性の為に要るけど、要るかね?

対話用途の人も少なからず居るだろうからdashとしては出せなくても、名前を変えてシェルスクリプトエンジンとしてもっと特化した版があれば嬉しい
2022/12/16(金) 16:12:38.11ID:nGRI2Vf+
シェルスクリプトなんてコンパイルしたところで外部呼び出しだらけだし大して速くもならんでしょ

恩恵あるのはビルトインだけでループぐるぐる回すベンチくらい
2022/12/16(金) 16:15:48.57ID:IL6/baQf
>>960
> vi編集モードの指定がやけに細かいな
もしかしてPOSIXが仕様を決めたから
dashはその通りに作ってるとか思ってる?

vi編集モードとかemacsとか、それを最初にやったのはkshなの
dashやbashや他のシェルはそれを真似しただけ
POSIXはkshやdashやbashで移植性があるものを文書化しただけなの

> 対話用途の人も少なからず居るだろうからdashとしては出せなくても、
> 名前を変えてシェルスクリプトエンジンとしてもっと特化した版があれば嬉しい

自分で作ればいいじゃん?POSIXに準拠してないシェルを作ってもいいんだよ。
dashはPOSIXに準拠するという方針なだけ

機能を減らすことで何が嬉しいのか知らんけど/bin/shとしては使えなくなるだろうね。
別にbashをインストールしなきゃ対話的に使えないOSになってしまう
2022/12/16(金) 16:18:55.94ID:IL6/baQf
>>961
×シェルスクリプトなんてコンパイルしたところで外部呼び出しだらけだし大して速くもならんでしょ
○外部呼び出しだらけのシェルスクリプトはコンパイルしたところで速くならない

他の言語のようにビルトインだけで作ればいいんだよ
作れるわけがない?

作れない理由を潰せば作れるよね?
シェルの将来としてそのようなシェルがあってもいい
2022/12/16(金) 16:53:39.13ID:OmUfbGxN
>>961
それを言ってはおしまいだけど、IFS決め打ちって文脈からパースについて楽できないかって話ね

しかし複合文は先読みでエラー出せることから分かるように、環境の更新や副作用起こす展開をしないループなら既に手抜きは可

長大なベタ書きならIFS決め打ちで結構削れるだろうが、そんなケチくさい努力に見合うとは思わない
2022/12/16(金) 17:10:31.82ID:IL6/baQf
>>964
何の話してるの?
楽できる機能を搭載したシェル作ればいいだけじゃん?
2022/12/16(金) 17:23:00.10ID:0LHDM9/j
まああれだね
「POSIXが変なことを考えていて、コンパイラとかを作ろうとしてる」
と勘違いしているアホが居る

POSIXがどういうものかを理解していれば
「POSIXはコンパイラを作ろうとしているシェルがあることを知っていて
そういったシェルを将来作れるように考慮している」
が正しいとわかる
2022/12/16(金) 23:21:48.19ID:KwA6ycaA
じゃあ後追いでええのにな。
様子や実装具合を見ながら。

どうせ普及せんのやろし。w
2022/12/16(金) 23:35:49.94ID:Out/cb9o
>>967
だから後追いじゃん?
POSIXが先に作ってる仕様なんてないぞ
どこにPOSIXがコンパイラの仕様を作ってる?
よーくみたまえよ
2022/12/17(土) 13:59:03.04ID:yWXMz5Ex
一部だけ認めるのでもまだ早い。
大半が実装してから共通項を整理するくらいでいい。
2022/12/17(土) 14:13:00.20ID:zTx/vduP
>>969
やっぱり理解が追いついてないか(苦笑)

1. シェルスクリプト用のコンパイラを作りました
2. この時点でPOSIX準拠になっていないといけない
3. 大半が実装してから共通項を整理する

大半が実装するまでの間、POSIX違反になっちゃいけないのよ
意味わかる?POSIX違反なコンパイラを作るな!って言われるでしょ

POSIXが正しいシェル間違ったシェルを決めるのは傲慢
POSIXは決まった以外ならどんなシェルでも許さなきゃいけない
2022/12/17(土) 14:13:48.77ID:zTx/vduP
訂正
POSIXは決まったこと以外であれば、どんなシェルでも許さなきゃいけない
2022/12/17(土) 14:23:48.31ID:zTx/vduP
「大半が実装するまでPOSIXでは認めない」
これが傲慢な考えだってわからないのは本当にヤバイよ
POSIXがルールになってるじゃん

「大半が実装しなくてもPOSIXはそれを禁止することはない」
2022/12/17(土) 15:41:00.83ID:fCc6f5AR
>>950
例にしてもラベルの位置が先頭なのは思慮が足りなさすぎるな、予約語認識のセマンティクスとBNFに手を入れることになる
仮にねじ込むとすれば、inの部分で認識される
新予約語に続けてラベル名
2022/12/17(土) 15:55:58.46ID:3o3z3wxM
for x of outerloop [in word+]
的な感じか
ofは適当だけど、既に予約されてて意味の通るトークンが流用できれば望ましい
2022/12/17(土) 16:24:44.82ID:dohNO5X8
>>973
それ例じゃないからw
あんたこれPOSIXの提案だって思ってるでしょ?

こんな事も考えられるってことでだけだよ
そんなことに突っ込んでも意味ない
2022/12/17(土) 16:25:41.46ID:dohNO5X8
どういう文法にするかはシェルを作っている人たちが考えることであって
「POSIXは仕様を考えません」ってスタンスは明確になっている
2022/12/17(土) 16:25:59.84ID:nev2pk2m
まだ試してないけどfor x ofの時点でシンタックスエラー吐くのが普通だろうし、自由に選べるはず
C-style((..))のような拡張とも被らない
2022/12/17(土) 16:38:44.90ID:kO3DzgkN
次スレ
シェルスクリプト総合 その38
https://mevius.5ch.net/test/read.cgi/tech/1671262640/
2022/12/17(土) 16:39:51.81ID:fCc6f5AR
>>978
おつおつ
2022/12/17(土) 17:24:25.53ID:f0H2QhnO
>>978
おつ
2022/12/18(日) 11:36:21.55ID:X5nUMPIw
>>973
forに足すなら浮いてる終端記号
in : In
を拡張するのが確かにスマートなんだけど
言語全体で見るとwhile/untilに使えないのが不自然

for_clause : For name do_group
| For name sequential_sep do_group
| For name linebreak in sequential_sep do_group
| For name linebreak in wordlist sequential_sep do_group
;
while_clause : While compound_list do_group
;
until_clause : Until compound_list do_group
;
do_group : Do compound_list Done
;

do_groupに足したいところだが、compound_listが何でもアリだから曖昧になる、末尾:は非コマンド名と予約しても現状通るし、do : ; done すらイディオム、もちろん今のうちから予約しておくのは良い事
ただし意味論的にキモい事になる(label:がwhile行とズレる)
while ...
do label:
...
done
ので、ラベルのようなあっても無くても困らないものでなく、もっと重要な拡張の為に取っておくべき
2022/12/18(日) 13:49:22.73ID:2VP7BjPM
> もちろん今のうちから予約しておくのは良い事
勝手に予約しないでください
2022/12/18(日) 15:19:58.34ID:dtHdvs65
コマンドがファイルでありえる限りヌル文字と/以外なんでもありだし、本当に任意コマンドを受け取って呼ぶならcommand, type, envとかで全部問い合わせるか、クォートする必要があるな

ところで任意文字列のコマンドが既にダメなのは今更な事に気付いた、例えば
✗com=mand arg1 arg2…
✔\com=mand arg1 arg2...

これを流用して意味を為さない
=label
なんてどうかと思ったが、bash/dashはcommand not found返しやがる
2022/12/18(日) 15:31:36.28ID:dtHdvs65
不用心にパス区切へ使われがちな:はなるべく避けてるけど、名前空間の表現なんかでpkg:nameくらいは使いたい
末尾:という制限付きならまあ

とりあえずbashは関数も実行ファイルも普通に作れるしガン無視の模用、実効性は疑問
2022/12/18(日) 15:46:15.04ID:ZsJ4rXOo
個々人が(覚えてたら)一応リスペクトしておくか、の積み重ねじゃね
2022/12/18(日) 16:06:25.57ID:ZsJ4rXOo
>>983
=は他のコンテキストでクオートする必要がないところが特異

任意文字がダメなのはコントロールオペレータやメタ文字、予約語もそう
当たり前だから忘れがちだけど、空白>|($&cを含んだコマンドを呼ぶならクオートする
2022/12/18(日) 16:48:20.92ID:X5nUMPIw
>>983
面白い挙動見つけたな
名前を受け取ってevalし、空でなければ普通に環境設定、空ならデフォルト動作として=cmdが呼ばれるとか
色々遊べそう

禍根はこうして産まれるんだなって
2022/12/18(日) 17:18:29.27ID:X5nUMPIw
一応opengroupのShell Command Languageには
The words that are recognized as variable assignments or redirections according to Shell Grammar Rules are saved for processing in steps 3 and 4.
と記載があるので、variable assignmentとして認識できないなら、コマンドとして検索すると間接的に示唆してるな

もちろん期待すべきではないが
2022/12/18(日) 17:34:17.53ID:hzU9uYVT
名前が空になるのは大抵eval "$var=$val"のようなコードでのバリデーション不足だから、エラーにしてくれれば親切なのに
残念
2022/12/18(日) 18:33:19.40ID:KWJCN7PT
挙動は揃ってるっぽいな
こんな時の為の明示的なunspecified
汚いから連想配列使えって?標準を示してくれればな
2022/12/18(日) 19:25:00.97ID:X5nUMPIw
親切にエラーを投げても構わないよ、って意図はしばしば察せられるね
正直とても分かりにくいが

変数はダメ文字多いけど、頑張るならx$VARとか
2022/12/18(日) 21:30:49.34ID:TnNkrrc4
>>989-990
それがBourne Shellの動作だからね
POSIXはそれを明確化しただけ

さっきからずっとPOSIXに文句を言っているようだが
POSIXにごちゃごちゃ言うようなないようじゃないよ

そんなの意味ないからbashやkshの開発者に
変更してくれって言わないとだめ
2022/12/18(日) 21:32:32.95ID:TnNkrrc4
>>991
> 変数はダメ文字多いけど、頑張るならx$VARとか
え?それで何が防げると思ってるの?
少しよく考えた方がいい
無意味な話をしてる。
2022/12/18(日) 21:38:48.78ID:TnNkrrc4
>>990
シェルスクリプトに連想配列はないよ
2022/12/18(日) 22:49:12.26ID:1Tc0QAtx
1レスで書いてよ
2022/12/19(月) 00:58:54.84ID:DF8VTccp
>>992
互換性を保つ必要があるわけだから
ここでごちゃごちゃ言ってもどうしようもないよね
POSIXに色々書いてあったとしてもそれは
後からでも変更できるので気にする必要はない
2022/12/19(月) 02:05:36.38ID:8Bk5E6e1
ここに居る人は多かれ少なかれ利害関係者なわけだけど、その意識が欠けてる感じがする

俺は物言うエンドユーザー(いわゆるクレーマー)だけど
ニュースグループ、メーリス、バグレポートに直接クレーム付けるのが憚られるインフォーマルな話題やネタは大体ここから拾ってたりする
おまえらエッジケース見付けるのうまいしな

少なくともchetは丁寧に返信してくれるよ、他は知らん
2022/12/19(月) 02:10:26.67ID:sparn4DJ
なんか大した実績もないクソ雑魚が
いきがってるなw
2022/12/19(月) 02:16:02.35ID:8Bk5E6e1
>>998
まあ実績はないけど、言わんで困るのも俺だしな
2022/12/19(月) 02:21:06.52ID:sparn4DJ
まあちゃんと日本語話せるようになれよw
お前の日本語は意味不明で誰も理解できんからwww
10011001
垢版 |
Over 1000Thread
このスレッドは1000を超えました。
新しいスレッドを立ててください。
life time: 439日 3時間 31分 36秒
レス数が1000を超えています。これ以上書き込みはできません。
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況