Programmer 都愛貼 code,gist 與 gist-vim 的搭配用法

身為一個寫 blog 的 programmer,不能少的就是在 blog 上面貼 code,最近的流行是用 gist,gist 可以讓你把一段 code 放在 github 上,而且還可以有 version control。

在 gist 畫面的左邊,會給你一個 embedded this gist 的連結,像這樣
<script src="https://gist.github.com/aknow/6232870.js"></script>

把他複製貼到 blogger 上就可以了,成果如下。

但是阿,如果你是手動把 code 弄到 gist 上面,那這樣就太遜了,基本上各大編輯器都有跟 gist 互動的 plugin,如果你用 Vim,可以使用 gist-vim,可以讓你直接在 Vim 裡生成、編輯、讀取 gist,完成後還可以幫你把連結開起來。

當然,這篇用的 gist 就是這樣產生的。

保持專注的工作方法

幾個月前曾經在 facebook 上看這到這張圖的分享,上面提到了幾種保持專注的方法。我們知道如果工作或學習時能夠進入專注的「心流」狀態,這時就會發現時間似乎過得超快,而生產力也爆增。

From: http://fundersandfounders.com/focus-hacks/
所以我們得努力讓自己進入這樣的狀態,但問題是,事實上常有些因素讓我們分心,大致上可分成兩種,外界的干擾,以及自己分心,今天要跟大家分享我利用圖中這兩項
  • put on headphones
  • time yourself
所嘗試過的努力與方法,基本上這應該算是要對抗自己分心。
首先是帶上耳機,帶耳機除了可以隔絕外界的聲音,不會受干擾,也可以減少自己想去聽辦公室八卦的欲望。但是太安靜其實反而不好,所以我還是想讓自己聽一些東西,這邊有個關鍵點,千萬不要聽有聽得懂的歌詞的歌,不然是會被帶走的,所以到底要聽什麼呢?
我有聽過白噪音(white noise),科學研究白噪音有許多好處,例如幫助睡眠,阻擋分心,提昇專注力,有一個網站 SimplyNoise 可以產生這樣的聲音,他還有 pink noise,brown noise 各式變形,這稱之為 colors of noise,有興趣可以去看看。另外 android 上也有很多 app 提供白噪音的產生。
好了,但是當我聽了一陣子之後實在是受不了,覺得自己像個笨蛋。這時候我發現了 coffitivity,他會產生像是身處在咖啡廳的聲音(不過是英文的),咖啡廳的好處我想很多人都知道,這也是為什麼許多人喜歡在那邊讀書或是工作,而我自己的親身體驗也是,在大學的時代的某陣子,我甚至都待在早餐店念書。
coffitivity 建議使用咖啡廳環繞再加上略為大聲的個人音樂,所以除了這個,我還搭配了一個音樂,真的有效,不過還是一樣,在連續聽了一個禮拜過後,就開始有點膩了。我開始在 youtube 上找還有什麼適合的,用關鍵字「music productivity」,發現許多人都建立了屬於他們的 productivity 播放清單,本來我也想仿照蒐集一個,但是工程師的美德就是懶,非不得已絕不自己動手,幸運的是我發現了這個,Study Music Project,以及他的 youtube channel
The Study Music Project is a collection of music productions composed, written, and produced by Dennis Kuo.The sole purpose of the music is to help you focus as you study for school. Instrumentation, melody, and other musical articulations have been well thought-out to enhance concentration.
所以我現在的搭配是 coffitivity + Study Music Project,試用了一陣子,感覺還不錯,包括我寫這篇 blog 時也是這樣聽的。
再來是 time yourself,我是用 pomodoro 的方式在工作,詳細內容就請大家自己去看,簡單講就是以 30 分鐘為一單位,認真做 25 分鐘然後休息 5 分鐘,接著下一個循環。有許多 pomodoro 的相關工具,desktop tool,chrome extension,mobile app,我習慣用的是 android 上面的 pomodroido,有一些功能,但是我只有當作計時器用而已,好處是有一個時間的 progress bar,當看到的時候就可以提醒自己,還有多少時間,要堅持下去,不要隨便分心。
在使用 pomodoro 時,我還會準備一個 interrupt list,萬一真的分心時,趕快把想到的事情記下來,這樣你的腦袋就會知道這個東西已經記在別處了,可以不用一直掛念,趕緊回到 focus 狀態,不過其實這也是標準 pomodoro 上面教的方法。這個 interrupt list 我是用 trello 管理的,並不是說 trello 特別適合,而是因為我是用 trello 在管理我的工作事項,這些 interrupt 很有可能變成之後的 todo item,建議直接用同一個工具管理。
其他的有機會再來分享,我也要朝著有生產力的偉大航道前進。

在 Vim 中使用 clang_complete 做程式碼補完

先看一下效果,在這個例子中,我使用 standard library 中的 vector 容器,當打到 v. 的時候,Vim 會自動跳出視窗列出可以使用的 function,圖片中顯示的是再打了 p 之後的篩選結果。

之前我是使用 ctags + OmniCppComplete來做程式碼補完,他的缺點是:

  1. 要先產生 tags。
  2. ctags 其實看不懂程式碼,有些 code 會跑不出來,例如 libstdc++,所以網路上常見的作法是拿一份修改過的 header 給 ctags 跑。

總體來說,這樣搭配的補完效果跟 visual studio 是完全不能比的。

clangcomplete 這個 plug-in 跟 OmniCppComplete 不同,他是使用 LLVM compiler 的 front-end clang 去 compile 你的程式,所以可以列出最精確的補完清單,甚至你還可以給他 include path 跟 compile option,又會更準。這樣用起來,補完的資訊跟就變得跟 visual studio 一樣,都是由 compiler 提供,相信整體的品質應該會好上許多。

回到先前的例子,可以把 clangcomplete 的執行想成是先 compile 你的程式,再根據結果給你補完的清單,所以如果我前面忘了打 #include ,這個清單是會跑不出來的,會找不到。

安裝方式

  1. 安裝 clang,ubuntu 可以透過 apt-get 或是軟體商城把套件 clang,libclang-dev 裝上即可。windows 的話可以抓 source code 自己 build,或是他有提供一個基於 mingw32win32 binary
  2. 裝完後可以參考網頁上的範例,試一下,確定你的 clang 是好的。記得要把 clang / libclang.a / libclang.so / clang.dll 的位置加到 PATH 中。
  3. 安裝 Vim plug-in clang_complete,參考作者的安裝說明,或是你有使用 pathogen.vim 在管理 plug-in 的話,那麼不用我說,你一定知道要怎麼裝!
  4. 根據我的經驗,在 windows 的話,要複製一份 clang.dll 改名為 libclang.dll,這樣 clang_complete 才找得到。

使用方式

  1. 當打到 . / -> / :: 等的時候,補完視窗就會自己跳出,或是可以按 。
  2. 其他相關的使用與設定
  3. clang_complete 會跟一些補完的套件衝突,例如 OmniCppComplete,記得要先把那些停掉。

延伸 Reference

成為一個努力的人 -- 我的 MOOCs 之旅

記得在去年底的時候,我對自己許了一個新年願望:希望在新的一年,每一天都可以覺得比昨天的自己又更進步了,就如同網路上流傳的一句話「每天進步0.01!一年後你就比現在強大36倍!」。是的,我想成為一個努力的人,我想透過一連串的習慣與改變,讓自己更努力。 不過說真的,要一直努力,其...