X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/e649c3530c0f9b73ecf464f7b2834f4b3da004e3..22598191923908cf30fe0e54877e2993743c3ba1:/src/gras/DataDesc/datadesc.c diff --git a/src/gras/DataDesc/datadesc.c b/src/gras/DataDesc/datadesc.c index 052790b95e..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,13 +164,14 @@ void gras_datadesc_exit(void) { VERB0("Exiting DataDesc"); xbt_set_free(&gras_datadesc_set_local); + xbt_dict_free(&gras_dd_constants); DEBUG0("Exited DataDesc"); } /** This is mainly to debug */ -char * +const char * gras_datadesc_get_name(gras_datadesc_type_t ddt) { - return ddt->name; + return ddt?(const char*)ddt->name:"(null)"; } /** This is mainly to debug */ int @@ -144,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; } /**