Go的标准IDE:Acme文本编辑器

王益 · · 6283 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

摘要

Acme是一个文本编辑器。一说到文本编辑器,大家最容易想到的是Vim和Emacs之争。可是和Acme比起来,Vim和Emacs是同宗,都充分利用和依赖键盘操作;而Acme充分利用鼠标:像Emacs的组合键一样组合鼠标按键,又称“chord”。Vim和Emacs减少手在键盘和鼠标之间的移动,Acme方便迅速直接地定位,不需要按着箭头按键不放来移动光标。

听说过Acme的人比较少。但是说起它的作者Rob Pike大家就知道了。Rob Pike是Unix的主要设计者,也是Unix的后继Plan 9的设计者,还是Go语言的设计者。Acme是Plan 9上的标准IDE,也是Go语言的主要设计者Rob Pike、Russ Cox等每天使用的编辑器。

Russ Cox专门把Acme以及所有Plan 9的用户程序都移植到了Mac OS X,称为Plan 9 from User Space。他还录制了这段Youtube视频解释如何使用Acme。因为Russ的语速太快,我和同事Keith Tsang听写了这段字幕。大家可以下载Russ的视频和我们的字幕,在本地观看。

本文主要介绍Acme编辑器的使用方法,顺便介绍历史、思路、和各种八卦。

从Plan 9说起

Acme是一个Plan 9操作系统上的文本编辑器。Acme的理念和我们在Windows和Unix(包括Linux和Mac OS X)的世界里形成的理念很不一样。而Acme的理念实际上是Plan 9的理念。所以我们得先说说Plan 9。

Plan 9不是一个很知名的作品,但是它的前身Unix是世人皆知的。而Plan 9是Unix的几位作者在AT&T职业生涯的一件巅峰之作,是被设计来超越Unix的。实际上,Plan 9在1992年第一次发布时,就同时实现了Google Docs、Dropbox、Github、Remote Desktop等目前很火爆的互联网产品的功能。

Plan 9能做到这些,是因为它把所有内容都注册到一个称为9P的文件系统里。举个例子,一个Acme编辑器进程会对应9P中的一个目录acme——我们可以用9p ls acme命令看到这个目录;这个编辑器中的每个窗口对应一个子目录,而窗口标题,编辑内容分别是这个子目录里的文件——我们可以通过修改文件内容(比如通过调用一个shell script)来改变标题和编辑内容。

因为9P是个分布式的文件系统(类似后来的Google GFS和Hadoop HDFS),所以不管用户身在何处(公司、家里、旅馆、咖啡馆)都能看到同一个文件系统。甚至可以在家里的电脑上修改办公室电脑上运行的一个ACME的某个窗口里的内容。或者回家之后,让家里的电脑上运行的ACME访问办公室电脑上的ACME对应的目录,就看到了和办公室电脑上同样的界面——比远程桌面加上Dropbox更加远程桌面和Dropbox。

从Plan 9到Mac OS X

Plan9没有推广起来,一个原因是它的思想太过领先——在用户还没有意识到存在这样的问题的时候,就把问题解决了。想当年Google Docs一开始做市场推广的时候,很多用户还不相信文件存储在云端的安全性呢,更别说从client到browser了。另一个原因恐怕和AT&T作为电信公司被互联网冲击而衰落有关。详情请参见吴军博士的《浪潮之巅》。

不管Plan9的命运如何,它背后的团队可算是计算机科学历史上最耀眼的团队之一:

  • Ken Thompson:Unix、B语言(C语言前辈)、UTF-8,Go语言。2006年加入Google
  • Rob Pike:UTF-8、Go语言、Sawzall语言。2006年加入Google。
  • Dave Presotto:Unix的IPC机制。2004年加入Google,是Google最高权力机构“工程大师团”的成员。
  • Phil Winterbottom:PLANET高速通信网络、Inferno操作系统

其中Ken和Rob到Google之后设计了最近非常流行的Go语言。我第一次见到Go的吉祥物Gopher的时候,就觉得其漫画风格和Plan9的吉祥物Glenda一样一样儿的。放狗一搜,发现原来设计师真是同一个人——Renee French。这背后的故事,请看这篇文章《Glenda and Friends》。简化版本是——Renee是Rob Pike的夫人。

实际上,我知道Acme就是因为看到Rob Pike的徒弟、Go的设计者之一Russ Cox用Acme。Russ是Go和Google Code Search的作者。他多年坚持用一台老旧的Mac mini搞开发,并且甚为自豪。(因为不浪费粮食又环保。)

