[閒聊] 呼籲大家多遵守交通規則

作者: cuello (cuello)   2018-11-02 10:42:03
容我發發牢騷,請包涵
這學校老師應該都講過吧...
寫程式時,要記得回傳個有意義的 exit code
不然, 別的程式往往都要額外浪費時間處理
當然, 特別是指令行程式, GUI 就不那麼在.
但是無論是用 C 來 code, 還是任何 script
都有我們應該共同遵守的交通規則.
事情是這樣的
剛剛用到 pacmd(1)
這是 pulseaudio-utils 套件裡的程式
$ pacmd set-default-sink 1
$ echo $?
0
$ pacmd set-default-sink 你老師
Sink 你老師 does not exist.
$ echo $?
0
對的給 0, 不對的也給 0
那我不是還要去 parse "你老師" 那一行
來判斷這個指令的執行結果
(而且"你老師"也應該送到 stderr,
不是 stdout, 雖然此處並不關鍵...)
要是每個 CLI 程式都採這樣行為
我看我這個小 script 起碼變成兩倍大
而且要多花一倍的時間在這上面
沒記錯的話, 上一次碰到的是 xrandr(1)
搞得整個地球上的人都在想辦法繞道...
大家都遵守交通規則, 最後受益的也是大家
而且整體效率一定會顯著提升
有一次, 搭德國人車子在縣道
遠看, 另一台高速從旁邊衝出來
這個德國朋友卻繼續談笑, 不減速
我緊張地用手指著那台車....
他只說
沒關係, 我們在幹道
然後繼續向前衝, 眼看就...
咦? 他真的停下來了也!
這樣不是大家都省事嗎?
多包涵吧
作者: dou0228 (7777)   2018-11-02 10:44:00
這很正常,一堆程式搞不清楚啥該送去stderr/stdoutexit code 就更不用說最後變成 跑去 pipe grep string
作者: Neisseria (Neisseria)   2018-11-02 14:01:00
這不就是命令列程式的日常嗎? XD
作者: newversion (海納百川)   2018-11-02 21:07:00
man 看看, exit status 有沒有亂唬人
作者: lantw44 (#######################)   2018-11-02 23:58:00
印象中還看過有人用相反,正確回 1 錯誤回 0 的……
作者: LinBuoRen (林博仁)   2018-11-03 20:22:00
送 patch 造福萬千
作者: final01 (牛頓運動定律)   2018-11-05 23:26:00
其實你要多動動腦不是要人跟隨你的規則...
作者: Gold740716 (項為之強)   2018-11-06 20:53:00
也不是所有錯誤都要返回,像 rm -f 就算找不到檔案,也不會回報錯誤。
作者: cuello (cuello)   2018-11-07 05:31:00
SUCCESS 正是 -f 這選項的主要功能喔換句話說,-f 正是為了回報 SUCCESS 而設計的所以它的行為是符合設計的 feature, 不是 bug
作者: dou0228 (7777)   2018-11-07 08:50:00
我以為這已經是常識等級,沒想到還是需要解釋
作者: cuello (cuello)   2018-11-07 10:29:00
現代公民實在太忙了,沒空看說明書前輩們有空的話,還請多多推廣交通安全常識其實我應該多加一句話,效果可能會更好的... 好吧
作者: newversion (海納百川)   2018-11-07 17:50:00
有人應要腳踏車上高速公路,考驗汽車駕駛的智慧?
作者: bitlife (BIT一生)   2018-11-12 11:07:00
本文提的其實有點像rm -f 沒刪到檔算正常結束還是錯誤?這點我是覺得由開發者決定,而不像rm刪除權限不足一樣確定是錯誤.ls 也類似 'ls 你老師' 但沒'你老師'算不算錯誤?如果沒有檔案算錯誤,那麼 ls *a 但沒有a結尾這些都得變錯誤. 所以還是可能還是由開發者決定a結尾的檔目前linux的rm是設計-f來區隔,沒用-f沒找到檔就算錯誤ls無類似機制,沒找到就報錯. 你文中的例子比較傾向ls
作者: Bencrie   2018-11-12 12:27:00
那個行為 POSIX 應該有規範吧

Links booklink

Contact Us: admin [ a t ] ucptt.com