X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/6521142974bf561e632684f99fd1708726e474a0..174ff5d9a704689bdbeb8aaabe4557bcd96841c4:/src/xbt/dict_multi.c diff --git a/src/xbt/dict_multi.c b/src/xbt/dict_multi.c index c317b81e69..a11b2c96ce 100644 --- a/src/xbt/dict_multi.c +++ b/src/xbt/dict_multi.c @@ -1,19 +1,20 @@ -/* $Id$ */ - /* 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. */ #include "dict_private.h" -XBT_LOG_NEW_DEFAULT_SUBCATEGORY(dict_multi,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. @@ -28,50 +29,46 @@ static void _free_dict(void*d) { */ 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_ex_t e; - xbt_dict_t thislevel,nextlevel=NULL; +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_dict_t thislevel, nextlevel = NULL; 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_assert0(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= 1, "Can't get a zero-long key set in a multidict"); - - DEBUG2("xbt_multidict_get(%p, %ld)", mdict, xbt_dynar_length(keys)); - - for (i=0 , thislevel=mdict ; - i= 1, + "Can't get a zero-long key set in a multidict"); + + XBT_DEBUG("xbt_multidict_get(%p, %ld)", mdict, xbt_dynar_length(keys)); + + 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); - 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); } - + xbt_dynar_get_cpy(keys, i, &thiskey); xbt_dynar_get_cpy(lens, i, &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); - int i; +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++) { - 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); - 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; } @@ -183,59 +179,62 @@ xbt_multidict_get(xbt_dict_t mdict, xbt_dynar_t keys) { */ void -xbt_multidict_remove_ext(xbt_dict_t mdict, xbt_dynar_t keys, xbt_dynar_t lens) { - xbt_dict_t thislevel,nextlevel=NULL; +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_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_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