summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
6e5b158)
Author: noodles
Date: 2002/11/16 12:06:41
Add cleanupcgi function & various code cleanups.
int i;
char *request_method;
int content_length, paircount;
int i;
char *request_method;
int content_length, paircount;
- char *cgiinput;
- char **cgivars;
- char **pairlist;
+ char *cgiinput = NULL;
+ char **cgivars = NULL;
+ char **pairlist = NULL;
char *nvpair,*eqpos;
/* Depending on the request method, read all CGI input into cgiinput */
/* (really should produce HTML error messages, instead of exit()ing) */
char *nvpair,*eqpos;
/* Depending on the request method, read all CGI input into cgiinput */
/* (really should produce HTML error messages, instead of exit()ing) */
- request_method=getenv("REQUEST_METHOD");
+ request_method = getenv("REQUEST_METHOD");
if (request_method == NULL) {
if (argc > 1) {
if (request_method == NULL) {
if (argc > 1) {
+ cgiinput = strdup(argv[1]);
} else {
return NULL;
}
} else if (strlen(request_method)==0) {
return NULL;
} else {
return NULL;
}
} else if (strlen(request_method)==0) {
return NULL;
- } else if (!strcmp(request_method, "GET") || !strcmp(request_method, "HEAD")) {
+ } else if (!strcmp(request_method, "GET") ||
+ !strcmp(request_method, "HEAD")) {
cgiinput=strdup(getenv("QUERY_STRING"));
} else if (!strcmp(request_method, "POST")) {
if (getenv("CONTENT_TYPE") != NULL &&
cgiinput=strdup(getenv("QUERY_STRING"));
} else if (!strcmp(request_method, "POST")) {
if (getenv("CONTENT_TYPE") != NULL &&
}
if (!(content_length = atoi(getenv("CONTENT_LENGTH")))) {
}
if (!(content_length = atoi(getenv("CONTENT_LENGTH")))) {
- printf("getcgivars(): No Content-Length was sent with the POST request.\n");
+ printf("getcgivars(): No Content-Length was sent with"
+ " the POST request.\n");
exit(1);
}
if (!(cgiinput= (char *) malloc(content_length+1))) {
exit(1);
}
if (!(cgiinput= (char *) malloc(content_length+1))) {
- printf("getcgivars(): Could not malloc for cgiinput.\n");
+ printf("getcgivars(): Could not malloc for "
+ "cgiinput.\n");
nvpair=strtok(cgiinput, "&");
while (nvpair) {
pairlist[paircount++]= strdup(nvpair) ;
nvpair=strtok(cgiinput, "&");
while (nvpair) {
pairlist[paircount++]= strdup(nvpair) ;
- if (!(paircount%256)) pairlist=(char **) realloc(pairlist,(paircount+256)*sizeof(char **));
+ if (!(paircount%256)) {
+ pairlist=(char **) realloc(pairlist,
+ (paircount+256)*sizeof(char **));
+ }
nvpair=strtok(NULL, "&") ;
}
nvpair=strtok(NULL, "&") ;
}
/* Return the list of name-value strings */
return cgivars;
}
/* Return the list of name-value strings */
return cgivars;
}
+
+
+/**
+ * cleanupcgi - free the memory allocated for our CGI parameters.
+ * @cgivars: The CGI parameter list to free.
+ *
+ * Frees up the elements of the CGI parameter array and then frees the
+ * array.
+ */
+void cleanupcgi(char **cgivars)
+{
+ int i;
+
+ if (cgivars != NULL) {
+ for (i = 0; cgivars[i] != NULL; i++) {
+ free(cgivars[i]);
+ cgivars[i] = NULL;
+ }
+ free(cgivars);
+ cgivars = NULL;
+ }
+
+ return;
+}
void unescape_url(char *url);
char **getcgivars(int argc, char *argv[]);
void unescape_url(char *url);
char **getcgivars(int argc, char *argv[]);
+/**
+ * cleanupcgi - free the memory allocated for our CGI parameters.
+ * @cgivars: The CGI parameter list to free.
+ *
+ * Frees up the elements of the CGI parameter array and then frees the
+ * array.
+ */
+void cleanupcgi(char **cgivars);
+