Russ离开AT&T加入Google之后忍不住怀念Plan 9,所以把Plan 9上的用户程序——包括Acme——移植到Mac OS X上,称为Plan 9 from User Space。大家可以方便地下载源码,然后在自己的苹果电脑上编译这套代码。

Plan 9 from User Space这个名字很有意思——Plan 9这个名字其实来自一部1959年美国科幻电影《Plan 9 from Outer Space》。

从键盘到鼠标

Plan 9的故事就此收尾了。回到Acme。

要描述一个文本编辑器,难免需要和伟大的Vim以及Emacs做类比。可是Acme和Vim,Emacs完全不是一个路子——Vim和Emacs是充分利用键盘的,Acme是充分利用鼠标的。(真是瞬间轰平Vim和Emacs比拼的大坑。)

我曾经用过很多年的Vim。读博士的时候看到同学王垠用Emacs,被Emacs可是展示图像和PDF文件、预览LaTeX和Graphviz源码给震撼了,从此踏上了Emacs之路,至今已经有12年了。目前的工作标配是Kinesis键盘+Logitech trackball+Emacs。

我看到很多Vim和Emacs的用户都在某种程度上追求牛鼻的键盘——机械按键、人体工学设计、甚至功能键的重新布局。这是因为我们大量按键。可我们的主要按键都花在哪儿了呢?

  1. 顺序输入
  2. 编辑

其实通常编辑是主流,长篇顺序输入不多。而编辑的主要操作包括:

  1. 移动光标到特定位置
  2. 剪切、拷贝、粘贴
  3. 小篇幅的输入

其中移动光标占据了绝大数多的敲键次数——设想一段常见的工作方式(以Emacs为例):

  1. 先移动到段落开始,(Ctrl-Shift-a)
  2. 向下一行,(Ctrl-n)
  3. 移动四个词,(Alt-f, Alt-f, Alt-f, Alt-f)
  4. 选取接下来半句话,(Ctrl-Shift-2, Alt-e)
  5. 剪切,(Ctrl-w)
  6. 移动到下一段开始,(Ctrl-Shift-e)
  7. 移动一行,(Ctrl-n)
  8. 移动两个字符,(Ctrl-f, Ctrl-f)
  9. 粘贴,(Ctrl-y)

一共14个组合键。

而如果用Acme呢:

  1. 移动鼠标到半句话开头处
  2. 按住鼠标左键选择那半句话,不放左键,按一下中键
  3. 移动鼠标到目标位置
  4. 按住左键的同时按一下右键

要说比速度——就像最快的算盘手和计算机比算数一样。

用任意编程语言写插件

现在很多编辑器都提供脚本语言,来写插件。尤其是Emacs的Emacs Lisp堪称Lisp方言中的经典。用Emacs Lisp为Emacs写插件,很像用Javascript操作DOM,因为Emacs把内部状态暴露出来,使得Emacs Lisp程序可以访问。

Acme和所有Plan 9上的用户程序一样,把内部状态通过9P文件系统暴露出来。这样一来,任何语言写的程序都可以访问了。最常见的程序是脚本程序。Plan 9上的标准shell程序叫9,它提供一种脚本语言,比Unix下的bash等脚本语言更接近我们常用的高级语言。比如这个只有几行的脚本Agofmt调用Go语言写的程序gofmt自动排版当前正在编写的Go语言源代码为标准格式。

如果要执行一个程序,只需要在任何地方写下这个程序的名字,然后鼠标右键点一下名字即可。比如在一个源码编辑窗口的菜单栏上写上Agofmt——对,菜单栏也可以写字——就相当于创建了一个新的菜单选项。

不仅可以用shell脚本语言可以写Acme插件,其实任何语言都可以。比如这是一个Go语言的package,用来访问9P文件系统。这使得我们也可以用Go语言为Acme写插件。

下载和安装

我们花了不少篇幅介绍Acme和常见的文本编辑器在理念上的不同。接下来我们终于可以开始说说如何安装Acme了。

要安装Acme最好是下载和安装Plan 9 from User Space,其中包括Acme和其他Plan 9操作系统的用户程序,比如shell——rc,9P文件系统访问程序——9p等。

Plan 9 from User Space支持以下操作系统

  • Linux
  • Mac OS X
  • FreeBSD, NetBSD, OpenBSD
  • SunOS

下载地址是:Downloads - plan9port - Plan 9 from User Space

Russ Cox一直勤劳地维护着Plan 9 from User Space,不断更新代码。我下载的版本是plan9port-20140306.tgz。

接下来的工作很简单:解压、编译:

cd /usr/local
sudo tar xzf plan9port-20140306.tgz
mv plan9port plan9
cd plan9
./INSTALL

