| //===-- Transfer.h ----------------------------------------------*- C++ -*-===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file defines a transfer function that evaluates a program statement and |
| // updates an environment accordingly. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLVM_CLANG_ANALYSIS_FLOWSENSITIVE_TRANSFER_H |
| #define LLVM_CLANG_ANALYSIS_FLOWSENSITIVE_TRANSFER_H |
| |
| #include "clang/AST/Stmt.h" |
| #include "clang/Analysis/FlowSensitive/DataflowAnalysisContext.h" |
| #include "clang/Analysis/FlowSensitive/DataflowEnvironment.h" |
| #include "clang/Analysis/FlowSensitive/TypeErasedDataflowAnalysis.h" |
| |
| namespace clang { |
| namespace dataflow { |
| |
| /// Maps statements to the environments of basic blocks that contain them. |
| class StmtToEnvMap { |
| public: |
| StmtToEnvMap(const ControlFlowContext &CFCtx, |
| llvm::ArrayRef<std::optional<TypeErasedDataflowAnalysisState>> |
| BlockToState) |
| : CFCtx(CFCtx), BlockToState(BlockToState) {} |
| |
| /// Returns the environment of the basic block that contains `S`. |
| /// The result is guaranteed never to be null. |
| const Environment *getEnvironment(const Stmt &S) const; |
| |
| private: |
| const ControlFlowContext &CFCtx; |
| llvm::ArrayRef<std::optional<TypeErasedDataflowAnalysisState>> BlockToState; |
| }; |
| |
| /// Evaluates `S` and updates `Env` accordingly. |
| /// |
| /// Requirements: |
| /// |
| /// `S` must not be `ParenExpr` or `ExprWithCleanups`. |
| void transfer(const StmtToEnvMap &StmtToEnv, const Stmt &S, Environment &Env); |
| |
| } // namespace dataflow |
| } // namespace clang |
| |
| #endif // LLVM_CLANG_ANALYSIS_FLOWSENSITIVE_TRANSFER_H |