diff --git a/README.md b/README.md index 90f43fb57..f903a0b1b 100644 --- a/README.md +++ b/README.md @@ -71,6 +71,10 @@ add functionality that cannot easily be added to the Git backend. +You can even have a ["co-located" local +repository](docs/git-compatibility.md#co-located-jujutsugit-repos) where you can +use both `jj` and `git` commands interchangeably. + ### The working copy is automatically committed Jujutsu uses a real commit to represent the working copy. Checking out a commit diff --git a/docs/git-compatibility.md b/docs/git-compatibility.md index 00ca1edd0..14ef81fef 100644 --- a/docs/git-compatibility.md +++ b/docs/git-compatibility.md @@ -85,22 +85,6 @@ commits will be accessible in both repos. Use `jj git import` to update the Jujutsu repo with changes made in the Git repo. Use `jj git export` to update the Git repo with changes made in the Jujutsu repo. -### Co-located Jujutsu/Git repos - -If you initialize the Jujutsu repo in the same working copy as the Git repo by -running `jj init --git-repo=.`, then the import and export will happen -automatically on every command (because not doing that makes it very confusing -when the working copy has changed in Git but not in Jujutsu or vice versa). We -call such repos "co-located". - -This mode is meant to make it easier to start using readonly `jj` commands in an -existing Git repo. You should then be able to switch to using mutating `jj` -commands and readonly Git commands. It's also useful when tools (e.g. build -tools) expect a Git repo to be present. - -There are some bugs and surprising behavior related to `jj undo` in this mode, -such as #922. - ## Creating a repo by cloning a Git repo To create a Jujutsu repo from a remote Git URL, use `jj git clone @@ -109,6 +93,67 @@ https://github.com/octocat/Hello-World` will clone GitHub's "Hello-World" repo into a directory by the same name. +## Co-located Jujutsu/Git repos + +A "co-located" Jujutsu repo is a hybrid Jujutsu/Git repo. These can be created +if you initialize the Jujutsu repo in an existing Git repo by running `jj init +--git-repo=.` or with `jj git clone --colocate`. The Git repo and the Jujutsu +repo then share the same working copy. Jujutsu will import and export from and +to the Git repo on every `jj` command automatically. + +This mode is very convenient when tools (e.g. build tools) expect a Git repo to +be present. + +It is allowed to mix `jj` and `git` commands in such a repo in any order. +However, it may be easier to keep track of what is going on if you mostly use +read-only `git` commands and use `jj` to make changes to the repo. One reason +for this (see below for more) is that `jj` commands will usually put the git +repo in a "detached HEAD" state, since in `jj` there is not concept of a +"currently tracked branch". Before doing mutating Git commands, you may need to +tell Git what the current branch should be with a `git switch` command. + +You can undo the results of mutating `git` commands using `jj undo` and `jj op +restore`. Inside `jj op log`, changes by `git` will be represented as an "import +git refs" operation. + +There are a few downsides to this mode of operation. Generally, using co-located +repos may require you to deal with more involved Jujutsu and Git concepts. + +* Interleaving `jj` and `git` commands increases the chance of confusing branch + conflicts or [conflicted (AKA divergent) change + ids](glossary.md#divergent-change). These never lose data, but can be + annoying. + + Such interleaving can happen unknowingly. For example, some IDEs can cause + it because they automatically run `git fetch` in the background from time to + time. + +* Git tools will have trouble with revisions that contain conflicted files. While + `jj` renders these files with conflict markers in the working copy, they are + stored in a non-human-readable fashion inside the repo. Git tools will often + see this non-human-readable representation. + +* When a `jj` branch is conflicted, the position of the branch in the Git repo + will disagree with one or more of the conflicted positions. The state of that + branch in git will be labeled as though it belongs to a remote named "git", + e.g. `branch@git`. + +* Jujutsu will ignore Git's staging area. It will not understand merge conflicts + as Git represents them, unfinished `git rebase` states, as well as other less + common states a Git repository can be in. + +* Colocated repositories are less resilient to + [concurrency](technical/concurrency.md#syncing-with-rsync-nfs-dropbox-etc) + issues if you share the repo using an NFS filesystem or Dropbox. In general, + such use of Jujutsu is not currently thoroughly tested. + +* There may still be bugs when interleaving mutating `jj` and `git` commands, + usually having to do with a branch pointer ending up in the wrong place. We + are working on the known ones, and are not aware of any major ones. Please + report any new ones you find, or if any of the known bugs are less minor than + they appear. + + ## Branches TODO: Describe how branches are mapped