$ rm foobar
rm: remove regular file `foobar'?
Що означає файл "регулярним" і чому rm
такий файл розглядається як окремий випадок?
$ rm foobar
rm: remove regular file `foobar'?
Що означає файл "регулярним" і чому rm
такий файл розглядається як окремий випадок?
Відповіді:
Я думаю rm
, це псевдонім, можливо rm -i
. "Звичайна" частина нічого не означає, це означає лише, що це не труба, пристрій, розетка чи щось інше "особливе".
file /etc/passwd
або file /dev/null
.
Будь-який файл, який пройшов тест ( -f
), є звичайним файлом:
$ test -f afile.zip && echo regular
regular
Якщо ви переглянете сторінку чоловіка, test
ви побачите всі типи файлів.
Ви також можете перевірити правильність файлу за допомогою stat
команди:
$ stat afile.zip
File: `afile.zip'
Size: 1512 Blocks: 8 IO Block: 4096 regular file
Device: fd02h/64770d Inode: 10370668 Links: 1
Access: (0664/-rw-rw-r--) Uid: ( 500/ saml) Gid: ( 501/ saml)
Access: 2013-11-07 15:52:06.719632792 -0500
Modify: 2013-11-07 15:52:00.949760104 -0500
Change: 2013-11-07 15:52:00.949760104 -0500
Щоб дізнатися більше про різницю між звичайним файлом та іншими можливими типами, перегляньте сторінку "man" stat
. Обов’язково перегляньте підручник з програмістами, а не чоловічу сторінку для фактичної stat
команди.
$ man 2 stat
Зокрема, у цьому розділі показано різні типи файлів:
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
rm -i
.