mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-28 04:33:05 +00:00
Add convinience constructor for function calls with two args.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14885 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7c4676f341
commit
8e9b219b67
@ -70,6 +70,7 @@ public:
|
||||
class CallInst : public Instruction {
|
||||
CallInst(const CallInst &CI);
|
||||
void init(Value *Func, const std::vector<Value*> &Params);
|
||||
void init(Value *Func, Value *Actual1, Value *Actual2);
|
||||
void init(Value *Func, Value *Actual);
|
||||
void init(Value *Func);
|
||||
|
||||
@ -79,7 +80,12 @@ public:
|
||||
CallInst(Value *F, const std::vector<Value*> &Par,
|
||||
const std::string &Name, BasicBlock *InsertAtEnd);
|
||||
|
||||
// Alternate CallInst ctors w/ one actual & no actuals, respectively.
|
||||
// Alternate CallInst ctors w/ two actuals, w/ one actual and no
|
||||
// actuals, respectively.
|
||||
CallInst(Value *F, Value *Actual1, Value *Actual2,
|
||||
const std::string& Name = "", Instruction *InsertBefore = 0);
|
||||
CallInst(Value *F, Value *Actual1, Value *Actual2,
|
||||
const std::string& Name, BasicBlock *InsertAtEnd);
|
||||
CallInst(Value *F, Value *Actual, const std::string& Name = "",
|
||||
Instruction *InsertBefore = 0);
|
||||
CallInst(Value *F, Value *Actual, const std::string& Name,
|
||||
|
@ -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())
|
||||
|
Loading…
Reference in New Issue
Block a user