aboutsummaryrefslogtreecommitdiff
path: root/include/llvm/Function.h
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-01-02 23:42:30 +0000
committerChris Lattner <sabre@nondot.org>2008-01-02 23:42:30 +0000
commit50ee9ddc8f0633af6cb0a5693a2c706e98f944da (patch)
treee9d758370876a5e6235f5f0ac307f9b5d598c1cb /include/llvm/Function.h
parenta114b14e5dd1869b8dfcf79736fe05a3616b520a (diff)
Split param attr implementation out from Function.cpp into its
own file. Don't #include ParameterAttributes.h into any major public header files: just move methods out of line as appropriate. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45517 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Function.h')
-rw-r--r--include/llvm/Function.h27
1 files changed, 7 insertions, 20 deletions
diff --git a/include/llvm/Function.h b/include/llvm/Function.h
index d68d5133dc..31ee6d7544 100644
--- a/include/llvm/Function.h
+++ b/include/llvm/Function.h
@@ -21,7 +21,6 @@
#include "llvm/GlobalValue.h"
#include "llvm/BasicBlock.h"
#include "llvm/Argument.h"
-#include "llvm/ParameterAttributes.h"
#include "llvm/Support/Annotation.h"
namespace llvm {
@@ -161,34 +160,22 @@ public:
void clearCollector();
/// @brief Determine whether the function has the given attribute.
- bool paramHasAttr(uint16_t i, ParameterAttributes attr) const {
- return ParamAttrs && ParamAttrs->paramHasAttr(i, attr);
- }
-
+ bool paramHasAttr(uint16_t i, unsigned attr) const;
+
/// @brief Determine if the function cannot return.
- bool doesNotReturn() const {
- return paramHasAttr(0, ParamAttr::NoReturn);
- }
+ bool doesNotReturn() const;
/// @brief Determine if the function cannot unwind.
- bool doesNotThrow() const {
- return paramHasAttr(0, ParamAttr::NoUnwind);
- }
+ bool doesNotThrow() const;
/// @brief Determine if the function does not access memory.
- bool doesNotAccessMemory() const {
- return paramHasAttr(0, ParamAttr::ReadNone);
- }
+ bool doesNotAccessMemory() const;
/// @brief Determine if the function does not access or only reads memory.
- bool onlyReadsMemory() const {
- return doesNotAccessMemory() || paramHasAttr(0, ParamAttr::ReadOnly);
- }
+ bool onlyReadsMemory() const;
/// @brief Determine if the function returns a structure.
- bool isStructReturn() const {
- return paramHasAttr(1, ParamAttr::StructRet);
- }
+ bool isStructReturn() const;
/// deleteBody - This method deletes the body of the function, and converts
/// the linkage to external.