Program Listing for File DGraph.h#
↰ Return to documentation for file (src/midend/programAnalysis/OpenAnalysis/Utils/DGraph.h)
// $Id: DGraph.h,v 1.2 2006/04/24 00:21:34 dquinlan Exp $
// -*-C++-*-
// * BeginRiceCopyright *****************************************************
//
// Copyright ((c)) 2002, Rice University
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
//
// * Neither the name of Rice University (RICE) nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// This software is provided by RICE and contributors "as is" and any
// express or implied warranties, including, but not limited to, the
// implied warranties of merchantability and fitness for a particular
// purpose are disclaimed. In no event shall RICE or contributors be
// liable for any direct, indirect, incidental, special, exemplary, or
// consequential damages (including, but not limited to, procurement of
// substitute goods or services; loss of use, data, or profits; or
// business interruption) however caused and on any theory of liability,
// whether in contract, strict liability, or tort (including negligence
// or otherwise) arising in any way out of the use of this software, even
// if advised of the possibility of such damage.
//
// ******************************************************* EndRiceCopyright *
// Best seen in 120-column wide window (or print in landscape mode).
//--------------------------------------------------------------------------------------------------------------------
// This file is part of Mint.
// Arun Chauhan (achauhan@cs.rice.edu), Dept of Computer Science, Rice University, 2001.
//--------------------------------------------------------------------------------------------------------------------
#ifndef DGraph_H
#define DGraph_H
// Mint headers
#include "BaseGraph.h"
//--------------------------------------------------------------------------------------------------------------------
// DGraph
//--------------------------------------------------------------------------------------------------------------------
class DGraph : public BaseGraph {
public:
class DFSIterator;
class BFSIterator;
class IncomingEdgesIterator;
class OutgoingEdgesIterator;
class SourceNodesIterator;
class SinkNodesIterator;
class Edge;
class Node;
friend class DFSIterator;
friend class BFSIterator;
//------------------------------------------------------------------------------------------------------------------
class Node : public BaseGraph::Node {
public:
Node () {}
virtual ~Node () {
incoming_edges.clear();
outgoing_edges.clear();
}
int num_incoming () { return incoming_edges.size(); }
int num_outgoing () { return outgoing_edges.size(); }
private:
std::list<Edge*> incoming_edges;
std::list<Edge*> outgoing_edges;
friend class DGraph;
friend class DGraph::DFSIterator;
friend class DGraph::BFSIterator;
friend class DGraph::IncomingEdgesIterator;
friend class DGraph::OutgoingEdgesIterator;
friend class DGraph::SourceNodesIterator;
friend class DGraph::SinkNodesIterator;
};
//------------------------------------------------------------------------------------------------------------------
class Edge : public BaseGraph::Edge {
public:
Edge (Node* _source, Node* _sink) : BaseGraph::Edge(_source, _sink) {}
virtual ~Edge () {}
Node* source () { return dynamic_cast<Node*>(n1); }
Node* sink () { return dynamic_cast<Node*>(n2); }
Node* head () { return sink(); }
Node* tail () { return source(); }
friend class DGraph;
};
//------------------------------------------------------------------------------------------------------------------
class DFSIterator : public BaseGraph::DFSIterator {
public:
DFSIterator (DGraph& g) : BaseGraph::DFSIterator(g) { std::cerr << "Dgraph DFSIterator" << p << std::endl; }
virtual ~DFSIterator () {}
operator Node* () { return dynamic_cast<Node*>(p); }
Node* operator -> () { return dynamic_cast<Node*>(p); }
};
//------------------------------------------------------------------------------------------------------------------
class BFSIterator : public BaseGraph::BFSIterator {
public:
BFSIterator (DGraph& g) : BaseGraph::BFSIterator(g) {}
virtual ~BFSIterator () {}
operator Node* () { return dynamic_cast<Node*>(p); }
Node* operator -> () { return dynamic_cast<Node*>(p); }
};
//------------------------------------------------------------------------------------------------------------------
class IncomingEdgesIterator : public Iterator {
public:
IncomingEdgesIterator (Node* n) { center = n; iter = center->incoming_edges.begin(); }
~IncomingEdgesIterator () {}
void operator++ () { ++iter; }
operator bool () { return (iter != center->incoming_edges.end()); }
// operator std::list<Edge*>::iterator& () { return iter; }
Edge* operator-> () { return *iter; }
operator Edge* () { return *iter; }
private:
Node* center;
std::list<Edge*>::iterator iter;
};
//------------------------------------------------------------------------------------------------------------------
class OutgoingEdgesIterator : public Iterator {
public:
OutgoingEdgesIterator (Node* n) { center = n; iter = center->outgoing_edges.begin(); }
~OutgoingEdgesIterator () {}
void operator++ () { ++iter; }
operator bool () { return (iter != center->outgoing_edges.end()); }
// operator std::list<Edge*>::iterator& () { return iter; }
Edge* operator-> () { return *iter; }
operator Edge* () { return *iter; }
private:
Node* center;
std::list<Edge*>::iterator iter;
};
//------------------------------------------------------------------------------------------------------------------
class SourceNodesIterator : public Iterator {
public:
SourceNodesIterator (Node* n) { center = n; iter = center->incoming_edges.begin(); }
~SourceNodesIterator () {}
void operator++ () { ++iter; }
operator bool () { return (iter != center->incoming_edges.end()); }
Node* operator-> () { Edge* e = *iter; return e->source(); }
operator Node* () { Edge* e = *iter; return e->source(); }
private:
Node* center;
std::list<Edge*>::iterator iter;
};
//------------------------------------------------------------------------------------------------------------------
class SinkNodesIterator : public Iterator {
public:
SinkNodesIterator (Node* n) { center = n; iter = center->outgoing_edges.begin(); }
~SinkNodesIterator () {}
void operator++ () { ++iter; }
operator bool () { return (iter != center->outgoing_edges.end()); }
Node* operator-> () { Edge* e = *iter; return e->sink(); }
operator Node* () { Edge* e = *iter; return e->sink(); }
private:
Node* center;
std::list<Edge*>::iterator iter;
};
//------------------------------------------------------------------------------------------------------------------
class NodesIterator : public BaseGraph::NodesIterator {
public:
NodesIterator (DGraph& g) : BaseGraph::NodesIterator(g) {}
virtual ~NodesIterator () {}
operator Node* () { return dynamic_cast<Node*>(*iter); }
Node* operator -> () { return dynamic_cast<Node*>(*iter); }
};
//------------------------------------------------------------------------------------------------------------------
class BiDirNodesIterator : public BaseGraph::BiDirNodesIterator {
public:
BiDirNodesIterator (DGraph& g) : BaseGraph::BiDirNodesIterator(g) {}
BiDirNodesIterator (DGraph& g, dirType d) : BaseGraph::BiDirNodesIterator(g, d) {}
virtual ~BiDirNodesIterator () {}
operator Node* () { return dynamic_cast<Node*>(*iter); }
Node* operator -> () { return dynamic_cast<Node*>(*iter); }
};
//------------------------------------------------------------------------------------------------------------------
class EdgesIterator : public BaseGraph::EdgesIterator {
public:
EdgesIterator (DGraph& g) : BaseGraph::EdgesIterator(g) {}
virtual ~EdgesIterator () {}
operator Edge* () { return dynamic_cast<Edge*>(*iter); }
Edge* operator -> () { return dynamic_cast<Edge*>(*iter); }
};
//------------------------------------------------------------------------------------------------------------------
DGraph () : BaseGraph() {}
DGraph (Node* root) : BaseGraph (root) {}
virtual ~DGraph () {}
virtual void add (DGraph::Edge* e);
virtual void add (DGraph::Node* n);
virtual void remove (DGraph::Edge* e);
virtual void remove (DGraph::Node* n);
private:
BaseGraph::Node* create_DFS_links (BaseGraph::Node* start_node);
BaseGraph::Node* create_BFS_links (BaseGraph::Node* start_node);
};
//--------------------------------------------------------------------------------------------------------------------
#endif