[cfe-dev] clang does not emit Ivar class name when compiling libobjc2 on Linux (Mac and gcc Linux are OK)

David Chisnall via cfe-dev cfe-dev at lists.llvm.org
Thu Sep 15 01:14:21 PDT 2016


As I said on the libobjc2 bug report, please file a clang bug and assign it to me.

David

> On 14 Sep 2016, at 20:53, Lobron, David via cfe-dev <cfe-dev at lists.llvm.org> wrote:
> 
> Hello cfe-users,
> 
> I'm working to get my the libobjc2 Objective-C runtime working on Linux with clang-3.8.0.  I'm running into a problem with a library of mine that does class introspection.  My ObjC code does type introspection by looping through the ivars of an object and calling ivar_getTypeEncoding on each to get the type of the ivar.  When I compile with gcc, the ivar type for non-primitive variables comes through as @"NSString", @"NSDictionary", etc.  This also works with clang on my Mac.  But when I compile with clang on Linux, I only get the @ character.  I verified that the call to class_copyIvarList on Linux does return a list of Ivar objects, but when I call ivar_getTypeEncoding on those objects on Linux, I only get @, rather than the class name.  I've copied my library's ObjC code below.  
> 
> I talked this over with the owners of libobjc2, and we were wondering if there is a flag I can pass to clang to instruct it to emit this class data.  I looked at lib/CodeGen/CGObjCGNU.cpp in the clang source tree, but it wasn't immediately clear what flag I could pass here.  It's possible that there's no such flag, and the non-Apple clang simply doesn't emit this data, but I'd be somewhat surprised if Apple had diverged that much.
> 
> Thanks in advance for any help you can give,
> 
> David
> 
> My library's introspection code, with a debug print statement:
> 
> Ivar *ivarList = class_copyIvarList(c, &ivarCount);
> for (i = 0; i < ivarCount; i++) {
>  Ivar ivar = ivarList[i];
>  const char *ivarCname = ivar_getName(ivar);
>  if (ivarCname != 0 && ivarCname[0] != '_') {
>     NSString *ivarName = [NSString stringWithUTF8String:ivarCname];
>     const char *ivarType = ivar_getTypeEncoding(ivar);                    
>     if (ivarType[0] == '@' && ivarType[1] == '"') {
>         NSString *className = [[[NSString alloc] initWithBytes: &ivarType[2]
>                              length: strlen(&ivarType[2])-1
>                         encoding: NSUTF8StringEncoding] autorelease];
>         Class c = NSClassFromString(className);
>         if (c == nil) {
>             NSLog(@"WARNING: unknown class name \"%@\" in declaration of %@", className, [self class]);
>         } else {
>             NSLog(@"DBG: Deduced class %@ from className %@", c, className);
> 
> With gcc and clang on the Mac, I get messages like this:
> 
> 2016-09-14 19:29:21.950 archiveserver[1015:1015] DBG: Deduced class NSSet from className NSSet
> 2016-09-14 19:29:21.950 archiveserver[1015:1015] DBG: Deduced class NSString from className NSString
> 2016-09-14 19:29:21.950 archiveserver[1015:1015] DBG: Deduced class NSString from className NSString
> 2016-09-14 19:29:21.950 archiveserver[1015:1015] DBG: Deduced class NSString from className NSString
> 2016-09-14 19:29:21.950 archiveserver[1015:1015] DBG: Deduced class NSDictionary from className NSDictionary
> 2016-09-14 19:29:21.950 archiveserver[1015:1015] DBG: Deduced class NSDictionary from className NSDictionary
> 2016-09-14 19:29:21.950 archiveserver[1015:1015] DBG: Deduced class NSArray from className NSArray
> 
> With clang on Linux, nothing is printed, because ivarType[1] is not a double quote, so the second if evaluates to false.
> 
> 
> 
> _______________________________________________
> cfe-dev mailing list
> cfe-dev at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev

-------------- next part --------------
A non-text attachment was scrubbed...
Name: smime.p7s
Type: application/pkcs7-signature
Size: 3719 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-dev/attachments/20160915/aa78d313/attachment.bin>


More information about the cfe-dev mailing list