diff options
author | nicm <nicm> | 2017-04-28 19:13:55 +0000 |
---|---|---|
committer | nicm <nicm> | 2017-04-28 19:13:55 +0000 |
commit | 0f2f783584c62879a1182972e915f550bf23f00a (patch) | |
tree | a516d196841ac2f8e478e068a2a7e3c946f7a186 /session.c | |
parent | bcd6b416749cbac712c29ee07049e98c5930c800 (diff) | |
download | rtmux-0f2f783584c62879a1182972e915f550bf23f00a.tar.gz rtmux-0f2f783584c62879a1182972e915f550bf23f00a.tar.bz2 rtmux-0f2f783584c62879a1182972e915f550bf23f00a.zip |
Log what is happening with window and session reference counts much more
obviously.
Diffstat (limited to 'session.c')
-rw-r--r-- | session.c | 16 |
1 files changed, 12 insertions, 4 deletions
@@ -189,13 +189,21 @@ session_create(const char *prefix, const char *name, int argc, char **argv, return (s); } -/* Remove a reference from a session. */ +/* Add a reference to a session. */ void -session_unref(struct session *s) +session_add_ref(struct session *s, const char *from) { - log_debug("session %s has %d references", s->name, s->references); + s->references++; + log_debug("%s: %s %s, now %d", __func__, s->name, from, s->references); +} +/* Remove a reference from a session. */ +void +session_remove_ref(struct session *s, const char *from) +{ s->references--; + log_debug("%s: %s %s, now %d", __func__, s->name, from, s->references); + if (s->references == 0) event_once(-1, EV_TIMEOUT, session_free, s, NULL); } @@ -248,7 +256,7 @@ session_destroy(struct session *s) free((void *)s->cwd); - session_unref(s); + session_remove_ref(s, __func__); } /* Check a session name is valid: not empty and no colons or periods. */ |