diff options
Diffstat (limited to 'util/sbase/scripts')
| -rwxr-xr-x | util/sbase/scripts/getconf.sh | 218 | ||||
| -rwxr-xr-x | util/sbase/scripts/install | 21 | ||||
| -rwxr-xr-x | util/sbase/scripts/mkbox | 103 | ||||
| -rwxr-xr-x | util/sbase/scripts/mkproto | 24 | ||||
| -rwxr-xr-x | util/sbase/scripts/uninstall | 32 | 
5 files changed, 398 insertions, 0 deletions
| diff --git a/util/sbase/scripts/getconf.sh b/util/sbase/scripts/getconf.sh new file mode 100755 index 00000000..70902a30 --- /dev/null +++ b/util/sbase/scripts/getconf.sh @@ -0,0 +1,218 @@ +#!/bin/sh + +ifdef() { +	printf 'static const struct var %s[] = {\n' "$1" +	awk '{printf("#ifdef %s\n\t{\"%s\",\t%s},\n#endif\n", $2, $1, $2)}' +	echo '};' +} + +ifdef confstr_l << EOF +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 +POSIX_V7_THREADS_LDFLAGS       _CS_POSIX_V7_THREADS_LDFLAGS +POSIX_V7_WIDTH_RESTRICTED_ENVS _CS_POSIX_V7_WIDTH_RESTRICTED_ENVS +V7_ENV                         _CS_V7_ENV +EOF + +ifdef limits_l << EOF +_POSIX_CLOCKRES_MIN                 _POSIX_CLOCKRES_MIN +_POSIX_AIO_LISTIO_MAX               _POSIX_AIO_LISTIO_MAX +_POSIX_AIO_MAX                      _POSIX_AIO_MAX +_POSIX_ARG_MAX                      _POSIX_ARG_MAX +_POSIX_CHILD_MAX                    _POSIX_CHILD_MAX +_POSIX_DELAYTIMER_MAX               _POSIX_DELAYTIMER_MAX +_POSIX_HOST_NAME_MAX                _POSIX_HOST_NAME_MAX +_POSIX_LINK_MAX                     _POSIX_LINK_MAX +_POSIX_LOGIN_NAME_MAX               _POSIX_LOGIN_NAME_MAX +_POSIX_MAX_CANON                    _POSIX_MAX_CANON +_POSIX_MAX_INPUT                    _POSIX_MAX_INPUT +_POSIX_MQ_OPEN_MAX                  _POSIX_MQ_OPEN_MAX +_POSIX_MQ_PRIO_MAX                  _POSIX_MQ_PRIO_MAX +_POSIX_NAME_MAX                     _POSIX_NAME_MAX +_POSIX_NGROUPS_MAX                  _POSIX_NGROUPS_MAX +_POSIX_OPEN_MAX                     _POSIX_OPEN_MAX +_POSIX_PATH_MAX                     _POSIX_PATH_MAX +_POSIX_PIPE_BUF                     _POSIX_PIPE_BUF +_POSIX_RE_DUP_MAX                   _POSIX_RE_DUP_MAX +_POSIX_RTSIG_MAX                    _POSIX_RTSIG_MAX +_POSIX_SEM_NSEMS_MAX                _POSIX_SEM_NSEMS_MAX +_POSIX_SEM_VALUE_MAX                _POSIX_SEM_VALUE_MAX +_POSIX_SIGQUEUE_MAX                 _POSIX_SIGQUEUE_MAX +_POSIX_SSIZE_MAX                    _POSIX_SSIZE_MAX +_POSIX_SS_REPL_MAX                  _POSIX_SS_REPL_MAX +_POSIX_STREAM_MAX                   _POSIX_STREAM_MAX +_POSIX_SYMLINK_MAX                  _POSIX_SYMLINK_MAX +_POSIX_SYMLOOP_MAX                  _POSIX_SYMLOOP_MAX +_POSIX_THREAD_DESTRUCTOR_ITERATIONS _POSIX_THREAD_DESTRUCTOR_ITERATIONS +_POSIX_THREAD_KEYS_MAX              _POSIX_THREAD_KEYS_MAX +_POSIX_THREAD_THREADS_MAX           _POSIX_THREAD_THREADS_MAX +_POSIX_TIMER_MAX                    _POSIX_TIMER_MAX +_POSIX_TTY_NAME_MAX                 _POSIX_TTY_NAME_MAX +_POSIX_TZNAME_MAX                   _POSIX_TZNAME_MAX +_POSIX2_BC_BASE_MAX                 _POSIX2_BC_BASE_MAX +_POSIX2_BC_DIM_MAX                  _POSIX2_BC_DIM_MAX +_POSIX2_BC_SCALE_MAX                _POSIX2_BC_SCALE_MAX +_POSIX2_BC_STRING_MAX               _POSIX2_BC_STRING_MAX +_POSIX2_CHARCLASS_NAME_MAX          _POSIX2_CHARCLASS_NAME_MAX +_POSIX2_COLL_WEIGHTS_MAX            _POSIX2_COLL_WEIGHTS_MAX +_POSIX2_EXPR_NEST_MAX               _POSIX2_EXPR_NEST_MAX +_POSIX2_LINE_MAX                    _POSIX2_LINE_MAX +_POSIX2_RE_DUP_MAX                  _POSIX2_RE_DUP_MAX +EOF + +ifdef sysconf_l << EOF +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 +_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 +_XOPEN_VERSION                    _SC_XOPEN_VERSION +EOF + +ifdef pathconf_l << EOF +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 +EOF diff --git a/util/sbase/scripts/install b/util/sbase/scripts/install new file mode 100755 index 00000000..ce78c1da --- /dev/null +++ b/util/sbase/scripts/install @@ -0,0 +1,21 @@ +#!/bin/sh + +set -e + +while read type src dst perm +do +	case $type in +	d) +		mkdir -p $src +		;; +	c) +		cp -f $src $dst +		;; +	*) +		echo install: wrong entry type >&2 +		exit 1 +		;; +	esac + +	chmod $perm $dst +done < $1 diff --git a/util/sbase/scripts/mkbox b/util/sbase/scripts/mkbox new file mode 100755 index 00000000..99e40441 --- /dev/null +++ b/util/sbase/scripts/mkbox @@ -0,0 +1,103 @@ +#!/bin/sh + +trap "rm -rf build" INT QUIT TERM + +rm -rf build +mkdir -p build + +cp *.h build + +cat > build/sbase-box.c <<EOF +#include <unistd.h> + +#include <libgen.h> +#include <errno.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include "util.h" +#include "sbase-box.h" + +struct cmd { +	char *name; +	int (*fn)(int, char **); +} cmds[] = { +	{"install", xinstall_main}, +	{"[", test_main}, +$(grep -l ^main *.c | +while read f +do +	sed -n ' +	/^main/ { +		s/main/'${f%.c}'_main/ +		s/-/_/g +		w build/'$f' +		s/\(^.*\)(.*)/	{"'${f%.c}'", \1},/p +		d +	} +	w 'build/$f $f +done) +	{NULL}, +}; + +static void +install(char *path) +{ +	int r; +	struct cmd *bp; +	char fname[FILENAME_MAX]; + +	if (path == NULL) { +		fputs("sbase-box [-i path] [command]\n", stderr); +		exit(1); +	} + +	for (bp = cmds; bp->name; ++bp) { +		r = snprintf(fname, sizeof(fname), "%s/%s", path, bp->name); +		if (r < 0 || r >= sizeof(fname)) { +			fprintf(stderr, +			        "sbase-box: destination path truncated for '%s'\n", +			        bp->name); +			exit(1); +		} +		remove(fname); +		if (symlink("sbase-box", fname) < 0) { +			fprintf(stderr, +			        "sbase-box: %s: %s\n", +			        bp->name, strerror(errno)); +			exit(1); +		} +	} +} + +int +main(int argc, char *argv[]) +{ +	char *s = basename(argv[0]); +	struct cmd *bp; + +	if (!strcmp(s, "sbase-box") && argc > 1) { +		argc--; argv++; +		if (strcmp(argv[0], "-i") == 0) { +			install(argv[1]); +			exit(0); +		} +		s = basename(argv[0]); +	} + +	for (bp = cmds; bp->name; ++bp) { +		if (strcmp(bp->name, s) == 0) +			return (*bp->fn)(argc, argv); +	} + +	for (bp = cmds; bp->name; ++bp) +		printf("%s ", bp->name); +	putchar('\n'); + +	return 0; +} +EOF + +sed -n 's/.* \(.*_main\).*/int \1(int, char **);/p'\ +	build/sbase-box.c > build/sbase-box.h diff --git a/util/sbase/scripts/mkproto b/util/sbase/scripts/mkproto new file mode 100755 index 00000000..192fe56b --- /dev/null +++ b/util/sbase/scripts/mkproto @@ -0,0 +1,24 @@ +#!/bin/sh + +usage() +{ +	echo mkproto: prefix manprefix proto>&2 +	exit 1 +} + +prefix=${1?$(usage)} +manprefix=${2?$(usage)} +proto=${3?$(usage)} + +trap "rm -f scripts/proto" EXIT INT QUIT TERM + +(set -e +echo d $prefix/bin $prefix/bin 755 +find . ! -name . -prune -type f \( -perm -u+x -o -perm -g+x -o -perm o+x \) | +sed "s@.*@c & $prefix/bin/& 755@" + +echo d $manprefix/man1 $manprefix/man1 755 +find . ! -name . -prune -name '*.1' | +sed "s@.*@c & $manprefix/man1/& 644@") > $proto + +trap "" EXIT INT QUIT TERM diff --git a/util/sbase/scripts/uninstall b/util/sbase/scripts/uninstall new file mode 100755 index 00000000..e9c74f2d --- /dev/null +++ b/util/sbase/scripts/uninstall @@ -0,0 +1,32 @@ +#!/bin/sh + +set -e + +while read type src dst perm +do +	case $type in +	d) +		echo $type $src $dst $perm +		continue +		;; +	c) +		rm -f $dst +		;; +	*) +		echo uninstall: wrong entry type >&2 +		exit 1 +		;; +	esac +done < $1 | +sort -r | +while read type src dst perm +do +	case $type in +	d) +		if test `ls $dst | wc -l` -eq 0 +		then +			rmdir $dst +		fi +		;; +	esac +done | 
