2001-06-06 20:29:01 +00:00
|
|
|
//===-- llvm/ValueHolder.h - Class to hold multiple values -------*- C++ -*--=//
|
|
|
|
//
|
2002-04-28 04:47:06 +00:00
|
|
|
// This defines a class that is used as a fancy Definition container. It is
|
|
|
|
// special because it helps keep the symbol table of the container function up
|
|
|
|
// to date with the goings on inside of it.
|
2001-06-06 20:29:01 +00:00
|
|
|
//
|
|
|
|
// This is used to represent things like the instructions of a basic block and
|
2002-04-28 04:47:06 +00:00
|
|
|
// the arguments to a function.
|
2001-06-06 20:29:01 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_VALUEHOLDER_H
|
|
|
|
#define LLVM_VALUEHOLDER_H
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
2001-07-14 06:07:58 +00:00
|
|
|
// ValueSubClass - The type of objects that I hold
|
|
|
|
// ItemParentType - I call setParent() on all of my "ValueSubclass" items, and
|
|
|
|
// this is the value that I pass in.
|
2002-04-28 04:47:06 +00:00
|
|
|
// SymTabType - This is the class type, whose symtab I insert my
|
|
|
|
// ValueSubClass items into. Most of the time it is
|
|
|
|
// ItemParentType, but Instructions have item parents of BB's
|
|
|
|
// but symtabtype's of a Function
|
2001-06-06 20:29:01 +00:00
|
|
|
//
|
2001-07-14 06:07:58 +00:00
|
|
|
template<class ValueSubclass, class ItemParentType, class SymTabType>
|
2001-06-06 20:29:01 +00:00
|
|
|
class ValueHolder {
|
2002-01-20 22:54:45 +00:00
|
|
|
std::vector<ValueSubclass*> ValueList;
|
2001-06-06 20:29:01 +00:00
|
|
|
|
|
|
|
ItemParentType *ItemParent;
|
2001-07-14 06:07:58 +00:00
|
|
|
SymTabType *Parent;
|
2001-06-06 20:29:01 +00:00
|
|
|
|
|
|
|
ValueHolder(const ValueHolder &V); // DO NOT IMPLEMENT
|
|
|
|
public:
|
2001-07-14 06:07:58 +00:00
|
|
|
inline ValueHolder(ItemParentType *IP, SymTabType *parent = 0) {
|
2001-06-06 20:29:01 +00:00
|
|
|
assert(IP && "Item parent may not be null!");
|
|
|
|
ItemParent = IP;
|
|
|
|
Parent = 0;
|
|
|
|
setParent(parent);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline ~ValueHolder() {
|
|
|
|
// The caller should have called delete_all first...
|
|
|
|
assert(empty() && "ValueHolder contains definitions!");
|
2002-04-28 04:47:06 +00:00
|
|
|
assert(Parent == 0 && "Should have been unlinked from function!");
|
2001-06-06 20:29:01 +00:00
|
|
|
}
|
|
|
|
|
2001-07-14 06:07:58 +00:00
|
|
|
inline const SymTabType *getParent() const { return Parent; }
|
|
|
|
inline SymTabType *getParent() { return Parent; }
|
|
|
|
void setParent(SymTabType *Parent); // Defined in ValueHolderImpl.h
|
2001-06-06 20:29:01 +00:00
|
|
|
|
2001-10-18 20:04:40 +00:00
|
|
|
inline unsigned size() const { return ValueList.size(); }
|
|
|
|
inline bool empty() const { return ValueList.empty(); }
|
2001-06-06 20:29:01 +00:00
|
|
|
inline const ValueSubclass *front() const { return ValueList.front(); }
|
|
|
|
inline ValueSubclass *front() { return ValueList.front(); }
|
2001-10-18 20:04:40 +00:00
|
|
|
inline const ValueSubclass *back() const { return ValueList.back(); }
|
|
|
|
inline ValueSubclass *back() { return ValueList.back(); }
|
|
|
|
inline const ValueSubclass *operator[](unsigned i) const {
|
|
|
|
return ValueList[i];
|
|
|
|
}
|
|
|
|
inline ValueSubclass *operator[](unsigned i) {
|
|
|
|
return ValueList[i];
|
|
|
|
}
|
2001-06-06 20:29:01 +00:00
|
|
|
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
// sub-Definition iterator code
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
//
|
2002-01-20 22:54:45 +00:00
|
|
|
typedef std::vector<ValueSubclass*>::iterator iterator;
|
|
|
|
typedef std::vector<ValueSubclass*>::const_iterator const_iterator;
|
|
|
|
typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
|
|
|
|
typedef std::reverse_iterator<iterator> reverse_iterator;
|
2001-06-08 20:52:54 +00:00
|
|
|
|
2001-06-08 21:07:26 +00:00
|
|
|
inline iterator begin() { return ValueList.begin(); }
|
|
|
|
inline const_iterator begin() const { return ValueList.begin(); }
|
|
|
|
inline iterator end () { return ValueList.end(); }
|
|
|
|
inline const_iterator end () const { return ValueList.end(); }
|
2001-06-06 20:29:01 +00:00
|
|
|
|
2001-06-08 21:07:26 +00:00
|
|
|
inline reverse_iterator rbegin() { return ValueList.rbegin(); }
|
2001-06-08 20:52:54 +00:00
|
|
|
inline const_reverse_iterator rbegin() const { return ValueList.rbegin(); }
|
2001-06-08 21:07:26 +00:00
|
|
|
inline reverse_iterator rend () { return ValueList.rend(); }
|
|
|
|
inline const_reverse_iterator rend () const { return ValueList.rend(); }
|
2001-06-08 20:52:54 +00:00
|
|
|
|
2001-06-06 20:29:01 +00:00
|
|
|
// ValueHolder::remove(iterator &) this removes the element at the location
|
|
|
|
// specified by the iterator, and leaves the iterator pointing to the element
|
|
|
|
// that used to follow the element deleted.
|
|
|
|
//
|
2002-05-06 02:59:52 +00:00
|
|
|
ValueSubclass *remove(iterator &DI);
|
|
|
|
ValueSubclass *remove(const iterator &DI);
|
|
|
|
void remove(ValueSubclass *D);
|
|
|
|
void remove(iterator Start, iterator End);
|
|
|
|
ValueSubclass *pop_back();
|
2001-06-06 20:29:01 +00:00
|
|
|
|
2002-04-01 17:52:16 +00:00
|
|
|
// replaceWith - This removes the element pointed to by 'Where', and inserts
|
|
|
|
// NewValue in it's place. The old value is returned. 'Where' must be a
|
|
|
|
// valid iterator!
|
|
|
|
//
|
|
|
|
ValueSubclass *replaceWith(iterator &Where, ValueSubclass *NewValue);
|
|
|
|
|
2001-11-10 06:47:45 +00:00
|
|
|
// delete_span - Remove the elements from begin to end, deleting them as we
|
|
|
|
// go. This leaves the iterator pointing to the element that used to be end.
|
|
|
|
//
|
|
|
|
iterator delete_span(iterator begin, iterator end) {
|
|
|
|
while (end != begin)
|
|
|
|
delete remove(--end);
|
|
|
|
return end;
|
|
|
|
}
|
|
|
|
|
|
|
|
void delete_all() { // Delete all removes and deletes all elements
|
|
|
|
delete_span(begin(), end());
|
|
|
|
}
|
|
|
|
|
2001-06-25 07:31:05 +00:00
|
|
|
void push_front(ValueSubclass *Inst); // Defined in ValueHolderImpl.h
|
|
|
|
void push_back(ValueSubclass *Inst); // Defined in ValueHolderImpl.h
|
|
|
|
|
|
|
|
// ValueHolder::insert - This method inserts the specified value *BEFORE* the
|
|
|
|
// indicated iterator position, and returns an interator to the newly inserted
|
|
|
|
// value.
|
|
|
|
//
|
|
|
|
iterator insert(iterator Pos, ValueSubclass *Inst);
|
2002-03-29 05:49:37 +00:00
|
|
|
|
|
|
|
// ValueHolder::insert - This method inserts the specified _range_ of values
|
2002-04-29 21:23:30 +00:00
|
|
|
// before the 'Pos' iterator, returning a new iterator that points to the
|
|
|
|
// first item inserted. *This currently only works for vector iterators...*
|
2002-03-29 05:49:37 +00:00
|
|
|
//
|
|
|
|
// FIXME: This is not generic so that the code does not have to be around
|
|
|
|
// to be used... is this ok?
|
|
|
|
//
|
2002-04-29 21:23:30 +00:00
|
|
|
iterator insert(iterator Pos, // Where to insert
|
|
|
|
iterator First, iterator Last); // Vector to read insts from
|
2001-06-06 20:29:01 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|