Line data Source code
1 : /* 2 : * Copyright (c) 2013 Juniper Networks, Inc. All rights reserved. 3 : */ 4 : 5 : #include "db/db_graph_vertex.h" 6 : 7 : #include "db/db_graph.h" 8 : #include "db/db_graph_edge.h" 9 : 10 : using namespace boost; 11 : 12 3707041 : DBGraphVertex::adjacency_iterator::adjacency_iterator() 13 3707041 : : graph_(NULL) { 14 3707041 : } 15 : 16 1141972 : DBGraphVertex::adjacency_iterator::adjacency_iterator(DBGraph *graph, 17 1141972 : Vertex vertex) 18 1141972 : : graph_(graph) { 19 1141972 : boost::tie(iter_, end_) = adjacent_vertices(vertex, *graph_->graph()); 20 1141972 : } 21 : 22 3463213 : DBGraphVertex &DBGraphVertex::adjacency_iterator::dereference() const { 23 3463213 : Vertex adj = *iter_; 24 3463213 : return *(graph_->vertex_data(adj)); 25 : } 26 : 27 1451403 : DBGraphVertex::edge_iterator::edge_iterator() 28 1451403 : : graph_(NULL), vertex_(NULL) { 29 1451403 : } 30 : 31 360503 : DBGraphVertex::edge_iterator::edge_iterator(DBGraph *graph, 32 360503 : DBGraphVertex *vertex) 33 360503 : : graph_(graph), vertex_(vertex) { 34 360503 : boost::tie(iter_, end_) = out_edges(vertex->vertex(), *graph_->graph()); 35 360503 : } 36 : 37 1087939 : DBGraphEdge &DBGraphVertex::edge_iterator::dereference() const { 38 1087939 : Edge edge = *iter_; 39 2175878 : return *(graph_->edge_data(edge)); 40 : } 41 : 42 288772 : DBGraphVertex *DBGraphVertex::edge_iterator::target() const { 43 288772 : Edge descriptor = *iter_; 44 288772 : DBGraphEdge *edge = graph_->edge_data(descriptor); 45 288772 : DBGraphVertex *v_target = edge->target(graph_); 46 288772 : if (v_target == vertex_) { 47 114814 : return edge->source(graph_); 48 : } 49 173958 : return v_target; 50 : } 51 : 52 108108 : bool DBGraphVertex::HasAdjacencies(DBGraph *graph) const { 53 108108 : DBGraphBase::adjacency_iterator iter, end; 54 108108 : boost::tie(iter, end) = adjacent_vertices(vertex_id_, *graph->graph()); 55 216216 : return (iter != end); 56 : }