ディレクトリのバージョン

Subversion はツリーの構造を追いかけるのであって、それはファイルの内容 だけにはとどまりません。これはCVSを置き換えるために Subversionが書かれた 大きな理由の一つです。

CVSユーザとしてのあなたに、これが何を意味するかをここで挙げておきます:

最後の点についてもっと説明します。ディレクトリのバージョン管理は 難しい問題です。それは、混合リビジョンの作業コピーを認めたいので、 このモデルを乱用することに対する制限が必要になります。

理論的な見地からすると、 ディレクトリ fooの リビジョン 5 というのは、ディレクトリエントリと属性の、ある特定のあつまりを 意味します。fooのファイルを追加したり削除 し、コミットしたとします。リビジョン 5 のfoo がまだあるといえば嘘になります。しかし、コミット後に fooのリビジョン番号を上げたとすれば、 これもやはり嘘になります。まだ更新してはいないので、 foo に、まだ受け取っていないほかの人の変更が 加えられたかも知れないからです。

Subversion はこの問題を、.svnの領域に コミットされた追加と削除を静かに記録することで取り扱います。 svn updateを実行すると、 すべての変更点がリポジトリに反映され ディレクトリの新しいリビジョン番号は正しく設定されます。 そのため、更新後においてだけ、ディレクトリの完全な リビジョンを手にしている、と安全に言うことができます。 ほとんどの場合、作業コピーは不完全な ディレクトリ リビジョンを含んでいます。

同様にして、もしディレクトリ上の属性変更をコミットしようとした ときに問題が起こります。普通、コミットは作業ディレクトリの ローカルなリビジョン番号を上げます。しかし、やはり、それは 嘘です。というのは、更新がかかっていないことにより、ディレクトリ がまだ受け取っていない追加や削除があるかも知れないからです。 それで、ディレクトリが最新の状態になければ、ディレクトリ上の 属性変更をコミットすることはできません。

ディレクトリのバージョン管理の制限についての詳細は、 「混合リビジョン状態の作業コピー」を見てください。