summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/stat.c156
1 files changed, 76 insertions, 80 deletions
diff --git a/src/stat.c b/src/stat.c
index fbe3266fa..de216f12f 100644
--- a/src/stat.c
+++ b/src/stat.c
@@ -33,6 +33,9 @@
# define SECURITY_ID_T security_id_t
#else
# define SECURITY_ID_T int
+# define is_flask_enabled() 0
+# define stat_secure(a,b,c) stat(a,b)
+# define lstat_secure(a,b,c) lstat(a,b)
#endif
#define PROGRAM_NAME "stat"
@@ -319,92 +322,40 @@ print_statfs (char *pformat, char m, char const *filename, void const *data, SEC
break;
case 'l':
-#ifdef __USE_FILE_OFFSET64
- strcat(pformat, "lu");
-#else
- strcat(pformat, "u");
-#endif
- printf(pformat, statfsbuf->f_namelen);
+ strcat(pformat, "llu");
+ printf(pformat, (uintmax_t) (statfsbuf->f_namelen));
break;
case 't':
-#ifdef __USE_FILE_OFFSET64
strcat(pformat, "lx");
-#else
- strcat(pformat, "x");
-#endif
- printf(pformat, statfsbuf->f_type);
+ printf(pformat, (long int) (statfsbuf->f_type));
break;
case 'T':
/* print_human_fstype(statfsbuf, pformat);*/
print_human_fstype(statfsbuf);
break;
case 'b':
-#ifdef __USE_FILE_OFFSET64
strcat(pformat, "lld");
-#else
-# if !defined(__linux__) && defined (__GNU__)
- strcat(pformat, "d");
-# else
- strcat(pformat, "ld");
-# endif
-#endif
- printf(pformat, statfsbuf->f_blocks);
+ printf(pformat, (intmax_t) (statfsbuf->f_blocks));
break;
case 'f':
-#ifdef __USE_FILE_OFFSET64
strcat(pformat, "lld");
-#else
-# if !defined(__linux__) && defined (__GNU__)
- strcat(pformat, "d");
-# else
- strcat(pformat, "ld");
-# endif
-#endif
- printf(pformat, statfsbuf->f_bfree);
+ printf(pformat, (intmax_t) (statfsbuf->f_bfree));
break;
case 'a':
-#ifdef __USE_FILE_OFFSET64
strcat(pformat, "lld");
-#else
-# if !defined(__linux__) && defined (__GNU__)
- strcat(pformat, "d");
-# else
- strcat(pformat, "ld");
-# endif
-#endif
- printf(pformat, statfsbuf->f_bavail);
+ printf(pformat, (intmax_t) (statfsbuf->f_bavail));
break;
case 's':
-#ifdef __USE_FILE_OFFSET64
strcat(pformat, "ld");
-#else
- strcat(pformat, "d");
-#endif
- printf(pformat, statfsbuf->f_bsize);
+ printf(pformat, (long int) (statfsbuf->f_bsize));
break;
case 'c':
-#ifdef __USE_FILE_OFFSET64
strcat(pformat, "lld");
-#else
-# if !defined(__linux__) && defined (__GNU__)
- strcat(pformat, "d");
-# else
- strcat(pformat, "ld");
-# endif
-#endif
- printf(pformat, statfsbuf->f_files);
+ printf(pformat, (intmax_t) (statfsbuf->f_files));
break;
case 'd':
-#ifdef __USE_FILE_OFFSET64
strcat(pformat, "lld");
-#else
-# if !defined(__linux__) && defined (__GNU__)
- strcat(pformat, "d");
-# else
- strcat(pformat, "ld");
-# endif
-#endif
- printf(pformat, statfsbuf->f_ffree);
+ printf(pformat, (intmax_t) (statfsbuf->f_ffree));
break;
#ifdef FLASK_LINUX
case 'S':
@@ -650,8 +601,6 @@ do_statfs (char const *filename, int terse, int secure, char const *format)
int i;
#ifdef FLASK_LINUX
- if (!is_flask_enabled())
- secure = 0;
if (secure)
i = statfs_secure(filename, &statfsbuf, &sid);
else
@@ -667,16 +616,13 @@ do_statfs (char const *filename, int terse, int secure, char const *format)
{
if (terse != 0)
{
-#ifdef FLASK_LINUX
if (secure)
format = "%n %i %l %t %b %f %a %s %c %d %S %C";
else
-#endif
format = "%n %i %l %t %b %f %a %s %c %d";
}
else
{
-#ifdef FLASK_LINUX
if (secure)
format = " File: \"%n\"\n"
" ID: %-8i Namelen: %-7l Type: %T\n"
@@ -684,7 +630,6 @@ do_statfs (char const *filename, int terse, int secure, char const *format)
"Inodes: Total: %-10c Free: %-10d\n"
" SID: %-14S S_Context: %C\n";
else
-#endif
format = " File: \"%n\"\n"
" ID: %-8i Namelen: %-7l Type: %T\n"
"Blocks: Total: %-10b Free: %-10f Available: %-10a Size: %s\n"
@@ -703,15 +648,10 @@ do_stat (char const *filename, int follow_links, int terse, int secure, char con
int i;
SECURITY_ID_T sid = -1;
-#ifdef FLASK_LINUX
- /* FIXME: hoist this test into main. */
- if (!is_flask_enabled())
- secure = 0;
if (secure)
i = (follow_links == 1) ? stat_secure(filename, &statbuf, &sid) : lstat_secure(filename, &statbuf, &sid);
else
-#endif
- i = (follow_links == 1) ? stat(filename, &statbuf) : lstat(filename, &statbuf);
+ i = (follow_links == 1) ? stat(filename, &statbuf) : lstat(filename, &statbuf);
if (i == -1)
{
@@ -723,11 +663,9 @@ do_stat (char const *filename, int follow_links, int terse, int secure, char con
{
if (terse != 0)
{
-#ifdef FLASK_LINUX
if (secure)
format = "%n %s %b %f %u %g %D %i %h %t %T %X %Y %Z %o %S %C";
else
-#endif
format = "%n %s %b %f %u %g %D %i %h %t %T %X %Y %Z %o";
}
else
@@ -735,7 +673,6 @@ do_stat (char const *filename, int follow_links, int terse, int secure, char con
/* tmp hack to match orignal output until conditional implemented */
i = statbuf.st_mode & S_IFMT;
if (i == S_IFCHR || i == S_IFBLK) {
-#ifdef FLASK_LINUX
if (secure)
format =
" File: %N\n"
@@ -748,7 +685,6 @@ do_stat (char const *filename, int follow_links, int terse, int secure, char con
"Modify: %y\n"
"Change: %z\n";
else
-#endif
format =
" File: %N\n"
" Size: %-10s\tBlocks: %-10b IO Block: %-6o %F\n"
@@ -761,7 +697,6 @@ do_stat (char const *filename, int follow_links, int terse, int secure, char con
}
else
{
-#ifdef FLASK_LINUX
if (secure)
format =
" File: %N\n"
@@ -773,7 +708,6 @@ do_stat (char const *filename, int follow_links, int terse, int secure, char con
"Modify: %y\n"
"Change: %z\n";
else
-#endif
format =
" File: %N\n"
" Size: %-10s\tBlocks: %-10b IO Block: %-6o %F\n"
@@ -801,13 +735,72 @@ usage (int status)
Display file or filesystem status.\n\
\n\
-f, --filesystem display filesystem status instead of file status\n\
- -c --format=FMT FIXME\n\
+ -c --format=FORMAT FIXME\n\
-l, --link follow links\n\
-s, --secure FIXME\n\
-t, --terse print the information in terse form\n\
"), stdout);
fputs (HELP_OPTION_DESCRIPTION, stdout);
fputs (VERSION_OPTION_DESCRIPTION, stdout);
+
+ fputs (_("\n\
+The valid format sequences for files (without --filesystem):\n\
+\n\
+ %A - Access rights in human readable form\n\
+ %a - Access rights in octal\n\
+ %b - Number of blocks allocated\n\
+ %C - Security context in SE-Linux\n\
+"), stdout);
+ fputs (_("\
+ %D - Device number in hex\n\
+ %d - Device number in decimal\n\
+ %F - File type\n\
+ %f - raw mode in hex\n\
+ %G - Group name of owner\n\
+ %g - Group ID of owner\n\
+"), stdout);
+ fputs (_("\
+ %h - Number of hard links\n\
+ %i - Inode number\n\
+ %N - Quoted File name with dereference if symbolic link\n\
+ %n - File name\n\
+ %o - IO block size\n\
+ %S - Security ID in SE-Linux\n\
+ %s - Total size, in bytes\n\
+ %T - Minor device type in hex\n\
+ %t - Major device type in hex\n\
+"), stdout);
+ fputs (_("\
+ %U - User name of owner\n\
+ %u - User ID of owner\n\
+ %X - Time of last access as seconds since Epoch\n\
+ %x - Time of last access\n\
+ %Y - Time of last modification as seconds since Epoch\n\
+ %y - Time of last modification\n\
+ %Z - Time of last change as seconds since Epoch\n\
+ %z - Time of last change\n\
+\n\
+"), stdout);
+
+ fputs (_("\
+Valid format sequences for file systems:\n\
+\n\
+ %a - Free blocks available to non-superuser\n\
+ %b - Total data blocks in file system\n\
+ %C - Security context in SE-Linux\n\
+ %c - Total file nodes in file system\n\
+ %d - Free file nodes in file system\n\
+ %f - Free blocks in file system\n\
+"), stdout);
+ fputs (_("\
+ %i - File System id in hex\n\
+ %l - Maximum length of filenames\n\
+ %n - File name\n\
+ %S - Security ID in SE-Linux\n\
+ %s - Optimal transfer block size\n\
+ %T - Type in human readable form\n\
+ %t - Type in hex\n\
+"), stdout);
puts (_("\nReport bugs to <bug-fileutils@gnu.org>."));
}
exit (status);
@@ -915,6 +908,9 @@ main (int argc, char *argv[])
usage (EXIT_FAILURE);
}
+ if (!is_flask_enabled ())
+ secure = 0;
+
for (i = optind; i < argc; i++)
{
if (fs == 0)