mirror of
https://repo.or.cz/socat.git
synced 2025-01-08 22:12:33 +00:00
Print error on useless fdout,fdin options
This commit is contained in:
parent
9d93ce10b7
commit
8e58611133
3 changed files with 49 additions and 2 deletions
5
CHANGES
5
CHANGES
|
@ -213,6 +213,11 @@ corrections:
|
||||||
Help for filan -L was bad, is now corrected to:
|
Help for filan -L was bad, is now corrected to:
|
||||||
"follow symbolic links instead of showing their properties"
|
"follow symbolic links instead of showing their properties"
|
||||||
|
|
||||||
|
Address options fdin and fdout were silently ignored when not applicable
|
||||||
|
due to -u or -U option. Now these combinations are caught as errors.
|
||||||
|
Test: FDOUT_ERROR
|
||||||
|
Issue reported by Hendrik.
|
||||||
|
|
||||||
porting:
|
porting:
|
||||||
Red Hat issue 1020203: configure checks fail with some compilers.
|
Red Hat issue 1020203: configure checks fail with some compilers.
|
||||||
Use case: clang
|
Use case: clang
|
||||||
|
|
33
test.sh
33
test.sh
|
@ -12537,6 +12537,39 @@ N=$((N+1))
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
||||||
|
# test if option fdout in write only context issues an error
|
||||||
|
NAME=FDOUT_ERROR
|
||||||
|
case "$TESTS" in
|
||||||
|
*%$N%*|*%functions%*|*%bugs%*|*%socket%*|*%$NAME%*)
|
||||||
|
TEST="$NAME: fdout bails out in write-only context"
|
||||||
|
# use EXEC in write-only context with option fdout. Expected behaviour: error
|
||||||
|
if ! eval $NUMCOND; then :; else
|
||||||
|
tf="$td/test$N.stdout"
|
||||||
|
te="$td/test$N.stderr"
|
||||||
|
tdiff="$td/test$N.diff"
|
||||||
|
da="test$N $(date) $RANDOM"
|
||||||
|
CMD="$SOCAT $opts -u /dev/null EXEC:cat,fdout=1"
|
||||||
|
printf "test $F_n $TEST... " $N
|
||||||
|
$CMD >/dev/null 2>"${te}"
|
||||||
|
rc=$?
|
||||||
|
if [ $rc -eq 1 ]; then
|
||||||
|
$PRINTF "$OK\n"
|
||||||
|
numOK=$((numOK+1))
|
||||||
|
else
|
||||||
|
$PRINTF "$FAILED\n"
|
||||||
|
echo "$CMD"
|
||||||
|
cat "${te}"
|
||||||
|
echo "command did not terminate with error!"
|
||||||
|
numFAIL=$((numFAIL+1))
|
||||||
|
listFAIL="$listFAIL $N"
|
||||||
|
fi
|
||||||
|
fi # NUMCOND
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
PORT=$((PORT+1))
|
||||||
|
N=$((N+1))
|
||||||
|
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
# here come tests that might affect your systems integrity. Put normal tests
|
# here come tests that might affect your systems integrity. Put normal tests
|
||||||
# before this paragraph.
|
# before this paragraph.
|
||||||
|
|
|
@ -164,8 +164,17 @@ int _xioopen_progcall(int xioflags, /* XIO_RDONLY etc. */
|
||||||
if (!retropt_int(popts, OPT_LEFTFD, &fdi)) {
|
if (!retropt_int(popts, OPT_LEFTFD, &fdi)) {
|
||||||
fdo = fdi;
|
fdo = fdi;
|
||||||
}
|
}
|
||||||
retropt_int(popts, OPT_LEFTINFD, &fdi);
|
|
||||||
retropt_int(popts, OPT_LEFTOUTFD, &fdo);
|
if (retropt_int(popts, OPT_LEFTINFD, (unsigned short *)&fdi) >= 0) {
|
||||||
|
if ((xioflags&XIO_ACCMODE) == XIO_RDONLY) {
|
||||||
|
Error("_xioopen_progcall(): option fdin is useless in read-only mode");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (retropt_int(popts, OPT_LEFTOUTFD, (unsigned short *)&fdo) >= 0) {
|
||||||
|
if ((xioflags&XIO_ACCMODE) == XIO_WRONLY) {
|
||||||
|
Error("_xioopen_progcall(): option fdout is useless in write-only mode");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!retropt_int(popts, OPT_RIGHTFD, &rightin)) {
|
if (!retropt_int(popts, OPT_RIGHTFD, &rightin)) {
|
||||||
rightout = rightin;
|
rightout = rightin;
|
||||||
|
|
Loading…
Reference in a new issue