I am trying to figure out why when I convert my main.m file to a main.mm file, it no longer will link properly.
I have reduces the problem to the following example code:
#import <Foundation/Foundation.h>
#import <AppKit/AppKit.h>
int main( int argc, const char ** argv ) {
return NSApplicationMain( argc, argv);
}
I am using gnustep and linux. I enter the following commands and everything works as expected:
g++ -g -c main.m -I/usr/GNUstep/Local/Library/Headers -I/usr/GNUstep/System/Library/Headers
g++ -g -o test main.o -L/usr/GNUstep/Local/Library/Libraries -L/usr/GNUstep/System/Library/Libraries -lgnustep-base -lgnustep-gui
Now if I rename main.m to main.mm and use these two commands ( same exept main.m now main.mm):
g++ -g -c main.mm -I/usr/GNUstep/Local/Library/Headers -I/usr/GNUstep/System/Library/Headers
g++ -g -o test main.o -L/usr/GNUstep/Local/Library/Libraries -L/usr/GNUstep/System/Library/Libraries -lgnustep-base -lgnustep-gui
I get the following error:
main.mm:7: undefined reference to `NSApplicationMain(int, char const**)’
Can someone please find what I am doing wrong? I do not see why it is now failing to link.
I am trying to add some C++ classes to an objective c program and this is preventing me from continuing.
Thank you for any help you can provide.
The problem is that when you compile it as C++, the compiler mangles the name of the symbol
NSApplicationMain, so it can’t find it, since it’s looking for something like__Z17NSApplicationMainiPPKc. You can use thenmprogram (from binutils) to see what symbols the object files are referencing:In order to avoid this problem, C functions need to be declared with an
extern "C"modifier in order to tell the compiler not to mangle the name. Looking into<AppKit/NSApplication.h>, the header file whereNSApplicationMainis declared, I see this:Alas,
APPKIT_EXPORTis defined to be one ofextern,__declspec(dllexport),extern __declspec(dllexport), or nothing in<AppKit/AppKitDefines.h>. Since it’s also used for global variable declarations, we can’t get around this by redefining it toextern "C"(which would be extremely hacky and kludgy anyways). The AppKit header files do not seem to contain anyextern "C"declarations at all, although I do see them in various header files underFoundation/andGNUStepBase/.So what can you do? The solution is to wrap your includes with an
extern "C":This will give the functions defined in those header files the proper linkage, and it will all work out. But you shouldn’t have to do this — I would file a bug report with GNUstep, telling them to add proper
extern "C"declarations to their header files.