summaryrefslogtreecommitdiff
path: root/src/resolution.c
diff options
context:
space:
mode:
author諏訪子 <suwako@076.moe>2024-06-19 23:52:56 +0900
committer諏訪子 <suwako@076.moe>2024-06-19 23:52:56 +0900
commitb6e3f6cb5d1051777c35988f201e6730525e3389 (patch)
tree98679f1995f7b103f3314ce54fdf0d1c76df6dbd /src/resolution.c
parent8f378429801162d690dc68c0f15b483c1d291838 (diff)
掃除
Diffstat (limited to 'src/resolution.c')
-rw-r--r--src/resolution.c51
1 files changed, 6 insertions, 45 deletions
diff --git a/src/resolution.c b/src/resolution.c
index 1d9fde3..f089fd2 100644
--- a/src/resolution.c
+++ b/src/resolution.c
@@ -1,49 +1,10 @@
#include "resolution.h"
-
-#include <stdio.h>
-#include <string.h>
-#include <stdlib.h>
-#include <unistd.h>
-
-const char *run_res_command(const char *command) {
- char buf[128];
- char *out = NULL;
- size_t outsize = 0;
-
- FILE *p = popen(command, "r");
- if (!p) {
- fprintf(stderr, "解像度コマンドを実効に失敗: %s", command);
- return NULL;
- }
-
- while (fgets(buf, sizeof(buf), p) != NULL) {
- buf[strcspn(buf, "\n")] = '\0';
-
- size_t len = strlen(buf);
- char *nout = realloc(out, outsize + len + 1);
- if (nout == NULL) {
- perror("メモリの役割に失敗");
- free(out);
- pclose(p);
- return NULL;
- }
-
- out = nout;
-
- memccpy(out + outsize, buf, sizeof(buf), len);
- outsize += len;
- out[outsize] = '\0';
- }
-
- pclose(p);
-
- return out;
-}
+#include "common.h"
const char *display_resolution() {
- return run_res_command("xrandr --nograb --current | "
- "awk -F 'connected |\\\\+|\\\\(' '/ "
- "connected.*[0-9]+x[0-9]+\\+/ && $2 {printf $2 "
- "\", \"}' | sed 's/primary //' | "
- "sed 's/,\\([^,]*\\)$/\\1/'");
+ return run_command_s("xrandr --nograb --current | "
+ "awk -F 'connected |\\\\+|\\\\(' '/ "
+ "connected.*[0-9]+x[0-9]+\\+/ && $2 {printf $2 "
+ "\", \"}' | sed 's/primary //' | "
+ "sed 's/,\\([^,]*\\)$/\\1/'");
}