Nuxeo Core Developer Guide

Working with multiple versions of Nuxeo sources at the same time

Updated: December 16, 2024

There is some code refactoring between Nuxeo versions making it difficult to work on two branches at the same time. Especially, if you need to merge some changes from one branch to another. Moreover, switching from a version to another on the whole code makes IDE hang or consume CPU on refresh.

Here are some solutions making it easier to work on multiple branches.

Local Clone

Here is a simple way to work on multiple branches. We assume:

  • you are using Nuxeo shell functions (see Getting the Nuxeo source code)
  • your Eclipse's current workspace is ~/workspace/
  • you have cloned Nuxeo in ~/workspace/nuxeo/ and had checkout master

Sample of using Nuxeo master and 5.4.2 at the same time

# In order to be able to use multiple Eclipse workspaces, we'll clone Nuxeo 5.4.2 in another Eclipse workspace
mkdir ~/workspace-5.4/
git clone ~/workspace/nuxeo/ ~/workspace-5.4/nuxeo-5.4
cd ~/workspace-5.4/nuxeo-5.4
./clone.py 5.4.2

Now, you are able to commit on 5.4.2, merge on master, commit on master and push the whole:

cd ~/workspace-5.4/nuxeo-5.4
# do some work...
git commit -m"NXP-9999 - some work on 5.4.2" ...
# push your changeset(s) to your main ~/workspace/nuxeo/ repository
git push
cd ~/workspace/nuxeo/
# merge or cherry-pick your changes to master
git merge 5.4.2
git cherry-pick ...
# do some work...
git commit -m"some work on master" ...
# push your changesets to the public repository
git push ...

Updating your sources is done fetching on master, then pulling on 5.4:

cd ~/workspace/nuxeo/
gitf fetch
cd ~/workspace-5.4/nuxeo-5.4
gitf fetch

Whereas that method had no limitation using Mercurial, that's not the case using Git because of its notion of "bare and non-bare repositories"

Usually, you have cloned non-bare repositories and Git documentation states << By default, updating the current branch in a non-bare repository is denied, because it will make the index and work tree inconsistent with what you pushed, and will require 'git reset --hard' to match the work tree to HEAD. >>

That behavior is configurable by changing the "receive.denyCurrentBranch" Git property but the best way is to push other branches than the current one which was checkout on the destination.

For import into Eclipse, you have to use two different workspaces, one for each version.

Remember ~/workspace-5.4/nuxeo-5.4 is a clone of your local ~/workspace/nuxeo/ which is a clone of public repositories:

cd ~/workspace/nuxeo
$ git config --get remote.origin.url
[email protected]:nuxeo/nuxeo.git
cd ~/workspace-5.4/nuxeo-5.4
$ git config --get remote.origin.url
~/workspace/nuxeo

If you use m2eclipse plugin, it will rename the root nuxeo directory to nuxeo-ecm (the artifact name) so you have to create symbolic links pointing to two respective nuxeo and nuxeo-5.4 in each workspaces, to avoid issues or unwanted directories renaming.

Git Worktree

As of Git 2.5, a Git repository can now support multiple working trees, allowing you to check out more than one branch at a time. All the commits are stored in the main repository, making the workflow greatly simplified compared to the previous local-clone solution.

The worktree feature is experimental and should not be used with submodules/subtrees.

https://git-scm.com/docs/git-worktree https://github.com/git/git/blob/v2.5.0/Documentation/RelNotes/2.5.0.txt

Sample of using Nuxeo master and 6.0 at the same time

cd ~/workspace/
git -C nuxeo worktree add ~/workspace/nuxeo-6.0 6.0
cd nuxeo/addons
for dir in */.git; do (dir=$(dirname $dir); cd $dir ; git worktree add ~/workspace/nuxeo-6.0/addons/$dir 6.0) ; done

You can now work indifferently from ~/workspace/nuxeo or ~/workspace/nuxeo-6.0, commit, push... They share the same Git index.

You cannot checkout the same branch in two different work trees. The same limitation as for the non-bare repositories still applies.

At time of writing, very few tools have been updated to work with the worktree feature.

gitfunctions.sh has been updated.

clone.py still works fine but it has yet no dedicated option to properly initialize the worktree directories.