// Copyright 2016 The SwiftShader Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef COMPILER_ANALYZE_CALL_DEPTH_H_ #define COMPILER_ANALYZE_CALL_DEPTH_H_ #include "intermediate.h" #include #include // Traverses intermediate tree to analyze call depth or detect function recursion class AnalyzeCallDepth : public TIntermTraverser { public: AnalyzeCallDepth(TIntermNode *root); ~AnalyzeCallDepth(); virtual bool visitSwitch(Visit, TIntermSwitch*); virtual bool visitAggregate(Visit, TIntermAggregate*); unsigned int analyzeCallDepth(); private: class FunctionNode { public: FunctionNode(TIntermAggregate *node); const TString &getName() const; void addCallee(FunctionNode *callee); unsigned int analyzeCallDepth(AnalyzeCallDepth *analyzeCallDepth); unsigned int getLastDepth() const; void removeIfUnreachable(); private: TIntermAggregate *const node; TVector callees; Visit visit; unsigned int callDepth; }; FunctionNode *findFunctionByName(const TString &name); std::vector functions; typedef std::set FunctionSet; FunctionSet globalFunctionCalls; FunctionNode *currentFunction; }; #endif // COMPILER_ANALYZE_CALL_DEPTH_H_