2009-04-10 2 views
80
$ 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 
... 

Je sais que les 3 derniers octets sont en mode fichier, mais à quoi servent les 3 premiers chiffres? Je ne peux pas le trouver dans le manuel de l'utilisateur git.Comment lire le champ mode de la sortie de git-ls-tree

+0

git ls-tree a aussi un '-r': flag récursive. – ThorSummoner

+2

Git est tellement cassé ... Essayez de réinitialiser les autorisations avec quelque chose comme un 'chmod 0100755 ' pour rendre Git heureux. Ou encore plus drôle, git chmod 'en raison des modes de fichiers de Git (il n'existe pas) ... Voir aussi des questions comme [Comment supprimer des fichiers en disant" ancien mode 100755 nouveau mode 100644 "de Git?] (http://stackoverflow.com/q/1257592/608639), [Comment récupérer les autorisations de fichier à ce que git "pense" le fichier devrait être?] (http://stackoverflow.com/q/2517339). Cet outil est une blague cassée ... – jww

Répondre

53

Les 6 chiffres affichent le mode fichier en utilisant les notations UNIX classiques. Les deux premiers chiffres indiquent le type de fichier, le troisième concerne les bits set-uid/set-gid/sticky, et vous connaissez les trois derniers.

Voici comment man 2 stat documents sur mon système GNU/Linux: A partir du fichier Git index-format.txt

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 
+0

Merci, il semble que j'ai été en train de négliger la partie type de fichier du mode fichier. – an0

+8

Il peut être utile d'ajouter à votre réponse que les sous-modules sont listés avec un filemode de 160000 et le type d'objet "commit". –

+2

Pourquoi le premier '0' sur les premières lignes (par exemple' 0170000' au lieu de '170000'), puisqu'il est' 0' pour toutes les lignes, pourquoi ne pas l'omettre? –

98

, en ce qui concerne le mode:

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. 

En outre, un type d'objet de répertoire (binaires 0100) et les fichiers réguliers de groupe (writings 0664) sont autorisés comme indiqué par la méthode fsck.cfsck_tree. Le fichier inscriptible groupe non exécutable normal est un mode non standard pris en charge dans les versions antérieures de Git.

Cela rend les modes valides (comme binaire et octal):

  • 0100000000000000 (040000): Annuaire
  • 1000000110100100 (100644): fichier non exécutable régulier
  • 1000000110110100 (100664): régulier non -exécutable groupe-inscriptible fichier
  • 1000000111101101 (100755): Fichier exécutable régulier
  • 1010000000000000 (120000): Lien symbolique
  • 1110000000000000 (160000): Gitlink
+0

Bizarre ... Je viens de commettre quelques fichiers '644' dans git et le message de validation dit qu'ils ont été créés dans le repo comme '664' – MestreLion

+2

Le mode répertoire n'est pas valide car cela n'arrivera jamais. Git ne suit pas les répertoires, car les répertoires de Git n'existent qu'implicitement avec le contenu non-* ignoré *. – nemesis

+1

@nemesis Git utilise en effet le mode répertoire ('040000') pour représenter les répertoires. S'il vous plaît voir le 'fsck lié.c' code, ou simplement exécuter 'git ls-tree HEAD' dans un dépôt Git qui contient des répertoires. –

Questions connexes