Unify the way sessions are used by callbacks - store the address and use

the reference count, then check it is still on the global sessions list
in the callback.
This commit is contained in:
Nicholas Marriott
2010-12-20 00:03:55 +00:00
parent c65d4220f0
commit a51dcdc430
5 changed files with 43 additions and 17 deletions

View File

@ -81,6 +81,7 @@ cmd_load_buffer_exec(struct cmd *self, struct cmd_ctx *ctx)
cdata = xmalloc(sizeof *cdata);
cdata->session = s;
cdata->session->references++;
cdata->buffer = data->buffer;
c->stdin_data = cdata;
c->stdin_callback = cmd_load_buffer_callback;
@ -144,7 +145,6 @@ cmd_load_buffer_callback(struct client *c, void *data)
char *pdata;
size_t psize;
u_int limit;
int idx;
/*
* Event callback has already checked client is not dead and reduced
@ -153,7 +153,7 @@ cmd_load_buffer_callback(struct client *c, void *data)
c->flags |= CLIENT_EXIT;
/* Does the target session still exist? */
if (session_index(s, &idx) != 0)
if (!session_alive(s))
goto out;
psize = EVBUFFER_LENGTH(c->stdin_event->input);
@ -180,5 +180,6 @@ cmd_load_buffer_callback(struct client *c, void *data)
}
out:
cdata->session->references--;
xfree(cdata);
}