Backwards Compatibility With libxml2 and iPhone SDK
Q: Why does my application crash with an "Incompatible library version" error message?
A: Why does my application crash with an "Incompatible library version" error message?
If the following conditions are met:
your application links directly to libxml2, and
is built using the iPhone SDK 3.0 or later, and
has iPhone OS 2.x as a deployment target
then the application will crash when run on 2.x devices. This is due to a compatibility version change in libxml2 between iPhone OS 2.2.1 and iPhone OS 3.0 and later. You can work around this issue by linking directly to the older version of libxml2.
Fixing the compatibility version
You can link directly to a library by modifying the "Other Linker Flags" entry for your Xcode project. To do so, open the project's Build settings and search for "Other Linker Flags". Then find the full path to libxml2 in the appropriate 2.x SDK and add that to the flags. For example, if you have the 2.2.1 SDK installed, you can use the following:
$(DEVELOPER_DIR)/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS2.2.1.sdk/usr/lib/libxml2.dylib
.
Xcode will replace the $(DEVELOPER_DIR)
variable with the directory where your developer tools are installed, which makes this more portable in case the project is later opened on a machine with the tools installed in a non-default directory.
data:image/s3,"s3://crabby-images/9ef6d/9ef6d25148aa3e4c6adb03ac97abade7a6e45057" alt=""
data:image/s3,"s3://crabby-images/9ef6d/9ef6d25148aa3e4c6adb03ac97abade7a6e45057" alt=""
Making it work on the Simulator
The setting described above will solve the problem when building the application for the Device, but because the library path is fully specified, Xcode cannot switch to the appropriate version when building for the Simulator. It is necessary to add a "Build Setting Condition" to the "Other Linker Flags" entry. One condition will specify the "Other Linker Flags" when building for the Device, the other condition will do so when building for the Simulator. You can add build setting conditions by selecting the setting, and then clicking the menu in the bottom left of the window.
data:image/s3,"s3://crabby-images/5e1db/5e1db26a406f1d322adece1c6504b3b39dc24b83" alt=""
This will create a child entry for linker flags that is only enabled when the rules specified in the build setting condition are true. You will need to add two conditions - one for the Device and one for the Simulator. Set the linker flag for the device as described above. For the Simulator, you should use the Base SDK version by specifying -lxml2
. If you had previously set the linker flag without a build condition, you should remove that flag.
data:image/s3,"s3://crabby-images/8028e/8028e257b0f78e4aad1a4079dfa0e51976c6c505" alt=""
data:image/s3,"s3://crabby-images/8028e/8028e257b0f78e4aad1a4079dfa0e51976c6c505" alt=""
Document Revision History
Date | Notes |
---|---|
2009-08-05 | New document that describes how to work around the "Incompatible library version" link error when using libxml2. |
Copyright © 2009 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2009-08-05