Plurk FaceBook Twitter 收進你的MyShare個人書籤 MyShare
  顯示內嵌語法

OpenFoundry自由軟體充電報

OpenFoundry自由軟體充電報
2006.9.25/報主.Tumi

本期內容:
[OSSF專欄] Mac 中文輸入法發展的傳奇-OpenVanilla
[源碼心得] 一株香草的成長─我所知道的 OV 故事

[OSSF專欄] Mac 中文輸入法發展的傳奇-OpenVanilla

OpenVanilla是一套跨平台的文字輸入法框架 (text input method framework),除了在 Mac OS X 平台上擁有眾多使用者外,經由社群開發者的群策群力,目前亦有 X Window 版和剛開始發展的 Windows 版。這套原本是為了解決 Mac OS X 文字處理問題的輸入法框架,目前已經發展出超過二十種輸入法,對於有特殊文字符號需求的跨平台使用者來說是最佳的解決方案。(tuml/文 2006/9/24)

◎ 開發源起

因為一個想要讓輸入法變得更順己意的念頭,開啟了 OpenVanilla 的誕生。OpenVanilla 的創始者 lukhnos 表示,由於剛開始在使用 Mac 時,發現 Mac 上的傳統注音沒有自己慣用的倚天排列,但又適應不了 Mac 上的注音輸入,非常不便,便開始展開「自力救濟」,透過朋友間的討論詢問,發現 Apple 上有套輸入法的範例程式叫 BasicInputMethod,熱愛寫程式、但是有很長一段時間沒碰的 lukhnos 於是耐心從最基本的追蹤 (trace) 程式碼開始,並利用了同樣開放源碼的 xcin 專案中的注音輸入法表格,開始撰寫最初的香草輸入法。

香草注音輸入法釋出後開始受到社群開發者的注意,接著後來成為 OpenVanilla 主要成員的 mjhsieh 問 lukhnos 可否增加他常使用的倉頡輸入法,因為這套輸入法在 Mac 上用起來也不很順手,於是 lukhnos 依照香草注音的開發模式、寫出了香草倉頡輸入法,並將以上的輸入法整合成為香草輸入法 (VanillaInput) 專案。由於新增了倉頡輸入法,因此也吸引了更多使用者試用,計畫也因為受到使用者的回報而日益精進,不停進行小幅更新。

◎ OpenVanilla 誕生

面對著日益增加的需求,lukhnos 一方面感到開心,另一方面也在思考更新香草輸入法的軟體架構以因應日後需求,但是架構性的東西,需要慎重思考。在 gugod、audrey、zonble 等熱心的社群開發者協助下,香草輸入法重新架構,參考 xcin 在 UNIX 上以 "shared library" 方式達到可外掛模組的功能、並解決 encoding 問題,緊接著社群內另一套著名的酷音輸入法 OS X 版開發者 gugod 也把酷音輸入法移植到新的架構下,一套嶄新的 OpenVanilla 輸入法與文字處理架構儼然形成,接著其他的 OpenVanilla 核心開發者亦持續不停加入各式各樣的輸入法。

對 OpenVanilla 九位核心開發者而言,OpenVanilla 的開發不但可以趁機了解 OS X 的開發環境與工具,更像是透過 OpenVanilla 這樣的框架挑戰「輸入法的極限」。透過 gugod 的協助,OpenVanilla增加 makefile 架構後加速了輸入法種類的開發,緊接著各式各樣特殊的輸入法與功能如 ezbasic、PHP 輸入法 (OVIMPHP)、簡繁轉換等都紛紛加入 OpenVanilla 作為「實驗」,透過這種實驗性濃重的過程,開發團隊也可以順便「練功」,提升自己在 OS X 上的開發能力,然後再將學到的新技巧應用到 OpenVanilla 上。

OpenVanilla 在香草輸入法時期便已在中研院資訊所自由軟體鑄造場專案平台上進駐,提供專案瑕疵回報、待辦事項與檔案下載等功能,目前已經發展到 0.7.2 版,並採用 BSD 授權。OpenVanilla 從最常見的注音、倉頡,到特殊用途的日文、白話字 (POJ)、甚至藏文輸入模組等都包含在內,另外有正在實驗中的歐語拼字檢查模組,此外 OpenVanilla 並具有詞彙管理工具、簡繁轉換、字根反查、以及全形文字輸出、歐語智慧引號(可以打出成對的德文或法文用引號)等功能。

