X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/14d9356173a951022bf9bdadaa77652c67734a63..70388188c97f56fbe2b645c9b00dcb05d0b86509:/include/surf/surfxml_parse.h diff --git a/include/surf/surfxml_parse.h b/include/surf/surfxml_parse.h index fc6c31cf40..63bdca1b1e 100644 --- a/include/surf/surfxml_parse.h +++ b/include/surf/surfxml_parse.h @@ -12,13 +12,11 @@ #include "xbt/function_types.h" #include "xbt/dict.h" - SG_BEGIN_DECL() /* Hook for the different tags. All the functions which pointer to are push into here are run when the tag is encountered */ XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_platform_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_platform_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_host_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_host_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_router_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_router_cb_list; @@ -26,41 +24,44 @@ XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_link_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_link_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_route_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_route_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_link_c_ctn_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_link_c_ctn_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_link_ctn_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_link_ctn_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_process_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_process_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_argument_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_argument_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_prop_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_prop_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_set_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_set_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_foreach_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_foreach_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_route_c_multi_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_route_c_multi_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_cluster_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_cluster_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_trace_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_trace_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_trace_c_connect_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_trace_c_connect_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_trace_connect_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_trace_connect_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_random_cb_list; XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_random_cb_list; -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_AS_cb_list; // added by david -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_AS_cb_list; // added by david -XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_gateway_cb_list; // added by david -XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_gateway_cb_list; // added by david - +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_AS_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_AS_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_ASroute_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_ASroute_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_bypassRoute_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_bypassRoute_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_cluster_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_cluster_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_peer_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_peer_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_config_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_config_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) STag_surfxml_include_cb_list; +XBT_PUBLIC_DATA(xbt_dynar_t) ETag_surfxml_include_cb_list; XBT_PUBLIC(void) surf_parse_open(const char *file); XBT_PUBLIC(void) surf_parse_close(void); -XBT_PUBLIC(void) surf_parse_reset_parser(void); +XBT_PUBLIC(void) surf_parse_init_callbacks(void); +XBT_PUBLIC(void) surf_parse_reset_callbacks(void); XBT_PUBLIC(void) surf_parse_free_callbacks(void); XBT_PUBLIC(void) surf_parse_get_double(double *value, const char *string); XBT_PUBLIC(void) surf_parse_get_int(int *value, const char *string); - +XBT_PUBLIC(void) surf_parse_add_callback_config(void); +XBT_PUBLIC(void) surf_parse_models_setup(void); /* Prototypes of the functions offered by flex */ XBT_PUBLIC(int) surf_parse_lex(void); XBT_PUBLIC(int) surf_parse_get_lineno(void); @@ -80,6 +81,10 @@ XBT_PUBLIC_DATA(int_f_void_t) surf_parse; /* Entry-point to the parser. Se /* Set of macros to make the bypassing work easier. * See examples/msg/masterslave_bypass.c for an example of use */ + +extern unsigned int surfxml_buffer_stack_stack_ptr; +extern unsigned int surfxml_buffer_stack_stack[1024]; + #define SURFXML_BUFFER_SET(key,val) do { \ AX_surfxml_##key=AX_ptr; \ strcpy(A_surfxml_##key,val); \ @@ -89,12 +94,22 @@ XBT_PUBLIC_DATA(int_f_void_t) surf_parse; /* Entry-point to the parser. Se AX_ptr = 0; \ memset(surfxml_bufferstack,0,surfxml_bufferstack_size); } while(0) -#define SURFXML_START_TAG(tag) STag_surfxml_##tag() -#define SURFXML_END_TAG(tag) do { ETag_surfxml_##tag(); SURFXML_BUFFER_RESET(); } while(0) +#define SURFXML_START_TAG(tag) do{ \ + surfxml_buffer_stack_stack[surfxml_buffer_stack_stack_ptr] = AX_ptr;\ + surfxml_buffer_stack_stack_ptr++;\ + STag_surfxml_##tag(); \ + }while(0) + +#define SURFXML_END_TAG(tag) do{ \ + surfxml_buffer_stack_stack_ptr--;\ + AX_ptr = surfxml_buffer_stack_stack[surfxml_buffer_stack_stack_ptr-1];\ + ETag_surfxml_##tag();\ + } while(0) XBT_PUBLIC(void) surfxml_add_callback(xbt_dynar_t cb_list, void_f_void_t function); - +XBT_PUBLIC(void) surfxml_del_callback(xbt_dynar_t cb_list, + void_f_void_t function); SG_END_DECL() #endif