Cosmetics.
authorFrancois Fleuret <francois@fleuret.org>
Wed, 17 Mar 2010 07:13:23 +0000 (08:13 +0100)
committerFrancois Fleuret <francois@fleuret.org>
Wed, 17 Mar 2010 07:13:23 +0000 (08:13 +0100)
dus.c

diff --git a/dus.c b/dus.c
index 083f96e..620df1e 100644 (file)
--- a/dus.c
+++ b/dus.c
@@ -89,7 +89,7 @@ int ignore_entry(const char *name) {
 }
 
 void print_size_sum(size_sum_t s) {
-  char tmp[100];
+  char tmp[128];
   char *a = tmp + sizeof(tmp)/sizeof(char);
   *(--a) = '\0';
   if(s) {
@@ -103,7 +103,7 @@ void print_size_sum(size_sum_t s) {
   printf("%s", a);
 }
 
-size_sum_t file_or_dir_size(const char *name) {
+size_sum_t entry_size(const char *name) {
   DIR *dir;
   struct dirent *dir_e;
   struct stat dummy;
@@ -127,7 +127,7 @@ size_sum_t file_or_dir_size(const char *name) {
     while((dir_e = readdir(dir))) {
       if(!ignore_entry(dir_e->d_name)) {
         snprintf(subname, PATH_MAX, "%s/%s", name, dir_e->d_name);
-        result += file_or_dir_size(subname);
+        result += entry_size(subname);
       }
     }
     closedir(dir);
@@ -167,26 +167,26 @@ size_sum_t atoss(const char *string) {
 
 /**********************************************************************/
 
-struct file_with_size {
-  char *filename;
+struct entry_node {
+  struct entry_node *next;
+  char *name;
   size_sum_t size;
-  struct file_with_size *next;
 };
 
-struct file_with_size *create(char *name, struct file_with_size *current) {
-  struct file_with_size *result;
-  result = safe_malloc(sizeof(struct file_with_size));
-  result->filename = strdup(name);
-  result->size = file_or_dir_size(name);
-  result->next = current;
+struct entry_node *push_entry(char *name, struct entry_node *head) {
+  struct entry_node *result;
+  result = safe_malloc(sizeof(struct entry_node));
+  result->name = strdup(name);
+  result->size = entry_size(name);
+  result->next = head;
   return result;
 }
 
-void destroy(struct file_with_size *node) {
-  struct file_with_size *next;
+void destroy_entry_list(struct entry_node *node) {
+  struct entry_node *next;
   while(node) {
     next = node->next;
-    free(node->filename);
+    free(node->name);
     free(node);
     node = next;
   }
@@ -195,10 +195,10 @@ void destroy(struct file_with_size *node) {
 /**********************************************************************/
 
 int compare_files(const void *x1, const void *x2) {
-  const struct file_with_size **f1, **f2;
+  const struct entry_node **f1, **f2;
 
-  f1 = (const struct file_with_size **) x1;
-  f2 = (const struct file_with_size **) x2;
+  f1 = (const struct entry_node **) x1;
+  f2 = (const struct entry_node **) x2;
 
   if(reverse_sorting) {
     if((*f1)->size < (*f2)->size) {
@@ -269,10 +269,10 @@ void fancy_print(char *buffer, char *filename, size_sum_t size) {
   }
 }
 
-void print_sorted(struct file_with_size *root, int width, int height) {
+void print_sorted(struct entry_node *root, int width, int height) {
   char line[BUFFER_SIZE];
-  struct file_with_size *node;
-  struct file_with_size **nodes;
+  struct entry_node *node;
+  struct entry_node **nodes;
   int nb_nodes, n, first, last;
 
   nb_nodes = 0;
@@ -282,7 +282,7 @@ void print_sorted(struct file_with_size *root, int width, int height) {
     }
   }
 
-  nodes = safe_malloc(nb_nodes * sizeof(struct file_with_size *));
+  nodes = safe_malloc(nb_nodes * sizeof(struct entry_node *));
 
   n = 0;
   for(node = root; node; node = node->next) {
@@ -291,7 +291,7 @@ void print_sorted(struct file_with_size *root, int width, int height) {
     }
   }
 
-  qsort(nodes, nb_nodes, sizeof(struct file_with_size *), compare_files);
+  qsort(nodes, nb_nodes, sizeof(struct entry_node *), compare_files);
 
   first = 0;
   last = nb_nodes;
@@ -316,9 +316,9 @@ void print_sorted(struct file_with_size *root, int width, int height) {
 
   for(n = first; n < last; n++) {
     if(fancy_size_display) {
-      fancy_print(line, nodes[n]->filename, nodes[n]->size);
+      fancy_print(line, nodes[n]->name, nodes[n]->size);
     } else {
-      raw_print(line, nodes[n]->filename, nodes[n]->size);
+      raw_print(line, nodes[n]->name, nodes[n]->size);
     }
     if(width >= 0 && width < BUFFER_SIZE) {
       line[width] = '\0';
@@ -335,7 +335,7 @@ void print_sorted(struct file_with_size *root, int width, int height) {
 
 /**********************************************************************/
 
-void print_help(FILE *out) {
+void usage(FILE *out) {
   fprintf(out, "Usage: dus [OPTION]... [FILE]...\n");
   fprintf(out, "Version %s (%s)\n", VERSION_NUMBER, UNAME);
   fprintf(out, "List files and directories sorted according to their size or content size. Take the content of the current directory as argument if none is provided.\n");
@@ -365,34 +365,29 @@ void print_help(FILE *out) {
 
 /**********************************************************************/
 
+static struct option long_options[] = {
+  { "ignore-dots", no_argument, 0, 'd' },
+  { "reverse-order", no_argument, 0, 'r' },
+  { "show-top", no_argument, 0, 't' },
+  { "help", no_argument, 0, 'h' },
+  { "fancy", no_argument, 0, 'f' },
+  { "nb-columns", 1, 0, 'c' },
+  { "nb-lines", 1, 0, 'l' },
+  { "size-min", 1, 0, 'm' },
+  { 0, 0, 0, 0 }
+};
+
 int main(int argc, char **argv) {
   int c;
-  struct file_with_size *root;
+  struct entry_node *root;
   struct winsize win;
 
   root = 0;
 
   setlocale (LC_ALL, "");
 
-  while (1) {
-    int option_index = 0;
-    static struct option long_options[] = {
-      { "ignore-dots", no_argument, 0, 'd' },
-      { "reverse-order", no_argument, 0, 'r' },
-      { "show-top", no_argument, 0, 't' },
-      { "help", no_argument, 0, 'h' },
-      { "fancy", no_argument, 0, 'f' },
-      { "nb-columns", 1, 0, 'c' },
-      { "nb-lines", 1, 0, 'l' },
-      { "size-min", 1, 0, 'm' },
-      { 0, 0, 0, 0 }
-    };
-
-    c = getopt_long(argc, argv, "dfrtl:c:m:hd",
-                    long_options, &option_index);
-    if (c == -1)
-      break;
-
+  while ((c = getopt_long(argc, argv, "dfrtl:c:m:hd",
+                          long_options, NULL)) != -1) {
     switch (c) {
 
     case 'd':
@@ -424,20 +419,20 @@ int main(int argc, char **argv) {
       break;
 
     case 'h':
-      print_help(stdout);
+      usage(stdout);
       exit(EXIT_SUCCESS);
 
       break;
 
     default:
-      print_help(stderr);
+      usage(stderr);
       exit(EXIT_FAILURE);
     }
   }
 
   if (optind < argc) {
     while (optind < argc) {
-      root = create(argv[optind++], root);
+      root = push_entry(argv[optind++], root);
     }
   } else {
     DIR *dir;
@@ -446,7 +441,7 @@ int main(int argc, char **argv) {
     if(dir) {
       while((dir_e = readdir(dir))) {
         if(!ignore_entry(dir_e->d_name)) {
-          root = create(dir_e->d_name, root);
+          root = push_entry(dir_e->d_name, root);
         }
       }
       closedir(dir);
@@ -463,7 +458,7 @@ int main(int argc, char **argv) {
     print_sorted(root, -1, -1);
   }
 
-  destroy(root);
+  destroy_entry_list(root);
 
   exit(EXIT_SUCCESS);
 }