aboutsummaryrefslogtreecommitdiff
path: root/academic/qtoctave
diff options
context:
space:
mode:
authorMauro Giachero <mauro_dot_giachero_at_gmail_dot_com>2010-05-11 22:21:36 +0200
committerDavid Somero <xgizzmo@slackbuilds.org>2010-05-11 22:21:36 +0200
commit47d26f6fd331b8e4dd049ebba225078f7a200422 (patch)
tree5800e3dc49fb1cb3ae0f9c7f92c7b85f37366ab3 /academic/qtoctave
parent036fbd62a2f55e20ca478eafcccd239abcb7bfa3 (diff)
academic/qtoctave: Updated for version 0.8.1
Diffstat (limited to 'academic/qtoctave')
-rw-r--r--academic/qtoctave/README5
-rw-r--r--academic/qtoctave/doinst.sh3
-rw-r--r--academic/qtoctave/octave-sombrero.pngbin23362 -> 0 bytes
-rw-r--r--academic/qtoctave/qtoctave.SlackBuild68
-rw-r--r--academic/qtoctave/qtoctave.desktop10
-rw-r--r--academic/qtoctave/qtoctave.info10
-rw-r--r--academic/qtoctave/slack-desc2
7 files changed, 54 insertions, 44 deletions
diff --git a/academic/qtoctave/README b/academic/qtoctave/README
index 8a655952a2bab..8717567203bf8 100644
--- a/academic/qtoctave/README
+++ b/academic/qtoctave/README
@@ -1,7 +1,4 @@
-QtOctave is a graphical user interface for gnu octave, which is an
+QtOctave is a graphical user interface for gnu octave, which is an
open source program alternative to Matlab.
QtOctave requires Octave and Qt4, both available on SlackBuilds.org.
-
-If you build on a multicore system, add JOBS={#} to enable parallel
-compilation, as in: JOBS=4 ./qtoctave.SlackBuild
diff --git a/academic/qtoctave/doinst.sh b/academic/qtoctave/doinst.sh
new file mode 100644
index 0000000000000..5fb28930db0b9
--- /dev/null
+++ b/academic/qtoctave/doinst.sh
@@ -0,0 +1,3 @@
+if [ -x /usr/bin/update-desktop-database ]; then
+ /usr/bin/update-desktop-database -q usr/share/applications >/dev/null 2>&1
+fi
diff --git a/academic/qtoctave/octave-sombrero.png b/academic/qtoctave/octave-sombrero.png
deleted file mode 100644
index e18557cc9eab5..0000000000000
--- a/academic/qtoctave/octave-sombrero.png
+++ /dev/null
Binary files differ
diff --git a/academic/qtoctave/qtoctave.SlackBuild b/academic/qtoctave/qtoctave.SlackBuild
index c24da4b848ae1..fc0c8a2326ec8 100644
--- a/academic/qtoctave/qtoctave.SlackBuild
+++ b/academic/qtoctave/qtoctave.SlackBuild
@@ -3,9 +3,10 @@
# Slackware build script for QtOctave
# Written by Mauro Giachero (mauro dot giachero at gmail dot com)
+# Modified by Robby Workman <rworkman@slackbuilds.org>
PRGNAM=qtoctave
-VERSION=${VERSION:-0.7.1}
+VERSION=${VERSION:-0.8.1}
ARCH=${ARCH:-i486}
BUILD=${BUILD:-1}
TAG=${TAG:-_SBo}
@@ -15,12 +16,12 @@ TMP=${TMP:-/tmp/SBo}
PKG=$TMP/package-$PRGNAM
OUTPUT=${OUTPUT:-/tmp}
-JOBS=${JOBS:-3}
-
if [ "$ARCH" = "i486" ]; then
- SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+ SLKCFLAGS="-O2 -march=i486 -mtune=i686 -DNDEBUG"
elif [ "$ARCH" = "i686" ]; then
- SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686 -DNDEBUG"
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC -DNDEBUG"
fi
set -e # Exit on most errors
@@ -30,23 +31,46 @@ mkdir -p $TMP $PKG $OUTPUT
cd $TMP
rm -rf $PRGNAM-$VERSION
tar xvf $CWD/$PRGNAM-$VERSION.tar.gz
-cd $PRGNAM-$VERSION
+cd $PRGNAM-$VERSION/$PRGNAM
chown -R root:root .
find . \
\( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \
-exec chmod 755 {} \; -o \
\( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
-exec chmod 644 {} \;
-chmod a+x configure
-CFLAGS="$SLKCFLAGS" \
-CXXFLAGS="$SLKCFLAGS" \
-./configure \
- --prefix=/usr \
- --qtdir=/usr/lib/qt4
+cmake \
+ -DCMAKE_C_FLAGS_RELEASE:STRING="$SLKCFLAGS" \
+ -DCMAKE_CXX_FLAGS_RELEASE:STRING="$SLKCFLAGS" \
+ -DCMAKE_INSTALL_PREFIX:PATH=/usr \
+ .
+make
-make -j$JOBS
-make install INSTALL_ROOT=$PKG
+# The install target doesn't have a DESTDIR or INSTALL_ROOT or equivalent,
+# and setting the CMAKE_INSTALL_PREFIX to $PKG/usr results in a lot of
+# '/tmp/SBo/package-qtoctave' strings embedded in the qtoctave binary.
+# This *could* have security implications (for example, if that binary first
+# looks in the temp directory for things). It's low risk, and would require
+# someone on the system to have knowledge of how the package was built, so
+# I'm being a bit "chicken little" here, but correct is always better, so I'm
+# going to do this the hard way... --rworkman
+#
+# Be sure to check the src/cmake_install.cmake file in version updates to
+# make sure we don't miss something
+mkdir -p $PKG/usr/share/qtoctave $PKG/usr/bin \
+ $PKG/usr/share/applications $PKG/usr/share/icons/hicolor/64x64/apps
+cp -a src/config_files/config.rc src/images src/lang src/menus \
+ src/config_files/octave.xml src/octave_doc src/qtoctave_doc \
+ src/scripts $PKG/usr/share/qtoctave
+# QtOctave better fits in "Science & Math" (with Octave) than
+# under "Edutainment" subcategories
+# cp -a src/config_files/qtoctave.desktop $PKG/usr/share/applications/
+cat src/config_files/qtoctave.desktop |sed "s/Education/Development/g" \
+ >$PKG/usr/share/applications/qtoctave.desktop
+ln -s /usr/share/qtoctave/images/qtoctave.png $PKG/usr/share/icons/hicolor/64x64/apps/
+cp -a src/qtoctave $PKG/usr/bin
+find $PKG/usr/share -type f -exec chmod 0644 {} \;
+find $PKG/usr/share -type d -exec chmod 0755 {} \;
( cd $PKG
find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
@@ -54,21 +78,17 @@ make install INSTALL_ROOT=$PKG
)
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
-# The "doc" folder contains developer-oriented documentation, while (qt)octave-doc contain
-# user-oriented docs.
-cp -a $PRGNAM/doc LEEME.txt NEWS.txt LICENSE_GPL.txt README.txt \
+cp -a leeme.txt news.txt LICENSE_GPL.txt readme.txt \
$PKG/usr/doc/$PRGNAM-$VERSION
-ln -s /usr/share/$PRGNAM/qtoctave-doc $PKG/usr/doc/$PRGNAM-$VERSION/qtoctave-doc
-ln -s /usr/share/$PRGNAM/octave-doc $PKG/usr/doc/$PRGNAM-$VERSION/octave-doc
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
-
-# QtOctave doesn't have a nice icon for menus, so we use the Octave icon
-cp $CWD/octave-sombrero.png $PKG/usr/share/qtoctave/images
-mkdir -p $PKG/usr/share/applications
-cp $CWD/qtoctave.desktop $PKG/usr/share/applications
+( cd $PKG/usr/doc/$PRGNAM-$VERSION
+ ln -s /usr/share/$PRGNAM/qtoctave-doc .
+ ln -s /usr/share/$PRGNAM/octave-doc .
+)
mkdir -p $PKG/install
cat $CWD/slack-desc > $PKG/install/slack-desc
+cat $CWD/doinst.sh > $PKG/install/doinst.sh
cd $PKG
/sbin/makepkg -l y -c n -p $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.tgz
diff --git a/academic/qtoctave/qtoctave.desktop b/academic/qtoctave/qtoctave.desktop
deleted file mode 100644
index 8f0bf21c2e1bf..0000000000000
--- a/academic/qtoctave/qtoctave.desktop
+++ /dev/null
@@ -1,10 +0,0 @@
-[Desktop Entry]
-Encoding=UTF-8
-Name=QtOctave
-Comment=Scientific Computing using GNU Octave
-Exec=/usr/bin/qtoctave
-Icon=/usr/share/qtoctave/images/octave-sombrero.png
-Terminal=false
-Type=Application
-Categories=Development;Math;Science;
-StartupNotify=true
diff --git a/academic/qtoctave/qtoctave.info b/academic/qtoctave/qtoctave.info
index 2cd40018ddec7..ac60be796fb83 100644
--- a/academic/qtoctave/qtoctave.info
+++ b/academic/qtoctave/qtoctave.info
@@ -1,8 +1,8 @@
PRGNAM="qtoctave"
-VERSION="0.7.1"
+VERSION="0.8.1"
HOMEPAGE="http://qtoctave.wordpress.com/"
-DOWNLOAD="https://forja.rediris.es/frs/download.php/490/qtoctave-0.7.1.tar.gz"
-MD5SUM="c6dd28bd08d13803636c1eb08eb35930"
+DOWNLOAD="http://forja.rediris.es/frs/download.php/877/qtoctave-0.8.1.tar.gz"
+MD5SUM="b4e237b578f9c2624bb0fab2cb7ea691"
MAINTAINER="Mauro Giachero"
-EMAIL="mauro.giachero@gmail.com"
-APPROVED="rworkman"
+EMAIL="mauro_dot_giachero_at_gmail_dot_com"
+APPROVED="David Somero"
diff --git a/academic/qtoctave/slack-desc b/academic/qtoctave/slack-desc
index 828453fa1279e..2133fe67c59d6 100644
--- a/academic/qtoctave/slack-desc
+++ b/academic/qtoctave/slack-desc
@@ -5,7 +5,7 @@
# exactly 11 lines for the formatting to be correct. It's also customary to
# leave one space after the ':'.
- |-----handy-ruler------------------------------------------------------|
+ |-----handy-ruler----------------------------------------------------|
qtoctave: QtOctave (a qt-based gui for Octave)
qtoctave:
qtoctave: QtOctave is a graphical user interface for gnu octave, which is an