scmrepo icon indicating copy to clipboard operation
scmrepo copied to clipboard

scmrepo git driver hard codes hooks directory

Open liljenstolpe opened this issue 3 years ago • 2 comments

I have an issue in iterative/dvc#7967, that appears is actually an issue with scmrepo.

In scmrepo, there is an assumption that hooks are in .git/hooks, and it is hardcoded as such (my guess is there might be other assumptions like that as well). That's all well and good, unless the repo happens to be cloned/integrated as a submodule. In that case, the '.git' directory is actually the parent repo's .git/modules/. Therefore, the hooks directory actually should be <parentRepoDir>/.git/modules/<moduleName>/hooks.

You can actually just use:

git rev-parse --git-path hooks

to find out whatever the hook directory is for a given repo (or any other path, btw). That saves you from having to build all of the logic depending on where things land.

Happy to propose some code, but this might be something that makes more sense to generalize

liljenstolpe avatar Jul 06 '22 02:07 liljenstolpe

The issue here is that we cannot just directly call git rev-parse since we don't want to have a dependency on CLI git.

Basically what we really need is to implement the correct methods for getting GIT_DIR and GIT_COMMON_DIR in all of the scmrepo backends. Some of this functionality already exists in dulwich and libgit2/pygit2 but it gets more complicated when accounting for things like submodules and worktrees.

Then rather than the hard coded paths we would use the proper values for GIT_DIR in places like:

https://github.com/iterative/scmrepo/blob/708cd685a1bb737d87973625ece91ea301c95483/scmrepo/git/init.py#L111-L115

pmrowla avatar Jul 06 '22 05:07 pmrowla

Greetings, I agree, I should have been more specific - make a programatic call the same way that git rev-parse does. :)

liljenstolpe avatar Jul 08 '22 02:07 liljenstolpe