blob: 83ca0e638c973f6ba2c8ae3a28cd62b525fa7bce [file] [log] [blame]
Daniel Dunbar8c85fac2008-08-11 02:45:11 +00001//===----- CGObjCRuntime.h - Interface to ObjC Runtimes ---------*- C++ -*-===//
Chris Lattnera0fd5ee2008-03-01 08:50:34 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This provides an abstract class for Objective-C code generation. Concrete
11// subclasses of this implement code generation for specific Objective-C
12// runtime libraries.
13//
14//===----------------------------------------------------------------------===//
15
16#ifndef CLANG_CODEGEN_OBCJRUNTIME_H
17#define CLANG_CODEGEN_OBCJRUNTIME_H
Daniel Dunbarde300732008-08-11 04:54:23 +000018#include "clang/Basic/IdentifierTable.h" // Selector
Anton Korobeynikovcd5d08d2008-06-01 14:13:53 +000019#include "llvm/ADT/SmallVector.h"
Daniel Dunbarfd2ff6c2008-08-11 16:50:21 +000020#include "llvm/Support/IRBuilder.h"
Argiris Kirtzidis0560bcf2008-06-01 21:23:24 +000021#include <string>
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000022
23namespace llvm {
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000024 class Constant;
25 class Type;
26 class Value;
27 class Module;
Chris Lattnerb326b172008-03-30 23:03:07 +000028 class Function;
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000029}
30
31namespace clang {
Daniel Dunbarac93e472008-08-15 22:20:32 +000032 class ObjCCategoryImplDecl;
33 class ObjCImplementationDecl;
34 class ObjCMethodDecl;
Daniel Dunbar84bb85f2008-08-13 00:59:25 +000035 class ObjCProtocolDecl;
Chris Lattnerd71288e2008-06-26 04:37:12 +000036 class Selector;
Daniel Dunbar84bb85f2008-08-13 00:59:25 +000037
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000038namespace CodeGen {
Chris Lattner547907c2008-06-26 04:19:03 +000039 class CodeGenModule;
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000040
Anton Korobeynikovcd5d08d2008-06-01 14:13:53 +000041//FIXME Several methods should be pure virtual but aren't to avoid the
42//partially-implemented subclass breaking.
43
44/// Implements runtime-specific code generation functions.
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000045class CGObjCRuntime {
Daniel Dunbarfd2ff6c2008-08-11 16:50:21 +000046 typedef llvm::IRBuilder<> BuilderType;
47
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000048public:
49 virtual ~CGObjCRuntime();
Daniel Dunbarac93e472008-08-15 22:20:32 +000050
51 /// Generate the function required to register all Objective-C components in
52 /// this compilation unit with the runtime library.
53 virtual llvm::Function *ModuleInitFunction() = 0;
54
55 /// Get a selector for the specified name and type values. The
56 /// return value should have the LLVM type for pointer-to
57 /// ASTContext::getObjCSelType().
58 virtual llvm::Value *GetSelector(BuilderType &Builder,
59 Selector Sel) = 0;
60
61 /// Generate a constant string object.
62 virtual llvm::Constant *GenerateConstantString(const std::string &String) = 0;
63
64 /// Generate a category. A category contains a list of methods (and
65 /// accompanying metadata) and a list of protocols.
66 virtual void GenerateCategory(const ObjCCategoryImplDecl *OCD) = 0;
67
68 /// Generate a class stucture for this class.
69 virtual void GenerateClass(const ObjCImplementationDecl *OID) = 0;
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000070
Daniel Dunbarac93e472008-08-15 22:20:32 +000071 /// Generate an Objective-C message send operation.
Daniel Dunbarfd2ff6c2008-08-11 16:50:21 +000072 virtual llvm::Value *GenerateMessageSend(BuilderType &Builder,
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000073 const llvm::Type *ReturnTy,
74 llvm::Value *Receiver,
Chris Lattner8384c142008-06-26 04:42:20 +000075 Selector Sel,
Chris Lattnera0fd5ee2008-03-01 08:50:34 +000076 llvm::Value** ArgV,
Daniel Dunbarac93e472008-08-15 22:20:32 +000077 unsigned ArgC) = 0;
Daniel Dunbar84bb85f2008-08-13 00:59:25 +000078
Daniel Dunbarac93e472008-08-15 22:20:32 +000079 /// Generate an Objective-C message send operation to the super
80 /// class.
Chris Lattnerfaf23db2008-08-08 19:57:58 +000081 virtual llvm::Value *GenerateMessageSendSuper(llvm::IRBuilder<true> &Builder,
Chris Lattnerd71288e2008-06-26 04:37:12 +000082 const llvm::Type *ReturnTy,
Chris Lattnerd71288e2008-06-26 04:37:12 +000083 const char *SuperClassName,
84 llvm::Value *Receiver,
85 Selector Sel,
86 llvm::Value** ArgV,
87 unsigned ArgC) = 0;
Daniel Dunbarfa456242008-08-12 05:08:18 +000088
89 /// Emit the code to return the named protocol as an object, as in a
90 /// @protocol expression.
91 virtual llvm::Value *GenerateProtocolRef(llvm::IRBuilder<true> &Builder,
Daniel Dunbarac93e472008-08-15 22:20:32 +000092 const ObjCProtocolDecl *OPD) = 0;
Daniel Dunbarfa456242008-08-12 05:08:18 +000093
Anton Korobeynikovcd5d08d2008-06-01 14:13:53 +000094 /// Generate the named protocol. Protocols contain method metadata but no
95 /// implementations.
Daniel Dunbarac93e472008-08-15 22:20:32 +000096 virtual void GenerateProtocol(const ObjCProtocolDecl *OPD) = 0;
Daniel Dunbar84bb85f2008-08-13 00:59:25 +000097
Daniel Dunbarac93e472008-08-15 22:20:32 +000098 /// Generate a function preamble for a method with the specified
99 /// types.
100
101 // FIXME: Current this just generates the Function definition, but
102 // really this should also be generating the loads of the
103 // parameters, as the runtime should have full control over how
104 // parameters are passed.
105 virtual llvm::Function *GenerateMethod(const ObjCMethodDecl *OMD) = 0;
Daniel Dunbar84bb85f2008-08-13 00:59:25 +0000106
Anton Korobeynikovcd5d08d2008-06-01 14:13:53 +0000107 /// Look up the class for the specified name
Daniel Dunbarfd2ff6c2008-08-11 16:50:21 +0000108 virtual llvm::Value *LookupClass(BuilderType &Builder,
Daniel Dunbarac93e472008-08-15 22:20:32 +0000109 llvm::Value *ClassName) = 0;
Daniel Dunbar84bb85f2008-08-13 00:59:25 +0000110
Chris Lattnerb326b172008-03-30 23:03:07 +0000111 /// If instance variable addresses are determined at runtime then this should
112 /// return true, otherwise instance variables will be accessed directly from
113 /// the structure. If this returns true then @defs is invalid for this
114 /// runtime and a warning should be generated.
115 virtual bool LateBoundIVars() { return false; }
Chris Lattnera0fd5ee2008-03-01 08:50:34 +0000116};
117
Chris Lattnerb326b172008-03-30 23:03:07 +0000118/// Creates an instance of an Objective-C runtime class.
119//TODO: This should include some way of selecting which runtime to target.
Daniel Dunbar8c85fac2008-08-11 02:45:11 +0000120CGObjCRuntime *CreateGNUObjCRuntime(CodeGenModule &CGM);
121CGObjCRuntime *CreateMacObjCRuntime(CodeGenModule &CGM);
Chris Lattnera0fd5ee2008-03-01 08:50:34 +0000122}
123}
124#endif