aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main.c63
1 files changed, 59 insertions, 4 deletions
diff --git a/src/main.c b/src/main.c
index b69c13dde..5335b8e8c 100644
--- a/src/main.c
+++ b/src/main.c
@@ -230,7 +230,9 @@ static void help(void)
" -B/--use-ascii Use ASCII/text transfer\n"
" -c/--continue Resume a previous transfer where we left it\n"
" -C/--continue-at <offset> Specify absolute resume offset\n"
- " -d/--data POST data (H)\n"
+ " -d/--data <data> HTTP POST data (H)\n"
+ " --data-ascii <data> HTTP POST ASCII data (H)\n"
+ " --data-binary <data> HTTP POST binary data (H)\n"
" -D/--dump-header <file> Write the headers to this file\n"
" -e/--referer Referer page (H)\n"
" -E/--cert <cert:passwd> Specifies your certificate file and password (HTTPS)\n"
@@ -292,6 +294,7 @@ struct Configurable {
bool use_resume;
int resume_from;
char *postfields;
+ long postfieldsize;
char *referer;
long timeout;
char *outfile;
@@ -385,6 +388,36 @@ static char *file2string(FILE *file)
return NULL; /* no string */
}
+static char *file2memory(FILE *file, long *size)
+{
+ char buffer[1024];
+ char *ptr;
+ char *string=NULL;
+ char *newstring=NULL;
+ long len=0;
+ long stringlen=0;
+
+ if(file) {
+ while(len = fread(buffer, 1, sizeof(buffer), file)) {
+ if(string) {
+ newstring = realloc(string, len+stringlen);
+ if(newstring)
+ string = newstring;
+ else
+ break; /* no more strings attached! :-) */
+ }
+ else
+ string = malloc(len);
+ memcpy(&string[stringlen], buffer, len);
+ stringlen+=len;
+ }
+ *size = stringlen;
+ return string;
+ }
+ else
+ return NULL; /* no string */
+}
+
static int getparameter(char *flag, /* f or -long-flag */
char *nextarg, /* NULL if unset */
bool *usedarg, /* set to TRUE if the arg has been
@@ -392,11 +425,14 @@ static int getparameter(char *flag, /* f or -long-flag */
struct Configurable *config)
{
char letter;
+ char subletter=0; /* subletters can only occur on long options */
+
char *parse=NULL;
int res;
int j;
time_t now;
int hit=-1;
+ bool longopt=FALSE;
/* single-letter,
long-name,
@@ -416,6 +452,8 @@ static int getparameter(char *flag, /* f or -long-flag */
{"c", "continue", FALSE},
{"C", "continue-at", TRUE},
{"d", "data", TRUE},
+ {"da", "data-ascii", TRUE},
+ {"db", "data-binary", TRUE},
{"D", "dump-header", TRUE},
{"e", "referer", TRUE},
{"E", "cert", TRUE},
@@ -465,6 +503,7 @@ static int getparameter(char *flag, /* f or -long-flag */
int fnam=strlen(&flag[1]);
for(j=0; j< sizeof(aliases)/sizeof(aliases[0]); j++) {
if(strnequal(aliases[j].lname, &flag[1], fnam)) {
+ longopt = TRUE;
if(strequal(aliases[j].lname, &flag[1])) {
parse = aliases[j].letter;
hit = j;
@@ -492,7 +531,12 @@ static int getparameter(char *flag, /* f or -long-flag */
do {
/* we can loop here if we have multiple single-letters */
- letter = parse?*parse:'\0';
+ if(!longopt)
+ letter = parse?*parse:'\0';
+ else {
+ letter = parse[0];
+ subletter = parse[1];
+ }
*usedarg = FALSE; /* default is that we don't use the arg */
#if 0
@@ -500,7 +544,7 @@ static int getparameter(char *flag, /* f or -long-flag */
#endif
if(hit < 0) {
for(j=0; j< sizeof(aliases)/sizeof(aliases[0]); j++) {
- if(letter == *aliases[j].letter) {
+ if(letter == aliases[j].letter[0]) {
hit = j;
break;
}
@@ -618,12 +662,19 @@ static int getparameter(char *flag, /* f or -long-flag */
/* the data begins with a '@' letter, it means that a file name
or - (stdin) follows */
FILE *file;
+ char *ptr;
+
nextarg++; /* pass the @ */
+
if(strequal("-", nextarg))
file = stdin;
else
file = fopen(nextarg, "r");
- config->postfields = file2string(file);
+
+ if(subletter == 'b') /* forced binary */
+ config->postfields = file2memory(file, &config->postfieldsize);
+ else
+ config->postfields = file2string(file);
if(file && (file != stdin))
fclose(stdin);
}
@@ -1422,6 +1473,10 @@ int main(int argc, char *argv[])
curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, errorbuffer);
curl_easy_setopt(curl, CURLOPT_TIMEOUT, config.timeout);
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, config.postfields);
+
+ /* new in libcurl 7.2: */
+ curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, config.postfieldsize);
+
curl_easy_setopt(curl, CURLOPT_REFERER, config.referer);
curl_easy_setopt(curl, CURLOPT_AUTOREFERER, config.conf&CONF_AUTO_REFERER);
curl_easy_setopt(curl, CURLOPT_USERAGENT, config.useragent);