2013-03-25 01:00:21 +00:00
|
|
|
Creating packages for MacOSX
|
|
|
|
============================
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
Packaging your application for the MacOSX 10.6 platform can only be done inside
|
2012-02-15 09:25:17 +00:00
|
|
|
MacOSX. The following method has only been tested inside VirtualBox and
|
2011-07-15 14:43:34 +00:00
|
|
|
MacOSX 10.6, using the portable package of Kivy.
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
The package will only work for the 64 bit MacOSX. We no longer support 32 bit
|
|
|
|
MacOSX platforms.
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2014-08-15 22:06:21 +00:00
|
|
|
+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
| NOTE: Currently, packages for OSX can only be generated with Python 2.7. Python 3.3+ support is on the way... |
|
|
|
|
+---------------------------------------------------------------------------------------------------------------+
|
|
|
|
|
2012-08-17 00:19:14 +00:00
|
|
|
.. _mac_osx_requirements:
|
|
|
|
|
2011-07-15 14:43:34 +00:00
|
|
|
Requirements
|
|
|
|
------------
|
|
|
|
|
|
|
|
* Latest Kivy (the whole portable package, not only the github sourcecode)
|
2013-03-25 01:00:21 +00:00
|
|
|
* `PyInstaller 2.0 <http://www.pyinstaller.org/#Downloads>`_
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
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.
|
2012-08-17 00:19:14 +00:00
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
Thereafter, download and decompress the PyInstaller 2.0 package.
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2012-12-04 18:03:24 +00:00
|
|
|
.. warning::
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
It seems that the latest PyInstaller has a bug affecting Mach-O binaries.
|
|
|
|
(http://www.pyinstaller.org/ticket/614). To correct the issue, type::
|
2012-12-04 18:03:24 +00:00
|
|
|
|
|
|
|
cd pyinstaller-2.0/PyInstaller/lib/macholib
|
|
|
|
curl -O https://bitbucket.org/ronaldoussoren/macholib/raw/e32d04b5361950a9343ca453d75602b65787f290/macholib/mach_o.py
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
In version 2.1, the issue has already been corrected.
|
2012-12-04 18:03:24 +00:00
|
|
|
|
|
|
|
|
2012-08-17 00:19:14 +00:00
|
|
|
.. _mac_Create-the-spec-file:
|
|
|
|
|
2011-07-15 14:43:34 +00:00
|
|
|
Create the spec file
|
|
|
|
--------------------
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
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
|
2011-07-15 14:43:34 +00:00
|
|
|
file is named `main.py`. Replace both path/filename according to your system.
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
#. Open a console.
|
2011-07-15 14:43:34 +00:00
|
|
|
#. Go to the pyinstaller directory, and create the initial specs::
|
|
|
|
|
2012-09-24 19:40:57 +00:00
|
|
|
cd pyinstaller-2.0
|
2014-03-25 19:26:36 +00:00
|
|
|
kivy pyinstaller.py --windowed --name touchtracer ../kivy/examples/demo/touchtracer/main.py
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
#. The specs file is named `touchtracer/touchtracer.spec` and located inside the
|
2011-07-15 14:43:34 +00:00
|
|
|
pyinstaller directory. Now we need to edit the spec file to add kivy hooks
|
2013-03-25 01:00:21 +00:00
|
|
|
to correctly build the executable.
|
2011-07-15 14:43:34 +00:00
|
|
|
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())
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
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.
|
2012-09-24 19:40:57 +00:00
|
|
|
|
2011-07-15 14:43:34 +00:00
|
|
|
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()
|
2012-02-15 04:09:32 +00:00
|
|
|
object. This Tree will search and add every file found in the touchtracer
|
2011-07-15 14:43:34 +00:00
|
|
|
directory to your final package::
|
|
|
|
|
|
|
|
coll = COLLECT( exe, Tree('../kivy/examples/demo/touchtracer/'),
|
|
|
|
a.binaries,
|
|
|
|
#...
|
|
|
|
)
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
#. We are done. Your spec is ready to be executed!
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2012-08-17 00:19:14 +00:00
|
|
|
.. _Build the spec and create DMG:
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
Build the spec and create a DMG
|
|
|
|
-------------------------------
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
#. Open a console.
|
2011-07-15 14:43:34 +00:00
|
|
|
#. Go to the pyinstaller directory, and build the spec::
|
|
|
|
|
2012-09-24 19:40:57 +00:00
|
|
|
cd pyinstaller-2.0
|
|
|
|
kivy pyinstaller.py touchtracer/touchtracer.spec
|
2011-07-15 14:43:34 +00:00
|
|
|
|
|
|
|
#. 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
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
#. You will now have a Touchtracer.dmg available in the `touchtracer/dist` directory.
|
2011-07-15 14:43:34 +00:00
|
|
|
|
2012-09-25 13:50:15 +00:00
|
|
|
Including Gstreamer
|
|
|
|
-------------------
|
|
|
|
|
2013-03-25 01:00:21 +00:00
|
|
|
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
|
2012-09-25 13:50:15 +00:00
|
|
|
and libraries are missing. You need to include them in your .spec file too, by
|
2013-03-25 01:00:21 +00:00
|
|
|
adding one more arguments to the `COLLECT()` method::
|
2012-09-25 13:50:15 +00:00
|
|
|
|
|
|
|
import os
|
2012-09-25 14:26:06 +00:00
|
|
|
gst_plugin_path = os.environ.get('GST_PLUGIN_PATH').split(':')[0]
|
2012-09-25 13:50:15 +00:00
|
|
|
|
|
|
|
coll = COLLECT( exe, Tree('../kivy/examples/demo/touchtracer/'),
|
2012-12-04 18:03:24 +00:00
|
|
|
Tree(os.path.join(gst_plugin_path, '..')),
|
2012-09-25 13:50:15 +00:00
|
|
|
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')
|
|
|
|
|