IF_LUA

*if_lua.txt*    For Vim version 7.3.  最近更新: 2010年7月


		  VIM 参 考 手 册         by Luis Carvalho
				译者: Willis
				http://vimcdoc.sf.net


Vim 的 Lua 接口         				*lua* *Lua*

1. 命令         		|lua-commands|
2. vim 模块             	|lua-vim|
3. 缓冲区用户数据		|lua-buffer|
4. 窗口用户数据			|lua-window|

{Vi 没有任何以上的命令}

仅当 Vim 编译时加入 |+lua| 特性时 Lua 接口才可用。


1. 命令         					*lua-commands*

							*:lua*
:[range]lua {chunk}
			执行 Lua 语言块 {chunk}{Vi 无此功能}

示例:

	:lua print("Hello, Vim!")
	:lua local curbuf = vim.buffer() curbuf[7] = "line #7"


:[range]lua << {endmarker}
{script}
{endmarker}
			执行 Lua 脚本 {script}{Vi 无此功能}
			注意: 如果编译时没有加入 Lua 特性,此命令不能工作。要
			避免错误,见 |script-here|。

{endmarker} 之前_不能_有任何空白。如果 "<<" 之后的 {endmarker} 省略,{script}
之后必须加上句号 '.',就像 |:append| 和 |:insert| 命令那样。
这种形式的 |:lua| 命令主要用于在 Vim 脚本中嵌入 Lua 代码。

