forked from github/server
Crashbug in der Auswertung, reference count bei magie-message nicht richtig (ADDMSG Makro)
This commit is contained in:
parent
c1f37f78e3
commit
a6e923896d
1 changed files with 38 additions and 24 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue