Как прочитать поле режима вывода 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.

3 ответа

Решение

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

Из мерзавца index-format.txt файл, касающийся режима:

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) разрешены, как указано fsck.cfsck_tree метод. Обычный неисполняемый файл с возможностью записи в группы - это нестандартный режим, который поддерживался в более ранних версиях Git.

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

  • 0100000000000000 (040000): Каталог
  • 1000000110100100 (100644): Обычный неисполняемый файл
  • 1000000110110100 (100664): Обычный неисполняемый файл с возможностью записи в группы
  • 1000000111101101 (100755): Обычный исполняемый файл
  • 1010000000000000 (120000): Символическая ссылка
  • 1110000000000000 (160000): Gitlink

Чтобы добавить к ответу user649852 Git 2.40 (Q1 2023) добавляет:

См. (1 февраля 2023 г.) от Glen Choo ( chooglen) .
(Объединено Junio ​​C Hamano -- gitster-- в коммите 2c91b13, 09 февраля 2023 г.)

коммит 3a2ebaedocs: задокументировать нулевые биты в индексе "режим"

Подписано: Глен Чу

описывает «режим» как 32 бита, но документирует только 16 бит.

Задокументируйте недостающие 16 бит и укажите, что «неиспользуемые» биты должны быть равны нулю.

gitformat-indexтеперь включает в свою Documentation/gitformat-index.txtсправочную страницу :

16-бит не используется, должен быть равен нулю ...3-бит не используется, должен быть равен нулю

Это означает, что формат на самом деле:

  • 0(16x) 0100 000 000000000(040000): Каталог
  • 0(16x) 1000 000 110100100(100644): обычный неисполняемый файл
  • 0(16x) 1000 000 110110100(100664): Обычный неисполняемый файл с возможностью групповой записи.
  • 0(16x) 1000 000 111101101(100755): обычный исполняемый файл
  • 0(16x) 1010 000 000000000(120000): символическая ссылка
  • 0(16x) 1110 000 000000000(160000): Гитлинк
  • ^^^
  • always set to 0
Другие вопросы по тегам