如果以上輸入法都不能滿足使用者的需求,使用者還可以透過泛用輸入法模組自行創建新的輸入法,或是將公開取得的輸入法資料表拷貝至資料目錄中。Lukhons 解釋,泛用輸入法的出現可說是提供了一套開放的工具和方法(.cin格式的資料表格),讓使用者也可以參與其中,支持並成就了開放原始碼軟體開發模式的精神。

◎ 使用者迴響

OpenVanilla推出後受到使用者廣大迴響,大部分是 Mac 使用者,X Window 和 Windows 平台上的使用者也在逐漸增加中。從事 RD 工程師職務的 jiing 是 OpenVanilla 的忠實使用者,他說他把 Mac 買回家後第一件事便是去安裝 OpenVanilla 輸入法框架,玩玩一些奇特的輸入法(漁村輸入、藏文輸入),對於他最常用的香草倉頡時,剛開始用後發現自己習慣的很多字拆碼都是錯的,於是開始訂正自己的拆字方式,起初是有些不習慣,但是一段時間過後開始適應,速度也逐漸加快,加上 Mac 的鍵盤觸感優於一般的 PC 鍵盤,所以到後來 jiing 幾乎所有的文書作業都在 Mac 上完成,同時亦會向他的朋友推薦 OpenVanilla。

由於 OpenVanilla 具有可自行創建、修改現有輸入法的特性,對於文字輸入有特別要求的文字工作者來說也非常有用。從事人文學科研究的 momizi,在課堂上聆聽教授演講時需要用她的 ibook 做筆記,但身為倉頡使用者的她發現 Mac 上的倉頡與原有輸入習慣不同,感到非常痛苦,當時因緣際會接觸了 OpenVanilla 前身的香草倉頡,便立刻加入使用的行列,並根據使用經驗回報給開發者非常多寶貴意見。由於使用需求亦經常用到日文輸入,momizi 在開發者 gugod 的協助下,貢獻了 OpenVanilla 最早的日文輸入法表格(詳請參考本期 [源碼心得])。

◎ OpenVanilla 未來發展

關於 OpenVanilla 計畫的下一步,lukhons 表示,由於 OV 的開發團隊主要都是 Mac OS X 的使用者,而且都是自由貢獻,故未來 OV 短期內的功能開發都還是聚焦在 Mac OS X 版的功能上,「先以解決實際使用問題、讓大家能從開發或使用中獲得樂趣為主要方向」,其 他作業平台版本的 OV 發展就要看相關計劃開發者的貢獻度而定。但,lukhons 也不諱言,從個人角度來看,如果 OV 這樣的計畫要持續壯 大,「遲早會出現一堆『不好玩,但是得做』的東西」,從過去許多開放源碼專案的經驗可知,開發者此時必須要朝組織化的方向來思考了。

◎ 結語

Lukhnos 當初會為計畫命名「香草」,就是取其簡單樸素之意,然而最單純的東西往往也最容易廣為使用及流傳,OpenVanilla 從一個簡單但實際的解決方案開始,不但解決 lukhnos 的困難,同時也為眾多具有相同困擾的使用者解決問題,因而能在兩三年的時間內持續受到大家的喜愛,這也使得 OpenVanilla 計畫成為國內熱門的自由軟體專案之一。



[源碼心得] 一株香草的成長─我所知道的 OV 故事

momizi/文 2006/9/24

事情應該要回到 2004 年夏天,從大家突然開始人手一台 mac 說起。

2004 年夏天, #osxchat上的成員常一起坐在師大周邊的咖啡廳裡,一邊用免費 wifi 一邊一起工作。那天,記得是五月初的某天,lukhnos 和 b6s 拿到了他們新買的 power book,拿到某店內,在大家的慶賀聲中,舉行剝皮..開箱驗貨大典。我想我會一直記得那一天 lukhnos 臉上的歡喜神采吧。那天是我第一次見到 lukhnos,雖然以前從來不認識他,他卻給我一見如故的親切感。

當年八月,在 #osxchat 友人們的恭賀聲中,我也歡歡喜喜地買下了我十年來的夢想-我的第一台 ibook。機器買來就是要用的,但是沒有目的就不會積極去用。撐過了 windows 跳船到 osx 的適應期,真正面臨輸入法問題的時刻,是九月開學,我帶著我的小蘋果跑去重聽一年級的課,要用它打筆記的時候。

我用電腦打筆記的歷史大概是從 2001 年開始的,到 2004 年秋天已有三年多的經驗。對我們這個科系來說,筆記裡如果只有 1.ooo 2.xxx 3.oxo 式的重點,對於考試是沒有幫助的。加上我回家不可能有空再拿出錄音檔整理逐字稿,所以我的筆記從來都是盡我所能地替老師做語錄(但不打老師的閒聊與笑話)。

