Attempt to fix the heap-use-after-free error in mst_kruskal
For some reason the edges ware removed in one direction resulting in e->reverse point into invalid memory.
This commit is contained in:
parent
77eac310c5
commit
d49fd87dbc
1 changed files with 15 additions and 16 deletions
25
src/edge.c
25
src/edge.c
|
@ -83,24 +83,23 @@ void free_edge(edge_t *e) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void edge_add(edge_t *e) {
|
void edge_add(edge_t *e) {
|
||||||
splay_insert(edge_weight_tree, e);
|
if (!splay_insert(edge_weight_tree, e))
|
||||||
if (!e->from) {
|
logger(DEBUG_ALWAYS, LOG_ERR,
|
||||||
logger(DEBUG_ALWAYS, LOG_ERR, "edge_add(): e->from is NULL!");
|
"%s:%d: edge from: %s to: %s exists in edge_weight_tree",
|
||||||
abort();
|
__FUNCTION__, __LINE__, e->from->name, e->to->name);
|
||||||
}
|
|
||||||
|
|
||||||
if (!e->to) {
|
|
||||||
logger(DEBUG_ALWAYS, LOG_ERR, "edge_add(): e->to is NULL!");
|
|
||||||
abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
splay_insert(e->from->edge_tree, e);
|
|
||||||
|
|
||||||
|
if (splay_insert(e->from->edge_tree, e)) {
|
||||||
e->reverse = lookup_edge(e->to, e->from);
|
e->reverse = lookup_edge(e->to, e->from);
|
||||||
|
|
||||||
if(e->reverse)
|
if(e->reverse) {
|
||||||
|
if (e->reverse->reverse) {
|
||||||
|
logger(DEBUG_ALWAYS, LOG_ERR, "edge_add(): e->reverse->reverse should be NULL!");
|
||||||
|
abort();
|
||||||
|
}
|
||||||
e->reverse->reverse = e;
|
e->reverse->reverse = e;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void edge_del(edge_t *e) {
|
void edge_del(edge_t *e) {
|
||||||
if(e->reverse)
|
if(e->reverse)
|
||||||
|
|
Loading…
Reference in a new issue