วิธีอ่านฟิลด์โหมดของเอาต์พุตของ git-ls-tree


101
$ 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 ไม่เจอ


2
Git พังมาก ... ลองรีเซ็ตสิทธิ์ด้วยอะไรสักอย่างchmod 0100755 <file>เพื่อให้ Git มีความสุข หรือตลกกว่านั้นก็คือ git chmod <perm> <file> `เนื่องจากโหมดไฟล์ของ Git (ไม่มีอยู่) ... ดูคำถามเช่นฉันจะลบไฟล์ที่ระบุว่า" โหมดเก่า 100755 โหมดใหม่ 100644 "ได้อย่างไรจากการเปลี่ยนแปลงที่ไม่มีขั้นตอนใน Git? , วิธีการกู้คืนสิทธิ์ของไฟล์กับสิ่งที่ "คิด" ไฟล์ควรจะเป็น git? . เครื่องมือนี้ช่างเป็นเรื่องตลกเสียจริง ...
jww

คำตอบ:


63

ตัวเลข 6 หลักแสดงโหมดไฟล์โดยใช้สัญลักษณ์ UNIX แบบคลาสสิก ตัวเลขสองหลักแรกแสดงประเภทไฟล์ส่วนที่สามเกี่ยวกับ set-uid / set-gid / sticky bits และคุณรู้สามตัวสุดท้าย

นี่คือวิธีการ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

9
อาจเป็นการดีที่จะเพิ่มคำตอบของคุณว่าโมดูลย่อยจะแสดงรายการด้วยโหมดไฟล์ 160000 และอ็อบเจ็กต์ประเภท "คอมมิต"
Mark Longair

2
ทำไมต้องนำ0หน้าบรรทัดบนสุด (เช่น0170000แทนที่จะเป็น170000) เนื่องจากมี0ไว้สำหรับทุกบรรทัดทำไมไม่เพียงแค่ละเว้น
Ciro Santilli 郝海东冠状病六四事件法轮功

13
@CiroSantilli A ชั้นนำ0เป็นการประชุมแบบคลาสสิกเพื่อระบุตัวเลขฐานแปด
adl

6
คำตอบนี้ไม่ถูกต้อง: git ไม่ได้ใช้ทั้งหมดและมีบางส่วนพิเศษในตัวเอง (โมดูลย่อยมี 160000 เป็นต้น)
mirabilos

133

จาก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) ตามที่ระบุโดยวิธีการ ไฟล์ที่เขียนเป็นกลุ่มที่ไม่สามารถเรียกใช้งานได้ปกติคือโหมดที่ไม่ได้มาตรฐานซึ่งได้รับการสนับสนุนใน Git เวอร์ชันก่อนหน้าfsck.c fsck_tree

สิ่งนี้ทำให้โหมดที่ถูกต้อง (เป็นไบนารีและฐานแปด):

  • 0100000000000000( 040000): ไดเรกทอรี
  • 1000000110100100( 100644): ไฟล์ปกติที่ไม่สามารถเรียกใช้งานได้
  • 1000000110110100( 100664): ไฟล์กลุ่มที่เขียนไม่ได้ปกติ
  • 1000000111101101( 100755): ไฟล์ปฏิบัติการปกติ
  • 1010000000000000( 120000): ลิงค์สัญลักษณ์
  • 1110000000000000( 160000): Gitlink

แปลก ... ฉันเพิ่งกำหนด644ไฟล์บางไฟล์ในคอมไพล์และข้อความคอมมิตบอกว่าถูกสร้างขึ้นใน repo เมื่อ664
MestreLion

2
โหมดไดเร็กทอรีไม่ถูกต้องเนื่องจากจะไม่เกิดขึ้น Git ไม่ได้ติดตามไดเร็กทอรีเนื่องจากไดเร็กทอรีใน Git มีอยู่โดยปริยายโดยมีเนื้อหาที่ไม่ถูกละเว้น
ซวย

1
@nemesis Git ใช้040000โหมดไดเร็กทอรี ( ) เพื่อแสดงไดเร็กทอรี โปรดดูfsck.cรหัสที่เชื่อมโยงหรือเพียงดำเนินการgit ls-tree HEADในที่เก็บ Git ที่มีไดเร็กทอรี
Dan Cruz

1
เหตุใดสิทธิ์การเขียนกลุ่มจึงถูกเก็บไว้ แต่ไม่ใช่สิทธิ์อื่น ๆ ส่วนใหญ่ มีกรณีการใช้งานที่สำคัญหรือไม่?
Ciro Santilli 郝海东冠状病六四事件法轮功

1
@CiroSantilli巴拿馬文件六四事件法轮功: สิทธิ์ในการเขียนกลุ่มที่ไม่จริงเก็บไว้ มันเป็นเพียงแค่ว่าfsckรหัสจะไม่อ้างว่ารายการต้นไม้ที่มีโหมดที่เป็นที่ไม่ดี แนวคิดคือการเว้นที่ว่างสำหรับการอนุญาตกลุ่มในไฟล์หากจำเป็น ไม่เคยจำเป็นจึงไม่เคยเพิ่ม แต่รหัสการทดสอบก็ไม่เคยเปลี่ยนเพื่อห้ามเช่นกัน
torek
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.