How does git handle folder permission?
Asked Answered
G

1

56

I'm using git version 1.5.6.3, and it seems git doesn't notice a folder's mode changes

#create a test repository with a folder with 777 mode
:~$ mkdir -p test/folder
:~$ touch test/folder/dummy.txt
:~$ cd test
:~/test$ chmod 777 folder/

#init git repository
:~/test$ git init
Initialized empty Git repository in ~/test/.git/
:~/test$ git add .
:~/test$ git commit -m 'commit a directory'
Created initial commit 9b6b21a: commit a directory
 0 files changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 folder/dummy.txt

#change folder permission to 744
:~/test$ chmod 744 folder/
:~/test$ git status 
# On branch master
nothing to commit (working directory clean)

What does 04000 stand for?

:~/test$ git ls-tree HEAD folder
040000 tree 726c1d5f0155771348ea2daee6239791f1cd7731    folder

Is this normal behavior?

How can I track folder mode changes?

Golden answered 1/7, 2009 at 20:31 Comment(1)
Related: #738173Cule
R
74

The only 'permissions' bit that git tracks is the executable bit for files, the rest of the mode bits describe what type of file system object the object in each git tree is. git supports files and symlinks (blobs), directories (trees) and the submodules (commits).

git is designed to help track source code across different machines. Permission bits depend on user and group mappings between machines. In distributed environments where these mappings don't exist, tracking permission bits usually ends up hindering things rather than helping anything.

If you need to track more file system attributes that what git tracks natively you could consider and extension tool such as etckeeper.

Rudbeckia answered 1/7, 2009 at 20:38 Comment(3)
This isn't exactly accurate (anymore). see #40979421Yeaton
git now tracks 755 vs 644 (executable or not) on files, not folders.Yeaton
you say "executable bit", but aren't there 3 executable bits? One each for user, group, other. Which bit does git touch?Woozy

© 2022 - 2024 — McMap. All rights reserved.