From 986d0d6002f90a8737f5037b7423e1ac8fba98f2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=AB=8F=E8=A8=AA=E5=AD=90?= Date: Fri, 21 Jun 2024 22:35:41 +0900 Subject: =?UTF-8?q?=E3=81=94=E3=82=81=E3=82=93?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/storage.c | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) (limited to 'src/storage.c') diff --git a/src/storage.c b/src/storage.c index 5471a62..976c810 100644 --- a/src/storage.c +++ b/src/storage.c @@ -5,16 +5,20 @@ const char *display_storage() { const char *iszfs = run_command_s("LC_ALL=C zpool list 2>&1"); - if (!strstr(iszfs, "command not found: zpool")) { + if ( + strncmp( + iszfs, + "sh: command not found: zpool", + strlen("sh: command not found: zpool") + ) != 0 || + strncmp(iszfs, "sh: zpool: not found", strlen("sh: zpool: not found") + ) == 0) { + return run_command_s("df -h | " + "awk '/^\\/dev\\// {printf \"%s: %s / %s, \", $1, $3, $2}' | " + "awk '{sub(/, $/, \"\"); print}'"); + } + return run_command_s("zpool list | " "awk 'NR>1 {printf \"%s: %s / %s, \", $1, $3, $2}' | " "awk '{sub(/, $/, \"\"); print}'"); - } - - return run_command_s("df -h | " - "awk '/^\\/dev\\// {printf \"%s: %s / %s, \", $1, $3, $2}' | " - "awk '{sub(/, $/, \"\"); print}'"); - - return run_command_s("df -h | awk 'NR>1 {print $1 \": \" $3 \" / \" $2}' | " - "sed ':a;N;$!ba;s/\\n/, /g'"); } -- cgit v1.2.3