总览 SYNOPSIS
package forget ?package package ...?
package ifneeded package version ?script?
package names
package present ?-exact? package ?version?
package provide package ?version?
package require ?-exact? package ?version?
package unknown ?command?
package vcompare version1 version2
package versions package
package vsatisfies version1 version2
描述 DESCRIPTION
这个命令维持由当前解释器使用的可获得的包以及如何把它们装载到解释器中的一个简单的数据库。它支持每个包的多个版本,并基于应用的需要安排装载一个包的正确的版本。这个命令还检测并报告版本冲突。典型的,在通常的
Tcl 脚本中只调用 package require
和 package provide
命令;其他命令主要被系统脚本用来维护包数据库。
package
命令的行为由它的第一个参数确定。允许下列形式:
- package forget
?package package ...?
- 从这个解释器中删除关于每个指定的包的所有信息,包括由
package ifneeded 和 package provide
提供的信息。
- package ifneeded
package version ?script?
- 这个命令典型的只出现在系统配置脚本中,被用来设置包数据库。若需要一个特定的包的一个特定的版本,它指示如果这个包的这个版本是可获得的,可通过执行
script
来把这个包来增加到解释器上。脚本保存在一个数据库中,由随后的
package require
命令使用;典型的,script
为在包中的命令设置自动装载(或直接调用
load 和/或
source),接着调用package
provide
来指示这个包已经存在。在数据库中可以有一个单一的包的多个版本的信息。如果数据库已经包含了对
package 和 version
的信息,则新 script
替换现存的脚本。如果省略了
script 参数,返回包
package 的版本 version
的当前脚本,如果未对这个
package 和 version 调用 package
ifneeded
命令则返回一个空串。
- package
names
- 返回在这个解释器中所有包的名字,为这些包提供了一个版本(通过
package
provide)或可获得给它们的
package ifneeded
脚本。在列表中的元素的次序是任意的。
- package present
?-exact? package ?version?
- 除了在包没有装载时它不尝试并装载它之外,这个命令等价于
package require。
- package provide
package ?version?
- 调用这个命令来指示在这个解释器中包
package 的这个版本 version
现在已经存在。它典型的被作为一个
ifneeded脚本的一部分而调用一次,并在包最终装载时被包自身再次调用。如果以前的
package provide
命令已经提供的 package
的一个不同的版本则生成一个错误。如果省略了
version
参数,则命令返回当前提供包的版本号,如果在这个解释器中对
package 没有调用 package provide
命令则返回一个空串。
- package require
?-exact? package ?version?
- 这个命令典型的被想要使用特定包的特定版本的
Tcl
脚本调用。参数指示想要哪个包,和确保把包的合适版本装载到解释器中的命令。如果命令成功执行,它返回装载的包的版本号;否则生成一个错误。如果同时指定了
-exact 开关和 version
选项,则只接受给定版本。如果省略了
-exact 但指定了 version
,则主版本号与 version
相同但晚于 version
的版本也可以接受。如果省略了
-exact 和
version二者则任何版本都可接受。如果已经提供了
package
的一个版本(通过调用
package provide
命令),则它的版本号必须满足由-exact
和 version
给出的条件并且命令立即返回。否则,命令查找由以前的package
ifneeded
命令提供的信息的数据库,看是否能获得一个可接受的版本。如果有,则调用最可接受的版本号的脚本;它必须做所有装载这个包所必须的工作,包括调用为这个包调用
package provide。如果 package
ifneeded数据库不包含这个包的可接受的版本并且为这个解释器指定了一个
package unknown
命令则调用这个命令;当它完成的时候,Tcl
再次检查是否现在提供了这个包或是否有一个给它的
package
ifneeded脚本。如果所有这些步骤不能提供这个包的一个可接受的版本,则命令返回一个错误。
- package unknown
?command?
- 这个命令提供在一个“最后一搏”(``last
resort'') 命令,在 package require
期间如果 package ifneeded
数据库中没有一个包的合适的版本可调用这个命令。如果提供了
command
参数,它包含一个命令的第一部分,在一次
package require
命令期间调用这个命令的时候,Tcl
添加给出所须的包的名字和版本的两个附加参数。例如,如果
command是 foo bar
并且后来调用了命令
package require test 2.4,则 Tcl
将执行命令 foo bar test 2.4
来装载这个包。如果未给
package require
命令提供版本号,则给这个被调用的命令的版本参数是一个空串。如果
package unknown命令但不加
command
参数,则返回当前的
package unknown
脚本,如果没有就返回一个空串。如果指定
command
为一个空串,若当前有
package unknown
脚本则删除它。
- package vcompare
version1 version2
- 比较由 version1和 version2
给出的两个版本。如果
version1 比 version2 早就返回
-1,如果相同则返回0,如果
version1 比 version2 晚则返回
1。
- package versions
package
- 返回 package
的所有版本号,通过
package ifneeded
命令为它们提供了信息。
- package
vsatisfies version1 version2
- 如果为 version2
写的脚本不须更改就可为
version1 工作则返回
1(例如,version1 大于等于
version2
并且有相同的主版本号),否则返回
0。
版本号 VERSION NUMBERS
版本号由一个或多个用点号分隔的十进制数组成,比如
2 或 1.162 或
3.1.13.1。第一个数叫做主版本号。越大的数对应一个包的越晚的版本,最左边的数有更大的权重(significance).
例如,版本 2.1 比 1.3
晚而版本 3.4.6 比 3.3.5
晚。遗漏的字段等价于零:
版本 1.3 于版本 1.3.0 和 1.3.0.0
相同,所以它比 1.3.1 和
1.3.0.2
早。假定一个晚期版本向上(upward)兼容有相同主版本号的早期版本。
例如,为一个包的版本
2.3 写的 Tcl
脚本应当在版本
2.3.2、2.4、和 2.5.1
下不须更改就能工作。主版本号的变更表示有不兼容的变更:
如果代码是使用了一个包的版本
2.1
写成的,不保证在版本
1.7.3 或版本 3.1
下不须更改就能工作。
包索引 PACKAGE INDICES
推荐的在 Tcl
中使用包的方式是在脚本中调用
package require 和 package provide
命令,并使用过程
pkg_mkIndex
来建立包索引文件。一旦你已经这样做了,将自动的装载包来响应
package require
命令。详情请参见
pkg_mkIndex 的文档。
参见 SEE ALSO
msgcat(n), packagens(n), pkgMkIndex(n)
关键字 KEYWORDS
package, version
《中国 Linux 论坛 man
手册页翻译计划》:
http://cmpp.linuxforum.net
跋
本页面中文版由中文
man 手册页计划提供。
中文 man
手册页计划:https://github.com/man-pages-zh/manpages-zh