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

■ このスレッドは過去ログ倉庫に格納されています
2021/02/25(木) 09:20:14.64ID:ZyJLXTlk
シェルスクリプトに関する総合スレッドです。

全般
・荒しは無視しましょう。
・丁寧な姿勢を心掛けましょう。
・ネチケット(死語)を意識しましょう。
・「○○(他の言語)でいいやん」は禁止。他のスレに行ってください。

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

関連スレ
・【Bash】Windows Subsystem for Linux【WSL】9
https://mao.5ch.net/test/read.cgi/linux/1607589861/
・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/
2021/04/02(金) 18:12:13.70ID:Ka7wreYU
煽ってくる質問者なんてほっとけ
2021/04/02(金) 18:17:16.53ID:hbCxlU+U
移植性や持続性っても、
移植性ってただ他でも動くでしかないし、
持続性ってただ変わらない=古いのに固執でしかないし
メンテナンス性は軽視もしくは考慮外だからな(命名のいい加減さから考慮してないだろうなw)
その面が実務者(新しい人だけど)に公にやんわりとw指摘されて瀕死かな
2021/04/02(金) 18:25:37.14ID:2zuzxBMS
>>240
日本語でOK
2021/04/02(金) 18:35:13.75ID:hbCxlU+U
自分の無知を人の日本語wのせいにするんじゃないよ
2021/04/02(金) 18:42:19.12ID:ebi/L5xP
tsortはmakeのような動的依存解決&コード生成に使う発想は無かったわ

確かにスクリプト中でタイムスタンプでソート(sort)してからtsortすればmakeの基本機能はカバーできるが、実行したいコマンドを直接書くのはセパレータの扱いや依存が一つしか書けないなど厄介

書き散らしたシェル関数/コマンド"名"を直列に依存解決してダンプ、リファクタリングの参考にするのには気軽でいい
244デフォルトの名無しさん
垢版 |
2021/04/02(金) 19:16:18.60ID:1/Ara7QU
進捗率表示してくれるpvコマンドってどうなの?
やっぱその分処理遅くなったりする?
2021/04/02(金) 19:16:25.76ID:ebi/L5xP
見かけ上無引数のシェル関数で包めば、とりあえず簡単に動くコードは吐けるか
あんまりやりすぎるとmakeでタスクランナーと変わらんが
2021/04/02(金) 19:37:10.62ID:ebi/L5xP
>>244
timeするしかない
例え何も処理しないコマンドであっても、パイプに挟んだとたんバッファリングモードの不整合で遅くなることだってある
2021/04/02(金) 19:42:14.08ID:ebi/L5xP
たぶん求められている答えじゃないかもしれないけど…

ことパイプに関しては前後のコマンドすらスループットに大いに関係がある
特に挟まれる前提のコマンドなら、それ単体で遅い速いを言うのは意味がない
2021/04/02(金) 20:08:48.33ID:ITrGzi0M
進捗確認ツールならそれ自体は多分十分気をつけてるだろ、通信先が病的なら気をつけても無駄だが

遅くて困ってからstdbufとか試せば
どうしても必要なものとは思えないけど、インストールスクリプト等でこだわりがあるなら
249デフォルトの名無しさん
垢版 |
2021/04/02(金) 20:45:04.78ID:B/D63v/Y
確かにこれに限らずパイプ通しただけでもわからんよな
それ用のコマンドだから意識してるとは思うが
2021/04/02(金) 22:49:58.28ID:Gl9s1y4K
straceするんだ

ファイルIO想定で書いたけど、ストリームも一応(ロジックそのままで)対応しとくかみたいな奴が腐ったミカン
内部バッファにある程度貯めて処理するのが理想だけど、パイプラインのパーツはそうじゃない

こまめに空パイプ覗きに行って藪蛇ブロック、貯めたデータの処理止まってたり
時々ドバっと書き出すから後続はずっとアイドル

