diff options
-rw-r--r-- | development/pudb/README | 53 | ||||
-rw-r--r-- | development/pudb/pudb.SlackBuild | 139 | ||||
-rw-r--r-- | development/pudb/pudb.info | 14 | ||||
-rw-r--r-- | development/pudb/slack-desc | 6 |
4 files changed, 174 insertions, 38 deletions
diff --git a/development/pudb/README b/development/pudb/README index 9cafb649d7e65..253788f59440b 100644 --- a/development/pudb/README +++ b/development/pudb/README @@ -1,7 +1,52 @@ PuDB is a full-screen, console-based visual debugger for Python. -Its goal is to provide all the niceties of modern GUI-based debuggers in a -more lightweight and keyboard-friendly package. PuDB allows you to debug -code right where you write and test it--in a terminal. If you've worked -with the excellent (but nowadays ancient) DOS-based Turbo Pascal or C +Its goal is to provide all the niceties of modern GUI-based debuggers in a +more lightweight and keyboard-friendly package. PuDB allows you to debug +code right where you write and test it--in a terminal. If you've worked +with the excellent (but nowadays ancient) DOS-based Turbo Pascal or C tools, PuDB's UI might look familiar. + +By default this SlackBuild builds the python2 debugger, and if python3 is +detected, the python3 version too. The Pygments SlackBuild will automatically +install for python3 too. + +NOTE: The python3 application is named pudb3. +NOTE: You need python3-urwid installed to use pudb3. + +OPTIONS + +To *ONLY* build the python2 version, use: + +NO_PYTHON3=1 ./pudb.SlackBuild + +To *ONLY* build the python3 version, use: + +NO_PYTHON2=1 ./pudb.SlackBuild + +The python2 version requires a newer version of urwid than the stock Slackware +one, therefore this also builds a custom urwid named py2_urwid, which it can +use. This should not conflict with the stock Slackware version. + +OPTIONAL DEPENDENCIES + +python3-urwid for the python3 version. Note that it will still build without +this, so it can be installed later if needed. + +############################################################################### + +GETTING STARTED + +Please see starting.rst usage.rst misc.rst and shells.rst in +/usr/doc/pudb-$VERSION to get started, and also - + +Online docs: + +https://documen.tician.de/pudb/ + +A simple, but useful, illustrated example page: + +http://heather.cs.ucdavis.edu/~matloff/pudb.html + +Github page: + +https://github.com/inducer/pudb diff --git a/development/pudb/pudb.SlackBuild b/development/pudb/pudb.SlackBuild index 74958b618a73e..cd38d8a15a5ed 100644 --- a/development/pudb/pudb.SlackBuild +++ b/development/pudb/pudb.SlackBuild @@ -1,20 +1,39 @@ #!/bin/sh # # Slackware build script for pudb + +# Copyright 2018 David Woodfall <dave@dawoodfall.net> +# All rights reserved. +# +# Redistribution and use of this script, with or without modification, is +# permitted provided that the following conditions are met: +# +# 1. Redistributions of this script must retain the above copyright +# notice, this list of conditions and the following disclaimer. # -# Written by Rudson R. Alves rudsonalves@yahoo.com.br +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ''AS IS'' AND ANY EXPRESS OR IMPLIED +# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO +# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, +# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; +# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, +# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR +# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF +# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. PRGNAM=pudb -VERSION=${VERSION:-2015.2} +VERSION=${VERSION:-2017.1.4} +URWIDVER=2.0.1 BUILD=${BUILD:-1} TAG=${TAG:-_SBo} if [ -z "$ARCH" ]; then - case "$( uname -m )" in - i?86) ARCH=i486 ;; - arm*) ARCH=arm ;; - *) ARCH=$( uname -m ) ;; - esac + case "$( uname -m )" in + i?86) ARCH=i586 ;; + arm*) ARCH=arm ;; + *) ARCH=$( uname -m ) ;; + esac fi CWD=$(pwd) @@ -22,44 +41,114 @@ TMP=${TMP:-/tmp/SBo} PKG=$TMP/package-$PRGNAM OUTPUT=${OUTPUT:-/tmp} -if [ "$ARCH" = "i486" ]; then - SLKCFLAGS="-O2 -march=i486 -mtune=i686" - LIBDIRSUFFIX="" +if [ "$ARCH" = "i586" ]; then + SLKCFLAGS="-O2 -march=i586 -mtune=i686" + LIBDIRSUFFIX="" elif [ "$ARCH" = "i686" ]; then - SLKCFLAGS="-O2 -march=i686 -mtune=i686" - LIBDIRSUFFIX="" + SLKCFLAGS="-O2 -march=i686 -mtune=i686" + LIBDIRSUFFIX="" elif [ "$ARCH" = "x86_64" ]; then - SLKCFLAGS="-O2 -fPIC" - LIBDIRSUFFIX="64" + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" else - SLKCFLAGS="-O2" - LIBDIRSUFFIX="" + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" fi +if [ -n "$NO_PYTHON2" ] && [ -n "$NO_PYTHON3" ]; then + printf "%s\n" "You appear to not want to install anything." + exit 1 +fi + +# see if we have python3 installed +which python3 >/dev/null 2>&1 && PY3=1 + set -e rm -rf $PKG mkdir -p $TMP $PKG $OUTPUT cd $TMP + +# install custom urwid package +if [ -z "$NO_PYTHON2" ]; then + rm -rf urwid-$URWIDVER + tar xfv $CWD/urwid-$URWIDVER.tar.gz + cd urwid-$URWIDVER + + chown -R root:root . + find -L . \ + \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ + -o -perm 511 \) -exec chmod 755 {} \; -o \ + \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + + # change the module name so our urwid doesn't call the stock version + sed -i "s%'name':\"urwid\"%'name':\"py2_urwid\"%" setup.py + sed -i "23 a import py2_urwid\n\ +import sys\n\ +sys.modules['urwid'] = py2_urwid" urwid/__init__.py + + python setup.py install --root=$PKG + + # rename it so it doesn't collide with the stock version + mv $PKG/usr/lib$LIBDIRSUFFIX/python2.7/site-packages/urwid \ + $PKG/usr/lib$LIBDIRSUFFIX/python2.7/site-packages/py2_urwid + cd .. +fi + rm -rf $PRGNAM-$VERSION tar xvf $CWD/$PRGNAM-$VERSION.tar.gz cd $PRGNAM-$VERSION chown -R root:root . find -L . \ - \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ - -o -perm 511 \) -exec chmod 755 {} \; -o \ - \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ - -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ + -o -perm 511 \) -exec chmod 755 {} \; -o \ + \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + +# install the python3 version before we wreck the python2 build +if [ -n "$PY3" ] && [ -z "$NO_PYTHON3" ]; then + python3 setup.py install --root=$PKG +fi + +# install the edited python2 version +if [ -z "$NO_PYTHON2" ]; then + # change all references to urwid to our custom py2_urwid + for py in \ + settings.py \ + source_view.py \ + debugger.py \ + theme.py \ + __init__.py \ + ui_tools.py \ + var_view.py + do + sed -i "s%import urwid%import py2_urwid as urwid%g" pudb/$py + done -python setup.py install --root=$PKG + sed -i "s%urwid>=1.1.1%py2_urwid>=1.1.1%" setup.py -find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \ - | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true + # done so now install + python setup.py install --root=$PKG +fi + +find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" \ + | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null \ + || true + +# added more docs, some examples and a test debug script +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION/examples +cp -a README.rst LICENSE \ + doc/starting.rst doc/usage.rst doc/misc.rst doc/shells.rst \ + $PKG/usr/doc/$PRGNAM-$VERSION + +cp -a example-* debug_me.py $PKG/usr/doc/$PRGNAM-$VERSION/examples -mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION -cp -a MANIFEST.in PKG-INFO README.rst $PKG/usr/doc/$PRGNAM-$VERSION cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild +# this might come in handy later for someone +cat $CWD/README > $PKG/usr/doc/$PRGNAM-$VERSION/README.slackware + mkdir -p $PKG/install cat $CWD/slack-desc > $PKG/install/slack-desc diff --git a/development/pudb/pudb.info b/development/pudb/pudb.info index 38d8730a9f9e6..58f593815aa63 100644 --- a/development/pudb/pudb.info +++ b/development/pudb/pudb.info @@ -1,10 +1,12 @@ PRGNAM="pudb" -VERSION="2015.2" +VERSION="2017.1.4" HOMEPAGE="https://pypi.python.org/pypi/pudb" -DOWNLOAD="https://pypi.python.org/packages/source/p/pudb/pudb-2015.2.tar.gz" -MD5SUM="0e155dc7c07d59090269df5a02a9eaac" +DOWNLOAD="https://github.com/inducer/pudb/archive/v2017.1.4/pudb-2017.1.4.tar.gz \ + https://pypi.org/packages/source/u/urwid/urwid-2.0.1.tar.gz" +MD5SUM="7d42e623ffa7b27af30330ac9e118c15 \ + c70a7016fa1ad2c2a979dbebd4de78c2" DOWNLOAD_x86_64="" MD5SUM_x86_64="" -REQUIRES="" -MAINTAINER="Rudson R. Alves" -EMAIL="rudsonalves@yahoo.com.br" +REQUIRES="Pygments" +MAINTAINER="David Woodfall" +EMAIL="dave@dawoodfall.net" diff --git a/development/pudb/slack-desc b/development/pudb/slack-desc index 62e3fb05ce2c1..1755e59e9e153 100644 --- a/development/pudb/slack-desc +++ b/development/pudb/slack-desc @@ -6,9 +6,7 @@ # customary to leave one space after the ':' except on otherwise blank lines. |-----handy-ruler------------------------------------------------------| -pudb: pudb (A full-screen, console-based Python debugger) -pudb: -pudb: PuDB is a full-screen, console-based visual debugger for Python. +pudb: pudb (A console-based Python debugger) pudb: pudb: Its goal is to provide all the niceties of modern GUI-based debuggers pudb: in a more lightweight and keyboard-friendly package. PuDB allows you @@ -17,3 +15,5 @@ pudb: pudb: If you've worked with the excellent (but nowadays ancient) DOS-based pudb: Turbo Pascal or C tools, PuDB's UI might look familiar. pudb: +pudb: https://pypi.python.org/pypi/pudb +pudb: https://github.com/inducer/pudb |