Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1351157
  • 博文数量: 206
  • 博客积分: 10571
  • 博客等级: 上将
  • 技术积分: 2610
  • 用 户 组: 普通用户
  • 注册时间: 2007-04-30 11:50
文章分类
文章存档

2014年(1)

2013年(4)

2012年(18)

2010年(14)

2009年(31)

2008年(3)

2007年(135)

分类: LINUX

2007-04-30 16:53:38

Emacs 编辑器完全介绍(5)

 

移动光标

1.     基本操作。

o        C-f, C-b: 字符为单位移动。

o        M-f, M-b: 单词为单位移动。

o        C-a, C-e: 移动到行首,行末。

o        M-m: 移动到第一个非空格字符。(back-to-indentation)

o        M-a, M-e: 移动到句子头,句子尾。

o        M-{, M-}: 移动到段落头,段落尾。

o        C-v, M-v: 翻页。

o        M-<, M->: 到文件头和文件尾。

o        M-r: 加参数,移动到窗口里的某一行。不加参数缺省移动到窗口中间。

o        M-x goto-char: 到文件的第 N 字节。

o        M-x goto-line: 到文件第 N 行。

o        C-x C-n: 设定 goal-column.

o        C-u C-x C-n: 取消 goal-column.

2.     以语法结构为单位移动。

文档一般都有各种结构,比如LISP里有S表达式,C语言里的函数,LaTeX 里的 \begin{...}...\end{...} ... 如果我们能够已文档的语法单位来移动,就会使操作非常高效。

1.    defundefun LISP 里就是最高一级的 sexp,而在 C 语言里,它的含义就是函数。

2.                 C-M-a   defun

3.                 C-M-e   defun

这样,我们在C语言程序里可以一个函数一个函数的跳过。也可以从一个函数中间一下跳到函数开头或末尾。

4.    语法单位(sexp)。语法单位在各种 major mode 有不同的定义:

§         lisp-mode: 一个S表达式。

§         c-mode: 一个变量名,一个 (...), 一个 {...}, 一个 [...], ...

所以在 Emacs 里,寻找匹配的括号可以在括号处使用 C-M-f C-M-b.

§         Gnus: 一个thread。包括所有的 Re:

其实 defun 可以被看作最高一级的 sexp。所以范围小一点的移动操作就是在同级 sexp 之间移动。

C-M-f   到下一个同级语法结构

C-M-b   到上一个同级语法结构

注意,这种移动不能越过语法结构的边界而进入上一级结构。所以,你如果在

for (i=0; i<10; i++) { ...}

for 循环的括号里向右移动,到达右边括号时,就会被提示到达边界。

注意,文档中的注释在这两个操作中会被跳过,这是非常方便的。

5.    进入和退出子结构。

LISP中,S表达式是嵌套的括号,进入子结构就是进入到这一级 (...) 里面。而在 C 语言中,进入子结构就是进入 (...), {...}, [...] 的里面。 C-M-d: 进入到下一级结构里。C-M-u: 进入到上一级结构里。

C-M-a, C-M-e, C-M-f, C-M-b, C-M-d, C-M-u 这几个命令组合起来可以迅速的在程序里移动。往往手可以按住 C-M 不放,所以还是很顺手的。

6.    段落:

7.                 M-} (forward-paragraph)

8.                 M-{ (backward-paragraph)

段落在不同的mode有不同的含义,它的含义是由 paragraph-start 变量决定的。这个正则表达式可以告诉 Emacs 那些符号出现被认为是一个段落开始了。

9.    句子:

10.             M-e (backward-sentence)

11.             M-a (forward-sentence)

句子在不同的模式有不同的含义。比如在 c-mode, “句子成为了语句的代名词,所以 M-a M-e 可以以语句为单位移动。

句子的含义是由 sentence-end 变量决定的。这个正则表达式可以告诉 Emacs 那些符号出现被认为是一个句子结束了……比如我的 sentence-end 是这样设置的:

(setq sentence-end "\\([。!?]\\|……\\|[.?!][]\"')}]*\\($\\|[ \t]\\)\\)[ \t\n]*")

这样中文的句子就可以被正确识别了。

3.     一些特殊模式专有的移动方式。

o        HTML 模式。

1.  跳过同一级 tag

2.                        C-c C-f  向前跳过同一级 tag (sgml-skip-tag-forward)

3.                        C-c C-b  向后跳过同一级 tag (sgml-skip-tag-backward)

o      LaTeX 模式。

o                            C-c C-u   到最近的上一级 \begin{...} 处。

o                            C-c }     到最近的上一级匹配 {...} 处。


阅读(870) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~