呼籲大家多遵守交通規則 - Linux

Table of Contents

容我發發牢騷,請包涵

這學校老師應該都講過吧...
寫程式時,要記得回傳個有意義的 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)
搞得整個地球上的人都在想辦法繞道...

大家都遵守交通規則, 最後受益的也是大家
而且整體效率一定會顯著提升

有一次, 搭德國人車子在縣道
遠看, 另一台高速從旁邊衝出來
這個德國朋友卻繼續談笑, 不減速
我緊張地用手指著那台車....
他只說

沒關係, 我們在幹道

然後繼續向前衝, 眼看就...
咦? 他真的停下來了也!

這樣不是大家都省事嗎?
多包涵吧



--

All Comments

Caitlin avatarCaitlin2018-11-04
這很正常,一堆程式搞不清楚啥該送去stderr/stdout
exit code 就更不用說
最後變成 跑去 pipe grep string
Elvira avatarElvira2018-11-07
這不就是命令列程式的日常嗎? XD
Zenobia avatarZenobia2018-11-12
man 看看, exit status 有沒有亂唬人
Gary avatarGary2018-11-14
印象中還看過有人用相反,正確回 1 錯誤回 0 的……
Xanthe avatarXanthe2018-11-16
送 patch 造福萬千
Faithe avatarFaithe2018-11-17
其實你要多動動腦不是要人跟隨你的規則...
Eartha avatarEartha2018-11-18
也不是所有錯誤都要返回,像 rm -f 就算找不到檔案,
也不會回報錯誤。
Daph Bay avatarDaph Bay2018-11-20
SUCCESS 正是 -f 這選項的主要功能喔
Regina avatarRegina2018-11-21
換句話說,-f 正是為了回報 SUCCESS 而設計的
Genevieve avatarGenevieve2018-11-22
所以它的行為是符合設計的 feature, 不是 bug
Zanna avatarZanna2018-11-26
我以為這已經是常識等級,沒想到還是需要解釋
Ula avatarUla2018-11-28
現代公民實在太忙了,沒空看說明書
Sierra Rose avatarSierra Rose2018-11-30
前輩們有空的話,還請多多推廣交通安全常識
Emma avatarEmma2018-12-02
其實我應該多加一句話,效果可能會更好的... 好吧
Noah avatarNoah2018-12-07
有人應要腳踏車上高速公路,考驗汽車駕駛的智慧?
Elma avatarElma2018-12-11
本文提的其實有點像rm -f 沒刪到檔算正常結束還是錯誤?
這點我是覺得由開發者決定,而不像rm刪除權限不足一樣確定
Mary avatarMary2018-12-14
是錯誤.
David avatarDavid2018-12-18
ls 也類似 'ls 你老師' 但沒'你老師'算不算錯誤?
Gilbert avatarGilbert2018-12-19
如果沒有檔案算錯誤,那麼 ls *a 但沒有a結尾這些都得變錯
誤. 所以還是可能還是由開發者決定
a結尾的檔
Erin avatarErin2018-12-23
目前linux的rm是設計-f來區隔,沒用-f沒找到檔就算錯誤
Elma avatarElma2018-12-27
ls無類似機制,沒找到就報錯. 你文中的例子比較傾向ls
Rebecca avatarRebecca2018-12-29
那個行為 POSIX 應該有規範吧