[hackers] [slstatus] components/swap.c | move duplicated code to separate function || Laslo Hunhold

From: <git_AT_suckless.org>
Date: Tue, 1 May 2018 20:24:51 +0200 (CEST)

commit 19343ff34385db441b5efc2e1a57cdd7fd95ec26
Author: Laslo Hunhold <dev_AT_frign.de>
AuthorDate: Tue May 1 20:20:58 2018 +0200
Commit: Aaron Marcher <me_AT_drkhsh.at>
CommitDate: Tue May 1 20:24:13 2018 +0200

    components/swap.c | move duplicated code to separate function

diff --git a/components/swap.c b/components/swap.c
index 08a97de..fe779db 100644
--- a/components/swap.c
+++ b/components/swap.c
_AT_@ -6,30 +6,40 @@
 
         #include "../util.h"
 
- const char *
- swap_free(void)
+ static size_t
+ pread(const char *path, char *buf, size_t bufsiz)
         {
- long total, free;
                 FILE *fp;
                 size_t bytes_read;
- char *match;
 
- fp = fopen("/proc/meminfo", "r");
- if (fp == NULL) {
- fprintf(stderr, "fopen '/proc/meminfo': %s\n",
+ if (!(fp = fopen(path, "r"))) {
+ fprintf(stderr, "fopen '%s': %s\n", path,
                                 strerror(errno));
- return NULL;
+ return 0;
                 }
-
- if ((bytes_read = fread(buf, sizeof(char), sizeof(buf) - 1,
- fp)) == 0) {
- fprintf(stderr, "fread '/proc/meminfo': %s\n",
+ if ((bytes_read = fread(buf, sizeof(char), bufsiz, fp)) == 0) {
+ fprintf(stderr, "fread '%s': %s\n", path,
                                 strerror(errno));
                         fclose(fp);
- return NULL;
+ return 0;
                 }
                 fclose(fp);
 
+ buf[bytes_read] = '\0';
+
+ return bytes_read;
+ }
+
+ const char *
+ swap_free(void)
+ {
+ long total, free;
+ char *match;
+
+ if (!pread("/proc/meminfo", buf, sizeof(buf) - 1)) {
+ return NULL;
+ }
+
                 if ((match = strstr(buf, "SwapTotal")) == NULL)
                         return NULL;
                 sscanf(match, "SwapTotal: %ld kB\n", &total);
_AT_@ -45,25 +55,11 @@
         swap_perc(void)
         {
                 long total, free, cached;
- FILE *fp;
- size_t bytes_read;
                 char *match;
 
- fp = fopen("/proc/meminfo", "r");
- if (fp == NULL) {
- fprintf(stderr, "fopen '/proc/meminfo': %s\n",
- strerror(errno));
- return NULL;
- }
-
- if ((bytes_read = fread(buf, sizeof(char), sizeof(buf) - 1,
- fp)) == 0) {
- fprintf(stderr, "fread '/proc/meminfo': %s\n",
- strerror(errno));
- fclose(fp);
+ if (!pread("/proc/meminfo", buf, sizeof(buf) - 1)) {
                         return NULL;
                 }
- fclose(fp);
 
                 if ((match = strstr(buf, "SwapTotal")) == NULL)
                         return NULL;
_AT_@ -84,24 +80,11 @@
         swap_total(void)
         {
                 long total;
- FILE *fp;
- size_t bytes_read;
                 char *match;
 
- fp = fopen("/proc/meminfo", "r");
- if (fp == NULL) {
- fprintf(stderr, "fopen '/proc/meminfo': %s\n",
- strerror(errno));
- return NULL;
- }
- if ((bytes_read = fread(buf, sizeof(char), sizeof(buf) - 1,
- fp)) == 0) {
- fprintf(stderr, "fread '/proc/meminfo': %s\n",
- strerror(errno));
- fclose(fp);
+ if (!pread("/proc/meminfo", buf, sizeof(buf) - 1)) {
                         return NULL;
                 }
- fclose(fp);
 
                 if ((match = strstr(buf, "SwapTotal")) == NULL)
                         return NULL;
_AT_@ -114,24 +97,11 @@
         swap_used(void)
         {
                 long total, free, cached;
- FILE *fp;
- size_t bytes_read;
                 char *match;
 
- fp = fopen("/proc/meminfo", "r");
- if (fp == NULL) {
- fprintf(stderr, "fopen '/proc/meminfo': %s\n",
- strerror(errno));
+ if (!pread("/proc/meminfo", buf, sizeof(buf) - 1)) {
                         return NULL;
                 }
- if ((bytes_read = fread(buf, sizeof(char), sizeof(buf) - 1,
- fp)) == 0) {
- fprintf(stderr, "fread '/proc/meminfo': %s\n",
- strerror(errno));
- fclose(fp);
- return NULL;
- }
- fclose(fp);
 
                 if ((match = strstr(buf, "SwapTotal")) == NULL)
                         return NULL;
Received on Tue May 01 2018 - 20:24:51 CEST

This archive was generated by hypermail 2.3.0 : Tue May 01 2018 - 20:36:32 CEST