なんかインピーダンスみたいだな
2021/04/02(金) 22:56:06.54ID:Gl9s1y4K
リーダ/メイン/ライタの3プロセスで1コマンド構成するのがベストになんだろうが、めんどくさいな…

pvみたいに統計取るだけの奴は、読んだ分をそのまま書き出すだろうから、それ自身が問題起こすことは考えにくいかと

ところで、誰かtime したかー?
2021/04/02(金) 23:12:36.74ID:nXGaO3xM
タスクランナーなら、

Jenkins,
Ruby のRake, Thor,
JavaScript のnpm scripts, gulp
2021/04/02(金) 23:21:07.01ID:Gl9s1y4K
俺は他の使ってるが、単なるオレオレタスクランナーならモダン言語で良いの山ほどあるしな
やっぱり何でもmakeマンには賛同できないわ
2021/04/02(金) 23:22:46.09ID:Gl9s1y4K
どうせ自分用なんだから好きなの使えば良いわけだし
2021/04/02(金) 23:55:49.61ID:Fe5X0u2X
複数の言語を使ってるとなんで言語ごとに
タスクランナーを変えなきゃいけないんだよと思う
大したことなんかしないだろ
2021/04/03(土) 00:05:04.26ID:hWVbhofL
>>255
高度な機能を実装する為にモダン言語使っているというだけで、自分の好きなシェルを指定して、そのシェル文法で書くのが主流だと思うよ
(思う、というのはホスト言語の構文ももちろん使えるから、他人は知らん)
.ONESHELLみたいな汚いワークアラウンドも要らないしmakeよりはbsh
2021/04/03(土) 00:12:46.44ID:YB/KO+42
Makefileは真のタスクランナー(シェルスクリプト)の
よく使う使い方を書いたサンプルファイルだよw

makeコマンドが入っていれば、makeコマンドで実行できるし
入ってないならMakefileの中を見て
そこに書いてるサンプルを直接実行するもの
2021/04/03(土) 00:23:20.08ID:r67/WY6G
makeがcで書かれてるからといってcでルールかかない
2021/04/03(土) 00:24:59.87ID:r67/WY6G
のと同じか
スレチぎみだけどbashで書けるオススメおしえろ
2021/04/03(土) 00:28:21.58ID:YB/KO+42
> bashで書けるオススメおしえろ
どういう意味?

makeは依存ファイルに基づいてビルドするターゲットを決めるものだけど
その機能を使わないで、ただのタスクランナーとして使うなら
普通にシェルスクリプトにコード書けばいいんじゃん?
よくinstall.shとかあるでしょ?
インストールというタスクを実行してる
2021/04/03(土) 00:37:33.71ID:r67/WY6G
>>260
ロジック頭から追わなくてもルールベースで書けるってのが意義では、ここだけmake信者の気持ちは理解できる
カジュアル用途なら再コンパイル判定は要らないし、トポロジカルソートだけしてくれれば大体みんな満足でしょう

