During a refactor of an iOS project, I ran into this bear of a bug. During the linking phase, I get this message:
ld: duplicate symbol _OBJC_IVAR_$_TinCanViewController.currentViewController in /path/to/TinCanViewController-E98A666B7AF2673A.o and /path/to/TinCanViewController-E98A666B7AF2673A.o
As far as I can tell, it looks like it claims TinCanViewController-E98A666B7AF2673A.o
is declaring the specified symbol twice; both paths are pointing to the exact same .o file. I ran nm
on that specific file, and it only included that symbol once:
00008150 S _OBJC_IVAR_$_TinCanViewController.currentViewController
I ran nm
on all the other .o files in the directory to see if they were somehow declaring this symbol, too, but they're not. This happens to any member I add to the TinCanViewController class - it's not specific to currentViewController.
I feel like I must be somehow linking against the class twice somehow, but I've pretty assiduously gone through and checked all references to this class. In the refactored version, there are basically none. The AppDelegate includes it, but right now it's basically just a passthrough class that loads another ViewController at the start. No other classes in the project include it.
Any suggestions on what might be causing this or how I might debug it better?
Make sure delegate.m is only listed once within the Compile-Sources.
I had this happen but my problem was related to merge issues from our repo. The .m file was listed twice in a spot that it should only have been listed once (within the project, but not within the file/group structure, so you could not see the issue in Xcode, only the error). The fix is opening the .pbxproj file inside your project file and locating the duplicate entry in that file. After deleting the duplicate the project built just fine.
I think this is a bug with Apple's latest linker when creating universal static libraries. I can;t find the bug number currently, but this happens because it incorrectly generates armv6 and armv7 without disambiguating them.
To verify if this is the case, change the configuration to build only armv6 or amv7, and you won't have this problem.
This could also happen if you have a multi-target project and two targets have same file like
abc.m
and thatabc.m
is selected for both targets.What happened in my case was I had two targets named
ABC
andXYZ
and both had their ownDiagramViewController.m
file which are supposed to run code for their targets. I accidentally hadDiagramViewController.m
of targetABC
had target selected forXYZ
also.Solution :
Click on
.m
file go to file inspector and unselect additional target.I had this issue on the latest Xcode 4. Cause: I included
file.m
instead offile.h
Possibly, you included
TinCanViewController.m
(should beTinCanViewController.h
)I happened to have included the .h file and the .m file twice in the project. Once I removed the second copy, the error went away.