61 lines
1.9 KiB
C++
61 lines
1.9 KiB
C++
//--------------------------------------------------------------------*- C++ -*-
|
|
// CLING - the C++ LLVM-based InterpreterG :)
|
|
// author: Vassil Vassilev <vvasilev@cern.ch>
|
|
//
|
|
// This file is dual-licensed: you can choose to license it under the University
|
|
// of Illinois Open Source License or the GNU Lesser General Public License. See
|
|
// LICENSE.TXT for details.
|
|
//------------------------------------------------------------------------------
|
|
|
|
#ifndef CLING_TRANSACTION_UNLOADER
|
|
#define CLING_TRANSACTION_UNLOADER
|
|
|
|
namespace clang {
|
|
class CodeGenerator;
|
|
class CompilerInstance;
|
|
class Decl;
|
|
class Sema;
|
|
}
|
|
|
|
namespace cling {
|
|
|
|
class Transaction;
|
|
|
|
///\brief A simple eraser class that removes already created AST Nodes.
|
|
///
|
|
class TransactionUnloader {
|
|
private:
|
|
clang::Sema* m_Sema;
|
|
clang::CodeGenerator* m_CodeGen;
|
|
|
|
public:
|
|
TransactionUnloader(clang::Sema* S, clang::CodeGenerator* CG);
|
|
~TransactionUnloader();
|
|
|
|
///\brief Rolls back given transaction from the AST.
|
|
///
|
|
/// Removing includes reseting various internal stuctures in the compiler to
|
|
/// their previous states. For example it resets the lookup tables if the
|
|
/// declaration has name and can be looked up; Unloads the redeclaration
|
|
/// chain if the declaration was redeclarable and so on.
|
|
/// Note1: that the code generated for the declaration is not removed yet.
|
|
/// Note2: does not do dependency analysis.
|
|
///
|
|
///\param[in] T - The transaction to be removed.
|
|
///\returns true on success.
|
|
///
|
|
bool RevertTransaction(Transaction* T);
|
|
|
|
///\brief Unloads a single decl. It must not be in any other transaction.
|
|
/// This doesn't do dependency tracking. Use with caution.
|
|
///
|
|
///\param[in] D - The decl to be removed.
|
|
///
|
|
///\returns true on success
|
|
///
|
|
bool UnloadDecl(clang::Decl* D);
|
|
};
|
|
} // end namespace cling
|
|
|
|
#endif // CLING_AST_NODE_ERASER
|