A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
| inline |
side by side
model-checker : fix memory leak
[simgrid.git]
/
src
/
xbt
/
lib.c
diff --git
a/src/xbt/lib.c
b/src/xbt/lib.c
index
1141f8d
..
ccb1e0e
100644
(file)
--- a/
src/xbt/lib.c
+++ b/
src/xbt/lib.c
@@
-17,7
+17,7
@@
xbt_lib_t xbt_lib_new(void)
{
xbt_lib_t lib;
lib = xbt_new(s_xbt_lib_t, 1);
- lib->dict = xbt_dict_new
(
);
+ lib->dict = xbt_dict_new
_homogeneous(xbt_free
);
lib->levels = 0;
lib->free_f = NULL;
return lib;
@@
-60,7
+60,7
@@
void xbt_lib_set(xbt_lib_t lib, const char *key, int level, void *obj)
void **elts = xbt_dict_get_or_null(lib->dict, key);
if (!elts) {
elts = xbt_new0(void *, lib->levels);
- xbt_dict_set(lib->dict, key, elts,
xbt_free
);
+ xbt_dict_set(lib->dict, key, elts,
NULL
);
}
if (elts[level]) {
XBT_DEBUG("Replace %p by %p element under key '%s:%d'",
@@
-75,3
+75,13
@@
void *xbt_lib_get_or_null(xbt_lib_t lib, const char *key, int level)
void **elts = xbt_dict_get_or_null(lib->dict, key);
return elts ? elts[level] : NULL;
}
+
+xbt_dictelm_t xbt_lib_get_elm_or_null(xbt_lib_t lib, const char *key)
+{
+ return xbt_dict_get_elm_or_null(lib->dict, key);
+}
+
+void *xbt_lib_get_level(xbt_dictelm_t elm, int level){
+ void **elts = elm->content;
+ return elts ? elts[level] : NULL;
+}