Как прочитать поле режима вывода 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.c
fsck_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 г.)
коммит 3a2ebae
docs
: задокументировать нулевые биты в индексе "режим"Подписано: Глен Чу
описывает «режим» как 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