source: src/AST/AssertAcyclic.cpp@ 382edbe

ADT ast-experimental enum forall-pointer-decay jacob/cs343-translation new-ast-unique-expr pthread-emulation qualifiedEnum
Last change on this file since 382edbe was be8518f, checked in by Andrew Beach <ajbeach@…>, 6 years ago

Fixed up AssertAcyclic.

  • Property mode set to 100644
File size: 1.1 KB
RevLine 
[7cc0344]1//
2// Cforall Version 1.0.0 Copyright (C) 2019 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
7// AssertAcyclic.cpp -- Check that ast::ptr does not form a cycle.
8//
9// Author : Andrew Beach
10// Created On : Thu Jun 06 15:00:00 2019
11// Last Modified By : Andrew Beach
[be8518f]12// Last Modified On : Fri Jun 07 14:32:00 2019
13// Update Count : 1
[7cc0344]14//
15
16#include "AssertAcyclic.hpp"
17
18#include "AST/Pass.hpp"
19
20namespace {
21
[be8518f]22class NoStrongCyclesCore {
[7cc0344]23 std::vector<const ast::Node *> parents;
24public:
[be8518f]25 void previsit( const ast::Node * node ) {
26 for (auto & parent : parents) {
27 assert(parent != node);
[7cc0344]28 }
29 parents.push_back(node);
[be8518f]30 }
31 void postvisit( const ast::Node * ) {
32 parents.pop_back();
[7cc0344]33 }
34};
35
36}
37
38namespace ast {
39
[be8518f]40void assertAcyclic( const std::list< ast::ptr< ast::Decl > > & translationUnit ) {
[7cc0344]41 Pass<NoStrongCyclesCore> visitor;
42 for ( auto & decl : translationUnit ) {
43 decl->accept( visitor );
44 }
45}
46
47}
48
49// Local Variables: //
50// tab-width: 4 //
51// mode: c++ //
52// compile-command: "make install" //
53// End: //
Note: See TracBrowser for help on using the repository browser.