1
0
mirror of https://github.com/moparisthebest/curl synced 2024-12-21 23:58:49 -05:00

Added some logic that now prevents multiple conflicting HTTP request types

to get specified with the options.
This commit is contained in:
Daniel Stenberg 2000-07-25 07:34:04 +00:00
parent 78686a5487
commit 6bdfe18b67

View File

@ -80,6 +80,16 @@
#include <fcntl.h> #include <fcntl.h>
#endif #endif
typedef enum {
HTTPREQ_UNSPEC,
HTTPREQ_GET,
HTTPREQ_HEAD,
HTTPREQ_POST,
HTTPREQ_SIMPLEPOST,
HTTPREQ_CUSTOM,
HTTPREQ_LAST
} HttpReq;
/* Just a set of bits */ /* Just a set of bits */
#define CONF_DEFAULT 0 #define CONF_DEFAULT 0
@ -186,6 +196,16 @@ void main_free(void)
win32_cleanup(); win32_cleanup();
} }
int SetHTTPrequest(HttpReq req, HttpReq *store)
{
if((*store == HTTPREQ_UNSPEC) ||
(*store == req)) {
*store = req;
return CURLE_OK;
}
fprintf(stderr, "You can only select one HTTP request!\n");
return CURLE_FAILED_INIT;
}
static void helpf(char *fmt, ...) static void helpf(char *fmt, ...)
{ {
@ -313,6 +333,8 @@ struct Configurable {
struct HttpPost *httppost; struct HttpPost *httppost;
struct HttpPost *last_post; struct HttpPost *last_post;
HttpReq httpreq;
}; };
static int parseconfig(char *filename, static int parseconfig(char *filename,
@ -610,6 +632,8 @@ static int getparameter(char *flag, /* f or -long-flag */
} }
if(config->postfields) if(config->postfields)
config->conf |= CONF_POST; config->conf |= CONF_POST;
if(SetHTTPrequest(HTTPREQ_SIMPLEPOST, &config->httpreq))
return CURLE_FAILED_INIT;
break; break;
case 'D': case 'D':
/* dump-header to given file name */ /* dump-header to given file name */
@ -650,6 +674,8 @@ static int getparameter(char *flag, /* f or -long-flag */
&config->httppost, &config->httppost,
&config->last_post)) &config->last_post))
return CURLE_FAILED_INIT; return CURLE_FAILED_INIT;
if(SetHTTPrequest(HTTPREQ_POST, &config->httpreq))
return CURLE_FAILED_INIT;
break; break;
case 'h': /* h for help */ case 'h': /* h for help */
@ -665,6 +691,8 @@ static int getparameter(char *flag, /* f or -long-flag */
case 'I': case 'I':
config->conf ^= CONF_HEADER; /* include the HTTP header in the output */ config->conf ^= CONF_HEADER; /* include the HTTP header in the output */
config->conf ^= CONF_NOBODY; /* don't fetch the body at all */ config->conf ^= CONF_NOBODY; /* don't fetch the body at all */
if(SetHTTPrequest(HTTPREQ_HEAD, &config->httpreq))
return CURLE_FAILED_INIT;
break; break;
case 'K': case 'K':
res = parseconfig(nextarg, config); res = parseconfig(nextarg, config);
@ -794,6 +822,8 @@ static int getparameter(char *flag, /* f or -long-flag */
case 'X': case 'X':
/* HTTP request */ /* HTTP request */
GetStr(&config->customrequest, nextarg); GetStr(&config->customrequest, nextarg);
if(SetHTTPrequest(HTTPREQ_CUSTOM, &config->httpreq))
return CURLE_FAILED_INIT;
break; break;
case 'y': case 'y':
/* low speed time */ /* low speed time */