summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--getconf.c268
1 files changed, 268 insertions, 0 deletions
diff --git a/getconf.c b/getconf.c
new file mode 100644
index 0000000..edaf11e
--- /dev/null
+++ b/getconf.c
@@ -0,0 +1,268 @@
+/*
+ * UNG's Not GNU
+ *
+ * Copyright (c) 2011-2017, Jakob Kaivo <jkk@ung.org>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ *
+ */
+
+#define _XOPEN_SOURCE 700
+#include <limits.h>
+#include <stdio.h>
+#include <string.h>
+#include <unistd.h>
+
+static struct namelist {
+ const char *name;
+ int num;
+} pathnames[] = {
+ { "FILESIZEBITS", _PC_FILESIZEBITS },
+ { "LINK_MAX", _PC_LINK_MAX },
+ { "MAX_CANON", _PC_MAX_CANON },
+ { "MAX_INPUT", _PC_MAX_INPUT },
+ { "NAME_MAX", _PC_NAME_MAX },
+ { "PATH_MAX", _PC_PATH_MAX },
+ { "PIPE_BUF", _PC_PIPE_BUF },
+ { "POSIX2_SYMLINKS", _PC_2_SYMLINKS },
+ { "POSIX_ALLOC_SIZE_MIN", _PC_ALLOC_SIZE_MIN },
+ { "POSIX_REC_INCR_XFER_SIZE", _PC_REC_INCR_XFER_SIZE },
+ { "POSIX_REC_MAX_XFER_SIZE", _PC_REC_MAX_XFER_SIZE },
+ { "POSIX_REC_MIN_XFER_SIZE", _PC_REC_MIN_XFER_SIZE },
+ { "POSIX_REC_XFER_ALIGN", _PC_REC_XFER_ALIGN },
+ { "SYMLINK_MAX", _PC_SYMLINK_MAX },
+ { "_POSIX_CHOWN_RESTRICTED", _PC_CHOWN_RESTRICTED },
+ { "_POSIX_NO_TRUNC", _PC_NO_TRUNC },
+ { "_POSIX_VDISABLE", _PC_VDISABLE },
+ { "_POSIX_ASYNC_IO", _PC_ASYNC_IO },
+ { "_POSIX_PRIO_IO", _PC_PRIO_IO },
+ { "_POSIX_SYNC_IO", _PC_SYNC_IO },
+ /* { "_POSIX_TIMESTAMP_RESOLUTION", _PC_TIMESTAMP_RESOLUTION }, */ /* FIXME: just because glibc is broken... */
+ { 0, 0 },
+}, sysnames[] = {
+ { "AIO_LISTIO_MAX", _SC_AIO_LISTIO_MAX },
+ { "AIO_MAX", _SC_AIO_MAX },
+ { "AIO_PRIO_DELTA_MAX", _SC_AIO_PRIO_DELTA_MAX },
+ { "ARG_MAX", _SC_ARG_MAX },
+ { "ATEXIT_MAX", _SC_ATEXIT_MAX },
+ { "BC_BASE_MAX", _SC_BC_BASE_MAX },
+ { "BC_DIM_MAX", _SC_BC_DIM_MAX },
+ { "BC_SCALE_MAX", _SC_BC_SCALE_MAX },
+ { "BC_STRING_MAX", _SC_BC_STRING_MAX },
+ { "CHILD_MAX", _SC_CHILD_MAX },
+ { "COLL_WEIGHTS_MAX", _SC_COLL_WEIGHTS_MAX },
+ { "DELAYTIMER_MAX", _SC_DELAYTIMER_MAX },
+ { "EXPR_NEST_MAX", _SC_EXPR_NEST_MAX },
+ { "HOST_NAME_MAX", _SC_HOST_NAME_MAX },
+ { "IOV_MAX", _SC_IOV_MAX },
+ { "LINE_MAX", _SC_LINE_MAX },
+ { "LOGIN_NAME_MAX", _SC_LOGIN_NAME_MAX },
+ { "NGROUPS_MAX", _SC_NGROUPS_MAX },
+ { "MQ_OPEN_MAX", _SC_MQ_OPEN_MAX },
+ { "MQ_PRIO_MAX", _SC_MQ_PRIO_MAX },
+ { "OPEN_MAX", _SC_OPEN_MAX },
+ { "_POSIX_ADVISORY_INFO", _SC_ADVISORY_INFO },
+ { "_POSIX_BARRIERS", _SC_BARRIERS },
+ { "_POSIX_ASYNCHRONOUS_IO", _SC_ASYNCHRONOUS_IO },
+ { "_POSIX_CLOCK_SELECTION", _SC_CLOCK_SELECTION },
+ { "_POSIX_CPUTIME", _SC_CPUTIME },
+ { "_POSIX_FSYNC", _SC_FSYNC },
+ { "_POSIX_IPV6", _SC_IPV6 },
+ { "_POSIX_JOB_CONTROL", _SC_JOB_CONTROL },
+ { "_POSIX_MAPPED_FILES", _SC_MAPPED_FILES },
+ { "_POSIX_MEMLOCK", _SC_MEMLOCK },
+ { "_POSIX_MEMLOCK_RANGE", _SC_MEMLOCK_RANGE },
+ { "_POSIX_MEMORY_PROTECTION", _SC_MEMORY_PROTECTION },
+ { "_POSIX_MESSAGE_PASSING", _SC_MESSAGE_PASSING },
+ { "_POSIX_MONOTONIC_CLOCK", _SC_MONOTONIC_CLOCK },
+ { "_POSIX_PRIORITIZED_IO", _SC_PRIORITIZED_IO },
+ { "_POSIX_PRIORITY_SCHEDULING", _SC_PRIORITY_SCHEDULING },
+ { "_POSIX_RAW_SOCKETS", _SC_RAW_SOCKETS },
+ { "_POSIX_READER_WRITER_LOCKS", _SC_READER_WRITER_LOCKS },
+ { "_POSIX_REALTIME_SIGNALS", _SC_REALTIME_SIGNALS },
+ { "_POSIX_REGEXP", _SC_REGEXP },
+ { "_POSIX_SAVED_IDS", _SC_SAVED_IDS },
+ { "_POSIX_SEMAPHORES", _SC_SEMAPHORES },
+ { "_POSIX_SHARED_MEMORY_OBJECTS", _SC_SHARED_MEMORY_OBJECTS },
+ { "_POSIX_SHELL", _SC_SHELL },
+ { "_POSIX_SPAWN", _SC_SPAWN },
+ { "_POSIX_SPIN_LOCKS", _SC_SPIN_LOCKS },
+ { "_POSIX_SPORADIC_SERVER", _SC_SPORADIC_SERVER },
+ { "_POSIX_SS_REPL_MAX", _SC_SS_REPL_MAX },
+ { "_POSIX_SYNCHRONIZED_IO", _SC_SYNCHRONIZED_IO },
+ { "_POSIX_THREAD_ATTR_STACKADDR", _SC_THREAD_ATTR_STACKADDR },
+ { "_POSIX_THREAD_ATTR_STACKSIZE", _SC_THREAD_ATTR_STACKSIZE },
+ { "_POSIX_THREAD_CPUTIME", _SC_THREAD_CPUTIME },
+ { "_POSIX_THREAD_PRIO_INHERIT", _SC_THREAD_PRIO_INHERIT },
+ { "_POSIX_THREAD_PRIO_PROTECT", _SC_THREAD_PRIO_PROTECT },
+ { "_POSIX_THREAD_PRIORITY_SCHEDULING", _SC_THREAD_PRIORITY_SCHEDULING },
+ { "_POSIX_THREAD_PROCESS_SHARED", _SC_THREAD_PROCESS_SHARED },
+ { "_POSIX_THREAD_ROBUST_PRIO_INHERIT", _SC_THREAD_ROBUST_PRIO_INHERIT },
+ { "_POSIX_THREAD_ROBUST_PRIO_PROTECT", _SC_THREAD_ROBUST_PRIO_PROTECT },
+ { "_POSIX_THREAD_SAFE_FUNCTIONS", _SC_THREAD_SAFE_FUNCTIONS },
+ { "_POSIX_THREAD_SPORADIC_SERVER", _SC_THREAD_SPORADIC_SERVER },
+ { "_POSIX_THREADS", _SC_THREADS },
+ { "_POSIX_TIMEOUTS", _SC_TIMEOUTS },
+ { "_POSIX_TIMERS", _SC_TIMERS },
+ { "_POSIX_TRACE", _SC_TRACE },
+ { "_POSIX_TRACE_EVENT_FILTER", _SC_TRACE_EVENT_FILTER },
+ { "_POSIX_TRACE_EVENT_NAME_MAX", _SC_TRACE_EVENT_NAME_MAX },
+ { "_POSIX_TRACE_INHERIT", _SC_TRACE_INHERIT },
+ { "_POSIX_TRACE_LOG", _SC_TRACE_LOG },
+ { "_POSIX_TRACE_NAME_MAX", _SC_TRACE_NAME_MAX },
+ { "_POSIX_TRACE_SYS_MAX", _SC_TRACE_SYS_MAX },
+ { "_POSIX_TRACE_USER_EVENT_MAX", _SC_TRACE_USER_EVENT_MAX },
+ { "_POSIX_TYPED_MEMORY_OBJECTS", _SC_TYPED_MEMORY_OBJECTS },
+ { "_POSIX_VERSION", _SC_VERSION },
+ { "_POSIX_V7_ILP32_OFF32", _SC_V7_ILP32_OFF32 },
+ { "_POSIX_V7_ILP32_OFFBIG", _SC_V7_ILP32_OFFBIG },
+ { "_POSIX_V7_LP64_OFF64", _SC_V7_LP64_OFF64 },
+ { "_POSIX_V7_LPBIG_OFFBIG", _SC_V7_LPBIG_OFFBIG },
+ { "_POSIX_V6_ILP32_OFF32", _SC_V6_ILP32_OFF32 },
+ { "_POSIX_V6_ILP32_OFFBIG", _SC_V6_ILP32_OFFBIG },
+ { "_POSIX_V6_LP64_OFF64", _SC_V6_LP64_OFF64 },
+ { "_POSIX_V6_LPBIG_OFFBIG", _SC_V6_LPBIG_OFFBIG },
+ { "_POSIX2_C_BIND", _SC_2_C_BIND },
+ { "_POSIX2_C_DEV", _SC_2_C_DEV },
+ { "_POSIX2_CHAR_TERM", _SC_2_CHAR_TERM },
+ { "_POSIX2_FORT_DEV", _SC_2_FORT_DEV },
+ { "_POSIX2_FORT_RUN", _SC_2_FORT_RUN },
+ { "_POSIX2_LOCALEDEF", _SC_2_LOCALEDEF },
+ { "_POSIX2_PBS", _SC_2_PBS },
+ { "_POSIX2_PBS_ACCOUNTING", _SC_2_PBS_ACCOUNTING },
+ { "_POSIX2_PBS_CHECKPOINT", _SC_2_PBS_CHECKPOINT },
+ { "_POSIX2_PBS_LOCATE", _SC_2_PBS_LOCATE },
+ { "_POSIX2_PBS_MESSAGE", _SC_2_PBS_MESSAGE },
+ { "_POSIX2_PBS_TRACK", _SC_2_PBS_TRACK },
+ { "_POSIX2_SW_DEV", _SC_2_SW_DEV },
+ { "_POSIX2_UPE", _SC_2_UPE },
+ { "_POSIX2_VERSION", _SC_2_VERSION },
+ { "PAGE_SIZE", _SC_PAGE_SIZE },
+ { "PAGESIZE", _SC_PAGESIZE },
+ { "PTHREAD_DESTRUCTOR_ITERATIONS", _SC_THREAD_DESTRUCTOR_ITERATIONS },
+ { "PTHREAD_KEYS_MAX", _SC_THREAD_KEYS_MAX },
+ { "PTHREAD_STACK_MIN", _SC_THREAD_STACK_MIN },
+ { "PTHREAD_THREADS_MAX", _SC_THREAD_THREADS_MAX },
+ { "RE_DUP_MAX", _SC_RE_DUP_MAX },
+ { "RTSIG_MAX", _SC_RTSIG_MAX },
+ { "SEM_NSEMS_MAX", _SC_SEM_NSEMS_MAX },
+ { "SEM_VALUE_MAX", _SC_SEM_VALUE_MAX },
+ { "SIGQUEUE_MAX", _SC_SIGQUEUE_MAX },
+ { "STREAM_MAX", _SC_STREAM_MAX },
+ { "SYMLOOP_MAX", _SC_SYMLOOP_MAX },
+ { "TIMER_MAX", _SC_TIMER_MAX },
+ { "TTY_NAME_MAX", _SC_TTY_NAME_MAX },
+ { "TZNAME_MAX", _SC_TZNAME_MAX },
+ { "_XOPEN_CRYPT", _SC_XOPEN_CRYPT },
+ { "_XOPEN_ENH_I18N", _SC_XOPEN_ENH_I18N },
+ { "_XOPEN_REALTIME", _SC_XOPEN_REALTIME },
+ { "_XOPEN_REALTIME_THREADS", _SC_XOPEN_REALTIME_THREADS },
+ { "_XOPEN_SHM", _SC_XOPEN_SHM },
+ { "_XOPEN_STREAMS", _SC_XOPEN_STREAMS },
+ { "_XOPEN_UNIX", _SC_XOPEN_UNIX },
+ /* { "_XOPEN_UUCP", _SC_XOPEN_UUCP }, */ /* FIXME */
+ { "_XOPEN_VERSION", _SC_XOPEN_VERSION },
+ { 0, 0 },
+}, confnames[] = {
+ { "PATH", _CS_PATH },
+ { "POSIX_V7_ILP32_OFF32_CFLAGS", _CS_POSIX_V7_ILP32_OFF32_CFLAGS },
+ { "POSIX_V7_ILP32_OFF32_LDFLAGS", _CS_POSIX_V7_ILP32_OFF32_LDFLAGS },
+ { "POSIX_V7_ILP32_OFF32_LIBS", _CS_POSIX_V7_ILP32_OFF32_LIBS },
+ { "POSIX_V7_ILP32_OFFBIG_CFLAGS", _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS },
+ { "POSIX_V7_ILP32_OFFBIG_LDFLAGS", _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS },
+ { "POSIX_V7_ILP32_OFFBIG_LIBS", _CS_POSIX_V7_ILP32_OFFBIG_LIBS },
+ { "POSIX_V7_LP64_OFF64_CFLAGS", _CS_POSIX_V7_LP64_OFF64_CFLAGS },
+ { "POSIX_V7_LP64_OFF64_LDFLAGS", _CS_POSIX_V7_LP64_OFF64_LDFLAGS },
+ { "POSIX_V7_LP64_OFF64_LIBS", _CS_POSIX_V7_LP64_OFF64_LIBS },
+ { "POSIX_V7_LPBIG_OFFBIG_CFLAGS", _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS },
+ { "POSIX_V7_LPBIG_OFFBIG_LDFLAGS", _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS },
+ { "POSIX_V7_LPBIG_OFFBIG_LIBS", _CS_POSIX_V7_LPBIG_OFFBIG_LIBS },
+ /* { "POSIX_V7_THREADS_CFLAGS", _CS_POSIX_V7_THREADS_CFLAGS }, */ /* FIXME */
+ /* { "POSIX_V7_THREADS_LDFLAGS", _CS_POSIX_V7_THREADS_LDFLAGS }, */ /* FIXME */
+ { "POSIX_V7_WIDTH_RESTRICTED_ENVS", _CS_POSIX_V7_WIDTH_RESTRICTED_ENVS },
+ { "V7_ENV", _CS_V7_ENV },
+ { "POSIX_V6_ILP32_OFF32_CFLAGS", _CS_POSIX_V6_ILP32_OFF32_CFLAGS },
+ { "POSIX_V6_ILP32_OFF32_LDFLAGS", _CS_POSIX_V6_ILP32_OFF32_LDFLAGS },
+ { "POSIX_V6_ILP32_OFF32_LIBS", _CS_POSIX_V6_ILP32_OFF32_LIBS },
+ { "POSIX_V6_ILP32_OFFBIG_CFLAGS", _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS },
+ { "POSIX_V6_ILP32_OFFBIG_LDFLAGS", _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS },
+ { "POSIX_V6_ILP32_OFFBIG_LIBS", _CS_POSIX_V6_ILP32_OFFBIG_LIBS },
+ { "POSIX_V6_LP64_OFF64_CFLAGS", _CS_POSIX_V6_LP64_OFF64_CFLAGS },
+ { "POSIX_V6_LP64_OFF64_LDFLAGS", _CS_POSIX_V6_LP64_OFF64_LDFLAGS },
+ { "POSIX_V6_LP64_OFF64_LIBS", _CS_POSIX_V6_LP64_OFF64_LIBS },
+ { "POSIX_V6_LPBIG_OFFBIG_CFLAGS", _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS },
+ { "POSIX_V6_LPBIG_OFFBIG_LDFLAGS", _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS },
+ { "POSIX_V6_LPBIG_OFFBIG_LIBS", _CS_POSIX_V6_LPBIG_OFFBIG_LIBS },
+ { "POSIX_V6_WIDTH_RESTRICTED_ENVS", _CS_POSIX_V6_WIDTH_RESTRICTED_ENVS },
+ { "V6_ENV", _CS_V6_ENV },
+ { 0, 0 },
+/* TODO:
+} limitnames[] = {
+ { 0, 0 },
+*/
+};
+
+int getnum(const char *name, struct namelist *names)
+{
+ for (size_t i = 0; names[i].name; i++) {
+ if (!strcmp(name, names[i].name)) {
+ return names[i].num;
+ }
+ }
+ return -1;
+}
+
+int main(int argc, char *argv[])
+{
+ int c;
+ while ((c = getopt(argc, argv, "v:")) != -1) {
+ switch (c) {
+ case 'v': /** get values for specification [version] **/
+ /* TODO */
+ break;
+
+ default:
+ return 1;
+ }
+ }
+
+ if (optind >= argc) {
+ fprintf(stderr, "getconf: System variable or path variable and path name required\n");
+ return 1;
+ }
+
+ if (optind == argc - 2) {
+ long value = pathconf(argv[optind + 1], getnum(argv[optind], pathnames));
+ printf("%ld\n", value);
+ return 0;
+ }
+
+ int setting = getnum(argv[optind], sysnames);
+ if (setting != -1) {
+ long value = sysconf(setting);
+ printf("%ld\n", value);
+ return 0;
+ }
+
+ setting = getnum(argv[optind], confnames);
+ if (setting != -1) {
+ size_t n = confstr(setting, NULL, 0);
+ char value[n + 1];
+ confstr(setting, value, n);
+ printf("%s\n", value);
+ return 0;
+ }
+
+ fprintf(stderr, "getconf: Setting '%s' not found\n", argv[optind]);
+ return 0;
+}