目录

前言
序言
读者
How to Read This Book
本书约定
排版习惯
Tips and Warnings
本书的结构
This Book Is Free
致谢
来自 Ben Collins-Sussman
来自 Brian W. Fitzpatrick
来自 C. Michael Pilato
What Is Subversion?
Is Subversion the Right Tool?
Subversion的历史
Subversion的特性
Subversion的架构
Subversion的组件
What's New in Subversion
1. 基本概念
版本库
版本模型
The Problem of File Sharing
锁定-修改-解锁 方案
拷贝-修改-合并 方案
Subversion实践
Subversion版本库URL
工作拷贝
修订版本
工作拷贝怎样跟踪版本库
混合修订版本的工作拷贝
总结
2. 基本使用
求助!
Getting Data into Your Repository
svn import
Recommended Repository Layout
初始化检出
禁用密码缓存
用其它身份认证
基本的工作周期
更新你的工作拷贝
修改你的工作拷贝
检查你的修改
取消本地修改
解决冲突(合并别人的修改)
提交你的修改
检验历史
Generating a List of Historical Changes
Examining the Details of Historical Changes
Browsing the Repository
Fetching Older Repository Snapshots
有时你只需要清理
Disposing of a Working Copy
Recovering from an Interruption
总结
3. 高级主题
版本清单
修订版本关键字
版本日期
属性
为什么需要属性?
操作属性
属性和 Subversion 工作流程
自动设置属性
文件移植性
文件内容类型
文件的可执行性
行结束字符串
忽略未版本控制的条目
关键字替换
Sparse Directories
锁定
Creating Locks
Discovering Locks
Breaking and Stealing Locks
锁定交流
外部定义
Peg和实施修订版本
Changelists
Creating and Modifying Changelists
Changelists as Operation Filters
Changelist Limitations
网络模型
请求和响应
客户端凭证缓存
4. 分支与合并
什么是分支?
使用分支
创建分支
在分支上工作
The Key Concepts Behind Branching
Basic Merging
Changesets
Keeping a Branch in Sync
Mergeinfo and Previews
取消修改
找回删除的项目
Advanced Merging
Cherrypicking
Merge Syntax: Full Disclosure
Merges Without Mergeinfo
More on Merge Conflicts
Blocking Changes
Merge-Sensitive Logs and Annotations
关注还是忽视祖先
合并和移动
Blocking Merge-Unaware Clients
使用分支
标签
建立简单标签
建立复杂标签
分支维护
版本库布局
数据的生命周期
常用分支模式
发布分支
特性分支
Vendor Branches
常规的供方分支管理过程
svn_load_dirs.pl
总结
5. 版本库管理
Subversion 版本库的定义
版本库开发策略
规划你的版本库结构
决定在哪里与如何部署你的版本库
选择数据存储格式
创建和配置你的版本库
创建版本库
实现版本库钩子
Berkeley DB 配置
版本库维护
管理员的工具箱
修正提交消息
管理磁盘空间
Berkeley DB 恢复
版本库数据的移植
过滤版本库历史
版本库复制
版本库备份
Managing Repository UUIDs
Moving and Removing Repositories
总结
6. 服务配置
概述
选择一个服务器配置
svnserve服务器
svnserve使用SSH通道
Apache 的 HTTP 服务器
推荐
svnserve, a Custom Server
调用服务器
Built-in Authentication and Authorization
Using svnserve with SASL
SSH 隧道
SSH 配置技巧
httpd, the Apache HTTP Server
先决条件
基本的 Apache 配置
认证选项
授权选项
额外的糖果
基于路径的授权
支持多种版本库访问方法
7. 定制你的Subversion体验
运行配置区
配置区布局
配置和Windows注册表
配置选项
本地化
Understanding Locales
Subversion's Use of Locales
Using External Editors
Using External Differencing and Merge Tools
外置 diff
外置 diff3
8. 嵌入Subversion
分层的库设计
版本库层
版本库访问层
客户端层
进入工作拷贝的管理区
条目文件
原始拷贝和属性文件
使用API
Apache可移植运行库
URL 和路径需求
使用 C 和 C++ 以外的语言
代码样例
9. Subversion 完全参考
The Subversion Command-Line Client: svn
svn选项
svn子命令
svnadmin
svnadmin选项
svnadmin子命令
svnlook
svnlook选项
svnlook子命令
svnsync
svnsync选项
svnsync子命令
svnserve
svnserve选项
svnversion
mod_dav_svn
Subversion Properties
版本控制的属性
未版本控制的属性
版本库钩子
A. Subversion 快速入门指南
安装 Subversion
快速指南
B. CVS用户的Subversion指南
版本号现在不同了
目录的版本
更多离线操作
区分状态和更新
状态
更新
分支和标签
元数据属性
解决冲突
二进制文件和行结束标记转换
版本化的模块
认证
迁移CVS版本库到Subversion
C. WebDAV和自动版本
What Is WebDAV?
自动版本化
客户端交互性
Standalone WebDAV Applications
File-Explorer WebDAV Extensions
WebDAV Filesystem Implementation
D. Copyright
索引

插图清单

1. Subversion's architecture
1.1. 一个典型的客户/服务器系统
1.2. 需要避免的问题
1.3. 锁定-修改-解锁 方案
1.4. 拷贝-修改-合并 方案
1.5. 拷贝-修改-合并 方案(续)
1.6. 版本库的文件系统
1.7. 版本库
4.1. 分支与开发
4.2. 开始规划版本库
4.3. 版本库与复制
4.4. 一个文件的分支历史
8.1. 二维的文件和目录
8.2. 版本时间—第三维!

表格清单

1.1. 1.1
4.1. 4.1
5.1. 5.1
6.1. 6.1
C.1. c.1

范例清单

5.1. txn-info.sh (reporting outstanding transactions)
5.2. 镜像版本库的 pre-revprop-change 钩子
5.3. 镜像版本库的 start-commit 钩子
6.1. 匿名访问的配置实例。
6.2. 一个认证访问的配置实例。
6.3. A sample configuration for mixed authenticated/anonymous access
6.4. 禁用所有的路径检查
7.1. Sample registration entries (.reg) file.
7.2. diffwrap.sh
7.3. diffwrap.bat
7.4. diff3wrap.sh
7.5. diff3wrap.bat
8.1. 使用版本库层
8.2. 使用 Python 处理版本库层
8.3. A Python status crawler