mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-09 13:33:17 +00:00
Add AnalysisResolver_New.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32384 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f3dc6d9f95
commit
186bf2bc54
@ -50,6 +50,7 @@ class BasicBlockPassManager;
|
|||||||
class FunctionPassManagerT;
|
class FunctionPassManagerT;
|
||||||
class ModulePassManager;
|
class ModulePassManager;
|
||||||
struct AnalysisResolver;
|
struct AnalysisResolver;
|
||||||
|
class AnalysisResolver_New;
|
||||||
|
|
||||||
// AnalysisID - Use the PassInfo to identify a pass...
|
// AnalysisID - Use the PassInfo to identify a pass...
|
||||||
typedef const PassInfo* AnalysisID;
|
typedef const PassInfo* AnalysisID;
|
||||||
@ -62,6 +63,7 @@ typedef const PassInfo* AnalysisID;
|
|||||||
class Pass {
|
class Pass {
|
||||||
friend struct AnalysisResolver;
|
friend struct AnalysisResolver;
|
||||||
AnalysisResolver *Resolver; // AnalysisResolver this pass is owned by...
|
AnalysisResolver *Resolver; // AnalysisResolver this pass is owned by...
|
||||||
|
AnalysisResolver_New *Resolver_New; // Used to resolve analysis
|
||||||
const PassInfo *PassInfoCache;
|
const PassInfo *PassInfoCache;
|
||||||
|
|
||||||
// AnalysisImpls - This keeps track of which passes implement the interfaces
|
// AnalysisImpls - This keeps track of which passes implement the interfaces
|
||||||
@ -72,7 +74,7 @@ class Pass {
|
|||||||
void operator=(const Pass&); // DO NOT IMPLEMENT
|
void operator=(const Pass&); // DO NOT IMPLEMENT
|
||||||
Pass(const Pass &); // DO NOT IMPLEMENT
|
Pass(const Pass &); // DO NOT IMPLEMENT
|
||||||
public:
|
public:
|
||||||
Pass() : Resolver(0), PassInfoCache(0) {}
|
Pass() : Resolver(0), Resolver_New(0), PassInfoCache(0) {}
|
||||||
virtual ~Pass() {} // Destructor is virtual so we can be subclassed
|
virtual ~Pass() {} // Destructor is virtual so we can be subclassed
|
||||||
|
|
||||||
/// getPassName - Return a nice clean name for a pass. This usually
|
/// getPassName - Return a nice clean name for a pass. This usually
|
||||||
@ -107,6 +109,9 @@ public:
|
|||||||
virtual void print(std::ostream &O, const Module *M) const;
|
virtual void print(std::ostream &O, const Module *M) const;
|
||||||
void dump() const; // dump - call print(std::cerr, 0);
|
void dump() const; // dump - call print(std::cerr, 0);
|
||||||
|
|
||||||
|
// Access AnalysisResolver_New
|
||||||
|
inline void setResolver(AnalysisResolver_New *AR) { Resolver_New = AR; }
|
||||||
|
inline AnalysisResolver_New *getResolver() { return Resolver_New; }
|
||||||
|
|
||||||
/// getAnalysisUsage - This function should be overriden by passes that need
|
/// getAnalysisUsage - This function should be overriden by passes that need
|
||||||
/// analysis information to do their job. If a pass specifies that it uses a
|
/// analysis information to do their job. If a pass specifies that it uses a
|
||||||
|
Loading…
x
Reference in New Issue
Block a user