1
0
mirror of https://github.com/anope/anope.git synced 2026-06-12 19:14:47 +02:00

BUILD : 1.7.5 (351) BUGS : N/A NOTES : Rewrote the internals of moduleData, this will save _lots_ of memory especially on larger networks. The downside is modules using it need to make a tiny, tiny change... :/

git-svn-id: svn://svn.anope.org/anope/trunk@351 31f1291d-b8d6-0310-a050-a5561fc1590b


git-svn-id: http://anope.svn.sourceforge.net/svnroot/anope/trunk@227 5417fbe8-f217-4b02-8779-1006273d7864
This commit is contained in:
rob rob@31f1291d-b8d6-0310-a050-a5561fc1590b
2004-09-19 10:28:02 +00:00
parent aa896a87ac
commit fe0992a6ab
16 changed files with 217 additions and 233 deletions
+1
View File
@@ -3,6 +3,7 @@ Anope Version S V N
Provided by Anope Dev. <dev@anope.org> - 2004
08/24 A New -l option for am script to list possible selectors. [ #00]
09/08 A Removed rand() and ported bsd's arc4random() to fit our needs. [ #00]
09/19 F Rewrote the internals of moduleData to save lots of memory. [ #00]
09/17 F Fixed MySQL error, whereby checks are only done if mysql is on. [ #00]
09/14 F Fixed /os MODE by joining nested ifs into one. [ #00]
09/14 F Protection unsetting now does -a instead of +a. [ #00]
+3
View File
@@ -378,5 +378,8 @@ if [ "$UMASK" != "" ] ; then
WITH_PERM=" --with-permissions=$UMASK"
fi
echo "./configure $WITH_BIN $WITH_DATA $WITH_ENC $WITH_IRCD $WITH_RUN $WITH_PERM"
./configure $WITH_BIN $WITH_DATA $WITH_ENC $WITH_IRCD $WITH_RUN $WITH_PERM
+1 -1
View File
@@ -653,7 +653,7 @@ E u_int32_t getrandom32(void);
/**** modules.c ****/
E void moduleCallBackRun(void);
E void moduleCleanStruct(ModuleData * moduleData[]);
E void moduleCleanStruct(ModuleData **moduleData);
/**** news.c ****/
+7 -5
View File
@@ -220,12 +220,14 @@ int moduleAddCallback(char *name,time_t when,int (*func)(int argc, char *argv[])
void moduleDelCallback(char *name);
void moduleCallBackRun(void);
char *moduleGetData(ModuleData *md[], char *key); /* Get the value for this key from this struct */
int moduleAddData(ModuleData *md[], char *key, char *value); /* Set the value for this key for this struct */
void moduleDelData(ModuleData *md[], char *key); /* Delete this key/value pair */
void moduleDelAllData(ModuleData *md[]); /* Delete all key/value pairs for this module for this struct */
void moduleCleanStruct(ModuleData * moduleData[]); /* Clean a moduleData hash */
char *moduleGetData(ModuleData **md, char *key); /* Get the value for this key from this struct */
int moduleAddData(ModuleData **md, char *key, char *value); /* Set the value for this key for this struct */
void moduleDelData(ModuleData **md, char *key); /* Delete this key/value pair */
void moduleDelAllData(ModuleData **md); /* Delete all key/value pairs for this module for this struct */
void moduleCleanStruct(ModuleData **moduleData); /* Clean a moduleData hash */
void moduleDelAllDataMod(Module *m); /* remove all module data from all structs for this module */
int moduleDataDebug(ModuleData **md); /* Allow for debug output of a moduleData struct */
boolean moduleMinVersion(int major,int minor,int patch,int build); /* Checks if the current version of anope is before or after a given verison */
/*************************************************************************/
+10 -16
View File
@@ -129,7 +129,6 @@ typedef struct server_ Server;
typedef struct user_ User;
typedef struct channel_ Channel;
typedef struct ModuleData_ ModuleData; /* ModuleData struct */
typedef struct ModuleDataItem_ ModuleDataItem; /* A Module Data Item struct */
typedef struct memo_ Memo;
typedef struct nickrequest_ NickRequest;
typedef struct nickalias_ NickAlias;
@@ -301,19 +300,14 @@ struct ircdcapab_ {
* ModuleData strucs used to allow modules to add / delete module Data from existing structs
*/
struct ModuleDataItem_ {
char *key; /* The key */
char *value; /* The Value */
ModuleDataItem *next; /* The next ModuleDataItem in this list */
};
struct ModuleData_ {
struct ModuleData_ {
char *moduleName; /* Which module we belong to */
ModuleDataItem *di; /* The first Item they own */
char *key; /* The key */
char *value; /* The Value */
ModuleData *next; /* The next ModuleData record */
};
/*************************************************************************/
/*************************************************************************/
/* Memo info structures. Since both nicknames and channels can have memos,
* we encapsulate memo data in a MemoList to make it easier to handle. */
@@ -324,7 +318,7 @@ struct memo_ {
time_t time; /* When it was sent */
char sender[NICKMAX];
char *text;
ModuleData *moduleData[1024]; /* Module saved data attached to the Memo */
ModuleData *moduleData; /* Module saved data attached to the Memo */
};
typedef struct {
@@ -358,7 +352,7 @@ struct nickalias_ {
int16 status; /* See NS_* below */
NickCore *nc; /* I'm an alias of this */
/* Not saved */
ModuleData *moduleData[1024]; /* Module saved data attached to the nick alias */
ModuleData *moduleData; /* Module saved data attached to the nick alias */
User *u; /* Current online user that has me */
};
@@ -380,7 +374,7 @@ struct nickcore_ {
uint16 channelmax; /* Maximum number of channels allowed */
/* Unsaved data */
ModuleData *moduleData[1024]; /* Module saved data attached to the NickCore */
ModuleData *moduleData; /* Module saved data attached to the NickCore */
time_t lastmail; /* Last time this nick record got a mail */
SList aliases; /* List of aliases */
};
@@ -514,7 +508,7 @@ struct chaninfo_ {
struct channel_ *c; /* Pointer to channel record (if *
* channel is currently in use) */
ModuleData *moduleData[1024]; /* Module saved data attached to the ChannelInfo */
ModuleData *moduleData; /* Module saved data attached to the ChannelInfo */
/* For BotServ */
@@ -695,7 +689,7 @@ struct user_ {
NickAlias *na;
ModuleData *moduleData[1024]; /* defined for it, it should allow the module Add/Get */
ModuleData *moduleData; /* defined for it, it should allow the module Add/Get */
int isSuperAdmin; /* is SuperAdmin on or off? */
+10 -11
View File
@@ -38,17 +38,17 @@ cat >version.h <<EOF
*
*/
#define VERSION_MAJOR "$VERSION_MAJOR"
#define VERSION_MINOR "$VERSION_MINOR"
#define VERSION_PATCH "$VERSION_PATCH"
#define VERSION_EXTRA "$VERSION_EXTRA"
#define VERSION_BUILD "$VERSION_BUILD"
#ifndef VERSION_H
#define VERSION_H
#define VERSION_MAJOR $VERSION_MAJOR
#define VERSION_MINOR $VERSION_MINOR
#define VERSION_PATCH $VERSION_PATCH
#define VERSION_EXTRA $VERSION_EXTRA
#define VERSION_BUILD $VERSION_BUILD
#define BUILD "$BUILD"
const char version_number[] = "$VERSION";
const char version_build[] =
"build #" BUILD ", compiled " __DATE__ " " __TIME__;
#define VERSION_STRING "$VERSION"
#ifdef DEBUG_COMMANDS
# define VER_DEBUG "D"
@@ -106,8 +106,7 @@ const char version_build[] =
# define VER_MODULE
#endif
/* the space is needed cause if you build with nothing it will complain */
const char version_flags[] = " " VER_DEBUG VER_ENCRYPTION VER_THREAD VER_OS VER_GHBNR VER_MYSQL VER_MODULE;
#endif
EOF
+1 -1
View File
@@ -20,7 +20,7 @@ INCLUDES = ../include/commands.h ../include/defs.h ../include/language.h \
../include/pseudo.h ../include/sysconf.h ../include/config.h \
../include/encrypt.h ../include/messages.h ../include/services.h \
../include/timeout.h ../include/datafiles.h ../include/extern.h \
../include/modules.h ../include/slist.h ../include/version.h \
../include/modules.h ../include/slist.h \
../include/dreamforge.h ../include/bahamut.h ../include/ultimate2.h \
../include/ultimate3.h ../include/hybrid.h ../include/ptlink.h ../include/unreal31.h \
../include/viagra.h ../include/rageircd.h ../include/unreal32.h
+3 -5
View File
@@ -912,9 +912,7 @@ void load_cs_dbase(void)
memos->time = tmp32;
SAFE(read_buffer(memos->sender, f));
SAFE(read_string(&memos->text, f));
for (m = 0; m < MAX_CMD_HASH; m++) {
memos->moduleData[m] = NULL;
}
memos->moduleData = NULL;
}
}
@@ -2097,7 +2095,7 @@ int delchan(ChannelInfo * ci)
for (i = 0; i < ci->memos.memocount; i++) {
if (ci->memos.memos[i].text)
free(ci->memos.memos[i].text);
moduleCleanStruct(ci->memos.memos[i].moduleData);
moduleCleanStruct(&ci->memos.memos[i].moduleData);
}
free(ci->memos.memos);
}
@@ -2110,7 +2108,7 @@ int delchan(ChannelInfo * ci)
if (ci->badwords)
free(ci->badwords);
moduleCleanStruct(ci->moduleData);
moduleCleanStruct(&ci->moduleData);
free(ci);
if (nc)
+9
View File
@@ -75,6 +75,15 @@ time_t start_time;
/* Parameters and environment */
char **my_av, **my_envp;
/* Moved here from version.h */
const char version_number[] = VERSION_STRING;
const char version_build[] =
"build #" BUILD ", compiled " __DATE__ " " __TIME__;
/* the space is needed cause if you build with nothing it will complain */
const char version_flags[] =
" " VER_DEBUG VER_ENCRYPTION VER_THREAD VER_OS VER_GHBNR VER_MYSQL
VER_MODULE;
/******** Local variables! ********/
/* Set to 1 if we are waiting for input */
+3 -4
View File
@@ -192,7 +192,7 @@ static int delmemo(MemoInfo * mi, int num)
break;
}
if (i < mi->memocount) {
moduleCleanStruct(mi->memos[i].moduleData);
moduleCleanStruct(&mi->memos[i].moduleData);
free(mi->memos[i].text); /* Deallocate memo text memory */
mi->memocount--; /* One less memo now */
if (i < mi->memocount) /* Move remaining memos down a slot */
@@ -315,8 +315,7 @@ void memo_send(User * u, char *name, char *text, int z)
mi->memos = srealloc(mi->memos, sizeof(Memo) * mi->memocount);
m = &mi->memos[mi->memocount - 1];
strscpy(m->sender, source, NICKMAX);
for (j = 0; j < MAX_CMD_HASH; j++)
m->moduleData[j] = NULL;
m->moduleData = NULL;
if (mi->memocount > 1) {
m->number = m[-1].number + 1;
if (m->number < 1) {
@@ -786,7 +785,7 @@ static int do_del(User * u)
/* Delete all memos. */
for (i = 0; i < mi->memocount; i++) {
free(mi->memos[i].text);
moduleCleanStruct(mi->memos[i].moduleData);
moduleCleanStruct(&mi->memos[i].moduleData);
}
free(mi->memos);
mi->memos = NULL;
+155 -172
View File
@@ -14,6 +14,7 @@
*/
#include "modules.h"
#include "language.h"
#include "version.h"
#ifdef USE_MODULES
#include <dlfcn.h>
@@ -1748,6 +1749,24 @@ void moduleDisplayHelp(int service, User * u)
#endif
}
/**
* Output module data information into the log file.
* This is a vwey "debug only" function to dump the whole contents
* of a moduleData struct into the log files.
* @param md The module data for the struct to be used
* @return 0 is always returned;
**/
int moduleDataDebug(ModuleData **md) {
ModuleData *current = NULL;
alog("Dumping module data....");
for (current = *md; current; current = current->next) {
alog("Module: [%s]",current->moduleName);
alog(" Key [%s]\tValue [%s]",current->key, current->value);
}
alog("End of module data dump");
return 0;
}
/**
* Add module data to a struct.
* This allows module coders to add data to an existing struct
@@ -1756,72 +1775,40 @@ void moduleDisplayHelp(int service, User * u)
* @param value The value for the key/value pair, this is what will be stored for you
* @return MOD_ERR_OK will be returned on success
**/
int moduleAddData(ModuleData * md[], char *key, char *value)
int moduleAddData(ModuleData **md, char *key, char *value)
{
char *mod_name = sstrdup(mod_current_module_name);
int index = 0;
ModuleData *current = NULL;
ModuleData *newHash = NULL;
ModuleData *lastHash = NULL;
ModuleDataItem *item = NULL;
ModuleDataItem *itemCurrent = NULL;
ModuleDataItem *lastItem = NULL;
index = CMD_HASH(mod_name);
if (!key || !value) {
alog("A module tried to use ModuleAddData() with one ore more NULL arguments... returning");
return MOD_ERR_PARAMS;
}
for (current = md[index]; current; current = current->next) {
if (stricmp(current->moduleName, mod_name) == 0)
lastHash = current;
}
if (!lastHash) {
newHash = malloc(sizeof(ModuleData));
if (!newHash) {
return MOD_ERR_MEMORY;
}
newHash->next = NULL;
newHash->di = NULL;
newHash->moduleName = strdup(mod_name);
md[index] = newHash;
lastHash = newHash;
}
/**
* Ok, at this point lastHash will always be a valid ModuleData struct, and will always be "our" module Data Struct
**/
for (itemCurrent = lastHash->di; itemCurrent;
itemCurrent = itemCurrent->next) {
if (stricmp(itemCurrent->key, key) == 0) {
item = itemCurrent;
}
lastItem = itemCurrent;
}
if (!item) {
item = malloc(sizeof(ModuleDataItem));
if (!item) {
return MOD_ERR_MEMORY;
}
item->next = NULL;
item->key = strdup(key);
item->value = strdup(value);
if (lastItem)
lastItem->next = item;
else
lastHash->di = item;
} else {
free(item->key);
free(item->value);
item->key = strdup(key);
item->value = strdup(value);
}
free(mod_name);
return MOD_ERR_OK;
char *mod_name = sstrdup(mod_current_module_name);
ModuleData *newData=NULL;
ModuleData *tmp = *md;
if ( !key || !value ) {
alog("A module tried to use ModuleAddData() with one ore more NULL arguments... returning");
return MOD_ERR_PARAMS;
}
moduleDelData(md,key); /* Remove any existing module data for this module with the same key */
newData = malloc(sizeof(ModuleData));
if(!newData) {
return MOD_ERR_MEMORY;
}
newData->moduleName = sstrdup(mod_name);
newData->key = sstrdup(key);
newData->value = sstrdup(value);
if(tmp) {
newData->next = tmp->next;
} else {
newData->next = NULL;
}
*md = newData;
free(mod_name);
if(debug) {
moduleDataDebug(md);
}
return MOD_ERR_OK;
}
/**
@@ -1831,33 +1818,17 @@ int moduleAddData(ModuleData * md[], char *key, char *value)
* @param key The key to find the data for
* @return the value paired to the given key will be returned, or NULL
**/
char *moduleGetData(ModuleData * md[], char *key)
char *moduleGetData(ModuleData **md, char *key)
{
char *mod_name = sstrdup(mod_current_module_name);
int index = 0;
char *ret = NULL;
ModuleData *current = NULL;
ModuleData *lastHash = NULL;
ModuleDataItem *itemCurrent = NULL;
index = CMD_HASH(mod_name);
if (!md) {
return NULL;
}
for (current = md[index]; current; current = current->next) {
if (stricmp(current->moduleName, mod_name) == 0)
lastHash = current;
}
if (lastHash) {
for (itemCurrent = lastHash->di; itemCurrent;
itemCurrent = itemCurrent->next) {
if (strcmp(itemCurrent->key, key) == 0) {
ret = strdup(itemCurrent->value);
}
}
ModuleData *current = *md;
while(current) {
if((stricmp(current->moduleName,mod_name)==0) && (stricmp(current->key,key)==0)) {
return sstrdup(current->value);
}
}
free(mod_name);
return ret;
return NULL;
}
/**
@@ -1866,39 +1837,31 @@ char *moduleGetData(ModuleData * md[], char *key)
* @param md The module data for the struct to be used
* @param key The key to delete the key/value pair for
**/
void moduleDelData(ModuleData * md[], char *key)
void moduleDelData(ModuleData **md, char *key)
{
char *mod_name = sstrdup(mod_current_module_name);
int index = 0;
ModuleData *current = NULL;
ModuleData *lastHash = NULL;
ModuleDataItem *itemCurrent = NULL;
ModuleDataItem *prev = NULL;
ModuleDataItem *next = NULL;
index = CMD_HASH(mod_name);
for (current = md[index]; current; current = current->next) {
if (stricmp(current->moduleName, mod_name) == 0)
lastHash = current;
}
if (lastHash) {
for (itemCurrent = lastHash->di; itemCurrent; itemCurrent = next) {
next = itemCurrent->next;
if (strcmp(key, itemCurrent->key) == 0) {
free(itemCurrent->key);
free(itemCurrent->value);
itemCurrent->next = NULL;
free(itemCurrent);
if (prev) {
prev->next = next;
} else {
lastHash->di = next;
}
} else {
prev = itemCurrent;
}
}
ModuleData *current = *md;
ModuleData *prev = NULL;
ModuleData *next = NULL;
if(key) {
while(current) {
next = current->next;
if((stricmp(current->moduleName,mod_name)==0) && (stricmp(current->key,key)==0)) {
if(prev) {
prev->next = current->next;
} else {
*md = current->next;
}
free(current->moduleName);
free(current->key);
free(current->value);
current->next = NULL;
free(current);
}
prev = current;;
current = next;
}
}
free(mod_name);
}
@@ -1909,35 +1872,29 @@ void moduleDelData(ModuleData * md[], char *key)
* do just about anything and everything, its safe to use from inside the module.
* @param md The module data for the struct to be used
**/
void moduleDelAllData(ModuleData * md[])
void moduleDelAllData(ModuleData **md)
{
char *mod_name = sstrdup(mod_current_module_name);
int index = 0;
ModuleData *current = NULL;
ModuleData *lastHash = NULL;
ModuleDataItem *itemCurrent = NULL;
ModuleDataItem *prev = NULL;
ModuleDataItem *next = NULL;
index = CMD_HASH(mod_name);
for (current = md[index]; current; current = current->next) {
if (stricmp(current->moduleName, mod_name) == 0)
lastHash = current;
}
if (lastHash) {
for (itemCurrent = lastHash->di; itemCurrent; itemCurrent = next) {
next = itemCurrent->next;
free(itemCurrent->key);
free(itemCurrent->value);
itemCurrent->next = NULL;
free(itemCurrent);
if (prev) {
prev->next = next;
} else {
lastHash->di = next;
}
}
ModuleData *current = *md;
ModuleData *prev = NULL;
ModuleData *next = NULL;
while(current) {
next = current->next;
if((stricmp(current->moduleName,mod_name)==0)) {
if(prev) {
prev->next = current->next;
} else {
*md = current->next;
}
free(current->moduleName);
free(current->key);
free(current->value);
current->next = NULL;
free(current);
}
prev = current;;
current = next;
}
free(mod_name);
}
@@ -1946,7 +1903,7 @@ void moduleDelAllData(ModuleData * md[])
* This will delete all module data used in any struct by module m.
* @param m The module to clear all data for
**/
void moduleDelAllDataMod(Module * m)
void moduleDelAllDataMod(Module *m)
{
boolean freeme = false;
int i, j;
@@ -1963,29 +1920,29 @@ void moduleDelAllDataMod(Module * m)
for (i = 0; i < 1024; i++) {
/* Remove the users */
for (user = userlist[i]; user; user = user->next) {
moduleDelAllData(user->moduleData);
moduleDelAllData(&user->moduleData);
}
/* Remove the nick Cores */
for (nc = nclists[i]; nc; nc = nc->next) {
moduleDelAllData(nc->moduleData);
moduleDelAllData(&nc->moduleData);
/* Remove any memo data for this nick core */
for (j = 0; j < nc->memos.memocount; j++) {
moduleCleanStruct(nc->memos.memos[j].moduleData);
moduleCleanStruct(&nc->memos.memos[j].moduleData);
}
}
/* Remove the nick Aliases */
for (na = nalists[i]; na; na = na->next) {
moduleDelAllData(na->moduleData);
moduleDelAllData(&na->moduleData);
}
}
for (i = 0; i < 256; i++) {
/* Remove any chan info data */
for (ci = chanlists[i]; ci; ci = ci->next) {
moduleDelAllData(ci->moduleData);
moduleDelAllData(&ci->moduleData);
/* Remove any memo data for this nick core */
for (j = 0; j < ci->memos.memocount; j++) {
moduleCleanStruct(ci->memos.memos[j].moduleData);
moduleCleanStruct(&ci->memos.memos[j].moduleData);
}
}
}
@@ -1997,30 +1954,56 @@ void moduleDelAllDataMod(Module * m)
}
/**
* Remove any data fro many module used in the given struct.
* Remove any data from any module used in the given struct.
* Useful for cleaning up when a User leave's the net, a NickCore is deleted, etc...
* @param moduleData the moduleData struct to "clean"
**/
void moduleCleanStruct(ModuleData * moduleData[])
{
ModuleData *md = NULL, *nextMd = NULL;
ModuleDataItem *item = NULL, *nextItem = NULL;
int i;
for (i = 0; i < 1024; i++) {
for (md = moduleData[i]; md; md = nextMd) {
nextMd = md->next;
for (item = md->di; item; item = nextItem) {
nextItem = item->next;
free(item->key);
free(item->value);
item->next = NULL;
free(item);
}
free(md->moduleName);
free(md);
}
void moduleCleanStruct(ModuleData **moduleData) {
ModuleData *current = *moduleData;;
ModuleData *next = NULL;
while(current) {
next = current->next;
free(current->moduleName);
free(current->key);
free(current->value);
current->next = NULL;
free(current);
current = next;
}
*moduleData = NULL;
}
/**
* Check the current version of anope against a given version number
* Specifiying -1 for minor,patch or build
* @param major The major version of anope, the first part of the verison number
* @param minor The minor version of anope, the second part of the version number
* @param patch The patch version of anope, the third part of the version number
* @param build The build revision of anope from SVN
* @return True if the version newer than the version specified.
**/
boolean moduleMinVersion(int major,int minor,int patch,int build) {
boolean ret=false;
if(VERSION_MAJOR>major) { // Def. new
ret = true;
} else if(VERSION_MAJOR == major) { // Might be newer
if(minor == -1) { return true; } // They dont care about minor
if(VERSION_MINOR > minor) { // Def. newer
ret = true;
} else if(VERSION_MINOR == minor) { // Might be newer
if(patch == -1) { return true; } // They dont care about patch
if(VERSION_PATCH > patch) {
ret = true;
} else if(VERSION_PATCH == patch) {
if(build == -1) { return true; } // They dont care about build
if(VERSION_BUILD >= build) {
ret = true;
}
}
}
}
return ret;
}
/* EOF */
+2 -6
View File
@@ -1331,9 +1331,7 @@ void db_mysql_load_cs_dbase(void)
memos->time = atoi(row[2]);
snprintf(memos->sender, NICKMAX, "%s", row[3]);
memos->text = sstrdup(row[4]);
for (m = 0; m < MAX_CMD_HASH; m++) {
memos->moduleData[m] = NULL;
}
memos->moduleData = NULL;
memos++;
}
}
@@ -1545,9 +1543,7 @@ void db_mysql_load_ns_dbase(void)
memos->time = atoi(row[2]);
snprintf(memos->sender, NICKMAX, "%s", row[3]);
memos->text = sstrdup(row[4]);
for (m = 0; m < MAX_CMD_HASH; m++) {
memos->moduleData[m] = NULL;
}
memos->moduleData = NULL;
memos++;
}
mysql_free_result(res);
+5 -9
View File
@@ -558,9 +558,7 @@ void load_old_ns_dbase(void)
memos->time = tmp32;
SAFE(read_buffer(memos->sender, f));
SAFE(read_string(&memos->text, f));
for (m = 0; m < MAX_CMD_HASH; m++) {
memos->moduleData[m] = NULL;
}
memos->moduleData = NULL;
}
}
@@ -757,9 +755,7 @@ void load_ns_dbase(void)
memos->time = tmp32;
SAFE(read_buffer(memos->sender, f));
SAFE(read_string(&memos->text, f));
for (m = 0; m < MAX_CMD_HASH; m++) {
memos->moduleData[m] = NULL;
}
memos->moduleData = NULL;
}
}
@@ -1562,13 +1558,13 @@ static int delcore(NickCore * nc)
if (nc->memos.memos) {
for (i = 0; i < nc->memos.memocount; i++) {
if (nc->memos.memos[i].text)
moduleCleanStruct(nc->memos.memos[i].moduleData);
moduleCleanStruct(&nc->memos.memos[i].moduleData);
free(nc->memos.memos[i].text);
}
free(nc->memos.memos);
}
moduleCleanStruct(nc->moduleData);
moduleCleanStruct(&nc->moduleData);
free(nc);
@@ -1666,7 +1662,7 @@ int delnick(NickAlias * na)
if (na->last_quit)
free(na->last_quit);
moduleCleanStruct(na->moduleData);
moduleCleanStruct(&na->moduleData);
free(na);
+1 -1
View File
@@ -3096,7 +3096,7 @@ static int do_sqline(User * u)
if (mask && (reason = strtok(NULL, ""))) {
/* We first do some sanity check on the proposed mask. */
if (strspn(mask, "*?") == strlen(mask)) {
if (strspn(mask, "*") == strlen(mask)) {
notice_lang(s_OperServ, u, USERHOST_MASK_TOO_WIDE, mask);
return MOD_CONT;
}
+1 -1
View File
@@ -242,7 +242,7 @@ void delete_user(User * user)
if (user->nickTrack)
free(user->nickTrack);
moduleCleanStruct(user->moduleData);
moduleCleanStruct(&user->moduleData);
if (debug >= 2)
alog("debug: delete_user(): delete from list");
+5 -1
View File
@@ -8,10 +8,14 @@
VERSION_MAJOR="1"
VERSION_MINOR="7"
VERSION_PATCH="5"
VERSION_BUILD="350"
VERSION_BUILD="351"
# $Log$
#
# BUILD : 1.7.5 (351)
# BUGS : N/A
# NOTES : Rewrote the internals of moduleData, this will save _lots_ of memory especially on larger networks. The downside is modules using it need to make a tiny, tiny change... :/
#
# BUILD : 1.7.5 (350)
# BUGS :
# NOTES : Changed mysql init checks so they are only done if mysql is