From: Brian Norris Date: Tue, 29 Jan 2013 02:48:46 +0000 (-0800) Subject: cyclegraph: map Promises to Promise nodes X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=84d49e8de1334a7dad25864c5ba8827de2502947;p=c11tester.git cyclegraph: map Promises to Promise nodes --- diff --git a/cyclegraph.cc b/cyclegraph.cc index 49c462f5..58cb79f2 100644 --- a/cyclegraph.cc +++ b/cyclegraph.cc @@ -47,6 +47,26 @@ CycleNode * CycleGraph::getNode(const ModelAction *action) } /** + * @brief Returns a CycleNode corresponding to a promise + * + * Gets (or creates, if none exist) a CycleNode corresponding to a promised + * value. + * + * @param promise The Promise generated by a reader + * @return The CycleNode corresponding to the Promise + */ +CycleNode * CycleGraph::getNode(const Promise *promise) +{ + const ModelAction *reader = promise->get_action(); + CycleNode *node = readerToPromiseNode.get(reader); + if (node == NULL) { + node = new CycleNode(promise); + readerToPromiseNode.put(reader, node); + } + return node; +} + +/* * @brief Adds an edge between objects * * This function will add an edge between any two objects which can be diff --git a/cyclegraph.h b/cyclegraph.h index f812e24d..4a3d083d 100644 --- a/cyclegraph.h +++ b/cyclegraph.h @@ -45,10 +45,16 @@ class CycleGraph { void addNodeEdge(CycleNode *fromnode, CycleNode *tonode); void putNode(const ModelAction *act, CycleNode *node); CycleNode * getNode(const ModelAction *); + CycleNode * getNode(const Promise *promise); + HashTable *discovered; /** @brief A table for mapping ModelActions to CycleNodes */ HashTable actionToNode; + /** @brief A table for mapping reader ModelActions to Promise + * CycleNodes */ + HashTable readerToPromiseNode; + #if SUPPORT_MOD_ORDER_DUMP std::vector nodeList; #endif