{
static int AX_ptr = 0;
static int surfxml_bufferstack_size = 2048;
- static int surfxml_buffer_stack_stack_ptr = 0;
- static int surfxml_buffer_stack_stack[1024];
/* allocating memory for the buffer, I think 2kB should be enough */
surfxml_bufferstack = xbt_new0(char, surfxml_bufferstack_size);
/* 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); \
memset(surfxml_bufferstack,0,surfxml_bufferstack_size); } 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)
+ surfxml_buffer_stack_stack[surfxml_buffer_stack_stack_ptr] = AX_ptr;\
+ DEBUG2("surfxml_buffer_stack_stack[%d]=%d",surfxml_buffer_stack_stack_ptr,surfxml_buffer_stack_stack[surfxml_buffer_stack_stack_ptr]);\
+ surfxml_buffer_stack_stack_ptr++;\
+ STag_surfxml_##tag(); \
+ }while(0)
+
#define SURFXML_END_TAG(tag) do{ \
- AX_ptr = surfxml_buffer_stack_stack[surfxml_buffer_stack_stack_ptr-1];\
- surfxml_buffer_stack_stack_ptr--;\
- ETag_surfxml_##tag();\
- } while(0)
+ surfxml_buffer_stack_stack_ptr--;\
+ AX_ptr = surfxml_buffer_stack_stack[surfxml_buffer_stack_stack_ptr-1];\
+ DEBUG1("AX_ptr=%d",AX_ptr);\
+ 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);
xbt_dynar_t radical_elements;
xbt_dynar_t radical_ends;
- static int surfxml_buffer_stack_stack_ptr = 0;
- static int surfxml_buffer_stack_stack[1024];
+ static unsigned int surfxml_buffer_stack_stack_ptr = 1;
+ static unsigned int surfxml_buffer_stack_stack[1024];
+
+ surfxml_buffer_stack_stack[0]= 0;
surfxml_bufferstack_push(1);
surf_parse_get_int(&start, xbt_dynar_get_as(radical_ends, 0, char *));
surf_parse_get_int(&end, xbt_dynar_get_as(radical_ends, 1, char *));
+ DEBUG2("Create hosts and links from %d to %d",start,end);
for (i = start; i <= end; i++)
{
host_id = bprintf("%s%d%s", cluster_prefix, i, cluster_suffix);
static char *old_buff = NULL;
static void surf_parse_error(char *msg);
+unsigned int surfxml_buffer_stack_stack_ptr;
+unsigned int surfxml_buffer_stack_stack[1024];
+
+
void surfxml_bufferstack_push(int new)
{
if (!new)
void parse_platform_file(const char *file)
{
int parse_status;
+
+ surfxml_buffer_stack_stack_ptr = 1;
+ surfxml_buffer_stack_stack[0] = 0;
+
surf_parse_open(file);
init_data();
parse_status = surf_parse();