Cách đọc trường mode của đầu ra git-ls-tree


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

Tôi biết 3 chữ số bát phân cuối cùng là chế độ tệp, nhưng 3 chữ số đầu tiên để làm gì? Tôi không thể tìm thấy nó trong hướng dẫn sử dụng git.


2
Git bị hỏng quá ... Hãy thử đặt lại quyền bằng một cái gì đó như a chmod 0100755 <file>để làm cho Git hài lòng. Hay thậm chí buồn cười hơn, git chmod <perm> <file> `vì các chế độ tệp của Git (nó không tồn tại) ... Ngoài ra, hãy xem các câu hỏi như Làm cách nào để xóa các tệp có nội dung" chế độ cũ 100755 chế độ mới 100644 "khỏi các thay đổi không được đóng gói trong Git? , Làm thế nào để khôi phục quyền của tệp về những gì git "nghĩ" tệp phải là? . Công cụ này thật là một trò đùa hỏng ...
jww 10/12/16

Câu trả lời:


62

6 chữ số hiển thị chế độ tệp sử dụng ký hiệu UNIX cổ điển. Hai chữ số đầu tiên hiển thị loại tệp, chữ số thứ ba nói về các bit set-uid / set-gid / stick và bạn biết ba chữ số cuối cùng.

Đây là cách man 2 stattài liệu nó trên hệ thống GNU / Linux của tôi:

   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

9
Có thể đáng để thêm vào câu trả lời của bạn rằng các mô-đun con được liệt kê với mã tệp là 160000 và loại đối tượng "cam kết".
Mark Longair

2
Tại sao lại đứng đầu 0các dòng trên cùng (ví dụ 0170000thay vì 170000), vì nó 0dành cho tất cả các dòng, tại sao không bỏ qua nó?
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功

13
@CiroSantilli Hàng đầu 0là một quy ước cổ điển để biểu thị các số bát phân.
adl

6
Câu trả lời này là sai: git không sử dụng tất cả trong số họ, và có một vài người đặc biệt ngày của riêng mình (submodules có 160000, ví dụ)
mirabilos

129

Từ index-format.txttệp Git , về chế độ:

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.

Ngoài ra, một loại đối tượng thư mục (nhị phân 0100) và tệp thông thường có thể ghi theo nhóm (quyền 0664) được cho phép như được chỉ ra bởi phương thức. Tệp có thể ghi nhóm không thực thi thông thường là một chế độ không chuẩn đã được hỗ trợ trong các phiên bản trước đó của Git.fsck.c fsck_tree

Điều này làm cho các chế độ hợp lệ (dưới dạng nhị phân và bát phân):

  • 0100000000000000( 040000): Thư mục
  • 1000000110100100( 100644): Tệp không thực thi thông thường
  • 1000000110110100( 100664): Tệp có thể ghi nhóm thông thường không thực thi được
  • 1000000111101101( 100755): Tệp thực thi thông thường
  • 1010000000000000( 120000): Liên kết tượng trưng
  • 1110000000000000( 160000): Gitlink

Weird ... Tôi chỉ phạm phải một số 644tập tin trong git và thông điệp cam kết cho biết họ đã tạo ra trong repo như664
MestreLion

2
Chế độ thư mục không hợp lệ vì nó sẽ không bao giờ xảy ra. Git không theo dõi các thư mục, bởi vì các thư mục trong Git chỉ tồn tại ngầm với nội dung không bị bỏ qua .
nemesis

1
@nemesis Git thực sự sử dụng 040000chế độ thư mục ( ) để biểu diễn các thư mục. Vui lòng xem fsck.cmã được liên kết hoặc chỉ thực thi git ls-tree HEADtrong kho lưu trữ Git có chứa các thư mục.
Dan Cruz

1
Tại sao quyền ghi nhóm được giữ mà không phải hầu hết các quyền khác? Có một trường hợp sử dụng quan trọng?
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功

1
@CiroSantilli 巴拿馬 文件 六四 事件 法轮功: quyền ghi nhóm thực sự không được giữ . Chỉ là fsckmã sẽ không cho rằng mục nhập dạng cây với chế độ đó là xấu . Ý tưởng là để lại khoảng trống cho các quyền của nhóm đối với các tệp, nếu điều đó trở nên cần thiết. Nó không bao giờ cần thiết, do đó không bao giờ được thêm vào, nhưng mã thử nghiệm cũng không bao giờ được thay đổi để cấm nó.
torek
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.