示例:

	function! CurrentLineInfo()
	lua << EOF
	local linenr = vim.window().line
	local curline = vim.buffer()[linenr]
	print(string.format("Current line [%d] has %d chars",
		linenr, #curline))
	EOF
	endfunction


							*:luado*
:[range]luado {body}[range] 行范围的每行执行 Lua 函数
			"function (line) {body} end",其中,函数参数是每行的文
			本,结尾的 <EOL> 不计。函数返回值为字符串时用来替代当
			前行的文本。缺省的 [range] 是整个文件: "1,$"。
			{Vi 无此功能}

示例:

	:luado return string.format("%s\t%d", line:reverse(), #line)

	:lua require"lpeg"
	:lua -- balanced parenthesis grammar:
	:lua bp = lpeg.P{ "(" * ((1 - lpeg.S"()") + lpeg.V(1))^0 * ")" }
	:luado if bp:match(line) then return "-->\t" .. line end


							*:luafile*
:[range]luafile {file}
			执行 Lua {file} 文件中的脚本. {Vi 无此功能}
			整个参数用作单个文件名。

示例:

	:luafile script.lua
	:luafile %


以上的命令都可执行一段 Lua 代码块 (chunk),或从命令行 (:lua 和 :luado),或从文
件 (:luafile),并可给出行范围 [range]。和 Lua 解释器类似,每个代码块都有自己的
作用域,所以命令之间只有全局变量可以共享。Lua 缺省库中 "table"、"string"、
"math"、和 "package" 可用,而 "io" 和 "debug" 不可用,"os" 只提供以下函数:
"date"、"clock"、"time"、"difftime" 和 "getenv"。此外,Lua 的 "print" 函数的输
出重定向到 Vim 消息区,参数以空格而不是制表符分隔。

Lua 使用 "vim" 模块 (见 |lua-vim|) 来对 Vim 发出指令以及对缓冲区
(|lua-buffer|) 和窗口 (|lua-window|) 进行管理。不过在 |sandbox| 中执行命令时,
修改缓冲区内容、打开新缓冲区和改变光标位置的过程收到限制。



2. vim 模块						*lua-vim*

Lua 通过 "vim" 模块和 Vim 进行接口。输入行范围的首末行分别存入 "vim.firstline"
和 "vim.lastline"。该模块也包含一些对缓冲区、窗口以及当前行查询的例程、Vim 调
用和命令执行,以及其它各种操作。

	vim.isbuffer(value)	如果 "value" 是缓冲区用户数据,返回 'true'。否
				则返回 'false' (见 |lua-buffer|)。

	vim.buffer([arg])	如果 "arg" 是数值,返回缓冲区列表中编号为
				"arg" 的缓冲区。如果 "arg" 为字符串,返回完整
				明或简短名为 "arg" 的缓冲区。这两种情况下,如
				果找不到缓冲区,返回 'nil'。此外,如果
				"toboolean(arg)" 为 'true',返回缓冲区列表的首
				个缓冲区,否则返回当前缓冲区。

	vim.iswindow(value)	如果 "value" 是窗口用户数据,返回 'true'。否则
				返回 'false' (见 |lua-window|)。

	vim.window([arg])	如果 "arg" 是数值,返回编号为 "arg" 的窗口,如
				果找不到,返回 'nil'。此外,如果
				"toboolean(arg)" 为 'true',返回首个窗口,否则
				返回当前窗口。

	vim.command({cmd})	执行 vim (ex 模式) 命令 {cmd}。
				示例:
					:lua vim.command"set tw=60"
					:lua vim.command"normal ddp"

	vim.eval({expr})	计算表达式 {expr} (见 |expression|),把结果转
				化为 Lua 格式并返回。Vim 字符串和数值被直接转
				为响应的 Lua 字符串和数值类型。Vim 列表和字典
				被转化为 Lua 表 (列表成为以整数为键的表)。
				示例:
					:lua tw = vim.eval"&tw"
					:lua print(vim.eval"{'a': 'one'}".a)

	vim.line()		返回当前行 (没有结尾的 <EOL>),Lua 字符串。

	vim.beep()		鸣笛。

	vim.open({fname})	为文件 {fname} 打开新缓冲区并返回之。注意 并不
				把该缓冲区设为当前缓冲区。



3. 缓冲区用户数据					*lua-buffer*

缓冲区用户数据代表 vim 的缓冲区。缓冲区用户数据 "b" 包含以下属性和方法:

属性

	o "b()" 设置 "b" 为当前缓冲区。
	o "#b" 是缓冲区 "b" 的行数。
	o "b[k]" 代表行号 k: "b[k] = newline" 把第 "k" 行替换为字符串
	    "newline",还有 "b[k] = nil" 删除第 "k" 行。
	o "b.name" 包含缓冲区 "b" 的简短名 (只读)。
	o "b.fname" 包含缓冲区 "b" 的完整名 (只读)。
	o "b.number" 包含缓冲区 "b" 在缓冲区列表的位置 (只读)。

方法

	o "b:insert(newline"[, pos]")" 在缓冲区 "pos" (可选) 位置插入
	    "newline" 字符串。"pos" 缺省值为 "#b + 1"。如果 "pos == 0",
	    "newline" 将成为缓冲区的首行。
	o "b:next()" 返回缓冲区列表中 "b" 的下一个缓冲区。
	o "b:previous()" 返回缓冲区列表 "b" 的前一个缓冲区。
	o "b:isvalid()" 如果缓冲区 "b" 对应 "真正的" (内存没有释放的) Vim 缓
	    冲区时,返回 'true' (布尔值)。

示例:

	:lua b = vim.buffer() -- 当前缓冲区
	:lua print(b.name, b.number)
	:lua b[1] = "first line"
	:lua b:insert("FIRST!", 0)
	:lua b[1] = nil -- 删除首行
	:lua for i=1,3 do b:insert(math.random()) end
	:3,4lua for i=vim.lastline,vim.firstline,-1 do b[i] = nil end
	:lua vim.open"myfile"() -- 打开缓冲区,设为当前缓冲区

	function! ListBuffers()
	lua << EOF
	local b = vim.buffer(true) -- 列表中的首个缓冲区
	while b ~= nil do
		print(b.number, b.name, #b)
		b = b:next()
	end
	vim.beep()
	EOF
	endfunction



4. 窗口用户数据						*lua-window*

窗口对象代表 vim 窗口。窗口用户数据 "w" 有以下属性和方法:

属性

	o "w()" 设置 "w" 为当前窗口。
	o "w.buffer" 返回窗口 "w" 对应的缓冲区 (只读)。
	o "w.line" 返回窗口 "w" 的光标行位置。
	o "w.col" 返回窗口 "w" 的光标列位置。
	o "w.width" 代表窗口 "w" 的宽度。
	o "w.height" 代表窗口 "w" 的高度。

方法

	o "w:next()" 返回 "w" 的下一个窗口。
	o "w:previous()" 返回 "w" 的前一个窗口。
	o "w:isvalid()"  如果窗口 "w" 对应 "真正的" (内存没有释放的) Vim 窗
	    口,返回 'true' (布尔值)。

示例:

	:lua w = vim.window() -- 当前窗口
	:lua print(w.buffer.name, w.line, w.col)
	:lua w.width = w.width + math.random(10)
	:lua w.height = 2 * math.random() * w.height
	:lua n,w = 0,vim.window(true) while w~=nil do n,w = n + 1,w:next() end
	:lua print("有 " .. n .. " 个窗口")



 vim:tw=78:ts=8:ft=help:norl: