Traverser::Traverser() { // initialise the handler-function array to reduce the number of resizes m_vHandlerFuncs.resize(OC_NODES_END, 0); // register handler functions register_handler_function(OC_GROUP_NODE, &Traverser::handle_group); register_handler_function(OC_BOXED_GROUP_NODE, &Traverser::handle_boxed_group); }
logger *new_framelog(event_handler *h, void *database, char *event_name, char *subframe_varname, char *buffer_varname) { struct framelog *ret; int event_id; database_event_format f; int i; ret = calloc(1, sizeof(struct framelog)); if (ret == NULL) abort(); ret->update_only_at_sf9 = 1; ret->common.event_name = strdup(event_name); if (ret->common.event_name == NULL) abort(); ret->database = database; event_id = event_id_from_name(database, event_name); ret->common.handler_id = register_handler_function(h,event_id,_event,ret); f = get_format(database, event_id); /* look for subframe and buffer args */ ret->subframe_arg = -1; ret->buffer_arg = -1; for (i = 0; i < f.count; i++) { if (!strcmp(f.name[i], subframe_varname)) ret->subframe_arg = i; if (!strcmp(f.name[i], buffer_varname)) ret->buffer_arg = i; } if (ret->subframe_arg == -1) { printf("%s:%d: subframe argument '%s' not found in event '%s'\n", __FILE__, __LINE__, subframe_varname, event_name); abort(); } if (ret->buffer_arg == -1) { printf("%s:%d: buffer argument '%s' not found in event '%s'\n", __FILE__, __LINE__, buffer_varname, event_name); abort(); } if (strcmp(f.type[ret->subframe_arg], "int") != 0) { printf("%s:%d: argument '%s' has wrong type (should be 'int')\n", __FILE__, __LINE__, subframe_varname); abort(); } if (strcmp(f.type[ret->buffer_arg], "buffer") != 0) { printf("%s:%d: argument '%s' has wrong type (should be 'buffer')\n", __FILE__, __LINE__, buffer_varname); abort(); } return ret; }
logger *new_iqlog(event_handler *h, void *database, char *event_name, char *nb_rb, char *N_RB_UL, char *symbols_per_tti, char *buffer_varname) { struct iqlog *ret; int event_id; database_event_format f; int i; ret = calloc(1, sizeof(struct iqlog)); if (ret == NULL) abort(); ret->common.event_name = strdup(event_name); if (ret->common.event_name == NULL) abort(); ret->database = database; event_id = event_id_from_name(database, event_name); ret->common.handler_id = register_handler_function(h,event_id,_event,ret); f = get_format(database, event_id); /* look for args */ ret->nb_rb_arg = -1; ret->N_RB_UL_arg = -1; ret->symbols_per_tti_arg = -1; ret->buffer_arg = -1; for (i = 0; i < f.count; i++) { if (!strcmp(f.name[i], nb_rb)) ret->nb_rb_arg = i; if (!strcmp(f.name[i], N_RB_UL)) ret->N_RB_UL_arg = i; if (!strcmp(f.name[i], symbols_per_tti)) ret->symbols_per_tti_arg = i; if (!strcmp(f.name[i], buffer_varname)) ret->buffer_arg = i; } if (ret->nb_rb_arg == -1) { printf("%s:%d: argument '%s' not found in event '%s'\n", __FILE__, __LINE__, nb_rb, event_name); abort(); } if (ret->N_RB_UL_arg == -1) { printf("%s:%d: argument '%s' not found in event '%s'\n", __FILE__, __LINE__, N_RB_UL, event_name); abort(); } if (ret->symbols_per_tti_arg == -1) { printf("%s:%d: argument '%s' not found in event '%s'\n", __FILE__, __LINE__, symbols_per_tti, event_name); abort(); } if (ret->buffer_arg == -1) { printf("%s:%d: buffer argument '%s' not found in event '%s'\n", __FILE__, __LINE__, buffer_varname, event_name); abort(); } if (strcmp(f.type[ret->nb_rb_arg], "int") != 0) { printf("%s:%d: argument '%s' has wrong type (should be 'int')\n", __FILE__, __LINE__, nb_rb); abort(); } if (strcmp(f.type[ret->N_RB_UL_arg], "int") != 0) { printf("%s:%d: argument '%s' has wrong type (should be 'int')\n", __FILE__, __LINE__, N_RB_UL); abort(); } if (strcmp(f.type[ret->symbols_per_tti_arg], "int") != 0) { printf("%s:%d: argument '%s' has wrong type (should be 'int')\n", __FILE__, __LINE__, symbols_per_tti); abort(); } if (strcmp(f.type[ret->buffer_arg], "buffer") != 0) { printf("%s:%d: argument '%s' has wrong type (should be 'buffer')\n", __FILE__, __LINE__, buffer_varname); abort(); } return ret; }