tasty changes to the inventory command, which now has that name instead of just 'i'.
[feisty_meow.git] / scripts / files / summing_dir.pl
1 #!/usr/bin/perl
2
3 ###############################################################################
4 #                                                                             #
5 #  Name   : summing_dir                                                       #
6 #  Author : Chris Koeritz                                                     #
7 #  Rights : Copyright (C) 2000-$now by Author                                 #
8 #                                                                             #
9 #  Purpose:                                                                   #
10 #                                                                             #
11 #    Provides a somewhat stylized directory lister.                           #
12 #                                                                             #
13 ###############################################################################
14 #  This program is free software; you can redistribute it and/or modify it    #
15 #  under the terms of the GNU General Public License as published by the Free #
16 #  Software Foundation; either version 2 of the License or (at your option)   #
17 #  any later version.  See: "http://www.gruntose.com/Info/GNU/GPL.html" for a #
18 #  version of the License.  Please send any updates to "fred@gruntose.com".   #
19 ###############################################################################
20
21 require "filename_helper.pl";
22
23 use Env qw($TMP $color_add $TERM);
24
25 local($chewed_line) = "";
26 local(@arg_list);
27 local($print_list) = "";
28
29 # if there were no parameters, we make the default listing for the current
30 # directory.
31 if ($#ARGV < 0) {
32   $print_list = "Current Directory";
33   @arg_list = ( "." );
34 } else {
35   local(@munged_list) = &patch_name_for_pc(&remove_trailing_slashes(@ARGV));
36   $print_list = "@munged_list";
37   @arg_list = &glob_list(@ARGV);
38 }
39
40 foreach $dir (@arg_list) {
41   $chewed_line = $chewed_line . " \"$dir\"";
42 }
43
44 if ("$chewed_line" eq "") {
45   print "No files matched that path specification.\n";
46   exit 0;
47 }
48
49 # show the header, now that we know there's something to print.
50 print "[" . $print_list . "]\n\n";
51
52 ##print "chewed_line is: $chewed_line\n";
53
54 local($temp_file)=`mktemp "$TMP/zz_frdsumdir.XXXXXX"`;
55 chop($temp_file);
56
57 # drop the main payload, the list of directory info, but also save that
58 # info to a file for analysis.
59 system("ls -hlF $color_add $chewed_line");
60 system("ls -hlF $color_add $chewed_line > $temp_file");
61   # the color_add variable, if defined, will have flags for setting the
62   # directory listing color scheme.
63
64 ##print "file is: $temp_file\n";
65
66 local($lengths) = 0;
67
68 # open the file and process the lines to get file lengths.
69 open(DIRLIST, "<$temp_file");
70 # we only want to match ls -al style output lines, and only want to keep the size.
71 $pattern="^[^ ]+ +[^ ]+ +[^ ]+ +[^ ]+ +([0-9.]+[KMG]?).*\$";
72 foreach $file_line (<DIRLIST>) {
73   if ($file_line =~ /$pattern/) {
74     (local $munged = $file_line) =~ s/$pattern/\1/;
75     #print "munge=$munged\n";
76     if ($munged =~ /K$/) {
77       chop $munged;
78       $munged *= 1024.0;
79       #print "K munged is now $munged\n";
80     }
81     if ($munged =~ /M$/) {
82       chop $munged;
83       $munged *= 1024.0 * 1024.0;
84       #print "M munged is now $munged\n";
85     }
86     if ($munged =~ /G$/) {
87       chop $munged;
88       $munged *= 1024.0 * 1024.0 * 1024.0;
89       #print "G munged is now $munged\n";
90     }
91     $lengths += $munged;
92   }
93 }
94 close(DIRLIST);
95 unlink($temp_file);  # clean up.
96
97 #print "lens are: $lengths\n";
98
99 local($total)=int($lengths);
100 local($kbytes)=int($total / 102.4) / 10;
101 local($mbytes)=int($kbytes / 102.4) / 10;
102
103 print "\n";
104 print "These files occupy $total bytes ($kbytes KB / $mbytes MB).\n";
105 print "Overall Drive Usage (megs):\n";
106
107 system("df -m $chewed_line >$temp_file");
108
109 # now eat the file again, but this time to get drive space info.
110 open(DIRLIST, "<$temp_file");
111 local($space_info) = "";
112 local($did_title) = 0;  # true if we have printed the title by now.
113 foreach $file_line (<DIRLIST>) {
114   ($space_info = $file_line) =~ s/[^ ]* *([^ ]*) *([^ ]*) *([^ ]*) *([^ ]*) *.*$/\1     \2      \3      \4/;
115   if (!$did_title) {
116     # if the title hasn't been printed yet, we take some of the info out of
117     # the line and use it for the right sense of the last column.
118     print "Total        Used    Free    ";
119     $space_info =~ s/[^ ]*      *[^     ]*      *[^     ]*      *([^    ]*)/\1/;
120     print "$space_info";
121     $did_title = 1;
122   } else {
123   }
124 }
125 close(DIRLIST);
126 unlink($temp_file);  # clean up.
127
128 print "$space_info\n";
129
130 exit 0;
131