]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/distrib/wxPythonFull.spec.in
default style for statusbars varies by platform
[wxWidgets.git] / wxPython / distrib / wxPythonFull.spec.in
index 8dbf5154b6dc14f61b6842821e2cdc8a3b44ab1a..ef201326ef7cd899049a9368c3907f2e4b48bf5a 100644 (file)
@@ -1,34 +1,40 @@
 %define pref   %{_prefix}
 %define python         @PYTHON@
 %define pyver  @PYVER@
-%define debug  @DEBUG@
 %define port   @PORT@
 %define lcport         @LCPORT@
+%define unicode @UNICODE@
 %define tarname @TARNAME@
 %define version @VERSION@
 %define ver2    @VER2@
 %define release 1
-%define wxpref  %{pref}/lib/wxPython
+%define wxprefbase %{pref}/lib/wxPython
+%define wxpref  %{wxprefbase}-%{version}
+%define name    wxPython%{port}-py%{pyver}
 
-# Should --enable-debug_flag be used in release builds?
-%define debug_flag 1
 
+# 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
+%define builtin_libs 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
-%endif
+
+# Should --enable-debug_flag be used in release builds?  Using it
+# defines __WXDEBUG__ and gives us runtime diagnostics that are turned
+# into Python exceptions starting with 2.3.4.  (So turning it on is a
+# very helpful thing IMO and is recommended.)
+%define debug_flag 1
 
 
-%if %{debug} || %{debug_flag}
-    %define wxconfigname %{wxpref}/bin/wx%{lcport}d-%{ver2}-config
-%else
-    %define wxconfigname %{wxpref}/bin/wx%{lcport}-%{ver2}-config
-%endif
+# build the name of the real wx-config from the port, flags, etc.
+%define dbgflg %(if [ "%{debug_flag}" = "1" ]; then echo d; fi)
+%define uniflg %(if [ "%{unicode}" = "1" ]; then echo u; fi)
+%define DBGFLG %(if [ "%{debug_flag}" = "1" ]; then echo D; fi)
+%define UNIFLG %(if [ "%{unicode}" = "1" ]; then echo U; fi)
+%define wxconfigname %{wxpref}/bin/wx%{lcport}%{uniflg}%{dbgflg}-%{ver2}-config
 
+# turn off the generation of debuginfo rpm  (RH9)
+%define debug_package %{nil}
 
 #----------------------------------------------------------------
 Summary:   Cross platform GUI toolkit for Python using wx%{port}
@@ -42,17 +48,18 @@ Packager:  Robin Dunn <robin@alldunn.com>
 Group:     Development/Python
 BuildRoot: %{_tmppath}/%{name}-buildroot
 Prefix:    %{pref}
-#BuildRequires: %{python}
 
-Provides: wxwin
-Provides: wx%{port} = %{version}
 Provides: wxPython  = %{version}
+Provides: wxPython%{port}  = %{version}
+
+# Provides: libwx_%{lcport}%{uniflg}%{dbgflg}-%{ver2}.so
+# Provides: libwx_%{lcport}%{uniflg}%{dbgflg}-%{ver2}.so(WX%{port}%{UNIFLG}%{DBGFLG}_%{ver2})
+# Provides: libwx_%{lcport}%{uniflg}%{dbgflg}_gl-%{ver2}.so
+# Provides: libwx_%{lcport}%{uniflg}%{dbgflg}_gl-%{ver2}.so(WX%{port}%{UNIFLG}%{DBGFLG}_%{ver2})
 
 
-# They conflict with each other, so let them replace each other
-Obsoletes: %{othername}
 # old wxPython packages
-Obsoletes: wxPython
+Obsoletes: wxPython wxPython%{port}
 
 
 %description
@@ -65,13 +72,13 @@ This package is implemented using the %{port} port of wxWindows, and
 includes the wx%{port} shared libs and etc.
 
 
-%package devel
+%package -n wxPython%{port}-devel
 Summary: wxPython%{port} development files
 Group: Development/Libraries
 Requires: wxPython%{port} = %{version}
 
 
-%description devel
+%description -n wxPython%{port}-devel
 This packages contains the headers and etc. for building apps or
 Python extension modules that use the same wx%{port} shared libraries
 that wxPython uses.
@@ -83,135 +90,238 @@ that wxPython uses.
 
 #----------------------------------------------------------------
 %build
-if [ "$SMP" != "" ]; then
-    MAKE="make -j$SMP"
-else
-    MAKE="make"
-fi
 
-mkdir build
-cd build
+WXDIR=`pwd`
+mkdir bld
+cd bld
 
-# Configure, trying to reduce dependencies
+# Configure, trying to reduce external dependencies
 ../configure --with-%{lcport} \
        --prefix=%{wxpref} \
        --disable-soname \
+       --disable-monolithic \
        --enable-rpath=%{wxpref}/lib \
        --with-opengl \
-%if %{debug}
-       --enable-debug \
-%else
+%if %{unicode}
+       --enable-gtk2 \
+       --enable-unicode \
+%endif
+       --enable-geometry \
        --enable-optimise \
 %if %{debug_flag}
        --enable-debug_flag \
 %endif
-%endif
+%if %{builtin_libs}
        --with-libjpeg=builtin \
        --with-libpng=builtin \
        --with-libtiff=builtin \
        --with-zlib=builtin \
+%endif
 
-##     --enable-debug_flag \
-##     --with-odbc \
-
-
-# Build wxWindows
-$MAKE
 
-cd ../locale
-make allmo
+# Build wxWindows and some contrib libs
+make 
+make -C contrib/src/gizmos 
+make -C contrib/src/ogl CXXFLAGS="-DwxUSE_DEPRECATED=0"
+make -C contrib/src/stc
+make -C contrib/src/xrc
 
 
-# ** 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%{wxpref} install
+# Link the contrib header directories in place so we can build all of
+# wxPython without installing wxWindows
+if [ ! -e $WXDIR/include/wx/gizmos ]; then
+       cd $WXDIR/include/wx
+       ln -s ../../contrib/include/wx/* .
+fi
 
 
 # Now build wxPython
-cd ../wxPython
+cd $WXDIR/wxPython
 %{python} setup.py \
-       IN_CVS_TREE=1 \
        NO_SCRIPTS=1 \
-       WX_CONFIG="$RPM_BUILD_ROOT%{wxpref}/bin/wx-config --prefix=$RPM_BUILD_ROOT%{wxpref}" \
+       WXPORT=%{lcport} \
+       UNICODE=%{unicode} \
+       WX_CONFIG="$WXDIR/bld/wx-config --prefix=$WXDIR --exec-prefix=$WXDIR/bld" \
        build
 
 
+# Build wxrc (XRC resource tool)
+cd $WXDIR/bld/contrib/utils/wxrc
+make
+strip wxrc
+
+
 #----------------------------------------------------------------
 %install
-%find_lang wxstd
-cd wxPython
+
+WXDIR=`pwd`
+cd bld
+
+# Install wxWindows and the contribs so the wxPython build can find
+# all the headers it needs
+make prefix=$RPM_BUILD_ROOT%{wxpref} install
+make -C contrib/src/gizmos prefix=$RPM_BUILD_ROOT%{wxpref} install
+make -C contrib/src/ogl CXXFLAGS="-DwxUSE_DEPRECATED=0" prefix=$RPM_BUILD_ROOT%{wxpref} install
+make -C contrib/src/stc prefix=$RPM_BUILD_ROOT%{wxpref} install
+make -C contrib/src/xrc prefix=$RPM_BUILD_ROOT%{wxpref} install
+
+
+# install wxPython
+cd $WXDIR/wxPython
 %{python} setup.py \
-       IN_CVS_TREE=1 \
        NO_SCRIPTS=1 \
+       WXPORT=%{lcport} \
+       UNICODE=%{unicode} \
        WX_CONFIG="$RPM_BUILD_ROOT%{wxpref}/bin/wx-config --prefix=$RPM_BUILD_ROOT%{wxpref}" \
        install \
        --root=$RPM_BUILD_ROOT
 
-# Since I want this RPM to be as generic as possible I won't let
-# distutils copy the scripts, 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, then I can't let
-# it do that otherwise the dependencies will be fouled up.  Copy
-# them manually instead:
 
-mkdir -p $RPM_BUILD_ROOT/usr/bin
+
+cd $WXDIR/wxPython
+
+# install the wxPython headers
+cp -R include $RPM_BUILD_ROOT%{wxpref}
+mkdir -p $RPM_BUILD_ROOT%{wxpref}/include/wx/wxPython/i_files
+cp src/*.i $RPM_BUILD_ROOT%{wxpref}/include/wx/wxPython/i_files
+
+
+# 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 #!/bin/env line intact. 
+# TODO: Should this be dependent on %{builtin_libs} or something like
+# it?
+
+mkdir -p $RPM_BUILD_ROOT%{pref}/bin
 for s in \
+       helpviewer \
        img2png \
        img2py \
        img2xpm \
+       pyalacarte \
+       pyalamode \
        pycrust \
+       pywrap \
        pyshell \
        xrced; do
-    cp scripts/$s $RPM_BUILD_ROOT/usr/bin
+    cp scripts/$s $RPM_BUILD_ROOT%{pref}/bin
 done
 
 
+# Install wxrc
+cp $WXDIR/bld/contrib/utils/wxrc/wxrc $RPM_BUILD_ROOT%{pref}/bin
 
 
-#----------------------------------------------------------------
-%clean
-[ "$RPM_BUILD_ROOT" != "/" ] && rm -rf $RPM_BUILD_ROOT
+# install KDE & GNOME menus
+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
+mkdir -p $RPM_BUILD_ROOT/%{_libdir}/menu
+cat > $RPM_BUILD_ROOT%{_libdir}/menu/%{name} <<EOF
+?package(%{name}): \\
+       command="%{_bindir}/pyshell" \\
+       needs="X11" \\
+       icon="PyCrust.png" \\
+       section="Applications/Development/Tools" \\
+       title="PyShell" \\
+       longtitle="GUI Python Shell"
+?package(%{name}): \\
+       command="%{_bindir}/pycrust" \\
+       needs="X11" \\
+       icon="PyCrust.png" \\
+       section="Applications/Development/Tools" \\
+       title="PyCrust" \\
+       longtitle="GUI Python Shell with Filling"
+?package(%{name}): \\
+       command="%{_bindir}/pyalamode" \\
+       needs="X11" \\
+       icon="PyCrust.png" \\
+       section="Applications/Development/Tools" \\
+       title="PyAlaMode" \\
+       longtitle="GUI Python Shell with Filling and editor windows"
+?package(%{name}): \\
+       command="%{_bindir}/xrced" \\
+       needs="X11" \\
+       icon="XRCed.png" \\
+       section="Applications/Development/Tools" \\
+       title="XRCed" \\
+       longtitle="wxPython XRC resource editor"
+EOF
 
 
 #----------------------------------------------------------------
+
+%pre
+if [ -e %{wxprefbase} ]; then
+       # in case there are old dirs from an old install
+       rm -r %{wxprefbase}
+fi
+
+
 %post
-/sbin/ldconfig
+if [ ! -e %{wxprefbase} ]; then
+       ln -s wxPython-%{version}  %{wxprefbase}
+fi
+# This is done on Mandrake to update its menus:
+if [ -x /usr/bin/update-menus ]; then /usr/bin/update-menus || true ; fi
 
 
-#----------------------------------------------------------------
 %postun
-/sbin/ldconfig
+rm -f %{wxprefbase}
+# This is done on Mandrake to update its menus:
+if [ "$1" = "0" -a -x /usr/bin/update-menus ]; then /usr/bin/update-menus || true ; fi
+
 
+#----------------------------------------------------------------
+%clean
+[ "$RPM_BUILD_ROOT" != "/" ] && rm -rf $RPM_BUILD_ROOT
 
 
 #----------------------------------------------------------------
+
 %files
-%doc docs/preamble.txt
-%doc docs/licence.txt
-%doc docs/readme.txt
-%doc docs/changes.txt
-%doc wxPython/README.txt
-%doc wxPython/CHANGES.txt
 %defattr(-,root,root)
+%doc docs/preamble.txt docs/licence.txt docs/lgpl.txt docs/readme.txt docs/changes.txt
+%doc wxPython/docs/*
+%{_bindir}/*
+%{_libdir}/python%{pyver}/site-packages/*
+%dir %{wxpref}
+%dir %{wxpref}/lib
 %{wxpref}/lib/libwx*
-%{pref}/lib/python*
-%{wxpref}/share/
-%{pref}/bin/*
+%{wxpref}/share
+%{_datadir}/applnk/Development/*
+%{_datadir}/applications/*
+%{_datadir}/icons/hicolor/*/apps/*
+%{_datadir}/pixmaps/*
+%{_libdir}/menu/*
 
+##%{wxprefbase}
 
-%files devel
+
+%files -n wxPython%{port}-devel
 %defattr(-,root,root)
-%{wxpref}/include/wx
+%{wxpref}/include
 %{wxpref}/lib/wx
 %{wxconfigname}
 %{wxpref}/bin/wx-config
 
-
 #----------------------------------------------------------------
-%changelog
-
 # end of file