X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/806a8ef96de0bc6fbb75cadb0fbd8f3ef824d0b8..778f65057da68465382593cd036b6ee59ada54e9:/src/gras/DataDesc/datadesc.c diff --git a/src/gras/DataDesc/datadesc.c b/src/gras/DataDesc/datadesc.c index 6cb43be1a3..11ec857d64 100644 --- a/src/gras/DataDesc/datadesc.c +++ b/src/gras/DataDesc/datadesc.c @@ -11,16 +11,16 @@ #include "gras/DataDesc/datadesc_private.h" -XBT_LOG_NEW_DEFAULT_SUBCATEGORY(datadesc,gras,"Data description"); +XBT_LOG_NEW_DEFAULT_SUBCATEGORY(gras_ddt,gras,"Data description"); /* FIXME: make this host-dependent using a trick such as UserData*/ -xbt_set_t gras_datadesc_set_local=NULL; +/*@null@*/xbt_set_t gras_datadesc_set_local=NULL; /* callback for array size when sending strings */ static int -_strlen_cb(gras_cbps_t vars, void *data) { +_strlen_cb(/*@unused@*/gras_datadesc_type_t type,/*@unused@*/gras_cbps_t vars, void *data) { - return 1+(long int)strlen(data); + return 1+(int)strlen(data); } @@ -43,6 +43,9 @@ gras_datadesc_init(void) { gras_datadesc_set_local = xbt_set_new(); + + /* all known datatypes */ + ddt = gras_datadesc_scalar("signed char", gras_ddt_scalar_char, e_gras_dd_scalar_encoding_sint); @@ -59,6 +62,9 @@ gras_datadesc_init(void) { ddt = gras_datadesc_scalar("short int", gras_ddt_scalar_short, e_gras_dd_scalar_encoding_sint); + ddt = gras_datadesc_scalar("short", + gras_ddt_scalar_short, + e_gras_dd_scalar_encoding_sint); ddt = gras_datadesc_scalar("unsigned short int", gras_ddt_scalar_short, e_gras_dd_scalar_encoding_uint); @@ -79,6 +85,9 @@ gras_datadesc_init(void) { ddt = gras_datadesc_scalar("long int", gras_ddt_scalar_long, e_gras_dd_scalar_encoding_sint); + ddt = gras_datadesc_scalar("long", + gras_ddt_scalar_long, + e_gras_dd_scalar_encoding_sint); ddt = gras_datadesc_scalar("unsigned long int", gras_ddt_scalar_long, e_gras_dd_scalar_encoding_uint); @@ -112,6 +121,38 @@ gras_datadesc_init(void) { _strlen_cb); ddt = gras_datadesc_ref("string",ddt); + /* specific datatype: the exception type (for RPC) */ + ddt = gras_datadesc_struct("ex_t"); + gras_datadesc_struct_append(ddt,"msg",gras_datadesc_by_name("string")); + gras_datadesc_struct_append(ddt,"category",gras_datadesc_by_name("int")); + gras_datadesc_struct_append(ddt,"value",gras_datadesc_by_name("int")); + + gras_datadesc_struct_append(ddt,"remote",gras_datadesc_by_name("short int")); + + gras_datadesc_struct_append(ddt,"host",gras_datadesc_by_name("string")); + gras_datadesc_struct_append(ddt,"procname",gras_datadesc_by_name("string")); + gras_datadesc_struct_append(ddt,"pid",gras_datadesc_by_name("long int")); + gras_datadesc_struct_append(ddt,"file",gras_datadesc_by_name("string")); + gras_datadesc_struct_append(ddt,"line",gras_datadesc_by_name("int")); + gras_datadesc_struct_append(ddt,"func",gras_datadesc_by_name("string")); + gras_datadesc_struct_append(ddt,"used",gras_datadesc_by_name("int")); + gras_datadesc_cb_field_push(ddt,"used"); + gras_datadesc_struct_append(ddt,"bt_strings", + gras_datadesc_ref_pop_arr(gras_datadesc_by_name("string"))); + + gras_datadesc_struct_close(ddt); + + /* specific datatype: xbt_peer_t */ + ddt = gras_datadesc_struct("s_xbt_peer_t"); + gras_datadesc_struct_append(ddt,"name",gras_datadesc_by_name("string")); + gras_datadesc_struct_append(ddt,"port",gras_datadesc_by_name("int")); + gras_datadesc_struct_close(ddt); + + ddt = gras_datadesc_ref("xbt_peer_t",ddt); + + /* Dict containing the constant value (for the parsing macro) */ + gras_dd_constants = xbt_dict_new(); + } /** @@ -123,23 +164,16 @@ void gras_datadesc_exit(void) { VERB0("Exiting DataDesc"); xbt_set_free(&gras_datadesc_set_local); + xbt_dict_free(&gras_dd_constants); DEBUG0("Exited DataDesc"); } -/** - * gras_datadesc_get_name: - * - * Returns the name of a datadescription (to ease the debug) - */ -char * +/** This is mainly to debug */ +const char * gras_datadesc_get_name(gras_datadesc_type_t ddt) { - return ddt->name; + return ddt?(const char*)ddt->name:"(null)"; } -/** - * gras_datadesc_get_id: - * - * Returns the name of a datadescription (to ease the debug) - */ +/** This is mainly to debug */ int gras_datadesc_get_id(gras_datadesc_type_t ddt) { return ddt->code; @@ -152,7 +186,7 @@ gras_datadesc_get_id(gras_datadesc_type_t ddt) { * */ int gras_datadesc_size(gras_datadesc_type_t type) { - return type->size[GRAS_THISARCH]; + return type?type->size[GRAS_THISARCH]:0; } /**