這個時候我發現第一個問題:mac 內附的倉頡,雖說我在 OS7 的時候已有使用經驗,但是經過了那麼多年,關於如何輸入重碼字的記憶早已模糊,又有的字是拆碼方式與在 windows 上慣用的拆法不同。既然是追音式的筆記,你可想見在上課的當下,打字速度行雲流水是一件多麼必要的事情,但是 mac 倉頡卻足以令行雲流水變成混凝土灌漿,一個「黃」字,這麼平常普通的字,怎麼拆都拆不出來(註:mac 內建倉頡是 3.0 版,「黃」的拆碼跟 windows 上的倉頡不一樣),在拼命試的同時,老師已經講到不知道哪裡去了,心裡當然又氣又急。這個時候,lukhnos 正開始做香草倉頡 0.6 版,將要溺死的人,任何可以抓的東西他都會去抓,同理,我幾乎是沒有什麼掙扎就換過去用香草輸入法。由於我自己沒有技術背景,只能出張嘴,lukhnos 人很好,雖然他自己不用倉頡,我希望的功能,比方很基本的按 caps lock 鍵可以變成英數大寫這種功能,跟他說一聲,他當場就在咖啡店裡為我改出來一個0.61版讓我裝起來用,在 pc 上做為使用者,從來不曾感覺自己像這般倍受呵護。有使用,有需求,遇到問題就靠學校裡的wifi 立時往 #osxchat 上回報(當時我用的是香草6.0 + apple work,所以也真的遇到了各種各樣別人遇不到的問題),提了之後會有人幫著指點、幫著解決,回想起來,真是值得永遠記在心裡的善緣。

第二個遇上的問題是,無論是筆記或工作,我都經常需要中英日混打,但是為了打幾個日文字母就要把整個語系切成日本語,不僅小題大作,而且如果我只是要幾個字母,卻要看著日本語輸入法跳出的漢字選單按老半天,也浪費時間精神。同樣的,等這樣的步驟做完,老師已不知講到哪裡去了。於是我又問了,有沒有什麼辦法可以解決?那時有人教我,由於香草輸入法是讀入一個 .cin 表格,所以如果能整理出一個五十音的 .cin 表格,那麼就可以輸入日文字母。好像是 gugod 找到了古早時代的 ukiyoe(浮世繪).cin 表格給我看。我開起來看,裡頭有很多錯漏不全之處,直接用會有許多問題,需要有人修改。好在這世上的事不是每件事都要靠聰明或有高科技背景的人來做,沒有技術的人,也有他可以貢獻心力的事。我雖不敏,就 #osxchat 的成員背景來看,修改日文表格讓它符合繁中介面下日文使用者的需求,捨我其誰?

學會了如何在 pc/mac 上開啟 .cin檔案,知道了表格的組合規則,我在某間大家常一起工作的咖啡廳裡一個字一個字慢慢敲,把 ukiyoe.cin 上的錯誤改掉,增添新的內容。因為已經跟原先的 ukiyoe.cin 大大不同,我認為原名文不對題,新表格應該有個簡短、跟日文字母相關而涵意更深遠的新名字,便自做主張將它改名叫 iroha.cin,再由 gugod 幫忙修正一些程式碼,它便成了一個可用之物,含日文輸入法的香草輸入法 0.6.3 出現,此時已是 2005 年春。能夠行雲流水輸入中文、日文,我在小蘋果上要做什麼工作都沒問題了,在我心中,香草輸入法至此無敵於天下。整理出 iroha.cin 大概是整個香草輸入法開發過程中,令我最有成就感的一件事。

當然就如同世事變幻,人事流轉,隨著 OV 越來越知名,越來越多的高手加入開發團隊,也就越來越輪不到我這種沒技術的人為它出力。但至少我能說自己曾經為香草輸入法的成長付出過自己的一份心力,經此而實現了我一直盼望落實在生活中的社會性質目標:「開發覺悟,利己利人」。這對高手而言或許是微不足道的事,但這整個過程解開了我心中長久以來的一個結,對我而言是無上的自我實現。即使沒有前面說的一些小故事,OV 本身現在已經很好用了,能讓使用者按自己的需求去修改出自己需要的東西,讓我享受在小蘋果上的書寫,同樣是很有成就感的事情,這是我沒有在其他輸入法體驗過的優點,所以只要聽到新跳船的朋友抱怨 mac 上的輸入法不好用,我一定叫她趕快去裝 OV。

囉囉嗦嗦地說了很多,謝謝大家耐心看到這裡。 :)



報主的話:
本電子報為摘要版,若欲訂閱全文版請按此