silc_mutex_unlock(conn->internal->lock);
silc_client_ref_client(client, conn, client_entry);
- SILC_LOG_DEBUG(("Added"));
+ SILC_LOG_DEBUG(("Added %p", client_entry));
return client_entry;
}
if (!client_entry)
return FALSE;
- SILC_LOG_DEBUG(("Client %p refcnt %d->%d", client_entry,
- silc_atomic_get_int8(&client_entry->internal.refcnt),
- silc_atomic_get_int8(&client_entry->internal.refcnt) - 1));
if (silc_atomic_sub_int8(&client_entry->internal.refcnt, 1) > 0)
return FALSE;
- SILC_LOG_DEBUG(("Deleting client %p"));
+ SILC_LOG_DEBUG(("Deleting client %p", client_entry));
silc_mutex_lock(conn->internal->lock);
ret = silc_idcache_del_by_context(conn->internal->client_cache,
void silc_client_unref_client(SilcClient client, SilcClientConnection conn,
SilcClientEntry client_entry)
{
- if (client_entry)
+ if (client_entry) {
SILC_LOG_DEBUG(("Client %p refcnt %d->%d", client_entry,
silc_atomic_get_int8(&client_entry->internal.refcnt),
silc_atomic_get_int8(&client_entry->internal.refcnt) - 1));
- if (client_entry &&
- silc_atomic_sub_int8(&client_entry->internal.refcnt, 1) == 0)
silc_client_del_client(client, conn, client_entry);
+ }
}
/* Free client entry list */
if (!clients && !client->internal->params->nickname_force_format)
return;
- len = 0;
- freebase = TRUE;
- while ((entry = silc_dlist_get(clients))) {
- if (entry->internal.valid && entry != client_entry)
- len++;
- if (entry->internal.valid && entry != client_entry &&
- silc_utf8_strcasecmp(entry->nickname, client_entry->nickname)) {
- freebase = FALSE;
- unformatted = entry;
+ if (clients) {
+ len = 0;
+ freebase = TRUE;
+ while ((entry = silc_dlist_get(clients))) {
+ if (entry->internal.valid && entry != client_entry)
+ len++;
+ if (entry->internal.valid && entry != client_entry &&
+ silc_utf8_strcasecmp(entry->nickname, client_entry->nickname)) {
+ freebase = FALSE;
+ unformatted = entry;
+ }
+ }
+ if (!len || freebase) {
+ silc_client_list_free(client, conn, clients);
+ return;
}
}
- if (!len || freebase)
- return;
/* If we are changing nickname of our local entry we'll enforce
that we will always get the unformatted nickname. Give our
char tmp[6];
int num, max = 1;
- if (silc_dlist_count(clients) == 1)
+ if (clients && silc_dlist_count(clients) == 1)
break;
- silc_dlist_start(clients);
- while ((entry = silc_dlist_get(clients))) {
- if (!silc_utf8_strncasecmp(entry->nickname, newnick, off))
- continue;
- if (strlen(entry->nickname) <= off)
- continue;
- num = atoi(&entry->nickname[off]);
- if (num > max)
- max = num;
+ if (clients) {
+ silc_dlist_start(clients);
+ while ((entry = silc_dlist_get(clients))) {
+ if (!silc_utf8_strncasecmp(entry->nickname, newnick, off))
+ continue;
+ if (strlen(entry->nickname) <= off)
+ continue;
+ num = atoi(&entry->nickname[off]);
+ if (num > max)
+ max = num;
+ }
}
memset(tmp, 0, sizeof(tmp));
silc_mutex_unlock(conn->internal->lock);
silc_client_ref_channel(client, conn, channel);
- SILC_LOG_DEBUG(("Added"));
+ SILC_LOG_DEBUG(("Added %p", channel));
return channel;
}
return FALSE;
silc_client_empty_channel(client, conn, channel);
+ silc_hash_table_free(channel->user_list);
silc_free(channel->channel_name);
silc_free(channel->topic);
if (channel->founder_key)
SilcChannelEntry channel_entry)
{
silc_atomic_add_int8(&channel_entry->internal.refcnt, 1);
+ SILC_LOG_DEBUG(("Channel %p refcnt %d->%d", channel_entry,
+ silc_atomic_get_int8(&channel_entry->internal.refcnt) - 1,
+ silc_atomic_get_int8(&channel_entry->internal.refcnt)));
}
/* Release reference of channel entry */
void silc_client_unref_channel(SilcClient client, SilcClientConnection conn,
SilcChannelEntry channel_entry)
{
- if (channel_entry &&
- silc_atomic_sub_int8(&channel_entry->internal.refcnt, 1) == 0)
+ if (channel_entry) {
+ SILC_LOG_DEBUG(("Channel %p refcnt %d->%d", channel_entry,
+ silc_atomic_get_int8(&channel_entry->internal.refcnt),
+ silc_atomic_get_int8(&channel_entry->internal.refcnt)
+ - 1));
silc_client_del_channel(client, conn, channel_entry);
+ }
}
/* Free channel entry list */
silc_mutex_unlock(conn->internal->lock);
silc_client_ref_server(client, conn, server_entry);
- SILC_LOG_DEBUG(("Added"));
+ SILC_LOG_DEBUG(("Added %p", server_entry));
return server_entry;
}
SilcServerEntry server_entry)
{
silc_atomic_add_int8(&server_entry->internal.refcnt, 1);
+ SILC_LOG_DEBUG(("Server %p refcnt %d->%d", server_entry,
+ silc_atomic_get_int8(&server_entry->internal.refcnt) - 1,
+ silc_atomic_get_int8(&server_entry->internal.refcnt)));
}
/* Release reference of server entry */
void silc_client_unref_server(SilcClient client, SilcClientConnection conn,
SilcServerEntry server_entry)
{
- if (server_entry &&
- silc_atomic_sub_int8(&server_entry->internal.refcnt, 1) == 0)
+ if (server_entry) {
+ SILC_LOG_DEBUG(("Server %p refcnt %d->%d", server_entry,
+ silc_atomic_get_int8(&server_entry->internal.refcnt),
+ silc_atomic_get_int8(&server_entry->internal.refcnt)
+ - 1));
silc_client_del_server(client, conn, server_entry);
+ }
}
/* Free server entry list */