Jak czytać pole trybu wyjścia git-ls-tree

100
$ git ls-tree fb3a8bdd0ce
100644 blob 63c918c667fa005ff12ad89437f2fdc80926e21c    .gitignore
100644 blob 5529b198e8d14decbe4ad99db3f7fb632de0439d    .mailmap
100644 blob 6ff87c4664981e4397625791c8ea3bbb5f2279a3    COPYING
040000 tree 2fb783e477100ce076f6bf57e4a6f026013dc745    Documentation
100755 blob 3c0032cec592a765692234f1cba47dfdcc3a9200    GIT-VERSION-GEN
100644 blob 289b046a443c0647624607d471289b2c7dcd470b    INSTALL
100644 blob 4eb463797adc693dc168b926b6932ff53f17d0b1    Makefile
100644 blob 548142c327a6790ff8821d67c2ee1eff7a656b52    README
...

Wiem, że ostatnie 3 cyfry oktaw to tryb pliku, ale do czego służą pierwsze 3 cyfry? Nie mogę tego znaleźć w instrukcji obsługi gita.

an0
źródło
2
Git jest tak zepsuty ... Spróbuj zresetować uprawnienia za pomocą czegoś takiego jak a, chmod 0100755 <file>aby zadowolić Git. Lub jeszcze bardziej zabawne, git chmod <perm> <file> `z powodu trybów plików Gita (nie istnieje) ... Zobacz także pytania takie jak Jak usunąć pliki z napisem„ stary tryb 100755 nowy tryb 100644 ”ze zmian niestopowanych w Git? , Jak odzyskać uprawnienia do pliku, do jakiego git „myśli” powinien być plik? . To narzędzie to taki zepsuty żart ...
jww

Odpowiedzi:

62

6 cyfr przedstawia tryb pliku przy użyciu klasycznej notacji UNIX. Pierwsze dwie cyfry pokazują typ pliku, trzecia to set-uid / set-gid / sticky bits, a ostatnie trzy znasz.

Oto jak man 2 statdokumentuje to w moim systemie GNU / Linux:

   The following flags are defined for the st_mode field:

       S_IFMT     0170000   bit mask for the file type bit fields
       S_IFSOCK   0140000   socket
       S_IFLNK    0120000   symbolic link
       S_IFREG    0100000   regular file
       S_IFBLK    0060000   block device
       S_IFDIR    0040000   directory
       S_IFCHR    0020000   character device
       S_IFIFO    0010000   FIFO
       S_ISUID    0004000   set UID bit
       S_ISGID    0002000   set-group-ID bit (see below)
       S_ISVTX    0001000   sticky bit (see below)
       S_IRWXU    00700     mask for file owner permissions
       S_IRUSR    00400     owner has read permission
       S_IWUSR    00200     owner has write permission
       S_IXUSR    00100     owner has execute permission
       S_IRWXG    00070     mask for group permissions
       S_IRGRP    00040     group has read permission
       S_IWGRP    00020     group has write permission
       S_IXGRP    00010     group has execute permission
       S_IRWXO    00007     mask for permissions for others (not in group)
       S_IROTH    00004     others have read permission           
       S_IWOTH    00002     others have write permission
       S_IXOTH    00001     others have execute permission
adl
źródło
9
Warto dodać do swojej odpowiedzi, że podmoduły są wymienione z kodem pliku 160000 i typem obiektu „commit”.
Mark Longair
2
Dlaczego prowadzenie 0w górnych wierszach (np. 0170000Zamiast 170000), skoro dotyczy 0wszystkich wierszy, dlaczego by go po prostu nie pominąć?
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功
13
@CiroSantilli Interlinia 0to klasyczna konwencja oznaczania liczb ósemkowych.
adl
6
Ta odpowiedź jest błędna: git nie używa ich wszystkich, a ma kilka specjalnych (na przykład podmoduły mają 160000)
mirabilos
130

Z index-format.txtpliku Git , odnośnie trybu:

32-bit mode, split into (high to low bits)

    4-bit object type
      valid values in binary are 1000 (regular file), 1010 (symbolic link)
      and 1110 (gitlink)

    3-bit unused

    9-bit unix permission. Only 0755 and 0644 are valid for regular files.
    Symbolic links and gitlinks have value 0 in this field.

Ponadto typ obiektu katalogu (binarny 0100) i zwykły plik z możliwością zapisu przez grupę (uprawnienia 0664) są dozwolone, zgodnie z metodą. Zwykły, niewykonywalny plik z możliwością zapisu w grupie to niestandardowy tryb, który był obsługiwany we wcześniejszych wersjach Git.fsck.c fsck_tree

To sprawia, że ​​prawidłowe tryby (jako binarne i ósemkowe):

  • 0100000000000000( 040000): Katalog
  • 1000000110100100( 100644): Zwykły plik niewykonywalny
  • 1000000110110100( 100664): Zwykły, niewykonywalny plik z możliwością zapisu przez grupę
  • 1000000111101101( 100755): Zwykły plik wykonywalny
  • 1010000000000000( 120000): Dowiązanie symboliczne
  • 1110000000000000( 160000): Gitlink
Dan Cruz
źródło
Dziwne ... Właśnie popełniłem kilka 644plików w git, a komunikat o zatwierdzeniu powiedział, że zostały utworzone w repozytorium jako664
MestreLion,
2
Tryb katalogu jest nieprawidłowy, ponieważ nigdy się nie wydarzy. Git nie zapisuje katalogów, ponieważ katalogi w Git istnieć tylko w sposób dorozumiany z nieskomplikowaną ignorowane treści.
nemesis
1
@nemesis Git rzeczywiście używa 040000trybu directory ( ) do reprezentowania katalogów. Zobacz linkowany fsck.ckod lub po prostu wykonaj git ls-tree HEADw repozytorium Git, które zawiera katalogi.
Dan Cruz
1
Dlaczego zachowane są uprawnienia do zapisu grupy, ale nie większość innych uprawnień? Czy istnieje ważny przypadek użycia?
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功
1
@CiroSantilli 巴拿馬 文件 六四 事件 法轮功: uprawnienia do zapisu grupy nie są w rzeczywistości zachowane . Po prostu fsckkod nie będzie twierdził, że wpis drzewa w tym trybie jest zły . Pomysł polegał na pozostawieniu miejsca na uprawnienia grupowe do plików, jeśli okaże się to potrzebne. Nigdy nie był potrzebny, dlatego nigdy nie został dodany, ale kod testowy nigdy nie został zmieniony, aby tego zabronić.
torek