diff options
| author | Alkis Evlogimenos <alkis@evlogimenos.com> | 2004-07-16 12:04:28 +0000 |
|---|---|---|
| committer | Alkis Evlogimenos <alkis@evlogimenos.com> | 2004-07-16 12:04:28 +0000 |
| commit | 763d930d22423852a4e1269f59625ed813fcde36 (patch) | |
| tree | e57489465837ac904990b77ec282a010ba69c772 /llvm/lib | |
| parent | 135b870f72cd6e7291a5c2ff53e6ef9056d912b8 (diff) | |
| download | bcm5719-llvm-763d930d22423852a4e1269f59625ed813fcde36.tar.gz bcm5719-llvm-763d930d22423852a4e1269f59625ed813fcde36.zip | |
Add convinience constructor for function calls with two args.
llvm-svn: 14885
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/VMCore/iCall.cpp | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/llvm/lib/VMCore/iCall.cpp b/llvm/lib/VMCore/iCall.cpp index 9a81f7948f9..1e88be3e935 100644 --- a/llvm/lib/VMCore/iCall.cpp +++ b/llvm/lib/VMCore/iCall.cpp @@ -38,6 +38,21 @@ void CallInst::init(Value *Func, const std::vector<Value*> &Params) Operands.push_back(Use(Params[i], this)); } +void CallInst::init(Value *Func, Value *Actual1, Value *Actual2) +{ + Operands.reserve(3); + Operands.push_back(Use(Func, this)); + + const FunctionType *MTy = + cast<FunctionType>(cast<PointerType>(Func->getType())->getElementType()); + + assert((MTy->getNumParams() == 2 || + (MTy->isVarArg() && MTy->getNumParams() == 0)) && + "Calling a function with bad signature"); + Operands.push_back(Use(Actual1, this)); + Operands.push_back(Use(Actual2, this)); +} + void CallInst::init(Value *Func, Value *Actual) { Operands.reserve(2); @@ -79,6 +94,22 @@ CallInst::CallInst(Value *Func, const std::vector<Value*> &Params, init(Func, Params); } +CallInst::CallInst(Value *Func, Value *Actual1, Value *Actual2, + const std::string &Name, Instruction *InsertBefore) + : Instruction(cast<FunctionType>(cast<PointerType>(Func->getType()) + ->getElementType())->getReturnType(), + Instruction::Call, Name, InsertBefore) { + init(Func, Actual1, Actual2); +} + +CallInst::CallInst(Value *Func, Value *Actual1, Value *Actual2, + const std::string &Name, BasicBlock *InsertAtEnd) + : Instruction(cast<FunctionType>(cast<PointerType>(Func->getType()) + ->getElementType())->getReturnType(), + Instruction::Call, Name, InsertAtEnd) { + init(Func, Actual1, Actual2); +} + CallInst::CallInst(Value *Func, Value* Actual, const std::string &Name, Instruction *InsertBefore) : Instruction(cast<FunctionType>(cast<PointerType>(Func->getType()) |

