aboutsummaryrefslogtreecommitdiff
path: root/academic
diff options
context:
space:
mode:
authorFellype do Nascimento <fellype (at) gmail (dot) com>2020-02-16 05:50:51 +0700
committerWilly Sudiarto Raharjo <willysr@slackbuilds.org>2020-02-16 05:50:51 +0700
commitb850b9a2981ce5a5a423e99661a8ec19268b009a (patch)
tree1e64ced7b9373d5c8edbc3f4cd5d8ba2c80a314d /academic
parent6c9c06de67d67f3574ec3b5ba9093bb59ea10d0d (diff)
academic/getdp: Added (Finite Element Solver).
Signed-off-by: Willy Sudiarto Raharjo <willysr@slackbuilds.org>
Diffstat (limited to 'academic')
-rw-r--r--academic/getdp/Kernel_Operation__Broadcast.patch11
-rw-r--r--academic/getdp/README3
-rw-r--r--academic/getdp/getdp.SlackBuild109
-rw-r--r--academic/getdp/getdp.info10
-rw-r--r--academic/getdp/slack-desc19
5 files changed, 152 insertions, 0 deletions
diff --git a/academic/getdp/Kernel_Operation__Broadcast.patch b/academic/getdp/Kernel_Operation__Broadcast.patch
new file mode 100644
index 0000000000000..621e3e25aa665
--- /dev/null
+++ b/academic/getdp/Kernel_Operation__Broadcast.patch
@@ -0,0 +1,11 @@
+#diff a/Kernel/Operation_Broadcast.cpp b/Kernel/Operation_Broadcast.cpp
+#--- a/Kernel/Operation_Broadcast.cpp
+#+++ b/Kernel/Operation_Broadcast.cpp
+@@ -5,6 +5,7 @@
+
+ #include <vector>
+ #include <string>
++#include <cstring> // for strncpy()
+ #include <sstream>
+ #include <stdio.h>
+ #include <stdlib.h>
diff --git a/academic/getdp/README b/academic/getdp/README
new file mode 100644
index 0000000000000..dd3d1673d93f2
--- /dev/null
+++ b/academic/getdp/README
@@ -0,0 +1,3 @@
+GetDP (A General Environment for the Treatment of Discrete Problems)
+
+GetDP is a free finite element solver using mixed elements to discretize de Rham-type complexes in one, two and three dimensions. The main feature of GetDP is the closeness between the input data defining discrete problems (written by the user in ASCII data files) and the symbolic mathematical expressions of these problems.
diff --git a/academic/getdp/getdp.SlackBuild b/academic/getdp/getdp.SlackBuild
new file mode 100644
index 0000000000000..240d073028571
--- /dev/null
+++ b/academic/getdp/getdp.SlackBuild
@@ -0,0 +1,109 @@
+#!/bin/sh
+
+# Slackware build script for getdp
+# Copyright 2020 Fellype do Nascimento, Campinas, Brazil
+#
+# 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.
+#
+# 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=getdp
+VERSION=${VERSION:-3.3.0}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+if [ -z "$ARCH" ]; then
+ case "$( uname -m )" in
+ i?86) ARCH=i586 ;;
+ arm*) ARCH=arm ;;
+ *) ARCH=$( uname -m ) ;;
+ esac
+fi
+
+CWD=$(pwd)
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+if [ "$ARCH" = "i586" ]; then
+ SLKCFLAGS="-O2 -march=i586 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+ LIBDIRSUFFIX=""
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O3 -fPIC"
+ LIBDIRSUFFIX="64"
+else
+ SLKCFLAGS="-O2"
+ LIBDIRSUFFIX=""
+fi
+
+set -e
+
+rm -rf $PKG
+mkdir -p $TMP $PKG $OUTPUT
+cd $TMP
+rm -rf $PRGNAM-$VERSION-source
+tar -xzvf $CWD/$PRGNAM-$VERSION-source.tgz
+cd $PRGNAM-$VERSION-source
+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 {} \;
+
+# Patch that allow compilation without a fail (credits to: DragonFlyBSD/DPorts)
+patch -p1 < $CWD/Kernel_Operation__Broadcast.patch Kernel/Operation_Broadcast.cpp
+
+mkdir build
+cd build
+cmake -DCMAKE_INSTALL_PREFIX:PATH=/usr \
+ -DCMAKE_INSTALL_DOCDIR:PATH=/usr/share/getdp \
+ -DCMAKE_CXX_FLAGS:STRING="$SLKCFLAGS" \
+ -DCMAKE_C_FLAGS:STRING="$SLKCFLAGS" \
+ -DENABLE_BUILD_SHARED=ON \
+ -DENABLE_PETSC=OFF \
+ -DENABLE_SLEPC=OFF \
+ ..
+# only demos/ and templates/ folders will be leaved in the /usr/share/getdp dir
+
+make
+make install DESTDIR=$PKG
+cd -
+
+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
+
+mkdir -p $PKG/usr/man/man1
+mv $PKG/usr/share/man/man1/getdp.1 $PKG/usr/man/man1/
+rm -Rf $PKG/usr/share/man/
+
+find $PKG/usr/man -type f -exec gzip -9 {} \;
+for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -a CHANGELOG.txt CREDITS.txt LICENSE.txt README.txt $PKG/usr/doc/$PRGNAM-$VERSION
+cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
+rm $PKG/usr/share/getdp/*.txt
+rm -Rf $PKG/tmp
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+
+cd $PKG
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}
diff --git a/academic/getdp/getdp.info b/academic/getdp/getdp.info
new file mode 100644
index 0000000000000..8b5b964589af2
--- /dev/null
+++ b/academic/getdp/getdp.info
@@ -0,0 +1,10 @@
+PRGNAM="getdp"
+VERSION="3.3.0"
+HOMEPAGE="http://getdp.info/"
+DOWNLOAD="http://getdp.info/src/getdp-3.3.0-source.tgz"
+MD5SUM="0f3e4388bcecd454ff1a19fcfa5979ef"
+DOWNLOAD_x86_64=""
+MD5SUM_x86_64=""
+REQUIRES="arpack-ng OpenBLAS"
+MAINTAINER="Fellype do Nascimento"
+EMAIL="fellype (at) gmail (dot) com"
diff --git a/academic/getdp/slack-desc b/academic/getdp/slack-desc
new file mode 100644
index 0000000000000..7e8b01e9fd714
--- /dev/null
+++ b/academic/getdp/slack-desc
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description. Line
+# up the first '|' above the ':' following the base package name, and the '|' on
+# the right side marks the last column you can put a character in. You must make
+# exactly 11 lines for the formatting to be correct. It's also customary to
+# leave one space after the ':'.
+
+ |-----handy-ruler---------------------------------------------------------|
+getdp: getdp (Finite Element Solver)
+getdp:
+getdp: GetDP a free finite element solver using mixed elements to discretize de
+getdp: Rham-type complexes in one, two and three dimensions. The main feature of
+getdp: GetDP is the closeness between the input data defining discrete problems
+getdp: (written by the user in ASCII data files) and the symbolic mathematical
+getdp: expressions of these problems.
+getdp:
+getdp: GetDP is distributed under the terms of the GNU General Public License.
+getdp:
+getdp: