X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/357262e4a1ba5b056fde35a4d3e552a0e14db938..7f3450784cc9c696f269ff1bfde3623c180d4b58:/wxPython/distrib/wxPythonFull.spec.in diff --git a/wxPython/distrib/wxPythonFull.spec.in b/wxPython/distrib/wxPythonFull.spec.in index 326a695f4f..a4117823bd 100644 --- a/wxPython/distrib/wxPythonFull.spec.in +++ b/wxPython/distrib/wxPythonFull.spec.in @@ -1,144 +1,451 @@ -%define pref %{_prefix} -%define python @PYTHON@ -%define pyver @PYVER@ -%define debug @DEBUG@ -%define port @PORT@ -%define lcport @LCPORT@ -%define tarname @TARNAME@ -%define version @VERSION@ -%define release 1 - -%if %{debug} - %define name wxPython%{port}-py%{pyver}-dbg - %define othername wxPython%{port}-py%{pyver} -%else - %define name wxPython%{port}-py%{pyver} - %define othername wxPython%{port}-py%{pyver}-dbg +#---------------------------------------------------------------------- +# Name: wxPython.spec +# Purpose: RPM Build and packaging instructions +# +# Author: Robin Dunn +# +# RCS-ID: $Id$ +# Copyright: (c) 2004 by Total Control Software +# Licence: wxWindows license +#---------------------------------------------------------------------- + + +# The following values can be set on the rpmbuild command line with +# --define 'name VALUE' If no value is set on the command line then +# the default value set here will be used instead. + + +# Which version of Python to build with. Used to assemble python +# binary name so use '2.3', '2.4', etc. +%if %{?pyver:0}%{!?pyver:1} +%define pyver 2.4 +%endif + + +# Which wxWidgets port to build and use. Current acceptable values +# are 'gtk' and 'gtk2'. +%if %{?port:0}%{!?port:1} +%define port gtk2 +%endif + + +# Build in unicode mode? Can only be used if port is gtk2, acceptable +# values are '0' and '1' +%if %{?unicode:0}%{!?unicode:1} +%define unicode 1 +%endif + + +# Should the builtin image and etc. libs be used, or system libs? +# Distro specific RPMs should probably set this to 0, generic ones +# should use 1. +# NOTE: I'm trying 0 for this next release to see if I can get rid of +# this... +%if %{?builtin_libs:0}%{!?builtin_libs:1} +%define builtin_libs 0 %endif -Summary: Cross platform GUI toolkit for Python using wx%{port} -Name: %{name} -Version: %{version} -Release: %{release} -Source0: %{tarname}-%{version}.tar.gz -License: wxWindows Library Licence, Version 3 -url: http://wxPython.org/ -packager: Robin Dunn +# Should --enable-debug_flag be used in release builds? Using it +# defines __WXDEBUG__ and gives us runtime diagnostics that are turned +# into Python exceptions. (So turning it on is a very helpful thing +# IMO and is recommended.) The code is still compiled with +# optimization flags and and without debug info and such when this +# option is used, it simply turns on some extra code. +%if %{?debug_flag:0}%{!?debug_flag:1} +%define debug_flag 1 +%endif + + +# Used to set the Release tag below. I normally use it to define what +# distro the RPM was built on and also include the version of Python +# it was built with. +%if %{?release:0}%{!?release:1} +%define release 1_py%{pyver} +%endif + + +# This one is used to control whether the full 4 components of the +# verseion number are used in the site-packages subdirectory name. By +# default only 2 or 3 components (depending on stable/unstable status) +# are used. +%if %{?fullver:0}%{!?fullver:1} +%define fullver 0 +%endif + + +# Whether to add --enable-mediactrl to the wxWidgets configure. For +# some older versions of gstreamer-0.8 it currently incorerctly allows +# its use eventhough there is a compatibility problem that causes a +# failed compile. +%if %{?mediactrl:0}%{!?mediactrl:1} +%define mediactrl 1 +%endif + + +#---------------------------------------------------------------------- +# Other variables used below + +%define pref %{_prefix} +%define python /usr/bin/python%{pyver} +%define tarname @TARNAME@ +%define version @VERSION@ +%define ver2 @VER2@ + +%define chartype %(if [ "%{unicode}" = "1" ]; then echo unicode; else echo ansi; fi) +%define gtktype %(if [ "%{port}" = "gtk2" ]; then echo 2; fi) +%define using_gtk1 %(if [ "%{port}" = "gtk" ]; then echo 1; else echo 0; fi) + +%define wxprefbase %{pref}/lib/wxPython +%define wxpref %{wxprefbase}-%{version}-%{port}-%{chartype} +%define pkgname wxPython + +# turn off the generation of debuginfo rpm (RH9) ?? +%define debug_package %{nil} + + +#---------------------------------------------------------------------- +# Package definition +#---------------------------------------------------------------------- +Name: %{pkgname}%{ver2} +Summary: Cross platform GUI toolkit for Python +Version: %{version} +Release: %{release} +Source0: %{tarname}-%{version}.tar.bz2 +License: wx Library Licence, Version 3 +URL: http://wxPython.org/ +Packager: Robin Dunn +Group: Development/Python +BuildRoot: %{_tmppath}/%{pkgname}-buildroot +Prefix: %{pref} + +%description +Cross platform GUI toolkit for Python + + + + +%package -n %{pkgname}%{ver2}-%{port}-%{chartype} +Summary: Cross platform GUI toolkit for Python +Group: Development/Python +Requires: %{pkgname}-common +Obsoletes: wxPythonGTK%{gtktype}-py%{pyver}, wxPythonGTK%{gtktype} +Provides: wxPython + + +%description -n %{pkgname}%{ver2}-%{port}-%{chartype} +wxPython is a GUI toolkit for the Python programming language. It +allows Python programmers to create programs with a robust, highly +functional graphical user interface, simply and easily. It is +implemented as a Python extension module (native code) that wraps the +popular wxWidgets cross platform GUI library, which is written in C++. + +wxPython is a cross-platform toolkit. The same program will usually +run on multiple platforms without modification. Currently supported +platforms are 32-bit Microsoft Windows, most Unix or unix-like +systems, and Macintosh OS X. + +This package contains the wxPython runtime files built for the +wxWidgets %{port} port with %{chartype} character type. + + + + + +%package -n %{pkgname}-common-%{port}-%{chartype} +Summary: Common files for needed by all wxPython runtimes Group: Development/Python -BuildRoot: %{_tmppath}/%{name}-buildroot -Prefix: %{pref} +Provides: %{pkgname}-common + +# They obsolete each other so any of them can be installed over another +# without conflicts +Obsoletes: %{pkgname}-common-gtk-ansi +Obsoletes: %{pkgname}-common-gtk2-ansi +Obsoletes: %{pkgname}-common-gtk2-unicode + +%description -n %{pkgname}-common-%{port}-%{chartype} +This package contains the common files needed by any version of the +wxPython runtime. This pacakge also installs a wx.pth file which will +determine which of the installed runtimes is the default version of +wxPython that is imported automatically with a bare "import wx". -Provides: wxwin -Provides: wx%{port} = %{version} -Provides: wxPython = %{version} -# They conflict with each other, so let them replace each other -Obsoletes: %{othername} -# old wx and wxPython packages -Obsoletes: wx%{port}, wxPython -# and some funky mandrake names -Obsoletes: wxGTK2.3, wxGTK6 +%package -n %{pkgname}%{ver2}-devel-%{port}-%{chartype} +Summary: wxPython development files +Group: Development/Libraries +Requires: %{pkgname}%{ver2}-%{port}-%{chartype} = %{version} -%description -wxPython is a GUI toolkit for Python that is a wrapper around the -wxWindows C++ GUI library. wxPython provides a large variety of -window types and controls, all implemented with a native look and feel -(and native runtime speed) on the platforms it is supported on. +%description -n %{pkgname}%{ver2}-devel-%{port}-%{chartype} +This packages contains the headers and etc. for building apps or +Python extension modules that use the same wxWidgets shared libraries +that wxPython uses. -This package is implemented using the GTK port of wxWindows, and -includes the wx%{port} shared libs and etc. +#---------------------------------------------------------------------- %prep %setup -q -n %{tarname}-%{version} +#---------------------------------------------------------------------- %build -if [ "$SMP" != "" ]; then - MAKE="make -j$SMP" -else - MAKE="make" -fi -mkdir build -cd build +WXDIR=`pwd` -# Configure, trying to reduce dependencies -../configure --with-%{lcport} --enable-soname --prefix=%{pref} \ - --with-odbc \ +# Configure and build wxWidgets +mkdir bld +cd bld +../configure \ +%if %{using_gtk1} + --with-gtk=1 \ +%else + --with-gtk=2 \ +%endif + --prefix=%{wxpref} \ + --disable-monolithic \ + --disable-rpath \ --with-opengl \ -%if %{debug} - --enable-debug \ -%else + --with-gnomeprint \ + --enable-geometry \ --enable-optimise \ + --enable-sound --with-sdl \ +%if %{mediactrl} + --enable-mediactrl \ +%endif + --enable-display \ +%if %{unicode} + --enable-unicode \ +%else + --disable-unicode \ %endif +%if %{debug_flag} + --enable-debug_flag \ +%endif + --disable-debugreport \ +%if %{builtin_libs} --with-libjpeg=builtin \ --with-libpng=builtin \ --with-libtiff=builtin \ --with-zlib=builtin \ +%endif -## --enable-debug_flag \ - -# Build wxWindows -$MAKE - -cd ../locale -make allmo +make +make -C contrib/src/animate +make -C contrib/src/gizmos +make -C contrib/src/stc -# ** Unfortunately we have to do a bit of installation here so wxPython -# can be built. Perhaps wx-config should be changed to be able to be -# used from the build dir, maybe with an --inplace flag... Move these -# three lines to %install if/when that happens. -[ "$RPM_BUILD_ROOT" != "/" ] && rm -rf $RPM_BUILD_ROOT -cd ../build -make prefix=$RPM_BUILD_ROOT%{pref} install -# Now build wxPython -cd ../wxPython +# Build wxPython +cd $WXDIR/wxPython %{python} setup.py \ - IN_CVS_TREE=1 \ - WX_CONFIG="$RPM_BUILD_ROOT%{pref}/bin/wx-config --prefix=$RPM_BUILD_ROOT%{pref}" \ + WXPORT=%{port} \ + UNICODE=%{unicode} \ + EP_ADD_OPTS=1 \ + EP_FULL_VER=%{fullver} \ + NO_SCRIPTS=1 \ + WX_CONFIG="$WXDIR/bld/wx-config --no_rpath" \ + build_ext --rpath=%{wxpref}/lib \ build + +#---------------------------------------------------------------------- %install -## ** [ "$RPM_BUILD_ROOT" != "/" ] && rm -rf $RPM_BUILD_ROOT -%find_lang wxstd -cd wxPython + +WXDIR=`pwd` + +# Install wxGTK and contribs +cd bld +make prefix=$RPM_BUILD_ROOT%{wxpref} install +make -C contrib/src/animate prefix=$RPM_BUILD_ROOT%{wxpref} install +make -C contrib/src/gizmos prefix=$RPM_BUILD_ROOT%{wxpref} install +make -C contrib/src/stc prefix=$RPM_BUILD_ROOT%{wxpref} install + + + +# Install wxPython for wxGTK +cd $WXDIR/wxPython %{python} setup.py \ - IN_CVS_TREE=1 \ - WX_CONFIG="$RPM_BUILD_ROOT%{pref}/bin/wx-config --prefix=$RPM_BUILD_ROOT%{pref}" \ + WXPORT=%{port} \ + UNICODE=%{unicode} \ + EP_ADD_OPTS=1 \ + EP_FULL_VER=%{fullver} \ + NO_SCRIPTS=1 \ + WX_CONFIG="$RPM_BUILD_ROOT%{wxpref}/bin/wx-config --prefix=$RPM_BUILD_ROOT%{wxpref} --no_rpath" \ + build_ext --rpath=%{wxpref}/lib \ install \ --root=$RPM_BUILD_ROOT +# remove the wx-config symlink, we'll redo it when installing the -devel package +rm $RPM_BUILD_ROOT%{wxpref}/bin/wx-config + +# make sure that debug info is stripped +strip $RPM_BUILD_ROOT%{pref}/lib*/python%{pyver}/site-packages/wx-%{ver2}*-%{port}-%{chartype}/wx/*.so + + +# Since I want this RPM to be as generic as possible I won't let +# distutils copy the scripts (NO_SCRIPTS=1 above) since it will mangle +# the #! line to use the real python pathname. Since some distros +# install python 2.2 as python2 and others as python I can't let +# distutils do that otherwise the dependencies will be fouled up. +# Copy them manually instead, leaving the #!/usr/bin/env line intact. +cd $WXDIR/wxPython +mkdir -p $RPM_BUILD_ROOT%{pref}/bin +for s in \ + helpviewer \ + img2png \ + img2py \ + img2xpm \ + pyalacarte \ + pyalamode \ + pycrust \ + pywrap \ + pyshell \ + pywxrc \ + xrced; do + cp scripts/$s $RPM_BUILD_ROOT%{pref}/bin +done + + + +# install KDE & GNOME menu items +mkdir -p $RPM_BUILD_ROOT%{_datadir}/applnk/Development +mkdir -p $RPM_BUILD_ROOT%{_datadir}/applications +for d in distrib/*.desktop; do + install -m 644 $d $RPM_BUILD_ROOT%{_datadir}/applnk/Development + install -m 644 $d $RPM_BUILD_ROOT%{_datadir}/applications +done + +# install KDE icons +mkdir -p $RPM_BUILD_ROOT%{_datadir}/icons/hicolor/{16x16,32x32}/apps +mkdir -p $RPM_BUILD_ROOT%{_datadir}/pixmaps +install -m 644 wx/py/PyCrust_16.png $RPM_BUILD_ROOT%{_datadir}/icons/hicolor/16x16/apps/PyCrust.png +install -m 644 wx/py/PyCrust_32.png $RPM_BUILD_ROOT%{_datadir}/icons/hicolor/32x32/apps/PyCrust.png +install -m 644 wx/py/PyCrust_32.png $RPM_BUILD_ROOT%{_datadir}/pixmaps/PyCrust.png +install -m 644 wx/tools/XRCed/XRCed_16.png $RPM_BUILD_ROOT%{_datadir}/icons/hicolor/16x16/apps/XRCed.png +install -m 644 wx/tools/XRCed/XRCed_32.png $RPM_BUILD_ROOT%{_datadir}/icons/hicolor/32x32/apps/XRCed.png +install -m 644 wx/tools/XRCed/XRCed_32.png $RPM_BUILD_ROOT%{_datadir}/pixmaps/XRCed.png + +# install Mandrake menu items +mkdir -p $RPM_BUILD_ROOT%{_libdir}/menu +cat > $RPM_BUILD_ROOT%{_libdir}/menu/%{pkgname} <