diff --git a/configure b/configure index 1cd85af..939fccb 100755 --- a/configure +++ b/configure @@ -32,6 +32,27 @@ check_compile() { return $res } +check_define() { + printf "checking whether \$CC defines %s ... " "$1" + local res=1 + $CC $CPPFLAGS $CFLAGS -dM -E - /dev/null && res=0 + test x$res = x0 && printf "yes\n" || printf "no\n" + return $res +} + +check_compile_run() { + printf "checking %s ... " "$1" + local tmp=$(mktemp) + printf "$2" > "$tmp".c + local res=0 + $CC $CPPFLAGS $CFLAGS "$tmp".c -o "$tmp".out >/dev/null 2>&1 \ + || res=1 + test x$res = x0 && { "$tmp".out || res=1 ; } + rm -f "$tmp".c "$tmp".o "$tmp".out + test x$res = x0 && printf "yes\n" || printf "no\n" + return $res +} + usage() { echo "supported arguments" echo "--prefix=/path default: $prefix" @@ -111,6 +132,11 @@ check_compile 'whether netinet/in.h defines __u6_addr.__u6_addr16' \ '#include \nint main(int a, char**c){struct in6_addr x={.s6_addr32[0]=a};return x.s6_addr16[0]; }' } +check_define __OpenBSD__ && \ +check_compile_run 'whether OpenBSDs fclose() (illegally) calls close()' \ +'#include \n#include\nint close(int x){exit(0);}int main(){fclose(stdin);return 1;}' && \ +CPPFLAGS="$CPPFLAGS -DBROKEN_FCLOSE" + echo CC?=$CC>config.mak [ -z "$CPPFLAGS" ] || echo CPPFLAGS?=$CPPFLAGS>>config.mak [ -z "$CFLAGS" ] || echo USER_CFLAGS?=$CFLAGS>>config.mak diff --git a/src/libproxychains.c b/src/libproxychains.c index 4c12511..ec18496 100644 --- a/src/libproxychains.c +++ b/src/libproxychains.c @@ -290,7 +290,9 @@ static void get_chain_data(proxy_data * pd, unsigned int *proxy_count, chain_typ } } } +#ifndef BROKEN_FCLOSE fclose(file); +#endif if(!count) { fprintf(stderr, "error: no valid proxy found in config\n"); exit(1);