[hackers] [slstatus] swap.c: Refactor getstats() and its usage || Laslo Hunhold

From: <git_AT_suckless.org>
Date: Mon, 21 May 2018 23:06:24 +0200 (CEST)

commit 7f91ce265ea456b3096ccba7fdbb890bcf00e225
Author: Laslo Hunhold <dev_AT_frign.de>
AuthorDate: Mon May 21 23:03:34 2018 +0200
Commit: Aaron Marcher <me_AT_drkhsh.at>
CommitDate: Mon May 21 23:05:39 2018 +0200

    swap.c: Refactor getstats() and its usage
    
    Add a return value so we are able to check any errors and actually fail
    when there has been a critical error instead of carrying on uselessly.

diff --git a/components/swap.c b/components/swap.c
index c9bb920..37ee85c 100644
--- a/components/swap.c
+++ b/components/swap.c
_AT_@ -135,29 +135,27 @@
         #include <sys/types.h>
         #include <unistd.h>
 
- static void
+ static int
         getstats(int *total, int *used)
         {
                 struct swapent *sep, *fsep;
                 int rnswap, nswap, i;
 
- nswap = swapctl(SWAP_NSWAP, 0, 0);
- if (nswap < 1) {
+ if ((nswap = swapctl(SWAP_NSWAP, 0, 0)) < 1) {
                         warn("swaptctl 'SWAP_NSWAP':");
+ return 1;
                 }
-
- fsep = sep = calloc(nswap, sizeof(*sep));
- if (!sep) {
+ if (!(fsep = sep = calloc(nswap, sizeof(*sep)))) {
                         warn("calloc 'nswap':");
+ return 1;
                 }
-
- rnswap = swapctl(SWAP_STATS, (void *)sep, nswap);
- if (rnswap < 0) {
+ if ((rnswap = swapctl(SWAP_STATS, (void *)sep, nswap)) < 0) {
                         warn("swapctl 'SWAP_STATA':");
+ return 1;
                 }
-
                 if (nswap != rnswap) {
                         warn("getstats: SWAP_STATS != SWAP_NSWAP");
+ return 1;
                 }
 
                 *total = 0;
_AT_@ -169,6 +167,8 @@
                 }
 
                 free(fsep);
+
+ return 0;
         }
 
         const char *
_AT_@ -176,7 +176,9 @@
         {
                 int total, used;
 
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
 
                 return fmt_human((total - used) * 1024, 1024);
         }
_AT_@ -186,7 +188,9 @@
         {
                 int total, used;
 
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
 
                 if (total == 0) {
                         return NULL;
_AT_@ -200,7 +204,9 @@
         {
                 int total, used;
 
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
 
                 return fmt_human(total * 1024, 1024);
         }
_AT_@ -210,7 +216,9 @@
         {
                 int total, used;
 
- getstats(&total, &used);
+ if (getstats(&total, &used)) {
+ return NULL;
+ }
 
                 return fmt_human(used * 1024, 1024);
         }
Received on Mon May 21 2018 - 23:06:24 CEST

This archive was generated by hypermail 2.3.0 : Mon May 21 2018 - 23:12:24 CEST