#include <stdlib.h>
#include <string.h>
#include "log.h"
+#include "memory.h"
#include "list.h"
#include "client.h"
#include "channel.h"
{
channel_t *ch;
- ch = malloc(sizeof(channel_t));
- if (ch == NULL)
- Log_fatal("out of memory");
+ ch = Memory_safeMalloc(1, sizeof(channel_t));
memset(ch, 0, sizeof(channel_t));
ch->id = id;
ch->name = strdup(name);
if (list_get_next(&ch->node) == &list_get_entry(&ch->node, channel_t, node)->parent->subs)
return NULL;
else
- return list_get_entry(list_get_next(&ch->node), channel_t, node);
+ return list_get_entry(list_get_next(&ch->node), channel_t, node);
}
#endif
*channelpptr = ch;
return ch;
}
-
+
void Chan_init()
{
int i;
const char *defaultChannelName;
defaultChannelName = getStrConf(DEFAULT_CHANNEL);
-
+
for (i = 0; ; i++) {
if (Conf_getNextChannel(&chdesc, i) < 0) {
if (i == 0)
ch->position = chdesc.position;
ch->silent = chdesc.silent;
if (chdesc.password) {
- Log_info("Setting password on channel '%s'", ch->name);
+ Log_info("Setting password on channel '%s'", ch->name);
ch->password = strdup(chdesc.password);
}
if (strcmp(defaultChannelName, chdesc.name) == 0) {
- Log_info("Setting default channel '%s'", ch->name);
+ Log_info("Setting default channel '%s'", ch->name);
defaultChan = ch;
}
-
+
do {
Chan_iterate(&ch_itr);
} while (ch_itr != NULL && strcmp(ch_itr->name, chdesc.parent) != 0);
-
+
if (ch_itr == NULL)
Log_fatal("Error in channel configuration: parent '%s' not found", chdesc.parent);
else {
}
if (defaultChan == NULL)
defaultChan = rootChan;
-
+
if (defaultChan->noenter)
Log_fatal("Error in channel configuration: default channel is marked as noenter");
if (defaultChan->password)
/* Channel links */
for (i = 0; ; i++) {
channel_t *ch_src, *ch_dst, *ch_itr = NULL;
+ channellist_t *chl;
if (Conf_getNextChannelLink(&chlink, i) < 0) {
if (i == 0)
Log_info("No channel links found in configuration file.");
chlink.source);
else
ch_src = ch_itr;
-
- ch_itr = NULL;
+
+ ch_itr = NULL;
do {
Chan_iterate(&ch_itr);
} while (ch_itr != NULL && strcmp(ch_itr->name, chlink.destination) != 0);
chlink.destination);
else
ch_dst = ch_itr;
-
- list_add_tail(&ch_dst->link_node, &ch_src->channel_links);
+
+ chl = Memory_safeMalloc(1, sizeof(channellist_t));
+ chl->chan = ch_dst;
+ init_list_entry(&chl->node);
+ list_add_tail(&chl->node, &ch_src->channel_links);
ch_src->linkcount++;
Log_info("Adding channel link '%s' -> '%s'", ch_src->name, ch_dst->name);
}
void Chan_free()
{
struct dlist *itr, *save;
+ struct dlist *linkitr, *linksave;
channel_t *ch;
-
+
list_iterate_safe(itr, save, &channels) {
ch = list_get_entry(itr, channel_t, flatlist_node);
Log_debug("Free channel '%s'", ch->name);
free(ch->desc);
if (ch->password)
free(ch->password);
+ list_iterate_safe(linkitr, linksave, &ch->channel_links) {
+ channellist_t *chl;
+ chl = list_get_entry(linkitr, channellist_t, node);
+ free(chl);
+ }
free(ch);
}
}
{
channel_t *leaving = NULL;
int leaving_id = -1;
-
+
if (client->channel) {
list_del(&client->chan_node);
leaving = (channel_t *)client->channel;
/* Do nothing if user already is in this channel */
if ((channel_t *)client->channel == ch)
return 0;
-
- Log_debug("Add user %s to channel %s", client->username, ch->name);
+
+ Log_debug("Add user %s to channel %s", client->username, ch->name);
/* Only allowed in one channel at a time */
leaving_id = Chan_userLeave(client);
list_add_tail(&client->chan_node, &ch->clients);
return -1;
}
else
- return Chan_userJoin(ch_itr, client);
+ return Chan_userJoin(ch_itr, client);
}
channelJoinResult_t Chan_userJoin_id_test(int channelid, client_t *client)
channellist_t *chl;
struct dlist *itr;
channel_t *sub;
-
- chl = malloc(sizeof(channellist_t));
+
+ chl = Memory_safeMalloc(1, sizeof(channellist_t));
chl->chan = ch;
init_list_entry(&chl->node);
list_add_tail(&chl->node, head);