xbt_multidict_set_ext(xbt_dict_t mdict,
xbt_dynar_t keys, xbt_dynar_t lens,
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_error_t errcode;
- xbt_dict_t thislevel,nextlevel;
+ void *data, void_f_pvoid_t free_ctn) {
+
+ xbt_ex_t e;
+ xbt_dict_t thislevel,nextlevel=NULL;
DEBUG5("multi_set: at level %d, len=%ld, key=%p |%*s|", i, thislen, thiskey, (int)thislen,thiskey);
/* search the dict of next level */
DEBUG5("multi_set: at level %d, len=%ld, key=%p |%*s|", i, thislen, thiskey, (int)thislen,thiskey);
/* search the dict of next level */
- TRYCATCH(xbt_dict_get_ext(thislevel, thiskey, thislen, (void*)&nextlevel), mismatch_error);
-
- /* make sure the dict of next level exists */
- if (errcode == mismatch_error) {
+ TRY {
+ nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
+ } CATCH(e) {
+ if (e.category != not_found_error)
+ RETHROW;
+
+ /* 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();
VERB1("Create a dict (%p)",nextlevel);
xbt_dict_set_ext(thislevel, thiskey, thislen, nextlevel, &_free_dict);
xbt_dynar_get_cpy(lens, i, &thislen);
xbt_dict_set_ext(thislevel, thiskey, thislen, data, free_ctn);
xbt_dynar_get_cpy(lens, i, &thislen);
xbt_dict_set_ext(thislevel, thiskey, thislen, data, free_ctn);
* \arg data: what to store in the structure
* \arg free_ctn: function to use to free the pushed content on need
*/
* \arg data: what to store in the structure
* \arg free_ctn: function to use to free the pushed content on need
*/
for (i = 0; i < xbt_dynar_length(keys); i++) {
char *thiskey = xbt_dynar_get_as(keys, i, char*);
unsigned long int thislen = (unsigned long int) strlen(thiskey);
for (i = 0; i < xbt_dynar_length(keys); i++) {
char *thiskey = xbt_dynar_get_as(keys, i, char*);
unsigned long int thislen = (unsigned long int) strlen(thiskey);
- errcode = xbt_multidict_set_ext(mdict, keys, lens, data, free_ctn);
- xbt_dynar_free(&lens);
- return errcode;
+ TRY {
+ xbt_multidict_set_ext(mdict, keys, lens, data, free_ctn);
+ } CLEANUP {
+ xbt_dynar_free(&lens);
+ } CATCH(e) {
+ RETHROW;
+ }
i, thislevel, thislen, thiskey, (int)thislen,thiskey);
/* search the dict of next level: let mismatch raise if not found */
i, thislevel, thislen, thiskey, (int)thislen,thiskey);
/* search the dict of next level: let mismatch raise if not found */
- TRYOLD(xbt_dict_get_ext(thislevel, thiskey, thislen, (void*)&nextlevel));
+ nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
}
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);
- return xbt_dict_get_ext(thislevel, thiskey, thislen, data);
+ return xbt_dict_get_ext(thislevel, thiskey, thislen);
for (i = 0; i < xbt_dynar_length(keys); i++) {
char *thiskey = xbt_dynar_get_as(keys, i, char*);
for (i = 0; i < xbt_dynar_length(keys); i++) {
char *thiskey = xbt_dynar_get_as(keys, i, char*);
- errcode = xbt_multidict_get_ext(mdict, keys, lens, data),
+ res = xbt_multidict_get_ext(mdict, keys, lens),
xbt_dynar_get_cpy(lens, i, &thislen);
/* search the dict of next level */
xbt_dynar_get_cpy(lens, i, &thislen);
/* search the dict of next level */
- TRYCATCH(xbt_dict_get_ext(thislevel, thiskey, thislen, (void*)&nextlevel), mismatch_error);
-
- /* If non-existant entry, nothing to do */
- if (errcode == mismatch_error)
- return no_error;
+ TRY {
+ nextlevel = xbt_dict_get_ext(thislevel, thiskey, thislen);
+ } CATCH(e) {
+ /* If non-existant entry, nothing to do */
+ if (e.category == arg_error)
+ xbt_ex_free(e);
+ else
+ RETHROW;
+ }
}
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);
for (i = 0; i < xbt_dynar_length(keys); i++) {
char *thiskey = xbt_dynar_get_as(keys, i, char*);
unsigned long int thislen = strlen(thiskey);
xbt_dynar_push(lens,&thislen);
}
for (i = 0; i < xbt_dynar_length(keys); i++) {
char *thiskey = xbt_dynar_get_as(keys, i, char*);
unsigned long int thislen = strlen(thiskey);
xbt_dynar_push(lens,&thislen);
}