view include/mb_prop.h @ 1401:2fc1f54a1a3b

Mainly fix the clone_from_subtree to update the children of the parent node. We need to clearify all related codes in the future to make the logic more clear.
author wycc
date Sun, 03 Apr 2011 18:12:42 +0800
parents 586e50f82c1f
children
line wrap: on
line source

// -*- indent-tabs-mode: t; tab-width: 8; c-basic-offset: 4; -*-
// vim: sw=4:ts=8:sts=4
#ifndef __MB_PROP_H_
#define __MB_PROP_H_

#include "mb_tools.h"

/*! \defgroup mb_prop_grp Property
 * \brief A way the modules can set up their own properties on objects.
 *
 * Properties are key-value pairs that are associated with objects.
 * MadButterfly associate a property store for each object (coord or shape)
 * to keep property values.  Every property is identified by a ID; an
 * integer.  Programmer can use a ID to set/get value to/from a property
 * store.  The ID should be unique in a property store.
 *
 * \todo Add a free function pointer on entries to release resources when
 *	the store is destroy. (See: \ref mouse.c)
 *
 * @{
 */

typedef struct _mb_prop_entry mb_prop_entry_t;
typedef struct _mb_prop_store mb_prop_store_t;

struct _mb_prop_entry {
    int id;
    void *value;
    mb_prop_entry_t *next;
};

/*! \brief Property IDs. */
enum {
    PROP_DUMMY,
    PROP_MEVT_OB_CNT,
    PROP_MEVT_OBSERVER,
    PROP_JSOBJ,
    PROP_LAST
};

struct _mb_prop_store {
    elmpool_t *entry_pool;
    STAILQ(mb_prop_entry_t) entries;
};

#define mb_prop_store_init(prop_store, pent_pool)		\
    do {							\
	(prop_store)->entry_pool = pent_pool;			\
	STAILQ_INIT((prop_store)->entries);			\
    } while(0)

void mb_prop_store_destroy(mb_prop_store_t *prop_store);
void *mb_prop_set(mb_prop_store_t *prop_store, int id, void *value);
void *mb_prop_get(mb_prop_store_t *prop_store, int id);
void mb_prop_del(mb_prop_store_t *prop_store, int id);
int mb_prop_has(mb_prop_store_t *prop_store, int id);

/* @} */

#endif /* __MB_PROP_H_ */