/* * Copyright (c) 2012-2017 The ANTLR Project. All rights reserved. * Use of this file is governed by the BSD 3-clause license that * can be found in the LICENSE.txt file in the project root. */ package org.antlr.v4.automata; import org.antlr.v4.runtime.atn.ATNState; import org.antlr.v4.runtime.atn.Transition; import java.util.HashSet; import java.util.Set; /** A simple visitor that walks everywhere it can go starting from s, * without going into an infinite cycle. Override and implement * visitState() to provide functionality. */ public class ATNVisitor { public void visit(ATNState s) { visit_(s, new HashSet<Integer>()); } public void visit_(ATNState s, Set<Integer> visited) { if ( !visited.add(s.stateNumber) ) return; visited.add(s.stateNumber); visitState(s); int n = s.getNumberOfTransitions(); for (int i=0; i<n; i++) { Transition t = s.transition(i); visit_(t.target, visited); } } public void visitState(ATNState s) { } }