Commit 96409e74 authored by Deomid Ryabkov's avatar Deomid Ryabkov Committed by Marko Mikulicic

Fix ALL the leaks!

    PUBLISHED_FROM=0adf7c6c903075d6705693829f8758f8ff67d579
parent e28ee097
...@@ -4442,6 +4442,7 @@ static void mg_send_http_file2(struct mg_connection *nc, const char *path, ...@@ -4442,6 +4442,7 @@ static void mg_send_http_file2(struct mg_connection *nc, const char *path,
send_http_error(nc, 500, "Server Error"); send_http_error(nc, 500, "Server Error");
} else if (mg_match_prefix(opts->ssi_pattern, strlen(opts->ssi_pattern), } else if (mg_match_prefix(opts->ssi_pattern, strlen(opts->ssi_pattern),
path) > 0) { path) > 0) {
nc->proto_data = (void *) dp;
handle_ssi_request(nc, path, opts); handle_ssi_request(nc, path, opts);
} else { } else {
char etag[50], current_time[50], last_modified[50], range[50]; char etag[50], current_time[50], last_modified[50], range[50];
...@@ -5625,7 +5626,7 @@ static void cgi_ev_handler(struct mg_connection *cgi_nc, int ev, ...@@ -5625,7 +5626,7 @@ static void cgi_ev_handler(struct mg_connection *cgi_nc, int ev,
} }
break; break;
case MG_EV_CLOSE: case MG_EV_CLOSE:
free_http_proto_data(nc); free_http_proto_data(cgi_nc);
nc->flags |= MG_F_SEND_AND_CLOSE; nc->flags |= MG_F_SEND_AND_CLOSE;
nc->user_data = NULL; nc->user_data = NULL;
break; break;
...@@ -5672,6 +5673,7 @@ static void handle_cgi(struct mg_connection *nc, const char *prog, ...@@ -5672,6 +5673,7 @@ static void handle_cgi(struct mg_connection *nc, const char *prog,
dp->type = DATA_CGI; dp->type = DATA_CGI;
dp->cgi_nc = mg_add_sock(nc->mgr, fds[0], cgi_ev_handler); dp->cgi_nc = mg_add_sock(nc->mgr, fds[0], cgi_ev_handler);
dp->cgi_nc->user_data = nc; dp->cgi_nc->user_data = nc;
dp->cgi_nc->proto_data = dp;
nc->flags |= MG_F_USER_1; nc->flags |= MG_F_USER_1;
/* Push POST data to the CGI */ /* Push POST data to the CGI */
if (n > 0 && n < nc->recv_mbuf.len) { if (n > 0 && n < nc->recv_mbuf.len) {
...@@ -6756,6 +6758,7 @@ static void mg_mqtt_destroy_session(struct mg_mqtt_session *s) { ...@@ -6756,6 +6758,7 @@ static void mg_mqtt_destroy_session(struct mg_mqtt_session *s) {
for (i = 0; i < s->num_subscriptions; i++) { for (i = 0; i < s->num_subscriptions; i++) {
MG_FREE((void *) s->subscriptions[i].topic); MG_FREE((void *) s->subscriptions[i].topic);
} }
MG_FREE(s->subscriptions);
MG_FREE(s); MG_FREE(s);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment