-void dump_edges(void)
-{
- avl_node_t *node;
- edge_t *e;
- char *from_address, *to_address;
-cp
- syslog(LOG_DEBUG, _("Edges:"));
-
- for(node = edge_tree->head; node; node = node->next)
- {
- e = (edge_t *)node->data;
- from_address = address2str(e->from.address);
- to_address = address2str(e->to.address);
- syslog(LOG_DEBUG, _(" %s at %s port %hd - %s at %s port %hd options %ld weight %d"),
- e->from.node->name, from_address, e->from.port,
- e->to.node->name, to_address, e->to.port,
- e->options, e->weight);
- free(from_address);
- free(to_address);
- }
-
- syslog(LOG_DEBUG, _("End of edges."));
-cp
+edge_t *lookup_edge(node_t *from, node_t *to) {
+ assert(from);
+ assert(to);
+
+ edge_t v;
+
+ v.from = from;
+ v.to = to;
+
+ return splay_search(from->edge_tree, &v);