X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/715c6e1f1a58b294f61b8c7d3536bd73218ba64a..a30eb8d63c2291f6b50b935cecf16139b372f9f2:/src/gras/DataDesc/ddt_create.c diff --git a/src/gras/DataDesc/ddt_create.c b/src/gras/DataDesc/ddt_create.c index 81f2a50800..0bbc088f2b 100644 --- a/src/gras/DataDesc/ddt_create.c +++ b/src/gras/DataDesc/ddt_create.c @@ -53,13 +53,13 @@ static gras_datadesc_type_t gras_ddt_new(const char *name) { */ gras_datadesc_type_t gras_datadesc_by_name(const char *name) { xbt_ex_t e; - gras_datadesc_type_t res; + gras_datadesc_type_t res = NULL; TRY { res = (gras_datadesc_type_t)xbt_set_get_by_name(gras_datadesc_set_local,name); } CATCH(e) { if (e.category != not_found_error) RETHROW; - xbt_ex_free(e); + xbt_ex_free(&e); res = NULL; } return res; @@ -70,13 +70,13 @@ gras_datadesc_type_t gras_datadesc_by_name(const char *name) { */ gras_datadesc_type_t gras_datadesc_by_id(long int code) { xbt_ex_t e; - gras_datadesc_type_t res; + gras_datadesc_type_t res=NULL; TRY { res = (gras_datadesc_type_t)xbt_set_get_by_id(gras_datadesc_set_local,code); } CATCH(e) { if (e.category != not_found_error) RETHROW; - xbt_ex_free(e); + xbt_ex_free(&e); res = NULL; } return res; @@ -627,11 +627,11 @@ gras_datadesc_dynar(gras_datadesc_type_t elm_t, return res; } -xbt_error_t + +gras_datadesc_type_t gras_datadesc_import_nws(const char *name, const DataDescriptor *desc, - unsigned long howmany, - /* OUT */ gras_datadesc_type_t *dst) { + unsigned long howmany) { THROW_UNIMPLEMENTED; } @@ -692,6 +692,7 @@ void gras_datadesc_cb_field_send (gras_datadesc_type_t type, field->send = send; } + /** * The value, which must be an int, unsigned int, long int or unsigned long int * is pushed to the stacks of sizes and can then be retrieved with @@ -719,6 +720,38 @@ void gras_datadesc_cb_field_push (gras_datadesc_type_t type, xbt_abort(); } } + +/** + * Any previously pushed value is poped and the field value is multiplied to + * it. The result is then pushed back into the stack of sizes. It can then be + * retrieved with \ref gras_datadesc_ref_pop_arr or directly with \ref + * gras_cbps_i_pop. + * + * The field must be an int, unsigned int, long int or unsigned long int. + */ +void gras_datadesc_cb_field_push_multiplier (gras_datadesc_type_t type, + const char *field_name) { + + gras_dd_cat_field_t field=gras_dd_find_field(type,field_name); + gras_datadesc_type_t sub_type=field->type; + + DEBUG3("add a MPUSHy cb to '%s' field (type '%s') of '%s'", + field_name,sub_type->name,type->name); + if (!strcmp("int",sub_type->name)) { + field->send = gras_datadesc_cb_push_int_mult; + } else if (!strcmp("unsigned int",sub_type->name)) { + field->send = gras_datadesc_cb_push_uint_mult; + } else if (!strcmp("long int",sub_type->name)) { + field->send = gras_datadesc_cb_push_lint_mult; + } else if (!strcmp("unsigned long int",sub_type->name)) { + field->send = gras_datadesc_cb_push_ulint_mult; + } else { + ERROR1("Field %s is not an int, unsigned int, long int neither unsigned long int", + sub_type->name); + xbt_abort(); + } +} + /** * The given datadesc must be a struct or union (abort if not). * (useful to put the function pointers to the right value, for example)