diff options
author | Simo Sorce <idra@samba.org> | 2013-06-22 16:16:00 -0400 |
---|---|---|
committer | Simo Sorce <simo@redhat.com> | 2013-07-13 16:33:13 -0400 |
commit | 677ab0a79147f7606c73b63ecad91f8b1e7b63c1 (patch) | |
tree | f5402897d71f668564aa1f105ff6309198a6c1dd /tests/scripts | |
download | gss-ntlmssp-677ab0a79147f7606c73b63ecad91f8b1e7b63c1.tar.gz gss-ntlmssp-677ab0a79147f7606c73b63ecad91f8b1e7b63c1.tar.xz gss-ntlmssp-677ab0a79147f7606c73b63ecad91f8b1e7b63c1.zip |
Scheleton to start bulding the GSS-NTLMSSP project.
Diffstat (limited to 'tests/scripts')
-rwxr-xr-x | tests/scripts/dlopen.sh | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/tests/scripts/dlopen.sh b/tests/scripts/dlopen.sh new file mode 100755 index 0000000..890cc39 --- /dev/null +++ b/tests/scripts/dlopen.sh @@ -0,0 +1,76 @@ +#!/bin/sh + +test -n "$TMPDIR" || exit 1 +tempdir="$TMPDIR/dlopentest" +mkdir -p $tempdir +cat >> $tempdir/dlopen.c << _EOF +#include <dlfcn.h> +#include <stdio.h> +#include <limits.h> +#include <sys/stat.h> +/* Simple program to see if dlopen() would succeed. */ +int main(int argc, char **argv) +{ + int i; + struct stat st; + char buf[PATH_MAX]; + for (i = 1; i < argc; i++) { + if (dlopen(argv[i], RTLD_NOW)) { + fprintf(stdout, "dlopen() of \"%s\" succeeded.\n", + argv[i]); + } else { + snprintf(buf, sizeof(buf), "./%s", argv[i]); + if ((stat(buf, &st) == 0) && dlopen(buf, RTLD_NOW)) { + fprintf(stdout, "dlopen() of \"./%s\" " + "succeeded.\n", argv[i]); + } else { + fprintf(stdout, "dlopen() of \"%s\" failed: " + "%s\n", argv[i], dlerror()); + return 1; + } + } + } + return 0; +} +_EOF + +for arg in $@ ; do + case "$arg" in + "") + ;; + -I*|-D*|-f*|-m*|-g*|-O*|-W*) + cflags="$cflags $arg" + ;; + -l*|-L*) + ldflags="$ldflags $arg" + ;; + /*) + modules="$modules $arg" + ;; + *) + modules="$modules $arg" + ;; + esac +done + +${CC:-gcc} $RPM_OPT_FLAGS $CFLAGS -o $tempdir/dlopen $cflags $tempdir/dlopen.c $ldflags -ldl + +retval=0 +for module in $modules ; do + case "$module" in + "") + ;; + /*) + $tempdir/dlopen "$module" + retval=$? + ;; + *) + $tempdir/dlopen ./"$module" + retval=$? + ;; + esac +done + +rm -f $tempdir/dlopen $tempdir/dlopen.c +rmdir $tempdir +exit $retval |