tool_operate: bail out better on no URL

To avoid NULL derferences with many outputs and --next.

Follow-up to 034612cd51

Add test 760 to verify

Reported-by: BobodevMm on github
Fixes #18375
Closes #18376
This commit is contained in:
Daniel Stenberg 2025-08-23 10:16:49 +02:00
parent 1e430f806a
commit 29e4a124a3
No known key found for this signature in database
GPG key ID: 5CC908FDB71E12C2
3 changed files with 36 additions and 6 deletions

View file

@ -1119,6 +1119,11 @@ static CURLcode single_transfer(struct OperationConfig *config,
struct getout *u = state->urlnode;
FILE *err = (!global->silent || global->showerror) ? tool_stderr : NULL;
if(!u->url) {
/* This node has no URL. End of the road. */
warnf("Got more output options than URLs");
break;
}
if(u->infile) {
if(!config->globoff && !glob_inuse(&state->inglob))
result = glob_url(&state->inglob, u->infile, &state->upnum, err);
@ -1141,11 +1146,6 @@ static CURLcode single_transfer(struct OperationConfig *config,
glob_cleanup(&state->inglob);
state->upidx = 0;
state->urlnode = u->next; /* next node */
if(state->urlnode && !state->urlnode->url) {
/* This node has no URL. End of the road. */
warnf("Got more output options than URLs");
break;
}
continue;
}

View file

@ -108,7 +108,7 @@ test718 test719 test720 test721 test722 test723 test724 test725 test726 \
test727 test728 test729 test730 test731 test732 test733 test734 test735 \
test736 test737 test738 test739 test740 test741 test742 test743 test744 \
test745 test746 test747 test748 test749 test750 test751 test752 test753 \
test754 test755 test756 test757 test758 test759 \
test754 test755 test756 test757 test758 test759 test760 \
test780 test781 test782 test783 test784 test785 test786 test787 test788 \
test789 test790 test791 test792 test793 test794 test795 test796 test797 \
\

30
tests/data/test760 Normal file
View file

@ -0,0 +1,30 @@
<testcase>
<info>
<keywords>
globbing
</keywords>
</info>
#
# Client-side
<client>
<server>
none
</server>
<name>
more cmdline options than URLs and --next
</name>
<command>
-no1 -no2 --url "Qttp://internal.dxample.lol/status" -: --url "http"
</command>
</client>
#
# Verify data after the test has been "shot"
<verify>
# curl: (1) Protocol "qttp" not supported
<errorcode>
1
</errorcode>
</verify>
</testcase>