Search code examples
eclipsegitrepositoryegitworkspace

Workspace and repo paths arrangement for eclipse and git


I've seen similar questions but some are very old and some are not quite what I'm looking for or have no answers.

I have projects in Eclipse under /workspace/project1 and /workspace/project2. They are Gradle projects and are dependent on each other. I also have /workspace/project3 which is a Gradle project but independent.

I need to "upload" them to a git repo on Bitbucket. I installed EGit to help me with this. It asks me where my local repo is located and I don't know what to tell it. Should I create a repo per workspace or per group of dependent projects or what?

For example when I right click a project and press Team > Share > Git I get to this dialog and I don't know what I should fill in there.

enter image description here


Solution

  • Each (non-bare) git repository has a work directory in which the files of the currently checked out commit (referred to as HEAD) are stored.

    By default, the work directory is the parent of the git metadata directory (named .git), but it can be detached through a config setting. For example: git config core.worktree /path/to/workdir

    EGit cannot deal with repositories that have a detached work directory as answered here: EGit working directory not under the local repository

    But irrespective of this limitation, you cannot split the work directory of a git repository among several workspaces.

    Therefore, you should move the projects to the work directory to resemble this structure:

    ~/git/my-repo/.git
    ~/git/my-repo/project1
    ~/git/my-repo/project2
    ~/git/my-repo/project3
    

    If project3 is independent of the others, it may remain where it is or be located somewhere else entirely.

    A word of caution when planning to have interdependent projects spread across several git repositories. This makes the git repositories effectively interdependent as well, but without git having a dependency management tool.

    To have EGit move the projects, you would enter project1 in the Path within repository input field.

    Commonly used build files like the master pom.xml or corresponding Gradle files would be located in the root of the work directory. This also eases configuration of popular build services like Travis, Codeship and friends.