Crashbug in der Auswertung, reference count bei magie-message nicht richtig (ADDMSG Makro)

This commit is contained in:
Enno Rehling 2004-04-18 12:24:33 +00:00
parent c1f37f78e3
commit a6e923896d

View file

@ -15,6 +15,7 @@
#include "message.h" #include "message.h"
#include "goodies.h" #include "goodies.h"
#include "log.h"
/* libc includes */ /* libc includes */
#include <assert.h> #include <assert.h>
@ -35,6 +36,11 @@ mt_new(const char * name, const char * args[])
int i, nparameters = 0; int i, nparameters = 0;
message_type * mtype = (message_type *)malloc(sizeof(message_type)); message_type * mtype = (message_type *)malloc(sizeof(message_type));
assert(name!=NULL);
if (name!=NULL) {
log_error(("Trying to create message_type with name=0x0\n"));
return NULL;
}
if (args!=NULL) for (nparameters=0;args[nparameters];++nparameters); if (args!=NULL) for (nparameters=0;args[nparameters];++nparameters);
mtype->name = strdup(name); mtype->name = strdup(name);
@ -83,15 +89,21 @@ mt_new_va(const char * name, ...)
message * message *
msg_create(const struct message_type * type, void * args[]) msg_create(const struct message_type * type, void * args[])
{ {
int i; int i;
message * msg = (message *)malloc(sizeof(message)); message * msg = (message *)malloc(sizeof(message));
msg->type = type;
msg->parameters = calloc(sizeof(void*), type->nparameters); assert(type!=NULL);
msg->refcount=1; if (type==NULL) {
for (i=0;i!=type->nparameters;++i) { log_error(("Trying to create message with type=0x0\n"));
msg->parameters[i] = args[i]; return NULL;
} }
return msg; msg->type = type;
msg->parameters = calloc(sizeof(void*), type->nparameters);
msg->refcount=1;
for (i=0;i!=type->nparameters;++i) {
msg->parameters[i] = args[i];
}
return msg;
} }
message * message *
@ -139,35 +151,37 @@ mt_register(const message_type * type)
{ {
unsigned int hash = hashstring(type->name) % MT_MAXHASH; unsigned int hash = hashstring(type->name) % MT_MAXHASH;
messagetype_list * mtl = messagetypes[hash]; messagetype_list * mtl = messagetypes[hash];
while (mtl && mtl->data!=type) mtl=mtl->next; while (mtl && mtl->data!=type) mtl=mtl->next;
if (mtl==NULL) { if (mtl==NULL) {
mtl = malloc(sizeof(messagetype_list)); mtl = malloc(sizeof(messagetype_list));
mtl->data = type; mtl->data = type;
mtl->next = messagetypes[hash]; mtl->next = messagetypes[hash];
messagetypes[hash] = mtl; messagetypes[hash] = mtl;
} }
return type; return type;
} }
void void
msg_free(message *msg) msg_free(message *msg)
{ {
assert(msg->refcount==0); assert(msg->refcount==0);
free((void*)msg->parameters); free((void*)msg->parameters);
free(msg); free(msg);
} }
void void
msg_release(struct message * msg) msg_release(struct message * msg)
{ {
if (--msg->refcount>0) return; assert(msg->refcount>0);
msg_free(msg); if (--msg->refcount>0) return;
msg_free(msg);
} }
struct message * struct message *
msg_addref(struct message * msg) msg_addref(struct message * msg)
{ {
++msg->refcount; assert(msg->refcount>0);
return msg; ++msg->refcount;
return msg;
} }