这样就好了。随后修改一下Bash初始化文件,让Bash知道Plan 9程序安装在哪儿了:

export PLAN9=/usr/local/plan9
export PATH=$PLAN9/bin:$PATH

此时,只要运行

acme 

即可看到Acme窗口。但是其中的默认字体不怎么样。请用按Ctrl-C杀掉Acme。等配置好字体再启动它。

配置字体

Acme的默认字体是一种点阵字体,但是Acme也可以通过一个叫fontsrv的程序访问TrueType字体。

fontsrv是一个Plan 9 from User Space程序,它读取操作系统安装的TrueType字体,解码之后,注册到9P文件系统里,作为默认字体的补充。Acme即可访问。

但是fontsrv默认是不被编译安装的。为了安装它,需要:

cd $PLAN9/src/cmd/fontsrv
mk install

其中mk是Plan 9里类似GNU make的程序。正确安装之后,应该能看到$PLAN9/bin/fontsrv。

运行fontsrv很简单:

fontsrv &

争取执行之后,应该能用9p命令看到fontsrv注册进9P的字体:

9p ls font

然后我们可以重新启动Acme,并指定我们喜欢的字体:

acme -a -f /mnt/font/Consolas/13a/font &

使用TrueType字体之前的Acme是这样的:

用了之后是这样的


使用方法

Russ Cox录制了一段Youtube视频,演示Acme的使用方法。这是我在Youtube上找到的最靠谱Acme介绍。因为Acme频繁使用鼠标的三个按键,而Youtube视频不方便同时展示Acme的屏幕界面和Russ的手指动作,所以Russ修改了Acme的源码,使得每当他按键的时候,鼠标光标附近会弹出一个数字,标志他按的鼠标按键。

Russ的视频的唯一问题是:他的英语说得太快了——似乎在赶时间。而且他的Youtube视频没有字幕。为此,我充当了一会翻译,把他的视频配上了英语字幕。你可以用KeepVid之类的在线工具下载Russ的视频,然后从我的Github repository下载字幕,然后用VLC Player之类的视频播放器观看这个视频。VLC Player会展示字幕。

Acme文件系统

上文中我们说过,当我们在Plan 9操作系统里使用Acme的时候,Acme会把自己的内容都注册到9P文件系统里,这样我们即可用任何语言写程序来操作Acme的窗口内容了。但是实际上我们通常是在Mac OS X、Linux或者BSD里使用Acme的。Acme也可以把自己的内容注册到这些操作系统的文件系统里。但是需要FUSE的帮助。

以下我们展示如何让Acme注册自己到Mac OS X的文件系统里。为此,我们需要安装FUSE for OS X。这一步很简单,下载.dmg镜像文件,并且安装即可。需要注意的是——别把FUSE for OS X和MacFUSE搞混了。

随后,我们执行以下命令创建一个mount point:

sudo mkdir -p /mnt/acme
sudo chmod -R a+rwx /mnt

然后启动Acme(用fontsrv支持Acme使用TrueType字体):

fontsrv &
acme -a -f /mnt/font/Consolas/13a/font &

把Acme注册进/mnt/acme:

9 mount `namespace`/acme /mnt/acme

我们可以看看Acme在/mnt/acme目录里写了什么:

ls -l /mnt/acme
dr-x------  1 yiwang  101  0 Nov 10 09:16 1
dr-x------  1 yiwang  101  0 Nov 10 09:16 2
dr-x------  1 yiwang  101  0 Nov 10 09:16 acme
-rw-------  1 yiwang  101  0 Nov 10 09:16 cons
-r--------  1 yiwang  101  0 Nov 10 09:16 index
-rw-------  1 yiwang  101  0 Nov 10 09:16 label
dr-x------  1 yiwang  101  0 Nov 10 09:16 new

其中子目录1对应Acme的第一个窗口。这个窗口的tag上有几个默认的命令。我们可以从用户界面上看到:

我们也可以从文件系统里读出来:

cat /mnt/acme/1/tag
/Users/yiwang/Projects/fy/src/github.com/ Del Snarf Get | Look

既然可以读,不妨试试写:

echo "Del" >> /mnt/acme/1/tag    

我们发现,在第一个窗口的tag里,增加了一个Del命令:

此时,我们再次从文件系统里读,会看到这个被echo命令加入tag的Del命令:

cat /mnt/acme/1/tag
/Users/yiwang/Projects/fy/src/github.com/ Del Snarf Get | Look Del

有疑问加站长微信联系(非本文作者)

本文来自:知乎专栏

感谢作者:王益

查看原文:Go的标准IDE:Acme文本编辑器

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

6283 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传