### 本地化
*本地化*是让程序按照地区特定方式运行的行为,如果一个程序的格式、数字或者是日期是你的本地方式,或者是打印的信息(或者是接受的输入)是你本地的语言,这个程序被叫做已经*本地化了*,这部分描述了针对本地化的Subversion的步骤。
### 理解地区
许多现代操作系统都有一个“当前地区”的概念―也就是本地化习惯服务的国家和地区。这些习惯―通常是被一些运行配置机制选择―影响程序展现数据的方式,也有接受用户输入的方式。
在类Unix的系统,你可以运行**locale**命令来检查本地关联的运行配置的选项值:
~~~
$ locale
LANG=
LC_COLLATE="C"
LC_CTYPE="C"
LC_MESSAGES="C"
LC_MONETARY="C"
LC_NUMERIC="C"
LC_TIME="C"
LC_ALL="C"
~~~
输出是一个本地相关的环境变量和它们的值,在这个例子里,所有的变量设置为缺省的`C`地区,但是用户可以设置这些变量为特定的国家/语言代码组合。举个例子,如果有人设置`LC_TIME`变量为`fr_CA`,然后程序会知道使用讲法语的加拿大期望的格式来显示时间和日期信息。如果一个人会设置`LC_MESSAGES`变量为`zh_TW`,程序会知道使用繁体中文显示可读信息。如果设置`LC_ALL`的效果同分别设置所有的位置变量为同一个值有相同的效果。`LANG`用来作为没有设置地区变量的缺省值,为了查看Unix系统所有的地区列表,运行**locale -a**命令。
在Windows,地区配置是通过“地区和语言选项”控制面板管理的,可以从已存在的地区查看选择,甚至可以自定义(会是个很讨厌的复杂事情)许多显示格式习惯。
### Subversion对地区的支持
Subversion客户端,**svn**通过两种方式支持当前的地区配置。首先,它会注意`LC_MESSAGES`的值,然后尝试使用特定的语言打印所有的信息,例如:
~~~
$ export LC_MESSAGES=de_DE
$ svn help cat
cat: Ausgabe des Inhaltes der angegebenen Dateien oder URLs
Aufruf: cat ZIEL...
…
~~~
这个行为在Unix和Windows上同样工作,注意,尽管有时你的操作系统支持某个地区,Subversion客户端可能不能讲特定的语言。为了制作本地化信息,志愿者可以提供各种语言的翻译。翻译使用GNU gettext包编写,相关的翻译模块使用`.mo`作为后缀名。举个例子,德国翻译文件为`de.mo`。翻译文件安装到你的系统的某个位置,在Unix它们会在`/usr/share/locale/`,而在Windows它们通常会在Subversion安装的`\share\locale\`目录。一旦安装,一个命名在程序后面的模块会为此提供翻译。举个例子,`de.mo`会最终安装到`/usr/share/locale/de/LC_MESSAGES/subversion.mo`,通过查看安装的`.mo`文件,我们可以看到Subversion支持的语言。
第二种支持地区设置的方式包括**svn**怎样解释你的输入,版本库使用UTF-8保存了所有的路径,文件名和日志信息。在这种情况下,版本库是*国际化的*―也就是版本库准备接受任何人类的语言。这意味着,无论如何Subversion客户端要负责发送UTF-8的文件名和日志信息到版本库,为此,必须将数据从本地位置转化为UTF-8。
举个例子,你创建了一个文件叫做`caffè.txt`,然后提交了这个文件,你写的日志信息是“Adesso il caffè è più forte”,文件名和日志信息都包含非ASCII字符,但是因为你的位置设置为`it_IT`,Subversion知道把它们作为意大利语解释,在发送到版本库之前,它用一个意大利字符集转化数据为UTF-8。
注意当版本库要求UTF-8文件名和日志信息时,它*不会*注意到文件的内容,Subversion会把文件内容看作字节串,没有任何客户端和服务器会尝试理解或是编码这些内容。
**字符集转换错误**
当使用Subversion,你或许会碰到一个字符集转化关联的错误:
~~~
svn: Can't recode string.
~~~
这个信息是神秘的,但是通常会发生在Subversion客户端从版本库接收到一个UTF-8串,但是字符不能转化为当前的地区文字,举个例子,如果你的地区设置是`en_US`,但是一个写作者使用日本文件名提交,你会在**svn update**接受文件时会看到这个错误。
解决方案或者是设置你的地区为*可以*表示即将到来的UTF-8数据,或者是修改版本库的文件名或信息。(不要忘记和你的合作者拍拍手―项目必须首先决定通用的语言,这样所有的参与者会使用相同的地区设置。)
- 第1章介绍
- Subversion的历史
- Subversion的特性
- Subversion的架构
- 安装Subversion
- Subversion的组件
- 快速入门
- 第2章基本概念
- 版本模型
- Subversion实战
- 摘要
- 第3章指导教程
- 导入
- 修订版本: 号码、关键字和日期,噢,我的!
- 初始化的Checkout
- 基本的工作周期
- 检验历史
- 其他有用的命令
- 摘要
- 第4章分支与合并
- 使用分支
- 在分支间拷贝修改
- 常见用例
- 转换工作拷贝
- 标签
- 分支维护
- 摘要
- 第5章版本库管理
- 版本库的创建和配置
- 版本库维护
- 添加项目
- 摘要
- 第6章配置服务器
- 网络模型
- svnserve,一个自定义的服务器
- httpd,Apache的HTTP服务器
- 支持多种版本库访问方法
- 第7章高级主题
- 属性
- Peg和实施修订版本
- 外部定义
- 卖主分支
- 本地化
- Subversion版本库URL
- 第8章开发者信息
- 使用API
- 进入工作拷贝的管理区
- WebDAV
- 使用内存池编程
- 为Subversion做贡献
- 第9章Subversion完全参考
- svn add
- svn blame
- svn cat
- svn checkout
- svn cleanup
- svn commit
- svn copy
- svn delete
- svn diff
- svn export
- svn help
- svn import
- svn info
- svn list
- svn log
- svn merge
- svn mkdir
- svn move
- svn propdel
- svn propedit
- svn propget
- svn proplist
- svn propset
- svn resolved
- svn revert
- svn status
- svn switch
- svn update
- svnadmin
- svnadmin create
- svnadmin deltify
- svnadmin dump
- svnadmin help
- svnadmin hotcopy
- svnadmin list-dblogs
- svnadmin list-unused-dblogs
- svnadmin load
- svnadmin lstxns
- svnadmin recover
- svnadmin rmtxns
- svnadmin setlog
- svnadmin verify
- svnlook
- svnlook author
- svnlook cat
- svnlook changed
- svnlook date
- svnlook diff
- svnlook dirs-changed
- svnlook help
- svnlook history
- svnlook info
- svnlook log
- svnlook propget
- svnlook proplist
- svnlook tree
- svnlook uuid
- svnlook youngest
- svnserve
- svnversion
- mod_dav_svn Configuration Directives
- 附录A.Subversion对于CVS用户
- 目录的版本
- 更多离线操作
- 区分状态和更新
- 分支和标签
- 元数据属性
- 冲突解决
- 二进制文件和转化
- 版本化的模块
- 认证
- 转化CVS版本库到Subversion
- 附录C.WebDAV和自动版本化
- 自动版本化交互性
- Subversion和DeltaV
- 术语表