mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 19:23:23 +01:00
Fixed the MCJIT so that it can emit not only instance
methods but also class methods for Objective-C. Clang emits Objective-C method names with '\1' at the beginning, and the JIT has pre-existing logic to try prepending a '\1' when searching a module for an instance method (that is, a method whose name begins with '-'). I simply extended it to do the same thing when it encountered a class method (a method whose name begins with '+'). llvm-svn: 144451
This commit is contained in:
parent
26219cc439
commit
7c35e9d15b
@ -39,9 +39,9 @@ public:
|
||||
if (Name[0] == '_') ++Name;
|
||||
Function *F = M->getFunction(Name);
|
||||
// Some ObjC names have a prefixed \01 in the IR. If we failed to find
|
||||
// the symbol and it's of the ObjC conventions (starts with "-"), try
|
||||
// prepending a \01 and see if we can find it that way.
|
||||
if (!F && Name[0] == '-')
|
||||
// the symbol and it's of the ObjC conventions (starts with "-" or
|
||||
// "+"), try prepending a \01 and see if we can find it that way.
|
||||
if (!F && (Name[0] == '-' || Name[0] == '+'))
|
||||
F = M->getFunction((Twine("\1") + Name).str());
|
||||
assert(F && "No matching function in JIT IR Module!");
|
||||
return JMM->startFunctionBody(F, Size);
|
||||
@ -56,9 +56,9 @@ public:
|
||||
if (Name[0] == '_') ++Name;
|
||||
Function *F = M->getFunction(Name);
|
||||
// Some ObjC names have a prefixed \01 in the IR. If we failed to find
|
||||
// the symbol and it's of the ObjC conventions (starts with "-"), try
|
||||
// prepending a \01 and see if we can find it that way.
|
||||
if (!F && Name[0] == '-')
|
||||
// the symbol and it's of the ObjC conventions (starts with "-" or
|
||||
// "+"), try prepending a \01 and see if we can find it that way.
|
||||
if (!F && (Name[0] == '-' || Name[0] == '+'))
|
||||
F = M->getFunction((Twine("\1") + Name).str());
|
||||
assert(F && "No matching function in JIT IR Module!");
|
||||
JMM->endFunctionBody(F, FunctionStart, FunctionEnd);
|
||||
|
Loading…
Reference in New Issue
Block a user