シェルスクリプトに関する総合スレッドです。
全般
・荒しは無視しましょう。
・丁寧な姿勢を心掛けましょう。
・ネチケット(死語)を意識しましょう。
前スレ: シェルスクリプト総合 その27(https://mevius.5ch.net/test/read.cgi/unix/1525337663/)
探検
シェルスクリプト総合 その28
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
2018/07/24(火) 11:01:16.36ID:r0TJj2hB139デフォルトの名無しさん
2018/08/12(日) 15:45:28.66ID:CtXb4bgk >>138
シングルクオートだと変数が、展開されない気がすダブルクォートにしてみて
シングルクオートだと変数が、展開されない気がすダブルクォートにしてみて
140デフォルトの名無しさん
2018/08/12(日) 17:45:18.75ID:EQS0DV6K141デフォルトの名無しさん
2018/08/13(月) 00:38:00.83ID:z6+TJcGX "-d ${i} hour ago" の部分が -d "${i} hour ago" ではないのに何故大丈夫なのかと思ったが、
短いオプションだからパラメータと繋がってても大丈夫ってことだったんだな。
短いオプションだからパラメータと繋がってても大丈夫ってことだったんだな。
142デフォルトの名無しさん
2018/08/14(火) 19:59:14.84ID:0dSYKDxo 上のやり取りをみてふと思いたって実験してみると
GNU dateではフォーマットにCSIとかに代表されるANSI制御綴りを指定できるけど
BSD dateでは無理だな。
POSIXではこの二つのどちらが正しい実装なのかはよく分からんが
個人的な意見としてはBSD dateのほうが堅牢で,GNU dateのほうが柔軟だとは思う。まあ当然すぎる事実だけどw
GNU dateではフォーマットにCSIとかに代表されるANSI制御綴りを指定できるけど
BSD dateでは無理だな。
POSIXではこの二つのどちらが正しい実装なのかはよく分からんが
個人的な意見としてはBSD dateのほうが堅牢で,GNU dateのほうが柔軟だとは思う。まあ当然すぎる事実だけどw
143デフォルトの名無しさん
2018/08/15(水) 02:35:15.09ID:sxh1cciH BSD date の仕様が分からないけど、標準出力が端末とは限らないし
指定そのまま出すほうが正しいんじゃないかな
指定そのまま出すほうが正しいんじゃないかな
144デフォルトの名無しさん
2018/08/15(水) 13:56:33.60ID:/R99sNfj 標準出力がなんのかんけーがあんのー?
145デフォルトの名無しさん
2018/08/15(水) 16:29:17.30ID:fSWxnCwv かんけーし
146デフォルトの名無しさん
2018/08/17(金) 03:06:26.97ID:DWhhxT1h 単純な文字列置換ってどうしたら良いですかね?
sedつかうとメタ文字の置換で困るんです
sedつかうとメタ文字の置換で困るんです
147デフォルトの名無しさん
2018/08/17(金) 03:42:44.91ID:l9m154d6 その辺りが楽なperlでいいんじゃない?
シェルスクリプトから使っちゃいけないというわけじゃないし
シェルスクリプトから使っちゃいけないというわけじゃないし
148デフォルトの名無しさん
2018/08/17(金) 04:16:11.31ID:DWhhxT1h149デフォルトの名無しさん
2018/08/17(金) 04:55:42.82ID:xP9ZimWn awk
150デフォルトの名無しさん
2018/08/17(金) 04:56:29.20ID:DWhhxT1h awkに正規表現じゃない文字列置換命令ってありましたっけ?
151デフォルトの名無しさん
2018/08/17(金) 06:24:27.95ID:/a+SCakG Ruby が簡単
152デフォルトの名無しさん
2018/08/17(金) 06:38:46.91ID:eWaVkn5S >>151
perlが無いならrubyも無いでしょ
perlが無いならrubyも無いでしょ
153デフォルトの名無しさん
2018/08/17(金) 07:03:28.31ID:DWhhxT1h はい、rubyもないし、pythonもなし、nodeもないです
154デフォルトの名無しさん
2018/08/17(金) 08:18:50.56ID:/a+SCakG Ruby をインストールすれば?
漏れは、WSL で、Rubyを入れているけど
漏れは、WSL で、Rubyを入れているけど
155デフォルトの名無しさん
2018/08/17(金) 08:24:08.77ID:RTbKyx/W156デフォルトの名無しさん
2018/08/17(金) 08:34:23.82ID:vhwq6spf viは?
157デフォルトの名無しさん
2018/08/17(金) 08:36:24.83ID:RTbKyx/W 手動で置換は嫌です
158デフォルトの名無しさん
2018/08/17(金) 08:40:03.28ID:vhwq6spf viはスクリプト組めるでしょ
159デフォルトの名無しさん
2018/08/17(金) 08:44:27.28ID:TmUZ5Zjz パターン文字列をsedで置換しちゃうとか(GNU sed の場合)
$ pattern='foo[1]'
$ sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
foo[2]
$ pattern='foo[1]'
$ sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
foo[2]
160デフォルトの名無しさん
2018/08/17(金) 08:49:02.25ID:vhwq6spf 脳みそが解読を拒否してる
161デフォルトの名無しさん
2018/08/17(金) 08:53:02.98ID:xP9ZimWn162デフォルトの名無しさん
2018/08/17(金) 08:56:35.86ID:RTbKyx/W >>158
スクリプトの実行はできましたが、 %s/〜/〜/g
だと〜に/が入っていた時に困ります。
〜には何が入るかわかりません。
あとviは標準入力から読み込めませんでした
できれば標準入力から読み込みんで標準出力に出力したいです。
ちなみにviのバージョンです
# vi -H
These features are available:
Pattern searches with / and ?
Last command repeat with .
Line marking with 'x
Named buffers with "x
Some colon mode commands with :
Settable options with ":set"
Signal catching- ^C
Job suspend and resume with ^Z
Adapt to window re-sizes
BusyBox v1.28.3 () multi-call binary.
Usage: vi [OPTIONS] [FILE]...
Edit FILE
-c CMD Initial command to run ($EXINIT also available)
-R Read-only
-H List available features
スクリプトの実行はできましたが、 %s/〜/〜/g
だと〜に/が入っていた時に困ります。
〜には何が入るかわかりません。
あとviは標準入力から読み込めませんでした
できれば標準入力から読み込みんで標準出力に出力したいです。
ちなみにviのバージョンです
# vi -H
These features are available:
Pattern searches with / and ?
Last command repeat with .
Line marking with 'x
Named buffers with "x
Some colon mode commands with :
Settable options with ":set"
Signal catching- ^C
Job suspend and resume with ^Z
Adapt to window re-sizes
BusyBox v1.28.3 () multi-call binary.
Usage: vi [OPTIONS] [FILE]...
Edit FILE
-c CMD Initial command to run ($EXINIT also available)
-R Read-only
-H List available features
163デフォルトの名無しさん
2018/08/17(金) 09:00:22.48ID:RTbKyx/W >>159
GNU sedじゃないからだめなんでしょうね
# pattern='foo[1]'
# sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
-ash: syntax error: unexpected redirection
ちなみにsedの--versionと--helpです。
# sed --version
This is not GNU sed version 4.0
# sed --help
BusyBox v1.28.3 () multi-call binary.
Usage: sed [-i[SFX]] [-nrE] [-f FILE]... [-e CMD]... [FILE]...
or: sed [-i[SFX]] [-nrE] CMD [FILE]...
-e CMD Add CMD to sed commands to be executed
-f FILE Add FILE contents to sed commands to be executed
-i[SFX] Edit files in-place (otherwise sends to stdout)
Optionally back files up, appending SFX
-n Suppress automatic printing of pattern space
-r,-E Use extended regex syntax
If no -e or -f, the first non-option argument is the sed command string.
Remaining arguments are input files (stdin if none).
GNU sedじゃないからだめなんでしょうね
# pattern='foo[1]'
# sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
-ash: syntax error: unexpected redirection
ちなみにsedの--versionと--helpです。
# sed --version
This is not GNU sed version 4.0
# sed --help
BusyBox v1.28.3 () multi-call binary.
Usage: sed [-i[SFX]] [-nrE] [-f FILE]... [-e CMD]... [FILE]...
or: sed [-i[SFX]] [-nrE] CMD [FILE]...
-e CMD Add CMD to sed commands to be executed
-f FILE Add FILE contents to sed commands to be executed
-i[SFX] Edit files in-place (otherwise sends to stdout)
Optionally back files up, appending SFX
-n Suppress automatic printing of pattern space
-r,-E Use extended regex syntax
If no -e or -f, the first non-option argument is the sed command string.
Remaining arguments are input files (stdin if none).
164デフォルトの名無しさん
2018/08/17(金) 09:16:35.01ID:RTbKyx/W165デフォルトの名無しさん
2018/08/17(金) 09:16:49.96ID:TmUZ5Zjz >>163
ああ、bash じゃなくて ash だから here string("<<<") が使えないのね…
# echo 'foo[1]' | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こんな感じかな。
ああ、bash じゃなくて ash だから here string("<<<") が使えないのね…
# echo 'foo[1]' | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こんな感じかな。
166デフォルトの名無しさん
2018/08/17(金) 09:33:56.45ID:xP9ZimWn167デフォルトの名無しさん
2018/08/17(金) 09:48:06.80ID:RTbKyx/W >>166
なんかプラスが入った時おかしいっすね
GNU sed
$ pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
$ pattern='a+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]+
busybox sed
# pattern='+'
# echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
sed: bad regex '\+': Repetition not preceded by valid expression
なんかプラスが入った時おかしいっすね
GNU sed
$ pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
$ pattern='a+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]+
busybox sed
# pattern='+'
# echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
sed: bad regex '\+': Repetition not preceded by valid expression
168デフォルトの名無しさん
2018/08/17(金) 09:57:27.72ID:TmUZ5Zjz169デフォルトの名無しさん
2018/08/17(金) 09:58:49.05ID:TmUZ5Zjz あ、ごめん勘違いしてた。ちょっと考えてみる
170デフォルトの名無しさん
2018/08/17(金) 10:03:14.53ID:RTbKyx/W そう。何が問題なのかよくわからないw
171デフォルトの名無しさん
2018/08/17(金) 10:13:01.82ID:TmUZ5Zjz あれ?でもさ、
pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
入力が '+' でパターン文字列も '+' だから foo[2] に置換されるのは正しいんじゃないかな?
でもまぁ、GNU sed で -r オプション付けると `+` 記号がメタキャラクタになるから、付けない場合は
`+` を考慮する必要はなかったのね…
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こっちの方が良いみたい。
pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
入力が '+' でパターン文字列も '+' だから foo[2] に置換されるのは正しいんじゃないかな?
でもまぁ、GNU sed で -r オプション付けると `+` 記号がメタキャラクタになるから、付けない場合は
`+` を考慮する必要はなかったのね…
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こっちの方が良いみたい。
172デフォルトの名無しさん
2018/08/17(金) 10:13:20.76ID:5I+JCiH1173デフォルトの名無しさん
2018/08/17(金) 10:18:32.56ID:RTbKyx/W174デフォルトの名無しさん
2018/08/17(金) 10:20:29.64ID:RTbKyx/W だから要するに + はエスケープしたらダメってことなのか?
単純な文字列置換って正規表現置換よりも簡単な処理なのに
どれも面倒くさいなぁw
単純な文字列置換って正規表現置換よりも簡単な処理なのに
どれも面倒くさいなぁw
175デフォルトの名無しさん
2018/08/17(金) 10:33:33.58ID:hKcJGgnp ashの日本語manページはないのかなと思って検索した時に出てきた画面。
https://i.imgur.com/xzEhcAc.png
https://i.imgur.com/xzEhcAc.png
176デフォルトの名無しさん
2018/08/17(金) 10:37:43.83ID:RTbKyx/W177デフォルトの名無しさん
2018/08/17(金) 10:41:51.16ID:hKcJGgnp >>176
カラフルな検索結果だがこれと言って役に立たないという共通点があるな・・・
カラフルな検索結果だがこれと言って役に立たないという共通点があるな・・・
178デフォルトの名無しさん
2018/08/17(金) 10:51:57.16ID:RTbKyx/W179デフォルトの名無しさん
2018/08/17(金) 11:32:47.25ID:TmUZ5Zjz grep にある -F オプションと同等のオプションが sed にも
欲しいところではあるなぁ。生まれは同じなのに sed には無い
のは何故…(実はあったりして)
欲しいところではあるなぁ。生まれは同じなのに sed には無い
のは何故…(実はあったりして)
180デフォルトの名無しさん
2018/08/17(金) 18:50:11.51ID:D/YAmHXf fsedみたいなのを作ってる人ならしってる
181デフォルトの名無しさん
2018/08/18(土) 17:22:09.36ID:rQWtSS3z Googleのシェルスクリプトに関するコーディング規約で
「そう〔訳注: 連続したパイプ節が二つ以下〕でない場合は一行につき一つのパイプ節を含むようにする。その際,二番目以降のパイプ節は,2文字分の欧文空白による字下げを行なう。」
とあるんだが[1],ここの例示が
command1 \
| command2 \
| command3 \
| command4
となっている。
普通(といってもパイプをこのように多用しかつ改行しまくっている例はほとんど見たことがないのだが)https://github.com/ShellShoccar-jpn/kotoriotoko/blob/master/BIN/twtl.sh#L297
↑こことかでは
command1 |
command2 |
command3 |
command4
という書き方になっている。
俺はこっちの書式のほうが見慣れているので,自分のシェルスクリプトもこういう書き方でやっているのだが,みなさんはどういう書き方がいいとかあるだろうか。あるいはGoogleとは別のところが発表してるシェルスクリプトのコーディング規約とかないだろうか。
「そう〔訳注: 連続したパイプ節が二つ以下〕でない場合は一行につき一つのパイプ節を含むようにする。その際,二番目以降のパイプ節は,2文字分の欧文空白による字下げを行なう。」
とあるんだが[1],ここの例示が
command1 \
| command2 \
| command3 \
| command4
となっている。
普通(といってもパイプをこのように多用しかつ改行しまくっている例はほとんど見たことがないのだが)https://github.com/ShellShoccar-jpn/kotoriotoko/blob/master/BIN/twtl.sh#L297
↑こことかでは
command1 |
command2 |
command3 |
command4
という書き方になっている。
俺はこっちの書式のほうが見慣れているので,自分のシェルスクリプトもこういう書き方でやっているのだが,みなさんはどういう書き方がいいとかあるだろうか。あるいはGoogleとは別のところが発表してるシェルスクリプトのコーディング規約とかないだろうか。
182デフォルトの名無しさん
2018/08/18(土) 17:22:24.47ID:rQWtSS3z 一応俺の意見: 後者の利点としては,バックスラッシュが不要なこととコマンドが行頭に来て流れを掴みやすいということがある。
加えて簡易的なデバッグするときに,前者は
command1 \
| command2 \
| cat
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
cat
# command3 |
# command4
このように「新しい行を挿入してcatを入力」という単純な動作ができるので,例えばVimやEmacsなどマクロが作れるエディタなどでのデバッグ用の編集に有用というのもある。
実際俺はシェルスクリプトに関してはIDEを使わずVimで開発していて,この類のマクロを作成して便利に使っている。
長文すまん
[1]: http://google.github.io/styleguide/shell.xml#Pipelines
加えて簡易的なデバッグするときに,前者は
command1 \
| command2 \
| cat
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
cat
# command3 |
# command4
このように「新しい行を挿入してcatを入力」という単純な動作ができるので,例えばVimやEmacsなどマクロが作れるエディタなどでのデバッグ用の編集に有用というのもある。
実際俺はシェルスクリプトに関してはIDEを使わずVimで開発していて,この類のマクロを作成して便利に使っている。
長文すまん
[1]: http://google.github.io/styleguide/shell.xml#Pipelines
183デフォルトの名無しさん
2018/08/18(土) 18:05:23.17ID:5BnyFmRJ 簡易的なデバッグするときに前者は
command1 \
| command2 \
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
# command3 |
# command4
のように行頭に#をいれるだけではSyntax errorになるから前者の方がデバッグなど編集に有用とも言える
個人的には大差ないと思う
command1 \
| command2 \
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
# command3 |
# command4
のように行頭に#をいれるだけではSyntax errorになるから前者の方がデバッグなど編集に有用とも言える
個人的には大差ないと思う
184デフォルトの名無しさん
2018/08/18(土) 18:29:20.16ID:LW/iu6SG 末尾にバックスラッシュを入れることで次行を見なくても明確にコマンドが続くことがわかるから前者を支持する
185デフォルトの名無しさん
2018/08/18(土) 18:38:12.95ID:Bu4pj5O8 一長一短やな
使い分けか
使い分けか
186デフォルトの名無しさん
2018/08/18(土) 19:19:56.79ID:rQWtSS3z187デフォルトの名無しさん
2018/08/18(土) 19:21:44.26ID:rQWtSS3z ていうか少なくとも二人くらいは
後者の方式に賛同してるのか。
Googleもそっちを推奨してるし,俺も手癖を直すべきなのかな。
後者の方式に賛同してるのか。
Googleもそっちを推奨してるし,俺も手癖を直すべきなのかな。
188デフォルトの名無しさん
2018/08/18(土) 20:18:01.73ID:pAmB63kN189デフォルトの名無しさん
2018/08/18(土) 21:09:33.95ID:bNUWoVQ1 パイプ記号が重要だから頭にもってきたいかなあ
190デフォルトの名無しさん
2018/08/19(日) 00:41:34.89ID:6q4oK8R8 scsh 使え https://scsh.net/about/what.html
191デフォルトの名無しさん
2018/08/19(日) 01:23:37.19ID:A4xH6fb7 バックスラッシュで行継続(改行)って多くの言語で採用されているから
多くの人はパイプ先頭、バックスラッシュ行末じゃないかな?
多くの人はパイプ先頭、バックスラッシュ行末じゃないかな?
192デフォルトの名無しさん
2018/08/19(日) 02:52:07.69ID:YqoTvka6 俺は1行か2行くらいなら後者だな。
何行もずらずら並べるなら中括弧で囲んでパイプ記号を先頭に持ってくるかも。
行末にバックスラッシュを置いて行継続はあまり美しくないと思うのでなるべく書きたくない。
>>191
構文的に行末で文(言語によっては式)が完結できていれば行末を文の終わりとみなし
そうでなければ次の行に継続、というのもshそのものをはじめpython, JavaScriptなど多くの言語で採用されているよ。
(pythonはshと同じく行末バックスラッシュで継続もできるが)
更にRubyは行の終わりで完結できるように見えても次の行の先頭を見てどうするか決めていたりする。
何行もずらずら並べるなら中括弧で囲んでパイプ記号を先頭に持ってくるかも。
行末にバックスラッシュを置いて行継続はあまり美しくないと思うのでなるべく書きたくない。
>>191
構文的に行末で文(言語によっては式)が完結できていれば行末を文の終わりとみなし
そうでなければ次の行に継続、というのもshそのものをはじめpython, JavaScriptなど多くの言語で採用されているよ。
(pythonはshと同じく行末バックスラッシュで継続もできるが)
更にRubyは行の終わりで完結できるように見えても次の行の先頭を見てどうするか決めていたりする。
193デフォルトの名無しさん
2018/08/19(日) 04:00:58.03ID:O9LemqF2194デフォルトの名無しさん
2018/08/19(日) 16:16:41.68ID:L67BZdE+ shに限らず末尾に演算子を置く
195デフォルトの名無しさん
2018/08/19(日) 19:55:46.26ID:O9LemqF2 シェルスクリプトの話題からちょっと外れるんだけど
$ somecmd --help
としたときの手引きって標準エラー出力に出力すべき?
GNU Coreutilsでは基本的に標準出力なんだけど……。
$ somecmd --help
としたときの手引きって標準エラー出力に出力すべき?
GNU Coreutilsでは基本的に標準出力なんだけど……。
196デフォルトの名無しさん
2018/08/19(日) 20:37:51.45ID:6q4oK8R8 stderr だとページャにつなげたい時に
$ somecmd --help 2>&1 | $PAGER
とかするのが面倒。でも zsh とかだとエイリアスで
どうにかできるんだっけ?
$ somecmd --help 2>&1 | $PAGER
とかするのが面倒。でも zsh とかだとエイリアスで
どうにかできるんだっけ?
197デフォルトの名無しさん
2018/08/19(日) 22:24:00.37ID:teBDlI3J helpはエラーではないから標準出力でいいのでは
198デフォルトの名無しさん
2018/08/19(日) 23:44:45.76ID:O9LemqF2199デフォルトの名無しさん
2018/08/20(月) 00:18:14.36ID:anhi4Zz/ >>198
dクス、"|&" が使えるのは bash と zsh だけかな
dクス、"|&" が使えるのは bash と zsh だけかな
200デフォルトの名無しさん
2018/08/20(月) 00:25:54.45ID:V9a8ZDkH >>199
csh(系)も使える
csh(系)も使える
201デフォルトの名無しさん
2018/08/20(月) 01:00:54.38ID:Za3ebEAA202デフォルトの名無しさん
2018/08/20(月) 03:03:17.26ID:miyFFq/v csh由来のものをbashismというのはどうかと……
203デフォルトの名無しさん
2018/08/20(月) 03:04:00.88ID:O40ujeeV つくづく宗教戦争じみてるなこの文化は
204デフォルトの名無しさん
2018/08/20(月) 03:32:09.94ID:OmELABLW まあ>>201はそんな大層な意味で言ってるわけではないだろ。単にbashしか使ってない使い込んでるってだけの意味だろう。無知でしたという
205デフォルトの名無しさん
2018/08/20(月) 03:46:49.27ID:GIvuOFoC --helpで思い出したけど、あれって書き方ってあるの?
usageの書き方とかオプションの書き方とか
引数は大文字にするの?とか [ファイル]... とかの[] とか ... の使い方とか
あるようで、バラバラな気もしている
usageの書き方とかオプションの書き方とか
引数は大文字にするの?とか [ファイル]... とかの[] とか ... の使い方とか
あるようで、バラバラな気もしている
206デフォルトの名無しさん
2018/08/20(月) 04:15:12.27ID:Za3ebEAA >>205
とりあえず 天下のPOSIX様はこうおっしゃってる
utility_name[-a][-b][-c option_argument]
[-d|-e][-f[option_argument]][operand...]
http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap12.html#tag_12_01
ので 俺はそれに従ってる。だいたいのmanページやGNUユーティリティの--help出力もこれに準ずる形だと思うよ
とりあえず 天下のPOSIX様はこうおっしゃってる
utility_name[-a][-b][-c option_argument]
[-d|-e][-f[option_argument]][operand...]
http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap12.html#tag_12_01
ので 俺はそれに従ってる。だいたいのmanページやGNUユーティリティの--help出力もこれに準ずる形だと思うよ
207デフォルトの名無しさん
2018/08/21(火) 20:17:11.95ID:ExpCY3/V208デフォルトの名無しさん
2018/08/23(木) 05:30:33.48ID:L+hDtmKU シェルスクリプトの言語にJavaScriptってアリだと思う?
#! /usr/local/bin/js24
みたいなシェバンでさ。
#! /usr/local/bin/js24
みたいなシェバンでさ。
209デフォルトの名無しさん
2018/08/23(木) 05:39:54.64ID:ncZgpeak シェルスクリプトっていうのは
シェルとして実用に堪えるものじゃないとダメ
名前の通り
コマンドを呼び出すのに、いちいちsystem関数を
使うとかいうのは、シェルとして使えない
ls だけでlsコマンドを実行できるようにしたら
シェルスクリプトと認めてもいいが
シェルとして実用に堪えるものじゃないとダメ
名前の通り
コマンドを呼び出すのに、いちいちsystem関数を
使うとかいうのは、シェルとして使えない
ls だけでlsコマンドを実行できるようにしたら
シェルスクリプトと認めてもいいが
210デフォルトの名無しさん
2018/08/23(木) 07:32:38.64ID:d2Ifs7B7 >>208
ナシだと思う
ナシだと思う
211デフォルトの名無しさん
2018/08/23(木) 07:38:44.84ID:1n1CeI2l シェルスクリプトというより、他のインタプリタ言語と同じようにコマンド(内容)記述用としてあっていいって話だろう
212デフォルトの名無しさん
2018/08/23(木) 08:56:23.64ID:AY9SoYfw 普通にやるだろ。
#!/usr/bin/awk -f
とかだってたまにはやるぞ。
「#」がコメント扱いになる言語なら
気にせずどんどんやればいい。
そもそもshebangはUNIX上で「スクリプト言語」を呼び出す時の記法であって
現代UNIXではシェルは一切関与しないカーネルの機能だから
「シェルスクリプト」なんかじゃない。
(つまり実はスレ違い)
なお昔のSystem-V系UNIXにはカーネルにこの機能がなくexec(2)が失敗するので、
その場合にはシェルが代行してスクリプトのインタープリターをよびだしていた。
そういうUNIXはほぼ滅びたけどシェル側にはまだこの代行機能が残っていたりする。
シェルは関与しないのにshell-bangなんて変な名前だけど、
この言い方自体比較的新しくて、実装されてからだいぶ長い間名前がなかったんだよ。
普通はカーネルが処理しててシェルは関係ないってことを
知らない奴がつけた名前じゃないかと前から疑問に思ってる。
#!/usr/bin/awk -f
とかだってたまにはやるぞ。
「#」がコメント扱いになる言語なら
気にせずどんどんやればいい。
そもそもshebangはUNIX上で「スクリプト言語」を呼び出す時の記法であって
現代UNIXではシェルは一切関与しないカーネルの機能だから
「シェルスクリプト」なんかじゃない。
(つまり実はスレ違い)
なお昔のSystem-V系UNIXにはカーネルにこの機能がなくexec(2)が失敗するので、
その場合にはシェルが代行してスクリプトのインタープリターをよびだしていた。
そういうUNIXはほぼ滅びたけどシェル側にはまだこの代行機能が残っていたりする。
シェルは関与しないのにshell-bangなんて変な名前だけど、
この言い方自体比較的新しくて、実装されてからだいぶ長い間名前がなかったんだよ。
普通はカーネルが処理しててシェルは関係ないってことを
知らない奴がつけた名前じゃないかと前から疑問に思ってる。
213デフォルトの名無しさん
2018/08/23(木) 09:39:55.05ID:ncZgpeak214デフォルトの名無しさん
2018/08/23(木) 09:45:44.18ID:ncZgpeak > シェルは関与しないのにshell-bangなんて変な名前だけど、
shebang を shell-bangの略だと主張する人は少数派だよ
shebang を shell-bangの略だと主張する人は少数派だよ
215デフォルトの名無しさん
2018/08/23(木) 12:56:18.33ID:/qY100we216デフォルトの名無しさん
2018/08/23(木) 12:59:05.57ID:XdhcXIaw スクリプトスクリプトはもにょる
217デフォルトの名無しさん
2018/08/23(木) 13:18:49.52ID:cYcyOMDR スクリプト
スクリプトスクリプト
スクリプトスクリプトスクリプト
スクリプトスクリプトスクリプトスクリプト 👀
Rock54: Caution(BBR-MD5:1341adc37120578f18dba9451e6c8c3b)
スクリプトスクリプト
スクリプトスクリプトスクリプト
スクリプトスクリプトスクリプトスクリプト 👀
Rock54: Caution(BBR-MD5:1341adc37120578f18dba9451e6c8c3b)
218デフォルトの名無しさん
2018/08/23(木) 14:49:29.73ID:AY9SoYfw219デフォルトの名無しさん
2018/08/23(木) 14:59:38.25ID:AY9SoYfw >>214
shebang の e って何から来てるの?
俺は shell から来てるんだと思ってた。
なお shabang という書き方も少数派だが使われてはいるみたい。
実際 sharp-bang なわけで、こっちなら分かる。
shabang ならシバンじゃなくて、シャバンだよな。
シャバ〜ン。
shebang の e って何から来てるの?
俺は shell から来てるんだと思ってた。
なお shabang という書き方も少数派だが使われてはいるみたい。
実際 sharp-bang なわけで、こっちなら分かる。
shabang ならシバンじゃなくて、シャバンだよな。
シャバ〜ン。
220デフォルトの名無しさん
2018/08/23(木) 15:01:24.58ID:2Dv2zxdP 男なんだろ?
221デフォルトの名無しさん
2018/08/23(木) 15:09:53.60ID:Jv3FRRxD 違うよ〜☆
222デフォルトの名無しさん
2018/08/23(木) 15:11:13.70ID:e+w5jH4y 若さ、若さってなんだ
223デフォルトの名無しさん
2018/08/23(木) 15:13:13.81ID:eJiCstIz なんというか、ヒーローの名前のようだ。
224デフォルトの名無しさん
2018/08/23(木) 15:42:31.50ID:bMgbpjF3 それはギャバン
225デフォルトの名無しさん
2018/08/23(木) 16:36:01.71ID:YQoAQycd さぁ、盛り上がって参りました
226デフォルトの名無しさん
2018/08/23(木) 16:45:35.96ID:ssILkLQJ 宇宙刑事シャバン
227デフォルトの名無しさん
2018/08/23(木) 16:48:23.72ID:e+w5jH4y ギャバン
シャバン
シャリバン
シャバン
シャリバン
228デフォルトの名無しさん
2018/08/23(木) 17:03:22.02ID:ncZgpeak 癒着!
229デフォルトの名無しさん
2018/08/23(木) 18:14:50.72ID:AY9SoYfw なんつーかオッサンばっかだな。
まあ俺もそういう反応を期待してたわけだがw
まあ俺もそういう反応を期待してたわけだがw
230デフォルトの名無しさん
2018/08/23(木) 18:43:16.20ID:1n1CeI2l >>219
#! -> sharp-bang -> shabang -> 単語ならshellだしすでにあるとても似たshebangでいいんじゃね、shebangの意味自体が似合ってるし
とか。shebangというれっきとした単語の由来は別にある
#! -> sharp-bang -> shabang -> 単語ならshellだしすでにあるとても似たshebangでいいんじゃね、shebangの意味自体が似合ってるし
とか。shebangというれっきとした単語の由来は別にある
231デフォルトの名無しさん
2018/08/24(金) 01:02:04.55ID:TjDOkMEc 元ネタ分かんねーと思ったらおっさんどころかジジイじゃねーか
232デフォルトの名無しさん
2018/08/24(金) 07:46:54.31ID:mVdVBkdF マジで検索しても元ネタわからんw
平均年齢どのくらいだこのスレは
平均年齢どのくらいだこのスレは
233デフォルトの名無しさん
2018/08/24(金) 08:04:01.22ID:lit/+L8O 機動刑事シバン
234219
2018/08/24(金) 08:55:32.25ID:57yPHNQD235デフォルトの名無しさん
2018/08/24(金) 09:13:07.93ID:LbFHGrVQ236219
2018/08/24(金) 09:35:23.98ID:57yPHNQD237デフォルトの名無しさん
2018/08/24(金) 10:43:03.55ID:wXpFbMeR238デフォルトの名無しさん
2018/08/24(金) 10:59:15.82ID:4te4jIm4 蒸着の元ネタってギャバンだったのか…
DeadSpaceのアーマー更新シーンを蒸着言うやついたけど元ネタあったんだな
DeadSpaceのアーマー更新シーンを蒸着言うやついたけど元ネタあったんだな
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【サッカー】運命のW杯抽選会、NHK総合が生中継&DAZNが無料ライブ配信! 今夜 12月5日(金)26時~ ★3 [阿弥陀ヶ峰★]
- 【サッカー】運命のW杯抽選会、NHK総合が生中継&DAZNが無料ライブ配信! 今夜 12月5日(金)26時~ [阿弥陀ヶ峰★] ★2 [阿弥陀ヶ峰★]
- ひろゆき氏、日中対立に 「結局、人口というのは国力なので。10億人以上いる国に、1億2000万人で対抗可能であるというのが間違い」 [冬月記者★]
- 渡邊渚「性を売ってるくせに」批判に反論 幻滅「これが涛本の現状だよbネー」「『渾身bフ下着!』といb、ような意味でb竄チてない」★2 [Ailuropoda melanoleuca★]
- 渡邊渚さん脅迫か 写真集に包丁置く写真投稿 30代女性書類送検 渡邊さん「外に出るのも怖く身の危険を感じる」 [ひかり★]
- 【千葉】会社で58歳女性刺される 殺人未遂容疑で同僚の中国籍の男(39)逮捕 女性死亡 いすみ市 [ぐれ★]
- 【NHK/DAZN/YouTube】FIFAワールドカップ2026組み合わせ抽選★2
- 【01:45NHK~】サッカーW杯2026グルーブ分け組み合わせ抽選会いよいよスタート! [339712612]
- 【NHK/DAZN/YouTube】FIFAワールドカップ2026組み合わせ抽選★1
- 【残酷な事実】VIPをやっていると頭が悪くなります
- PCって冷蔵庫入れれば良くね???w
- 【風向き】ヤバい!高市が導入を検討する「防衛特別所得税」、ネトウヨらもまさかの反対の大合唱。。さすがに国民を舐めすぎたか? [219241683]
