svn status

最后更新于:2022-04-02 05:58:40

### 名称 svn status ― 打印工作拷贝文件和目录的状态。 ### 概要 ~~~ svn status [PATH...] ~~~ ### 描述 打印工作拷贝文件和目录的状态。如果没有参数,只会打印本地修改的项目(不会访问版本库),使用`--show-updates`选项,会添加工作修订版本和服务器过期信息。使用`--verbose`会打印每个项目的完全修订版本信息。 输出的前五列都是一个字符宽,每一列给出了工作拷贝项目的每一方面的信息。 第一列指出一个项目的是添加、删除还是其它的修改。 ' ' 没有修改。 'A' 预定要添加的项目。 'D' 预定要删除的项目。 'M' 项目已经修改了。 'R' 项目在工作拷贝中已经被替换了。 'C' 项目与从版本库的更新冲突。 'X' 项目与外部定义相关。 'I' 项目被忽略(例如使用`svn:ignore`属性)。 '' 项目不在版本控制之下。 '!' 项目已经丢失(例如,你使用**svn**移动或者删除了它)。这也说明了一个目录不是完整的(一个检出或更新中断)。 '~' 项目作为一种对象(文件、目录或链接)纳入版本控制,但是已经被另一种对象替代。 第二列告诉一个文件或目录的属性的状态。 ' ' 没有修改。 'M' 这个项目的属性已经修改。 'C' 这个项目的属性与从版本库得到的更新有冲突。 第三列只在工作拷贝锁定时才会出现。 ' ' 项目没有锁定。 'L' 项目已经锁定。 第四列只在预定包含历史添加的项目出现。 ' ' 没有历史预定要提交。 '+' 历史预定要伴随提交。 第五列只在项目跳转到相对于它的父目录时出现(见[“转换工作拷贝”一节])。 ' ' 项目是它的父目录的孩子。 'S' 项目已经转换。 过期信息出现在第八列(只在使用`--show-updates`选项时出现)。 ' ' 这个项目在工作拷贝是最新的。 '*' 在服务器这个项目有了新的修订版本。 余下的字段是可变得宽度且使用空格分隔,如果使用`--show-updates`或`--verbose`选项,工作修订版本是下一个字段。 如果传递`--verbose`选项,最后提交的修订版本和最后的提交作者会在后面显示。 工作拷贝路径永远是最后一个字段,所以它可以包括空格。 ### 别名 stat, st ### 变化 无 ### 是否访问版本库 只有使用`--show-updates`时会访问 ### 选项 ~~~ --show-updates (-u) --verbose (-v) --non-recursive (-N) --quiet (-q) --no-ignore --username USER --password PASS --no-auth-cache --non-interactive --config-dir ~~~ ### 例子 这是查看你在工作拷贝所做的修改的最简单的方法。 ~~~ $ svn status wc M wc/bar.c A + wc/qax.c ~~~ 如果你希望找出工作拷贝哪些文件是最新的,使用`--show-updates`选项(这不会对工作拷贝有任何修改)。这里你会看到`wc/foo.c`在上次更新后有了修改: ~~~ $ svn status --show-updates wc M 965 wc/bar.c * 965 wc/foo.c A + 965 wc/qax.c Status against revision: 981 ~~~ ### 注意 `--show-updates`*只会*在过期的项目(如果你运行**svn update**,就会更新的项目)旁边安置一个星号。`--show-updates`不会导致状态列表反映项目的版本库版本。 最后,是你能从status子命令得到的所有信息: ~~~ $ svn status --show-updates --verbose wc M 965 938 sally wc/bar.c * 965 922 harry wc/foo.c A + 965 687 harry wc/qax.c 965 687 harry wc/zig.c Head revision: 981 ~~~ 关于**svn status**的更多例子可以见[“**svn status**”一节]。
';