Cara membaca bidang mode keluaran git-ls-tree

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

Saya tahu 3 digit terakhir adalah mode file, tetapi untuk apa 3 digit pertama? Saya tidak bisa menemukannya di manual pengguna git.

an0
sumber
2
Git sangat rusak ... Coba setel ulang perizinan dengan sesuatu seperti a chmod 0100755 <file>untuk membuat Git senang. Atau yang lebih lucu, git chmod <perm> <file> `karena mode file Git (tidak ada) ... Lihat juga pertanyaan seperti Bagaimana cara menghapus file yang mengatakan" mode lama 100755 mode baru 100644 "dari perubahan yang tidak bertahap di Git? , Bagaimana memulihkan hak akses file ke file yang seharusnya "menurut" git? . Alat ini benar-benar lelucon yang rusak ...
jww

Jawaban:

62

6 digit tersebut menunjukkan mode file menggunakan notasi UNIX klasik. Dua digit pertama menunjukkan tipe file, yang ketiga adalah tentang set-uid / set-gid / sticky bits, dan Anda tahu tiga yang terakhir.

Berikut adalah cara man 2 statmendokumentasikannya di sistem GNU / Linux saya:

   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
adl
sumber
9
Mungkin ada baiknya menambahkan jawaban Anda bahwa submodul terdaftar dengan filemode 160000 dan tipe objek "komit".
Mark Longair
2
Mengapa awalan 0di baris teratas (misalnya, 0170000bukan 170000), karena ini 0untuk semua baris, mengapa tidak dihilangkan saja?
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功
13
@CiroSantilli Sebuah leading 0adalah konvensi klasik untuk menunjukkan bilangan oktal.
adl
6
Jawaban ini salah: git tidak menggunakan semuanya, dan memiliki beberapa yang khusus sendiri (submodul memiliki 160000, misalnya)
mirabilos
130

Dari index-format.txtfile Git , mengenai mode:

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.

Selain itu, jenis objek direktori (biner 0100) dan file biasa yang dapat ditulis grup (izin 0664) diperbolehkan seperti yang ditunjukkan oleh metode ini. File grup-writeable biasa yang tidak dapat dieksekusi adalah mode non-standar yang didukung di versi Git sebelumnya.fsck.c fsck_tree

Ini membuat mode yang valid (seperti biner dan oktal):

  • 0100000000000000( 040000): Direktori
  • 1000000110100100( 100644): File biasa yang tidak dapat dieksekusi
  • 1000000110110100( 100664): File grup-writeable biasa yang tidak dapat dieksekusi
  • 1000000111101101( 100755): File eksekusi biasa
  • 1010000000000000( 120000): Tautan simbolis
  • 1110000000000000( 160000): Gitlink
Dan Cruz
sumber
Aneh ... Saya baru saja melakukan beberapa 644file di git dan pesan komit mengatakan bahwa file tersebut dibuat di repo sebagai664
MestreLion
2
Mode direktori tidak valid karena tidak akan pernah terjadi. Git tidak melacak direktori, karena direktori di Git hanya ada secara implisit dengan konten yang tidak diabaikan .
musuh bebuyutan
1
@ nemesis Git memang menggunakan 040000mode direktori ( ) untuk merepresentasikan direktori. Silakan lihat fsck.ckode yang ditautkan , atau cukup jalankan git ls-tree HEADdi repositori Git yang berisi direktori.
Dan Cruz
1
Mengapa izin menulis grup disimpan, tetapi tidak untuk sebagian besar izin lainnya? Apakah ada kasus penggunaan yang penting?
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功
1
@CiroSantilli 巴拿馬 文件 六四 事件 法轮功: izin menulis grup sebenarnya tidak disimpan . Hanya saja fsckkode tersebut tidak akan mengklaim bahwa entri pohon dengan mode itu buruk . Idenya adalah memberikan ruang untuk izin grup pada file, jika ternyata diperlukan. Itu tidak pernah diperlukan, karenanya tidak pernah ditambahkan, tetapi kode pengujian tidak pernah diubah untuk melarangnya juga.
torek