2001-09-07 19:29:23 +00:00
|
|
|
//==-- llvm/Analysis/ConstantsScanner.h - Iterate over constants -*- C++ -*-==//
|
|
|
|
//
|
|
|
|
// This class implements an iterator to walk through the constants referenced by
|
|
|
|
// a method. This is used by the Bytecode & Assembly writers to build constant
|
|
|
|
// pools.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_ANALYSIS_CONSTANTSSCANNER_H
|
|
|
|
#define LLVM_ANALYSIS_CONSTANTSSCANNER_H
|
|
|
|
|
2002-02-12 21:04:35 +00:00
|
|
|
#include "llvm/Support/InstIterator.h"
|
2001-09-07 19:29:23 +00:00
|
|
|
#include "llvm/Instruction.h"
|
|
|
|
#include <iterator>
|
2001-12-03 22:26:30 +00:00
|
|
|
class Constant;
|
2001-09-07 19:29:23 +00:00
|
|
|
|
|
|
|
class constant_iterator
|
2001-12-03 22:26:30 +00:00
|
|
|
: public std::forward_iterator<const Constant, ptrdiff_t> {
|
2002-02-12 21:04:35 +00:00
|
|
|
const_inst_iterator InstI; // Method instruction iterator
|
2001-09-07 19:29:23 +00:00
|
|
|
unsigned OpIdx; // Operand index
|
|
|
|
|
|
|
|
typedef constant_iterator _Self;
|
|
|
|
|
|
|
|
inline bool isAtConstant() const {
|
|
|
|
assert(!InstI.atEnd() && OpIdx < InstI->getNumOperands() &&
|
|
|
|
"isAtConstant called with invalid arguments!");
|
2001-12-03 22:26:30 +00:00
|
|
|
return isa<Constant>(InstI->getOperand(OpIdx));
|
2001-09-07 19:29:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public:
|
2002-02-12 21:04:35 +00:00
|
|
|
inline constant_iterator(const Method *M) : InstI(inst_begin(M)), OpIdx(0) {
|
2001-09-07 19:29:23 +00:00
|
|
|
// Advance to first constant... if we are not already at constant or end
|
2002-02-12 21:04:35 +00:00
|
|
|
if (InstI != inst_end(M) && // InstI is valid?
|
2001-09-07 19:29:23 +00:00
|
|
|
(InstI->getNumOperands() == 0 || !isAtConstant())) // Not at constant?
|
|
|
|
operator++();
|
|
|
|
}
|
|
|
|
|
|
|
|
inline constant_iterator(const Method *M, bool) // end ctor
|
2002-02-12 21:04:35 +00:00
|
|
|
: InstI(inst_end(M)), OpIdx(0) {
|
2001-09-07 19:29:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline bool operator==(const _Self& x) const { return OpIdx == x.OpIdx &&
|
|
|
|
InstI == x.InstI; }
|
|
|
|
inline bool operator!=(const _Self& x) const { return !operator==(x); }
|
|
|
|
|
|
|
|
inline pointer operator*() const {
|
|
|
|
assert(isAtConstant() && "Dereferenced an iterator at the end!");
|
2001-12-03 22:26:30 +00:00
|
|
|
return cast<Constant>(InstI->getOperand(OpIdx));
|
2001-09-07 19:29:23 +00:00
|
|
|
}
|
|
|
|
inline pointer operator->() const { return operator*(); }
|
|
|
|
|
|
|
|
inline _Self& operator++() { // Preincrement implementation
|
|
|
|
++OpIdx;
|
|
|
|
do {
|
|
|
|
unsigned NumOperands = InstI->getNumOperands();
|
|
|
|
while (OpIdx < NumOperands && !isAtConstant()) {
|
|
|
|
++OpIdx;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (OpIdx < NumOperands) return *this; // Found a constant!
|
|
|
|
++InstI;
|
|
|
|
OpIdx = 0;
|
|
|
|
} while (!InstI.atEnd());
|
|
|
|
|
|
|
|
return *this; // At the end of the method
|
|
|
|
}
|
|
|
|
|
|
|
|
inline _Self operator++(int) { // Postincrement
|
|
|
|
_Self tmp = *this; ++*this; return tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool atEnd() const { return InstI.atEnd(); }
|
|
|
|
};
|
|
|
|
|
|
|
|
inline constant_iterator constant_begin(const Method *M) {
|
|
|
|
return constant_iterator(M);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline constant_iterator constant_end(const Method *M) {
|
|
|
|
return constant_iterator(M, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|