summaryrefslogtreecommitdiff
path: root/src/util.c
diff options
context:
space:
mode:
authorVito Caputo <vcaputo@gnugeneration.com>2017-01-18 19:12:41 -0800
committerGitHub <noreply@github.com>2017-01-18 19:12:41 -0800
commit467137113c8b3d6bcb73ecff8c76f23793f25cb7 (patch)
treeecf3064d6587ec875d5c021d46d44855dc814212 /src/util.c
parentee2073d4e411555aba878277131b56f7eb562c84 (diff)
parent404a356b2b22a134aea151145d1baabf253ee491 (diff)
Merge build system cleanups
- Move source to src/ subdir - Use $(top_srcdir)/src instead of ../../
Diffstat (limited to 'src/util.c')
-rw-r--r--src/util.c60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/util.c b/src/util.c
new file mode 100644
index 0000000..0e5825a
--- /dev/null
+++ b/src/util.c
@@ -0,0 +1,60 @@
+#include <limits.h>
+#include <stdio.h>
+#include <string.h>
+#include <unistd.h>
+
+#include "util.h"
+
+#define SYSFS_CPU "/sys/devices/system/cpu/cpu"
+#define MAXCPUS 1024
+
+unsigned get_ncpus(void)
+{
+ char path[cstrlen(SYSFS_CPU "1024") + 1];
+ unsigned n;
+
+ for (n = 0; n < MAXCPUS; n++) {
+ snprintf(path, sizeof(path), "%s%u", SYSFS_CPU, n);
+ if (access(path, F_OK) == -1)
+ break;
+ }
+
+ return n == 0 ? 1 : n;
+}
+
+
+static void query(const char *prompt, const char *def, char *buf, int len)
+{
+ buf[0] = '\0';
+
+ printf("%s [%s]: ", prompt, def);
+ fflush(stdout);
+
+ fgets(buf, len, stdin);
+ if (buf[0] == '\0' || buf[0] == '\n') {
+ snprintf(buf, len, "%s", def);
+ } else if(strchr(buf, '\n')) {
+ *strchr(buf, '\n') = '\0';
+ }
+}
+
+
+void ask_string(char *buf, int len, const char *prompt, const char *def)
+{
+ query(prompt, def, buf, len);
+}
+
+
+void ask_num(int *res, int max, const char *prompt, int def)
+{
+ char buf[21], buf2[256];
+ int num;
+
+ snprintf(buf, sizeof(buf), "%i", def);
+ do {
+ query(prompt, buf, buf2, sizeof(buf2));
+ num = atoi(buf2); /* TODO: errors (strtol)*/
+ } while (num > max);
+
+ *res = num;
+}
© All Rights Reserved