[Toybox] Patch stat supports %T format

enh enh at google.com
Thu May 7 12:57:28 PDT 2015


there's already a list of fstypes in toys/other/blkid.c. it would probably
make more sense to move that into lib and share it.

On Thu, May 7, 2015 at 3:59 AM, Hyejin Kim <hj8296 at gmail.com> wrote:

> Hi.
>
> As need internally, added %T format to print filesystem type as human
> readable form.
> Plz, have a look.
>
> smackfs currently commented but will support later.
>
>
>
> diff --git a/toys/other/stat.c b/toys/other/stat.c
> index a96c1de..a9f4685 100644
> --- a/toys/other/stat.c
> +++ b/toys/other/stat.c
> @@ -29,7 +29,7 @@ config STAT
>      %a  Available blocks    |%b  Total blocks       |%c  Total inodes
>      %d  Free inodes         |%f  Free blocks        |%i  File system ID
>      %l  Max filename length |%n  File name          |%s  Fragment size
> -    %S  Best transfer size  |%t  File system type
> +    %S  Best transfer size  |%t  File system type   |%T  Type in human
> readable form
>  */
>
>  #define FOR_stat
> @@ -46,6 +46,35 @@ GLOBALS(
>    struct group *group_name;
>  )
>
> +static char* ftype_to_string(uint64_t ftype)
> +{
> +  switch (ftype) {
> +    case 0xADFF: return "affs";
> +    case 0x5346544e: return "ntfs";
> + case 0x1Cd1: return "devpts";
> +    case 0x137D: return "ext";
> +    case 0xEF51: return "ext2";
> +    case 0xEF53: return "ext2/ext3";
> +    case 0x1BADFACE: return "bfs";
> +    case 0x9123683E: return "btrfs";
> +    case 0x28cd3d45: return "cramfs";
> +    case 0x3153464a: return "jfs";
> +    case 0x7275: return "romfs";
> + case 0x01021994: return "tmpfs";
> + case 0x3434: return "nilfs";
> + case 0x6969: return "nfs";
> + case 0x9fa0: return "proc";
> + case 0x534F434B: return "sockfs";
> + case 0x62656572: return "sysfs";
> + case 0x517B: return "smb";
> + case 0x4d44: return "msdos";
> + case 0x4006: return "fat";
> +    //case 0x43415d53: return "smackfs";
> +    case 0x73717368: return "squashfs";
> +    default: return "unknown";
> +  }
> +}
> +
>
>  // Note: the atime, mtime, and ctime fields in struct stat are the start
>  // of embedded struct timespec, but posix won't let them use that
> @@ -113,6 +142,7 @@ static void print_statfs(char type) {
>    else if (type == 'f') xprintf("%llu", statfs->f_bfree);
>    else if (type == 'l') xprintf("%ld", statfs->f_namelen);
>    else if (type == 't') xprintf("%lx", statfs->f_type);
> +  else if (type == 'T') xprintf("%s", ftype_to_string(statfs->f_type));
>    else if (type == 'i')
>      xprintf("%08x%08x", statfs->f_fsid.__val[0], statfs->f_fsid.__val[1]);
>    else if (type == 's') xprintf("%d", statfs->f_frsize);
> @@ -124,7 +154,7 @@ void stat_main(void)
>  {
>    int flagf = toys.optflags & FLAG_f;
>    char *format = flagf
> -    ? "  File: \"%n\"\n    ID: %i Namelen: %l    Type: %t\n"
> +    ? "  File: \"%n\"\n    ID: %i Namelen: %l    Type: %T\n"
>        "Block Size: %s    Fundamental block size: %S\n"
>        "Blocks: Total: %b\tFree: %f\tAvailable: %a\n"
>        "Inodes: Total: %c\tFree: %d"
> --
>
> _______________________________________________
> Toybox mailing list
> Toybox at lists.landley.net
> http://lists.landley.net/listinfo.cgi/toybox-landley.net
>
>


-- 
Elliott Hughes - http://who/enh - http://jessies.org/~enh/
Android native code/tools questions? Mail me/drop by/add me as a reviewer.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.landley.net/pipermail/toybox-landley.net/attachments/20150507/772c1460/attachment-0003.htm>


More information about the Toybox mailing list