プッシュ用のベアリポジトリがあるサーバーがあります。ただし、サーバーにはmasterブランチの作業コピーが必要です。
裸のリポジトリからのみ作業コピーを取得するにはどうすればよいですか?
リポジトリを同じマシン上の別のディレクトリに複製するだけです:
git clone /bare/repo/dir.git
現在のディレクトリはリポジトリの非ベアクローンになり、master
ブランチのチェックアウトが自動的に取得されます。次に、git pull
などの通常のコマンドを使用して、必要に応じて更新します。
副次的な利点として、この操作は非常に効率的です。ローカルディレクトリをgit clone
に指定すると、gitはハードリンクを使用してこれら2つのリポジトリ間でオブジェクトを共有しようとします。
ベアリポジトリは、作業ディレクトリの.gitディレクトリであり、ローカル構成ファイルのエントリです。 裸のリポジトリを完全なリポジトリに変換する:
.git
を作成し、そこにある裸のリポジトリからすべてのファイルを移動します.git/config
ファイルを編集して、bare = true
をbare = false
に変更しますWindowsでは.git
ディレクトリにHidden属性を設定できますが、ディレクトリ内のファイルにはnotを設定できます。
私は「分離された作業ツリー」アプローチを探していました(見られるように ここ ):
git init --bare
git config core.bare false
git config core.worktree /somewhere/else/
git checkout -f
これは他の2つの答えのリフですが、私のユースケースのギャップを埋めます-通常の完全なgitリポジトリで終わるため、Originからリポジトリを更新し、ブランチとgit操作をチェックアウトするために機能します.
git clone /path/to/bare/repo /new/path/to/full/repo
cd /new/path/to/full/repo
git remote set-url Origin [email protected]:Swift/swift.git
これらの3行のコードを実行した後、git pull
およびgit branch
およびgit checkout some_branch
など。リモートリポジトリに接続された通常の完全なgitリポジトリがあるためです。
これがどのように機能するかです:
$ git init --separate-git-dir /path/to/existing-bare-repository /path/to/workdir
$ cd /path/to/workdir
$ git checkout .
ほら!
情報:git init
は報告します:Reinitialized existing Git repository in /path/to/existing-bare-repository
。しかし、自信を持ってください。 man git-init
言います:既存のリポジトリでgit initを実行しても安全です。既に存在するものを上書きしません。
魔法はgit init
単独では、作業ディレクトリにファイルが表示されません。ルートディレクトリをチェックアウトする必要があります。
これには「git show」を使用できます。
http://www.kernel.org/pub/software/scm/git/docs/git-show.html
基本的に:
git --no-pager --git-dir /path/to/bar/repo.git show branch:path/to/file.txt