Как читать поле режима вывода git-ls-tree

$ 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
...

Я знаю, что последние 3 цифры октавы относятся к файловому режиму, но для чего нужны первые 3 цифры? Я не могу найти это в руководстве пользователя git.


person an0    schedule 10.04.2009    source источник
comment
Git настолько не работает ... Попробуйте сбросить разрешения с помощью чего-нибудь вроде chmod 0100755 <file>, чтобы Git был счастлив. Или, что еще более забавно, git chmod ‹perm› ‹file› `из-за файловых режимов Git (его не существует) ... Также см. Такие вопросы, как Как удалить файлы с надписью« старый режим 100755 новый режим 100644 »из неустановленных изменений в Git?, Как восстановить файл разрешения на то, каким git «думает» должен быть файл?. Этот инструмент - такая неудачная шутка ...   -  person jww    schedule 10.12.2016


Ответы (2)


6 цифр показывают режим файла с использованием классической нотации UNIX. Первые две цифры показывают тип файла, третья - о битах set-uid / set-gid / sticky, а последние три вы знаете.

Вот как man 2 stat это документирует в моей системе 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
person adl    schedule 10.04.2009
comment
Возможно, стоит добавить к вашему ответу, что подмодули перечислены с файловым режимом 160000 и фиксацией типа объекта. - person Mark Longair; 02.08.2010
comment
Почему ведущий 0 в верхних строках (например, 0170000 вместо 170000), поскольку он 0 для всех строк, почему бы просто не опустить его? - person Ciro Santilli 新疆再教育营六四事件ۍ 22.08.2014
comment
@CiroSantilli Ведущий 0 - это классическое соглашение для обозначения восьмеричных чисел. - person adl; 22.08.2014
comment
Этот ответ неверен: git не использует их все, а имеет несколько специальных (например, у подмодулей 160000). - person mirabilos; 02.09.2016

Из файла index-format.txt Git относительно режима :

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.

Кроме того, разрешены тип объекта каталога (двоичный 0100) и обычный файл с возможностью групповой записи (разрешения 0664), как указано в _ 3_ fsck_tree метод. Обычный неисполняемый файл с возможностью групповой записи - это нестандартный режим, который поддерживался в более ранних версиях Git.

Это делает допустимые режимы (как двоичные, так и восьмеричные):

  • 0100000000000000 (040000): Каталог
  • 1000000110100100 (100644): обычный неисполняемый файл
  • 1000000110110100 (100664): Обычный неисполняемый файл с возможностью групповой записи
  • 1000000111101101 (100755): обычный исполняемый файл
  • 1010000000000000 (120000): символическая ссылка
  • 1110000000000000 (160000): Gitlink
person Dan Cruz    schedule 01.12.2011
comment
Странно ... Я только что зафиксировал несколько 644 файлов в git, и в сообщении о фиксации говорится, что они были созданы в репозитории как 664 - person MestreLion; 20.12.2012
comment
Режим каталога недействителен, потому что этого никогда не произойдет. Git не отслеживает каталоги, потому что каталоги в Git существуют только неявно с не- игнорируемым содержимым. - person nemesis; 24.03.2014
comment
@nemesis Git действительно использует режим каталогов (040000) для представления каталогов. См. Связанный fsck.c код или просто выполните git ls-tree HEAD в репозитории Git, содержащем каталоги. - person Dan Cruz; 24.03.2014
comment
Ладно, плохо. Теперь я вижу, что вы говорите о ls-tree, которое показывает режимы файлов. Я думал о режиме, который появляется, когда вы фиксируете файлы (а каталоги на самом деле не фиксируются). Прости. - person nemesis; 25.03.2014
comment
Почему сохраняется разрешение на запись группы, но не большинство других разрешений? Есть ли важный вариант использования? - person Ciro Santilli 新疆再教育营六四事件ۍ 22.08.2014
comment
@CiroSantilli 巴拿馬 文件 六四 事件 法轮功: права на запись группы фактически не сохранены. Просто код fsck не будет утверждать, что запись в дереве с этим режимом плохая. Идея заключалась в том, чтобы оставить место для групповых разрешений на файлы, если это окажется необходимым. Он никогда не был нужен, поэтому никогда не добавлялся, но и код тестирования никогда не менялся, чтобы запретить это. - person torek; 23.07.2016
comment
@Dan Cruz Если есть только 16 цифр с основанием 2, почему они пишут 32-битный режим? - person Sevastyan Savanyuk; 21.08.2018
comment
@Sevastyan Git резервирует 16 бит для внутреннего использования; см. cache.h. - person Dan Cruz; 21.08.2018
comment
Небольшая поправка к моему предыдущему комментарию: в какой-то момент Git действительно сделал запись разрешения на групповую запись, и, очевидно, есть некоторые репозитории, в которых есть mode 100664 древовидные записи, поэтому git fsck позволяет им не утверждать, что эти очень старые репозитории плохие. Но хранение групповой записи оказалось неэффективным, и код был изменен, чтобы перестать это делать. - person torek; 19.01.2019