Table Of Contents
Creating packages for MacOSX¶
Packaging your application for the MacOSX 10.6 platform can only be done inside MacOSX. The following method has only been tested inside VirtualBox and MacOSX 10.6, using the portable package of Kivy.
The package will only work for the 64 bit MacOSX. We no longer support 32 bit MacOSX platforms.
- Latest Kivy (the whole portable package, not only the github sourcecode)
- PyInstaller 2.0
Please ensure that you have installed the Kivy DMG and installed the make-symlink script. The kivy command must be accessible from the command line.
Thereafter, download and decompress the PyInstaller 2.0 package.
It seems that the latest PyInstaller has a bug affecting Mach-O binaries. (http://www.pyinstaller.org/ticket/614). To correct the issue, type:
cd pyinstaller-2.0/PyInstaller/lib/macholib curl -O https://bitbucket.org/ronaldoussoren/macholib/raw/e32d04b5361950a9343ca453d75602b65787f290/macholib/mach_o.py
In version 2.1, the issue has already been corrected.
Create the spec file¶
As an example, we’ll package the touchtracer demo, using a custom icon. The touchtracer code is in the ../kivy/examples/demo/touchtracer/ directory, and the main file is named main.py. Replace both path/filename according to your system.
Open a console.
Go to the pyinstaller directory, and create the initial specs:
cd pyinstaller-2.0 kivy pyinstaller.py --windowed --name touchtracer ../kivy/examples/demo/touchtracer/main.py
The specs file is named touchtracer/touchtracer.spec and located inside the pyinstaller directory. Now we need to edit the spec file to add kivy hooks to correctly build the executable. Open the spec file with your favorite editor and put theses lines at the start of the spec:
from kivy.tools.packaging.pyinstaller_hooks import install_hooks install_hooks(globals())
In the Analysis() method, remove the hookspath=None parameter. If you don’t do this, the kivy package hook will not be used at all.
Then, you need to change the COLLECT() call to add the data of touchtracer (touchtracer.kv, particle.png, ...). Change the line to add a Tree() object. This Tree will search and add every file found in the touchtracer directory to your final package:
coll = COLLECT( exe, Tree('../kivy/examples/demo/touchtracer/'), a.binaries, #... )
We are done. Your spec is ready to be executed!
Build the spec and create a DMG¶
Open a console.
Go to the pyinstaller directory, and build the spec:
cd pyinstaller-2.0 kivy pyinstaller.py touchtracer/touchtracer.spec
The package will be the touchtracer/dist/touchtracer directory. Rename it to .app:
pushd touchtracer/dist mv touchtracer touchtracer.app hdiutil create ./Touchtracer.dmg -srcfolder touchtracer.app -ov popd
You will now have a Touchtracer.dmg available in the touchtracer/dist directory.
If you want to read video files, audio, or camera, you will need to include gstreamer. By default, only pygst/gst files are discovered, but all the gst plugins and libraries are missing. You need to include them in your .spec file too, by adding one more arguments to the COLLECT() method:
import os gst_plugin_path = os.environ.get('GST_PLUGIN_PATH').split(':') coll = COLLECT( exe, Tree('../kivy/examples/demo/touchtracer/'), Tree(os.path.join(gst_plugin_path, '..')), a.binaries, #... )
For Kivy.app < 1.4.1, you also need to update one script included in our Kivy.app. Go to /Applications/Kivy.app/Contents/Resources/kivy/kivy/tools/packaging/pyinstaller_hooks/, and edit the file named rt-hook-kivy.py, and add this line at the end:
environ['GST_PLUGIN_PATH'] = join(root, '..', 'gst-plugins')