summaryrefslogtreecommitdiff
path: root/sysutils/p5-Filesys-DiskSpace/files/patch-lib_Filesys_DiskSpace.pm
blob: c2eda50b4b1248de24fe329123389b0468904adb (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
--- lib/Filesys/DiskSpace.pm.orig	1999-09-05 22:41:22 UTC
+++ lib/Filesys/DiskSpace.pm
@@ -44,7 +44,7 @@ my %fs_type = (
 sub df ($) {
   my $dir = shift;
 
-  my ($fmt, $res, $type, $flags, $osvers, $w);
+  my ($fmt, $res, $type, $typestr, $flags, $osvers, $w);
 
   # struct fields for statfs or statvfs....
   my ($bsize, $frsize, $blocks, $bfree, $bavail, $files, $ffree, $favail);
@@ -53,7 +53,8 @@ sub df ($) {
   Carp::croak "Error: $dir is not a directory" unless -d $dir;
 
   # try with statvfs..
-  eval {  # will work for Solaris 2.*, OSF1 v3.2, OSF1 v4.0 and HP-UX 10.*.
+  ($^O ne 'freebsd' &&
+   eval {  # will work for Solaris 2.*, OSF1 v3.2, OSF1 v4.0 and HP-UX 10.*.
     {
       package main;
       require "sys/syscall.ph";
@@ -78,7 +79,7 @@ sub df ($) {
     $bsize = $frsize;
     # $blocks -= $bfree - $bavail;
     $res == 0 && defined $fs_type{$type};
-  }
+  })
   # try with statfs..
   || eval { # will work for SunOS 4, Linux 2.0.* and 2.2.*
     {
@@ -90,11 +91,37 @@ sub df ($) {
     # statfs...
 
     if ($^O eq 'freebsd') {
-      # only tested with FreeBSD 3.0. Should also work with 4.0.
-      my ($f1, $f2);
-      ($f1, $bsize, $f2, $blocks, $bfree, $bavail, $files, $ffree) =
-	unpack "L8", $fmt;
-      $type = 0; # read it from 'f_type' field ?
+      $type = 0;
+      {
+        package main;
+        require "sys/param.ph";
+        require "sys/mount.ph";
+      }
+      my $STATFS_VERSION;
+      if (defined(&main::STATFS_VERSION)) {
+        $STATFS_VERSION = &main::STATFS_VERSION;
+      }
+      if (defined($STATFS_VERSION)) {
+        my ($version, $f1);
+        my $crap =
+           "Q4" .   # f_syncwrites, f_asyncwrites, f_syncreads, f_asyncreads
+           "Q10" .  # f_spare[10]
+           "Lll2" . # f_namemax, f_owner, f_fsid
+           "c80";    # MFSNAMELEN
+        my $MFSNAMELEN = &main::MFSNAMELEN;
+        ($version, $f1, $flags, $bsize, $frsize, $blocks,
+         $bfree, $bavail, $files, $ffree, $typestr) =
+          unpack "L2Q5qQqx[$crap]Z$MFSNAMELEN", $fmt;
+        if ($STATFS_VERSION != 0x20030518) {
+          warn "Unknown STATFS_VERSION ($STATFS_VERSION) results may be bad.\n";
+        }
+      }
+      else {
+        # only tested with FreeBSD 3.0. Should also work with 4.0.
+        my ($f1, $f2);
+        ($f1, $bsize, $f2, $blocks, $bfree, $bavail, $files, $ffree) =
+         unpack "L8", $fmt;
+      }
     }
     else {
       ($type, $bsize, $blocks, $bfree, $bavail, $files, $ffree) =
@@ -108,7 +135,7 @@ sub df ($) {
     # files:  total file nodes in file system
     # ffree:  free file nodes in fs
 
-    $res == 0 && defined $fs_type{$type};
+    $res == 0 && (defined $typestr || defined $fs_type{$type});
   }
   || eval {
     {
@@ -170,7 +197,7 @@ sub df ($) {
   }
 
   warn "Warning : type $fs_type{$type} untested.. results may be incorrect\n"
-    unless $type != 2560  && defined $fs_type{$type};
+    unless defined($typestr) || ($type != 2560  && defined $fs_type{$type});
 
   if ($DEBUG) {
     warn "Fs type : [$type] $fs_type{$type}\n" .
@@ -185,7 +212,8 @@ sub df ($) {
     }
   }
 
-  ($type, $fs_type{$type}, ($blocks - $bavail) * $bsize / 1024,
+  ($type, (defined($typestr) ? $typestr : $fs_type{$type}),
+   ($blocks - $bavail) * $bsize / 1024,
    $bavail * $bsize / 1024, $files - $ffree, $ffree);
 }