osx - install app on mac with shared libraries outside bundle -


I am working on a QT application with some library dependencies for which I have to make an installer.

From everything taught by me, to build a bundle app with all kinds of library dependencies, and the best way to create the necessary QT framework inside myapp.app/Contents/Frameworks is the best way. In parallel ... that will also be deployed on the Mac. They will have the same library dependencies and will be created using the same QT version.

In that case it makes sense to set up libraries and Qt bundles ... so both (all) applications can be accessed without any copies of the same libraries.

Does it seem reasonable - and what to do with the Mac OSX concept of Bundle islands? And how do I create such an installer that keeps the libraries out of the app bundle?

The easiest way to deploy is to use the Qt MacDeuverkat command line tool for OS X, and You have correctly identified that there is a general method for placing the framework inside the app bundle, but many apps are copies of each framework.

It is advisable to suggest the QT framework to be taken to a different, outer space and add to it instead. However, you will need to manage the settings carefully, especially when it comes to providing updates and keep in mind that if the structure has been removed or replaced, then all your applications will fail to load. This, however, is similar to any outline dependent application.

The thing to consider is where the framework is kept normally, we live in an external framework / library / framework, but if we all start to use it for Qt, then the problems can be found. When your app is installed and other developers install their app framework with a different version of the library.

Applet defines various "applications" and initially, the most likely location appears to be "Application Support Directory", but the documentation says that: -

Any type of file that is not required to the app to run

Used, for example, templates for selecting the user if your app is a Then be deployed through Pl store, I would not be surprised if you are using this location it will be rejected. However, you are not using Apple Store, you can deploy frameworks here.

If the Apple Store is your method of deployment, then the library / framework may have been mentioned above QT, the structure to stay with the probability of problems,

Alternatively, you Think of how many applications are developing, and it is actually an issue that bundles frameworks several times with the benefits that it brings, such as allowing the user to remove the application clearly and its Are the dependencies, as well as to reduce the problem of changing or removing the structure?

If you choose to transfer them externally, you can mention the answer, which broadly describes how to create an installer package, as an outline for install_name_tool Along with the frameworks have updated their binary dependencies.


Comments