blob: 202deb87a1fb61569b28d87d64823a3009b57751 [file] [log] [blame]
//===--- Signature.h - An IR function signature -----------------*- C++ -*-===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2017 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
//
// This file defines the Signature type, which encapsulates all the
// information necessary to call a function value correctly.
//
//===----------------------------------------------------------------------===//
#ifndef SWIFT_IRGEN_SIGNATURE_H
#define SWIFT_IRGEN_SIGNATURE_H
#include "llvm/IR/Attributes.h"
#include "llvm/IR/CallingConv.h"
#include "swift/AST/Types.h"
namespace llvm {
class FunctionType;
}
namespace clang {
namespace CodeGen {
class CGFunctionInfo;
}
}
namespace swift {
class Identifier;
enum class SILFunctionTypeRepresentation : uint8_t;
class SILType;
namespace irgen {
class IRGenModule;
/// An encapsulation of different foreign calling-convention lowering
/// information we might have. Should be interpreted according to the
/// abstract CC of the formal function type.
class ForeignFunctionInfo {
public:
const clang::CodeGen::CGFunctionInfo *ClangInfo = nullptr;
};
/// A signature represents something which can actually be called.
class Signature {
llvm::FunctionType *Type = nullptr;
llvm::AttributeList Attributes;
ForeignFunctionInfo ForeignInfo;
llvm::CallingConv::ID CallingConv;
public:
Signature() {}
Signature(llvm::FunctionType *fnType, llvm::AttributeList attrs,
llvm::CallingConv::ID callingConv)
: Type(fnType), Attributes(attrs), CallingConv(callingConv) {}
bool isValid() const {
return Type != nullptr;
}
/// Compute the signature of the given type.
///
/// This is a private detail of the implementation of
/// IRGenModule::getSignature(CanSILFunctionType), which is what
/// clients should generally be using.
static Signature getUncached(IRGenModule &IGM,
CanSILFunctionType formalType);
llvm::FunctionType *getType() const {
assert(isValid());
return Type;
}
llvm::CallingConv::ID getCallingConv() const {
assert(isValid());
return CallingConv;
}
llvm::AttributeList getAttributes() const {
assert(isValid());
return Attributes;
}
ForeignFunctionInfo getForeignInfo() const {
assert(isValid());
return ForeignInfo;
}
// The mutators below should generally only be used when building up
// a callee.
void setType(llvm::FunctionType *type) {
Type = type;
}
llvm::AttributeList &getMutableAttributes() & {
assert(isValid());
return Attributes;
}
};
} // end namespace irgen
} // end namespace swift
#endif