]> git.michaelhowe.org Git - packages/o/openafs.git/commitdiff
volinfo: show header filenames even if error
authorMichael Meffie <mmeffie@sinenomine.net>
Wed, 11 Apr 2012 19:34:29 +0000 (15:34 -0400)
committerStephan Wiesand <stephan.wiesand@desy.de>
Wed, 13 Aug 2014 18:35:54 +0000 (14:35 -0400)
When invoked with -header option, print the header inode
number, and namei filename, even if the header file cannot
be opened.

Reviewed-on: http://gerrit.openafs.org/7190
Tested-by: BuildBot <buildbot@rampaginggeek.com>
Reviewed-by: Tom Keiser <tkeiser@sinenomine.net>
Reviewed-by: Derrick Brashear <shadow@dementix.org>
(cherry picked from commit b71f4ffa7c58ef7b27eb6e28d00892906aec49ec)

Change-Id: Ibd68433ea778d5359c873e3764800d60fa7ae95d
Reviewed-on: http://gerrit.openafs.org/11274
Reviewed-by: Chas Williams - CONTRACTOR <chas@cmf.nrl.navy.mil>
Reviewed-by: Andrew Deason <adeason@sinenomine.net>
Tested-by: BuildBot <buildbot@rampaginggeek.com>
Reviewed-by: Stephan Wiesand <stephan.wiesand@desy.de>
src/vol/vol-info.c

index 7a6d26b45d7da7ab790d44fa4b1ead02fe1e7c46..b46980bcb581e9081e7813900737417d88e31dfc 100644 (file)
@@ -1200,7 +1200,7 @@ HandleSpecialFile(const char *name, struct DiskPartition64 *dp,
                  struct VolumeHeader *header, Inode inode,
                  afs_sfsize_t * psize)
 {
-    afs_sfsize_t size = 0;
+    afs_sfsize_t size = -1;
     IHandle_t *ih = NULL;
     FdHandle_t *fdP = NULL;
 #ifdef AFS_NAMEI_ENV
@@ -1211,7 +1211,7 @@ HandleSpecialFile(const char *name, struct DiskPartition64 *dp,
     fdP = IH_OPEN(ih);
     if (fdP == NULL) {
        fprintf(stderr,
-               "%s: Error opening header file '%s' for volume %u", progname,
+               "%s: Error opening header file '%s' for volume %u\n", progname,
                name, header->id);
        perror("open");
        goto error;
@@ -1219,22 +1219,27 @@ HandleSpecialFile(const char *name, struct DiskPartition64 *dp,
     size = FDH_SIZE(fdP);
     if (size == -1) {
        fprintf(stderr,
-               "%s: Error getting size of header file '%s' for volume %u",
+               "%s: Error getting size of header file '%s' for volume %u\n",
                progname, name, header->id);
        perror("fstat");
        goto error;
     }
+    *psize += size;
+
+  error:
     if (DumpInfo) {
-       printf("\t%s inode\t= %s (size = %lld)\n",
-              name, PrintInode(NULL, inode), size);
+       printf("\t%s inode\t= %s (size = ", name, PrintInode(NULL, inode));
+       if (size != -1) {
+           printf("%lld)\n", size);
+       } else {
+           printf("unknown)\n");
+       }
 #ifdef AFS_NAMEI_ENV
        namei_HandleToName(&filename, ih);
        printf("\t%s namei\t= %s\n", name, filename.n_path);
 #endif /* AFS_NAMEI_ENV */
     }
-    *psize += size;
 
-  error:
     if (fdP != NULL) {
        FDH_REALLYCLOSE(fdP);
     }