blob: 0ec64113230441f0e8ea9fe219db52ef7eeaae79 [file] [log] [blame]
Chris Lattner2f7c9632001-06-06 20:29:01 +00001//===-- Method.cpp - Implement the Method class ------------------*- C++ -*--=//
2//
Chris Lattnerda975502001-09-10 07:58:01 +00003// This file implements the Method & GlobalVariable classes for the VMCore
4// library.
Chris Lattner2f7c9632001-06-06 20:29:01 +00005//
6//===----------------------------------------------------------------------===//
7
8#include "llvm/ValueHolderImpl.h"
9#include "llvm/DerivedTypes.h"
10#include "llvm/SymbolTable.h"
11#include "llvm/Module.h"
12#include "llvm/Method.h"
Chris Lattnerda975502001-09-10 07:58:01 +000013#include "llvm/GlobalVariable.h"
Chris Lattner2f7c9632001-06-06 20:29:01 +000014#include "llvm/BasicBlock.h"
15#include "llvm/iOther.h"
16
Chris Lattnerda975502001-09-10 07:58:01 +000017//===----------------------------------------------------------------------===//
18// Method Implementation
19//===----------------------------------------------------------------------===//
20
21
Chris Lattner2f7c9632001-06-06 20:29:01 +000022// Instantiate Templates - This ugliness is the price we have to pay
23// for having a ValueHolderImpl.h file seperate from ValueHolder.h! :(
24//
Chris Lattnerf2a738c2001-07-14 06:13:19 +000025template class ValueHolder<MethodArgument, Method, Method>;
26template class ValueHolder<BasicBlock , Method, Method>;
Chris Lattner2f7c9632001-06-06 20:29:01 +000027
28Method::Method(const MethodType *Ty, const string &name)
Chris Lattnerf2a738c2001-07-14 06:13:19 +000029 : Value(Ty, Value::MethodVal, name), SymTabValue(this), BasicBlocks(this),
Chris Lattner2f7c9632001-06-06 20:29:01 +000030 ArgumentList(this, this) {
31 assert(Ty->isMethodType() && "Method signature must be of method type!");
32 Parent = 0;
33}
34
35Method::~Method() {
36 dropAllReferences(); // After this it is safe to delete instructions.
37
38 // TODO: Should remove from the end, not the beginning of vector!
Chris Lattner4cee8d82001-06-27 23:41:11 +000039 iterator BI = begin();
40 while ((BI = begin()) != end())
Chris Lattner2f7c9632001-06-06 20:29:01 +000041 delete BasicBlocks.remove(BI);
42
43 // Delete all of the method arguments and unlink from symbol table...
44 ArgumentList.delete_all();
45 ArgumentList.setParent(0);
46}
47
48// Specialize setName to take care of symbol table majik
Chris Lattner5c764a52001-09-07 16:47:18 +000049void Method::setName(const string &name, SymbolTable *ST) {
Chris Lattner2f7c9632001-06-06 20:29:01 +000050 Module *P;
Chris Lattner5c764a52001-09-07 16:47:18 +000051 assert((ST == 0 || (!getParent() || ST == getParent()->getSymbolTable())) &&
52 "Invalid symtab argument!");
Chris Lattner2f7c9632001-06-06 20:29:01 +000053 if ((P = getParent()) && hasName()) P->getSymbolTable()->remove(this);
54 Value::setName(name);
55 if (P && getName() != "") P->getSymbolTableSure()->insert(this);
56}
57
58void Method::setParent(Module *parent) {
59 Parent = parent;
60
61 // Relink symbol tables together...
62 setParentSymTab(Parent ? Parent->getSymbolTableSure() : 0);
63}
64
65const Type *Method::getReturnType() const {
66 return ((const MethodType *)getType())->getReturnType();
67}
68
69const MethodType *Method::getMethodType() const {
70 return (const MethodType *)getType();
71}
72
73// dropAllReferences() - This function causes all the subinstructions to "let
74// go" of all references that they are maintaining. This allows one to
75// 'delete' a whole class at a time, even though there may be circular
76// references... first all references are dropped, and all use counts go to
77// zero. Then everything is delete'd for real. Note that no operations are
78// valid on an object that has "dropped all references", except operator
79// delete.
80//
81void Method::dropAllReferences() {
Chris Lattner4cee8d82001-06-27 23:41:11 +000082 for_each(begin(), end(), std::mem_fun(&BasicBlock::dropAllReferences));
Chris Lattner2f7c9632001-06-06 20:29:01 +000083}
Chris Lattnerda975502001-09-10 07:58:01 +000084
85//===----------------------------------------------------------------------===//
86// GlobalVariable Implementation
87//===----------------------------------------------------------------------===//
88
89GlobalVariable::GlobalVariable(const Type *Ty, const string &Name = "")
90 : Value(Ty, Value::GlobalVal, Name), Parent(0) {
91 assert(Ty->isPointerType() &&
92 (!Ty->isPointerType()->isArrayType() || // No unsized array pointers
93 Ty->isPointerType()->isArrayType()->isSized()) &&
94 "Global Variables must be pointers to a sized type!");
95}
96
97// Specialize setName to take care of symbol table majik
98void GlobalVariable::setName(const string &name, SymbolTable *ST) {
99 Module *P;
100 assert((ST == 0 || (!getParent() || ST == getParent()->getSymbolTable())) &&
101 "Invalid symtab argument!");
102 if ((P = getParent()) && hasName()) P->getSymbolTable()->remove(this);
103 Value::setName(name);
104 if (P && getName() != "") P->getSymbolTableSure()->insert(this);
105}