シェルオタとしては上の方に出てるtsort実装もやってみたくはある
2021/04/03(土) 00:40:42.08ID:YB/KO+42
>>261
ルールって何?ルールがなにもないんだけど?
2021/04/03(土) 00:42:44.05ID:r67/WY6G
ごめん、多分タスクランナーという言葉の解釈違いだわ
初めて聞いた言葉なので、>>236の用例を借りました
適切な順序で実行する必要があるコマンドの実行(但し非ビルド用途
2021/04/03(土) 00:52:45.70ID:r67/WY6G
>>262
connect: lounch-serverみたいな感じ、これなら生tsortでも済むけど
2021/04/03(土) 00:53:12.25ID:YB/KO+42
>>263
適切な順番に並べればいいだけじゃん?
例えばmake.shとか作って

task1() { ・・・}
task2() { ・・・}
task3() { ・・・}

cmd1() {
 task1
 task2
 task3
}

"$@"

とか書けば、make.sh cmd1でこの順番通りに実行できるでしょ?
task2がtask3に絶対依存するってものなら
task2の中からtask3を呼び出せばいいだけだし
シンプルな手続き型で書けることを
知らなきゃわからない独自の定義構文で書くのってアホらしいと思う
2021/04/03(土) 00:55:23.30ID:r67/WY6G
依存とレシピを同一視できるのが強みじゃないかな
2021/04/03(土) 00:56:16.66ID:YB/KO+42
なんのために?
2021/04/03(土) 00:57:18.69ID:r67/WY6G
簡潔性
2021/04/03(土) 00:58:12.59ID:YB/KO+42
>>265がより簡潔になるというのなら
それを見せてほしいが
2021/04/03(土) 01:06:37.77ID:r67/WY6G
>>269
適切な順番に並べたのなら書き直さなくていいよ、適切に並べる為の仕組みの話で
あと簡潔というのは各記述の話であってコード全体が簡潔になるという意味ではないぞ…むしろトポロジカルソート直列化後のコードは一般に冗長になる
2021/04/03(土) 01:14:42.13ID:r67/WY6G
つーかいい実装無いか尋ねてる俺になぜ聞く…
独特のレス見るに月末に初心者イビってた奴か?
2021/04/03(土) 01:14:50.26ID:YB/KO+42
適切に並べる為の仕組み?
どの順番で実行すべきかなんて人が知ってる
2021/04/03(土) 01:16:18.50ID:r67/WY6G
などとautotoolsもcmakeもわけわかんねー事をほざいでおります
2021/04/03(土) 01:18:13.59ID:r67/WY6G
タイポしちゃった、わけわかんねー、の前に、"も理解できないオッサン"を補って読んでください
2021/04/03(土) 01:20:35.91ID:YB/KO+42
>>273
autotoolsもcmakeも「発生した問題」を解決するためのツールであって
問題が発生してないのに、使うものではないと言ってます。
タスクランナーごときで問題が発生しますか?

まさにKeep it simple stupidの話だよ
シンプルにしておけ
2021/04/03(土) 01:34:22.75ID:r67/WY6G
>>275
やっぱ分かってねえじゃん
問題が起きないようアルゴリズムに任せるとこは任せましょう、というツールだよ…
そしてそのアプローチはカジュアルユースにも使えるよね?
2021/04/03(土) 01:37:02.86ID:YB/KO+42
> 問題が起きないようアルゴリズムに任せるとこは任せましょう
無理です。どちらにしろ人間が依存関係の情報を書かなければいけません。
単に書き方が変わってるだけです。
2021/04/03(土) 01:41:25.51ID:r67/WY6G
そういう意見はここじゃやくてそれらのツール、あと
>>252
Jenkins,
Ruby のRake, Thor,
JavaScript のnpm scripts, gulp
のメーリスにでも投稿してくれ
もしかしたら世の役に立たないこともないかもしれん
2021/04/03(土) 01:44:38.22ID:YB/KO+42
ここまでレスの応酬を続けておきながら、
今更そんなレスをするっていうのは
これ以上言い返せなくなったからということなんですね
2021/04/03(土) 01:44:39.70ID:r67/WY6G
昨日結構賑わいあって久々に良い感じの雰囲気だったのに、ID真っ赤にして空気乱してすまんかった
大人げない、反省
2021/04/03(土) 01:45:59.57ID:ANUlY9KL
>>279
ああもうそれでいいよ、君の勝ち
おめでとう
2021/04/03(土) 01:53:31.65ID:YB/KO+42
>>281
お前が、俺の勝ちに見えるのなら、そうなんだろうな
2021/04/03(土) 01:56:49.08ID:K2jZ2c+V
こいつが絡むといつもこう、目的が↑これが冗談じゃないからな
2021/04/03(土) 13:13:41.11ID:eS+08rtw
チャンピオンの誕生を祝して専スレを建てよう
敗者も向学のためご一緒にどうぞ
2021/04/03(土) 13:19:21.91ID:G0wsjcxM
それは良い考え。チャンピオンを称えてそうしてくれるとありがたい
2021/04/03(土) 15:48:41.71ID:cpKOTPf8
>>236
当たらずとも遠からず。
目的は、サーバーテスト。
で、テスト終了後にサーバーを始末したかったんや。。。

>>265
そんなんするくらいなら、makefileのほうが万倍マシやな!w
makeと違って、個別ターゲットの指定もできないし。

>>235
tsortを持ち出す教える君は、上から教えたい気持ちが漏れすぎやで!
https://togetter.com/li/1685
2021/04/03(土) 15:51:10.04ID:cpKOTPf8

リンク先を間違った。orz
https://togetter.com/li/1685635

電車が揺れすぎなんや!
288デフォルトの名無しさん
垢版 |
2021/04/04(日) 04:15:28.57ID:Y9bxvDcN
>>286
> そんなんするくらいなら、makefileのほうが万倍マシやな!w
> makeと違って、個別ターゲットの指定もできないし。

たった>>265のコードだけで個別ターゲット指定できてるんだが?w
makeの「依存ファイルに基づいてビルドするターゲットを決める」という
メイン機能を使わないなら>>265だけでいい。
シバンがないからこれがシェルスクリプト全体だってわからなかったか?

#!/bin/sh
target1() { echo "target1"; }
target2() { echo "target2"; }
target3() { echo "target3"; }
"$@"

↑これをmake.shとかいうファイル名で作って
./make.sh target1ってやってみ、ちゃんと動作するから

もし ./make.sh target1 target2 target3 みたいに
複数ターゲット指定できるようにしたいなら単にループすればいい

for target in "$@"; do
"$target"
done

お前にとってのmakeの価値はこのたった3行のコードにすぎんよ
一行でも書けるがw

# お前に必要なmakeコマンドの実装
for target; do "$target"; done
289252
垢版 |
2021/04/04(日) 06:36:12.78ID:0QnJQanX
まさに、それを書きやすくしたのが、

>>252
に書いた、タスクランナー

Ruby のRake, Thor などで、タスクを指定できる。
タスク同士の依存・実行順序も指定できる
290デフォルトの名無しさん
垢版 |
2021/04/04(日) 06:54:28.00ID:Y9bxvDcN
>>289
まあ実際それらを使っても書きやすくなってないんだけどなw
シェルスクリプトで手に負えなくなる規模ってのを
実際に見たことがないよ
2021/04/04(日) 10:55:57.93ID:Y9bxvDcN
たまたまビルドを作る必要があってMakefileにちゃんと依存関係を書いてみたが
やっぱり数個程度のファイルしかない場合は過剰なんだよなw
そしてその依存関係の定義はちゃんと正しいのか見なきゃいけなないという
タスクごとにそのまま書いたほうが分かりやすいっていうね
2021/04/04(日) 12:21:35.65ID:Y9bxvDcN
依存関係の定義なくしたw
正確に言えば依存ファイルの定義だな
依存のタスクは残しているが、依存ファイルはどうでもいいや
タスクを実行したら最初からビルドしなおしても時間はかからんし
2021/04/04(日) 12:30:56.36ID:sWeAOgyW
矮小化した自分に都合に良い条件でしか考えられない
連投さえして同じとこぐるぐる回ってるだけって馬鹿犬かよ
2021/04/04(日) 12:42:29.55ID:Y9bxvDcN
自分に都合に良い条件で考えるのは足り前
正確に言えば、実際のプロジェクトにいい条件ってこと
架空のプロジェクトを相手にしたってしょうがない
2021/04/04(日) 13:10:39.02ID:sWeAOgyW
プロジェクトってw
想像できませんってだけのそんなレスできるんだから趣味での経験しかないんだろうな
吠えて煩いだけの馬鹿犬だな
2021/04/04(日) 13:30:29.59ID:rmqTiba5
>>288
all : task1 task2 task3
task1: prepare
task2: prepare
task3: prepare
prepare :

という構成で、タスクは並列可、prepareは超重い、となると、makeが最適解やろ。
2021/04/04(日) 15:51:18.30ID:Y9bxvDcN
>>295
じゃお前が具体例だしたら?
想像できるって言ったんだから言えるよね
それとも口だけ?
2021/04/04(日) 15:53:37.76ID:Y9bxvDcN
>>296
task1 &
task2 &
task3 &
wait

でおわりやん
2021/04/04(日) 16:57:04.88ID:WsuFFQM2
狂犬
2021/04/04(日) 19:44:32.02ID:rmqTiba5
>>298
勝手に終わりにしとるだけやん!w
2021/04/05(月) 04:28:41.70ID:gsx4ZFoJ
終わりじゃない理由でもあるの?
2021/04/05(月) 06:19:20.07ID:3jUc8O+L
prepare無視して勝手に終わりにしてるってとこだろ
無視というかただわかってないからだろうけど
2021/04/05(月) 06:33:48.44ID:Ir9xQslo
そう言われてから出すとしたら等価ではないのをまた出しそうでだな
304デフォルトの名無しさん
垢版 |
2021/04/05(月) 08:37:32.95ID:gsx4ZFoJ
その前にprepareが何なのか言えよ
ただ実行する以外に何が違うのか書いてないのに
あとつけで違うとか言うなよ
2021/04/05(月) 08:49:07.73ID:Ir9xQslo
わかってないこと多すぎなのになぜもそう偉そうなのか
2021/04/05(月) 09:09:31.93ID:Ir9xQslo
>>304
prepareはprepareだろう。その意味意図がわからないのはちょっとなあ
知らないのにそんなに偉そうなのは恥以外の何物でもない、恥の上塗りだな
>>296がそう意図してるのかは不明だが、>>296のでできるのは>>298だけじゃないからな
親切なヒントやったぞ。さあ、どうぞ
2021/04/05(月) 10:59:23.34ID:gsx4ZFoJ
>>306
じゃあそれ以外の意図があるならそれを書いてくれ

task1関数、task2関数、task3関数 の一行目に
prepare関数を実行すれば終わりだろ?
2021/04/05(月) 11:01:51.92ID:gsx4ZFoJ
複数のタスクを指定したときにprepareを一回しか実行しないというのであれば
all関数の最初に一回だけ書いてもいいし
フラグを使って一回だけ実行するようにしてもいい(たった一行で実現可能)
動かしたい通りに書けば良い
2021/04/05(月) 11:04:18.21ID:i9PX2oQn
気持ち悪いスレだなあ
2021/04/05(月) 11:04:54.93ID:gsx4ZFoJ
leftpad事件と同じ匂いを感じててしまうな
われわれ(俺除くw)はこんな簡単なコードも書けなくなってしまったのか?
2021/04/05(月) 11:22:30.40ID:i9PX2oQn
>>284
棲み分けられるか正直疑問だし、御高説垂れにくい初心者スレ的なのはどうだろうか
2021/04/05(月) 11:52:33.18ID:qeGrbie0
>>308
そんなクソコードに頼らずとも使えるのがmakeなんやで!w
2021/04/05(月) 12:42:09.26ID:gsx4ZFoJ
>>312
makeはすぐ複雑化するよ

http://quruli.ivory.ne.jp/document/make_3.79.1/make-jp_16.html
C. 複雑なMakefileの例
ここにGNU makeプログラムのmakefileがあり、それは比較的複雑なものです。
2021/04/05(月) 12:43:47.04ID:gsx4ZFoJ
このMakefileを見て以下の情報を読み取るのは困難

> ここでは、最初のターゲットなのでデフォルトのゴールは‘all’です。
> この makefileの興味深い特徴は、‘testpad.h’がtestpadプログラムに よって
> 自動的に作成されるソースファイルである点です。そして、その プログラム自身は‘testpad.c’のコンパイルによるものです。

> ‘make’あるいは‘make all’と入力することでmakeが実行可能な ‘tar’、
> テープアクセスを提供する‘rmt’デーモン、‘tar.info’の Infoファイルを作成します。

> ‘make install’と入力すると、‘tar’、‘rmt’、‘tar.info’の 作成だけでなく、それらのインストールも行ないます。

> ‘make clean’と入力すると、makeは‘.o’ファイル、 ‘tar’、‘rmt’、‘testpad’、
> ‘testpad.h’、そして ‘core’ファイルをすべて削除します。

> ‘make distclean’と入力すると、makeは‘make clean’と同じ 削除以外に‘TAGS’、
> ‘Makefile’、そして‘config.status’ファイルも 削除します。
> (明らかではありませんが、このmakefileと‘config.status’は configureプログラムに
> よって作成されたもので、これはtarの 配布プログラムに含まれています。しかし、ここではそれは表示されていません。)

> ‘make realclean’と入力すると、makeは‘make distclean’の ときと同じ削除を行ない、
> さらに‘tar.texinfo’から生成されたInfoファイルの 削除も行ないます。

> さらに、ここでは、配布キットを作成するためのターゲットsharと distも示されています。
2021/04/05(月) 12:52:05.95ID:4wNso/hW
Makefileが複雑化するのはビルドする工程が複雑化しているという別の問題の顕在化でしかないでしょ

それと同じことができるシェルスクリプトを書くのとMakefileを書くのとどっちが簡単かって話じゃないの
2021/04/05(月) 13:07:34.94ID:i9PX2oQn
話題に挙がったついでだけどそこでtsortよ
ルールだけ抜き出して可視化しリファクタリングしなさい
2021/04/05(月) 13:09:49.69ID:gsx4ZFoJ
>>315
複雑なビルド工程をMakefileだと
・依存関係の定義として記述するのが正しいとされ、シェルスクリプトとしての柔軟性もないので
細切れのタスクが多数できてしまい、見づらくエスケープされたシェルスクリプト等を埋め込むことになる
と言ってます。

Makefileからシェルスクリプトを呼び出すんじゃなくて
シェルスクリプトから(必要な場合に必要な所だけ)makeを呼び出したほうがいいんだよ

そして大抵はmakeはいらない。多くの人がタスクランナーとして使ってるのはそういうこと
本当にmakeが必要なのは、C言語のような古い言語で、ヘッダファイルとソースファイルから
オブジェクトファイルを作ってリンクするような作業の部分だけでしょ?

つまり>>314に書いてあるタスクの殆どはmakeを使う必要がないってこと
2021/04/05(月) 13:28:19.87ID:qeGrbie0
>>317
見辛いシェルスクリプトコードならファイルにしたらええのに。w
2021/04/05(月) 14:41:15.13ID:VlUSW8N+
そもそもシェルスクリプトでファイル間の依存関係を定義するのに疲れたから make が生まれたと思うんですけど...

あと Makefile があれば make install や make clean が存在するっていうのが分かるのがいいんだよ
プロジェクトごとにシェルスクリプトがあったらどういう引数で読んだらいいかとか分からないだろ?
2021/04/05(月) 15:23:18.33ID:gsx4ZFoJ
> そもそもシェルスクリプトでファイル間の依存関係を定義するのに疲れたから make が生まれたと思うんですけど...

そうだよ?タスクランナーではなく依存関係を定義するために作られたのがmakeだよ
最初からそう言ってるじゃん
2021/04/05(月) 15:26:11.21ID:gsx4ZFoJ
> プロジェクトごとにシェルスクリプトがあったらどういう引数で読んだらいいかとか分からないだろ?

俺はそれよりもmakeで実行できるタスクに何があるのかわからんのだがw
make --helpした所で表示されないしな

Makefileみればわかるって?それはソース見ればわかるって言ってるようなもんだし
依存関係を見たいんじゃなくて、makeで直接実行することを目的としたタスクの一覧が見たいんだよ
2021/04/05(月) 16:03:10.00ID:r6jGhjiZ
>>300-302から自ら>>304と馬鹿な自分を自己紹介しておいてw
何でそうも偉ぶりたいのか。まともな神経あったらそんな態度は取らないわなあ
さすがだな
2021/04/05(月) 16:07:12.70ID:rGWHafb6
>>322
「ただ実行する以外に何が違うのか書いてない」に
対してレスはなにかありましたか?
それが答えだよ。
2021/04/05(月) 16:13:51.85ID:r6jGhjiZ
そのレスはコーダーと呼ばれる人種っぽいレスだな
いや、普通の日本語の文もそうだが読み取る能力が欠けてるだけだな
それは矮小化した自分に都合の良い条件でしか考えられないからだな
プロジェクトwwとか関係ないよ、ソース読めないといってるのと同じだな今回は
2021/04/05(月) 16:14:36.43ID:rGWHafb6
そんなレスは誰も求めてないよ
2021/04/05(月) 16:17:39.09ID:r6jGhjiZ
懲りずに
矮小化した自分に都合の良い条件
かよwそれこそ誰も求めてないぞ
2021/04/05(月) 17:28:04.19ID:qeGrbie0
>>321
ターゲットを調べたければ、sedでも使ったらすぐにわかるやん。w
2021/04/05(月) 20:09:00.48ID:nAjTTeFT
気持ち悪い煽りだな
2021/04/05(月) 20:33:09.06ID:Oftt9CcS
ルビキチ臭
2021/04/05(月) 21:07:57.60ID:rGWHafb6
>>327
ターゲットじゃなくてタスクを見たいんだってw
例えばシェルスクリプトなら--helpして分かりやすいusageが
表示されるように作るだろ?

sedではそのわかりやすさがない。頑張れば作れるだろうが
Makefileでそんなのが用意されてるのみたことないよ
331252
垢版 |
2021/04/05(月) 21:19:53.87ID:2g7RifS+
Ruby のタスクランナー、Rake, Thor などでは調べるのも簡単

thor list,
thor タスク名

などで、タスクを表示できる

タスク定義の仕方も決まっているので、保守しやすい。
シェルスクリプトでは、各人で書き方を変えるから、保守できない
2021/04/05(月) 21:21:58.48ID:VlUSW8N+
こいつがまともなレスしてるの初めて見たぞ... 明日も雨か?
2021/04/05(月) 21:22:55.94ID:qeGrbie0
>>330
自分で書く話なら、helpターゲットをつくったらええがな。w
実際、そういうmakefileを、おまえは見たことがなくても、ワイは見たことがあるで?
2021/04/05(月) 22:30:31.71ID:Oftt9CcS
あいつは何を言いたい何をしたいんだかな
何をしたいのかは「勝ちたい/負けたなくない」wwなのは明白だったか
2021/04/05(月) 22:47:11.83ID:rGWHafb6
>>333
だから結局そうなるから
Makefileに利点がないんだって
中身が複雑になる。そして利点がない。
2021/04/05(月) 22:48:23.80ID:rGWHafb6
>>331
thorのコードのほうが複雑になる

シンプルにしておけと言われるのに
なぜか複雑になる
2021/04/05(月) 22:56:26.91ID:Oftt9CcS
だから結局そうなるってwこいつの頭の中身はどうなってんだよ、ほんとに
利点を争ってるwのはそこじゃないだろうにな
「勝ちたい/負けたなくない」wwすぎて誤魔化しがカオス
2021/04/05(月) 22:59:22.09ID:Oftt9CcS
まあ、チャンピオンはこうだからチャンピオンなわけで、誰も勝てないわな
さすがチャンピオン
適当に諦めて試合放棄してもいいよ、挑戦者
2021/04/05(月) 23:00:22.41ID:rGWHafb6
それなら勝ち負けじゃなくてmakeの利点・欠点の話をすればいいじゃん
俺はずっとmakeの話をしてるんだが、お前は俺の話しかしてないじゃん
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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