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
Remove needless volatile qualifier.
[simgrid.git]
/
src
/
xbt
/
dict_multi.c
diff --git
a/src/xbt/dict_multi.c
b/src/xbt/dict_multi.c
index
10e0776
..
a6f8887
100644
(file)
--- a/
src/xbt/dict_multi.c
+++ b/
src/xbt/dict_multi.c
@@
-1,19
+1,22
@@
-/* $Id$ */
-
/* dict_multi - dictionnaries of dictionnaries of ... of data */
/* dict_multi - dictionnaries of dictionnaries of ... of data */
-/* Copyright (c) 2003-2005 Martin Quinson. All rights reserved. */
+/* Copyright (c) 2004, 2005, 2006, 2007, 2008, 2009, 2010. The SimGrid Team.
+ * All rights reserved. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
+#ifdef XBT_USE_DEPRECATED
+
#include "dict_private.h"
#include "dict_private.h"
-XBT_LOG_NEW_DEFAULT_SUBCATEGORY(xbt_dict_multi,xbt_dict, "Dictionaries of multiple keys");
+XBT_LOG_NEW_DEFAULT_SUBCATEGORY(xbt_dict_multi, xbt_dict,
+ "Dictionaries of multiple keys");
-static void _free_dict(void*d) {
- VERB1("free dict %p",d);
- xbt_dict_free((xbt_dict_t*)&d);
+static void _free_dict(void *d)
+{
+ XBT_VERB("free dict %p", d);
+ xbt_dict_free((xbt_dict_t *) & d);
}
/** \brief Insert \e data under all the keys contained in \e keys, providing their sizes in \e lens.
}
/** \brief Insert \e data under all the keys contained in \e keys, providing their sizes in \e lens.
@@
-28,44
+31,40
@@
static void _free_dict(void*d) {
*/
void
*/
void
-xbt_multidict_set_ext(xbt_dict_t mdict,
- xbt_dynar_t keys, xbt_dynar_t lens,
- void *data, void_f_pvoid_t free_ctn) {
+xbt_multidict_set_ext(xbt_dict_t mdict,
+ xbt_dynar_t keys, xbt_dynar_t lens,
+ void *data, void_f_pvoid_t free_ctn)
+{
- xbt_ex_t e;
- xbt_dict_t thislevel,nextlevel=NULL;
+ xbt_dict_t thislevel, nextlevel = NULL;
int i;
unsigned long int thislen;
char *thiskey;
int i;
unsigned long int thislen;
char *thiskey;
- int keys_len
=
xbt_dynar_length(keys);
+ int keys_len
=
xbt_dynar_length(keys);
xbt_assert(xbt_dynar_length(keys) == xbt_dynar_length(lens));
xbt_assert(xbt_dynar_length(keys) == xbt_dynar_length(lens));
- xbt_assert
0
(keys_len, "Can't set a zero-long key set in a multidict");
+ xbt_assert(keys_len, "Can't set a zero-long key set in a multidict");
-
DEBUG2
("xbt_multidict_set(%p,%d)", mdict, keys_len);
+
XBT_DEBUG
("xbt_multidict_set(%p,%d)", mdict, keys_len);
- for (i=0 , thislevel = mdict ;
- i<keys_len-1 ;
- i++ , thislevel = nextlevel) {
+ for (i = 0, thislevel = mdict; i < keys_len - 1;
+ i++, thislevel = nextlevel) {
xbt_dynar_get_cpy(keys, i, &thiskey);
xbt_dynar_get_cpy(lens, i, &thislen);
xbt_dynar_get_cpy(keys, i, &thiskey);
xbt_dynar_get_cpy(lens, i, &thislen);
- DEBUG5("multi_set: at level %d, len=%ld, key=%p |%*s|", i, thislen, thiskey, (int)thislen,thiskey);
+ XBT_DEBUG("multi_set: at level %d, len=%ld, key=%p |%*s|", i, thislen,
+ thiskey, (int) thislen, thiskey);
/* search the dict of next level */
/* search the dict of next level */
- TRY {
- nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
- } CATCH(e) {
- if (e.category != not_found_error)
- RETHROW;
-
+ nextlevel = xbt_dict_get_or_null_ext(thislevel, thiskey, thislen);
+ if (nextlevel == NULL) {
/* make sure the dict of next level exists */
/* make sure the dict of next level exists */
-
xbt_ex_free(e
);
-
nextlevel=xbt_dict_new(
);
- VERB1("Create a dict (%p)",nextlevel);
-
xbt_dict_set_ext(thislevel, thiskey, thislen, nextlevel,
&_free_dict);
+
nextlevel = xbt_dict_new(
);
+
XBT_VERB("Create a dict (%p)", nextlevel
);
+ xbt_dict_set_ext(thislevel, thiskey, thislen, nextlevel,
+
&_free_dict);
}
}
}
}
@@
-83,25
+82,26
@@
xbt_multidict_set_ext(xbt_dict_t mdict,
* \arg free_ctn: function to use to free the pushed content on need
*/
void
* \arg free_ctn: function to use to free the pushed content on need
*/
void
-xbt_multidict_set(xbt_dict_t
mdict,
- xbt_dynar_t keys,
-
void *data, void_f_pvoid_t free_ctn)
{
- xbt_dynar_t lens = xbt_dynar_new(sizeof(unsigned long int),NULL);
+xbt_multidict_set(xbt_dict_t mdict,
+ xbt_dynar_t keys,
void *data, void_f_pvoid_t free_ctn)
+{
+ xbt_dynar_t lens = xbt_dynar_new(sizeof(unsigned long int),
NULL);
unsigned long i;
unsigned long i;
- xbt_ex_t e;
for (i = 0; i < xbt_dynar_length(keys); i++) {
for (i = 0; i < xbt_dynar_length(keys); i++) {
- char *thiskey = xbt_dynar_get_as(keys, i, char*);
+ char *thiskey = xbt_dynar_get_as(keys, i, char
*);
unsigned long int thislen = (unsigned long int) strlen(thiskey);
unsigned long int thislen = (unsigned long int) strlen(thiskey);
-
DEBUG2("Push %ld as level %lu length",
thislen, i);
- xbt_dynar_push(lens,&thislen);
+
XBT_DEBUG("Push %ld as level %lu length",
thislen, i);
+ xbt_dynar_push(lens,
&thislen);
}
TRY {
xbt_multidict_set_ext(mdict, keys, lens, data, free_ctn);
}
TRY {
xbt_multidict_set_ext(mdict, keys, lens, data, free_ctn);
- } CLEANUP {
+ }
+ TRY_CLEANUP {
xbt_dynar_free(&lens);
xbt_dynar_free(&lens);
- } CATCH(e) {
+ }
+ CATCH_ANONYMOUS {
RETHROW;
}
}
RETHROW;
}
}
@@
-116,30
+116,30
@@
xbt_multidict_set(xbt_dict_t mdict,
*
* Dynars are not modified during the operation.
*/
*
* Dynars are not modified during the operation.
*/
-void *
-xbt_multidict_get_ext(xbt_dict_t mdict,
-
xbt_dynar_t keys, xbt_dynar_t lens)
{
- xbt_dict_t thislevel,nextlevel;
+void *
xbt_multidict_get_ext(xbt_dict_t mdict,
+ xbt_dynar_t keys, xbt_dynar_t lens)
+{
+ xbt_dict_t thislevel,
nextlevel;
int i;
unsigned long int thislen;
char *thiskey;
int i;
unsigned long int thislen;
char *thiskey;
- int keys_len
=
xbt_dynar_length(keys);
+ int keys_len
=
xbt_dynar_length(keys);
xbt_assert(xbt_dynar_length(keys) == xbt_dynar_length(lens));
xbt_assert(xbt_dynar_length(keys) == xbt_dynar_length(lens));
- xbt_assert0(xbt_dynar_length(keys) >= 1, "Can't get a zero-long key set in a multidict");
+ xbt_assert(!xbt_dynar_is_empty(keys),
+ "Can't get a zero-long key set in a multidict");
-
DEBUG2
("xbt_multidict_get(%p, %ld)", mdict, xbt_dynar_length(keys));
+
XBT_DEBUG
("xbt_multidict_get(%p, %ld)", mdict, xbt_dynar_length(keys));
- for (i=0 , thislevel=mdict ;
- i<keys_len-1 ;
- i++ , thislevel = nextlevel) {
+ for (i = 0, thislevel = mdict; i < keys_len - 1;
+ i++, thislevel = nextlevel) {
xbt_dynar_get_cpy(keys, i, &thiskey);
xbt_dynar_get_cpy(lens, i, &thislen);
xbt_dynar_get_cpy(keys, i, &thiskey);
xbt_dynar_get_cpy(lens, i, &thislen);
-
DEBUG6
("multi_get: at level %d (%p), len=%ld, key=%p |%*s|",
- i, thislevel, thislen, thiskey, (int)
thislen,
thiskey);
+
XBT_DEBUG
("multi_get: at level %d (%p), len=%ld, key=%p |%*s|",
+ i, thislevel, thislen, thiskey, (int)
thislen,
thiskey);
/* search the dict of next level: let mismatch raise if not found */
nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
/* search the dict of next level: let mismatch raise if not found */
nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
@@
-151,20
+151,19
@@
xbt_multidict_get_ext(xbt_dict_t mdict,
return xbt_dict_get_ext(thislevel, thiskey, thislen);
}
return xbt_dict_get_ext(thislevel, thiskey, thislen);
}
-void *
-
xbt_multidict_get(xbt_dict_t mdict, xbt_dynar_t keys)
{
- xbt_dynar_t lens = xbt_dynar_new(sizeof(unsigned long int),NULL);
+void *
xbt_multidict_get(xbt_dict_t mdict, xbt_dynar_t keys)
+{
+ xbt_dynar_t lens = xbt_dynar_new(sizeof(unsigned long int),
NULL);
unsigned long i;
void *res;
for (i = 0; i < xbt_dynar_length(keys); i++) {
unsigned long i;
void *res;
for (i = 0; i < xbt_dynar_length(keys); i++) {
- char *thiskey = xbt_dynar_get_as(keys, i, char*);
+ char *thiskey = xbt_dynar_get_as(keys, i, char
*);
unsigned long int thislen = (unsigned long int) strlen(thiskey);
unsigned long int thislen = (unsigned long int) strlen(thiskey);
- xbt_dynar_push(lens,&thislen);
+ xbt_dynar_push(lens,
&thislen);
}
}
- res = xbt_multidict_get_ext(mdict, keys, lens),
- xbt_dynar_free(&lens);
+ res = xbt_multidict_get_ext(mdict, keys, lens), xbt_dynar_free(&lens);
return res;
}
return res;
}
@@
-183,21
+182,24
@@
xbt_multidict_get(xbt_dict_t mdict, xbt_dynar_t keys) {
*/
void
*/
void
-xbt_multidict_remove_ext(xbt_dict_t mdict, xbt_dynar_t keys, xbt_dynar_t lens) {
- xbt_dict_t thislevel,nextlevel=NULL;
- int i;
+xbt_multidict_remove_ext(xbt_dict_t mdict, xbt_dynar_t keys,
+ xbt_dynar_t lens)
+{
+ volatile xbt_dict_t thislevel;
+ volatile xbt_dict_t nextlevel = NULL;
+ volatile int i;
xbt_ex_t e;
unsigned long int thislen;
char *thiskey;
xbt_ex_t e;
unsigned long int thislen;
char *thiskey;
- int keys_len
=
xbt_dynar_length(keys);
+ int keys_len
=
xbt_dynar_length(keys);
xbt_assert(xbt_dynar_length(keys) == xbt_dynar_length(lens));
xbt_assert(xbt_dynar_length(keys) == xbt_dynar_length(lens));
- xbt_assert0(xbt_dynar_length(keys), "Can't remove a zero-long key set in a multidict");
+ xbt_assert(xbt_dynar_length(keys),
+ "Can't remove a zero-long key set in a multidict");
- for (i=0 , thislevel=mdict ;
- i<keys_len-1 ;
- i++ , thislevel = nextlevel) {
+ for (i = 0, thislevel = mdict; i < keys_len - 1;
+ i++, thislevel = nextlevel) {
xbt_dynar_get_cpy(keys, i, &thiskey);
xbt_dynar_get_cpy(lens, i, &thislen);
xbt_dynar_get_cpy(keys, i, &thiskey);
xbt_dynar_get_cpy(lens, i, &thislen);
@@
-205,7
+207,8
@@
xbt_multidict_remove_ext(xbt_dict_t mdict, xbt_dynar_t keys, xbt_dynar_t lens) {
/* search the dict of next level */
TRY {
nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
/* search the dict of next level */
TRY {
nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
- } CATCH(e) {
+ }
+ CATCH(e) {
/* If non-existant entry, nothing to do */
if (e.category == arg_error)
xbt_ex_free(e);
/* If non-existant entry, nothing to do */
if (e.category == arg_error)
xbt_ex_free(e);
@@
-220,24
+223,26
@@
xbt_multidict_remove_ext(xbt_dict_t mdict, xbt_dynar_t keys, xbt_dynar_t lens) {
xbt_dict_remove_ext(thislevel, thiskey, thislen);
}
xbt_dict_remove_ext(thislevel, thiskey, thislen);
}
-void
-xbt_multidict_remove(xbt_dict_t mdict, xbt_dynar_t keys) {
-
- xbt_ex_t e;
- xbt_dynar_t lens = xbt_dynar_new(sizeof(unsigned long int),NULL);
+void xbt_multidict_remove(xbt_dict_t mdict, xbt_dynar_t keys)
+{
+ xbt_dynar_t lens = xbt_dynar_new(sizeof(unsigned long int), NULL);
unsigned long i;
for (i = 0; i < xbt_dynar_length(keys); i++) {
unsigned long i;
for (i = 0; i < xbt_dynar_length(keys); i++) {
- char *thiskey = xbt_dynar_get_as(keys, i, char*);
+ char *thiskey = xbt_dynar_get_as(keys, i, char
*);
unsigned long int thislen = strlen(thiskey);
unsigned long int thislen = strlen(thiskey);
- xbt_dynar_push(lens,&thislen);
+ xbt_dynar_push(lens,
&thislen);
}
TRY {
xbt_multidict_remove_ext(mdict, keys, lens);
}
TRY {
xbt_multidict_remove_ext(mdict, keys, lens);
- } CLEANUP {
+ }
+ TRY_CLEANUP {
xbt_dynar_free(&lens);
xbt_dynar_free(&lens);
- } CATCH(e) {
+ }
+ CATCH_ANONYMOUS {
RETHROW;
}
}
RETHROW;
}
}
+
+#endif