mirror of
https://github.com/moparisthebest/curl
synced 2024-11-11 12:05:06 -05:00
Kevin P Roth's idea of supporting multiple -d options was turned into reality
This commit is contained in:
parent
949eaf8ad4
commit
68c231e1b0
21
src/main.c
21
src/main.c
@ -686,6 +686,9 @@ static int getparameter(char *flag, /* f or -long-flag */
|
||||
break;
|
||||
case 'd':
|
||||
/* postfield data */
|
||||
{
|
||||
char *postdata=NULL;
|
||||
|
||||
if('@' == *nextarg) {
|
||||
/* the data begins with a '@' letter, it means that a file name
|
||||
or - (stdin) follows */
|
||||
@ -700,14 +703,26 @@ static int getparameter(char *flag, /* f or -long-flag */
|
||||
file = fopen(nextarg, "r");
|
||||
|
||||
if(subletter == 'b') /* forced binary */
|
||||
config->postfields = file2memory(file, &config->postfieldsize);
|
||||
postdata = file2memory(file, &config->postfieldsize);
|
||||
else
|
||||
config->postfields = file2string(file);
|
||||
postdata = file2string(file);
|
||||
if(file && (file != stdin))
|
||||
fclose(stdin);
|
||||
}
|
||||
else {
|
||||
GetStr(&config->postfields, nextarg);
|
||||
GetStr(&postdata, nextarg);
|
||||
}
|
||||
|
||||
if(config->postfields && *config->postfields) {
|
||||
/* we already have a string, we append this one
|
||||
with a separating &-letter */
|
||||
char *oldpost=config->postfields;
|
||||
config->postfields=maprintf("%s&%s", oldpost, postdata);
|
||||
free(oldpost);
|
||||
free(postdata);
|
||||
}
|
||||
else
|
||||
config->postfields=postdata;
|
||||
}
|
||||
if(config->postfields)
|
||||
config->conf |= CONF_POST;
|
||||
|
Loading…
Reference in New Issue
Block a user