diff options
author | Nitish Ragoomundun <lrugratz@gmail.com> | 2022-09-13 06:51:33 +0100 |
---|---|---|
committer | bedlam <dave@slackbuilds.org> | 2022-09-13 06:51:33 +0100 |
commit | fdeee1781c88f9f2d79bcc7c23d189e8794a5a25 (patch) | |
tree | 7e83a72b21ba9babe3f0ad71029d8ccd09a6d843 | |
parent | f5620dfba18ad08ed99b8ef31b469a189296c9d9 (diff) | |
download | slackbuilds-fdeee1781c88f9f2d79bcc7c23d189e8794a5a25.tar.gz |
libraries/netcdf-fortran: Added (netCDF Fortran API)
Signed-off-by: bedlam <dave@slackbuilds.org>
-rw-r--r-- | libraries/netcdf-fortran/README | 9 | ||||
-rw-r--r-- | libraries/netcdf-fortran/netcdf-fortran.SlackBuild | 128 | ||||
-rw-r--r-- | libraries/netcdf-fortran/netcdf-fortran.info | 10 | ||||
-rw-r--r-- | libraries/netcdf-fortran/netcdf.SlackBuild | 141 | ||||
-rw-r--r-- | libraries/netcdf-fortran/slack-desc | 19 |
5 files changed, 307 insertions, 0 deletions
diff --git a/libraries/netcdf-fortran/README b/libraries/netcdf-fortran/README new file mode 100644 index 0000000000..62fadba97f --- /dev/null +++ b/libraries/netcdf-fortran/README @@ -0,0 +1,9 @@ +The Unidata network Common Data Form (netCDF) is an interface for +scientific data access and a set of freely-distributed software +libraries that provide an implementation of the interface. The netCDF +library also defines a machine-independent format for representing +scientific data. Together, the interface, library, and format support +the creation, access, and sharing of scientific data. This software +package provides Fortran application interfaces for accessing netCDF +data. It depends on the netCDF C library, which must be installed +first. diff --git a/libraries/netcdf-fortran/netcdf-fortran.SlackBuild b/libraries/netcdf-fortran/netcdf-fortran.SlackBuild new file mode 100644 index 0000000000..49b5c30095 --- /dev/null +++ b/libraries/netcdf-fortran/netcdf-fortran.SlackBuild @@ -0,0 +1,128 @@ +#!/bin/bash + +# Slackware build script for netcdf-fortran + +# Copyright 2022 Nitish Ragoomundun, Mauritius +# 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. +# +# 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. + +cd $(dirname $0) ; CWD=$(pwd) + +PRGNAM=netcdf-fortran +VERSION=${VERSION:-4.5.4} +SRCNAM=v${VERSION} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} +PKGTYPE=${PKGTYPE:-tgz} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i586 ;; + arm*) ARCH=arm ;; + *) ARCH=$( uname -m ) ;; + esac +fi + +# If the variable PRINT_PACKAGE_NAME is set, then this script will report what +# the name of the created package would be, and then exit. This information +# could be useful to other scripts. +if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then + echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE" + exit 0 +fi + +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="-O2 -fPIC" + LIBDIRSUFFIX="64" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +fi + +set -e + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $PRGNAM-$VERSION + +# If downloaded using wget, the source archive will have a different name, so +# find the correct file to extract. +if [ -e $CWD/v$VERSION.tar.gz ]; then + tar xvf $CWD/v$VERSION.tar.gz +else + tar xvf $CWD/$PRGNAM-$VERSION.tar.gz +fi + +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 {} \; + +CFLAGS="$SLKCFLAGS" \ +CXXFLAGS="$SLKCFLAGS" \ +./configure \ + --prefix=/usr \ + --libdir=/usr/lib${LIBDIRSUFFIX} \ + --sysconfdir=/etc \ + --localstatedir=/var \ + --mandir=/usr/man \ + --datarootdir=/usr \ + --docdir=/usr/doc/$PRGNAM-$VERSION \ + --enable-static=no \ + --build=$ARCH-slackware-linux + +make +make install DESTDIR=$PKG + +find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \ + | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true + +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 COPYRIGHT README.md RELEASE_NOTES.md VERSION examples/ $PKG/usr/doc/$PRGNAM-$VERSION +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild +cat $CWD/README > $PKG/usr/doc/$PRGNAM-$VERSION/README$TAG + +rm -fv $PKG/usr/lib*/*.la + +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 diff --git a/libraries/netcdf-fortran/netcdf-fortran.info b/libraries/netcdf-fortran/netcdf-fortran.info new file mode 100644 index 0000000000..56329347bd --- /dev/null +++ b/libraries/netcdf-fortran/netcdf-fortran.info @@ -0,0 +1,10 @@ +PRGNAM="netcdf-fortran" +VERSION="4.5.4" +HOMEPAGE="https://www.unidata.ucar.edu/software/netcdf/" +DOWNLOAD="https://github.com/Unidata/netcdf-fortran/archive/refs/tags/v4.5.4.tar.gz" +MD5SUM="77e1be413ab343f42a4a6e8b338b45d5" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +REQUIRES="netcdf" +MAINTAINER="Nitish Ragoomundun" +EMAIL="lrugratz@gmail.com" diff --git a/libraries/netcdf-fortran/netcdf.SlackBuild b/libraries/netcdf-fortran/netcdf.SlackBuild new file mode 100644 index 0000000000..a0b97f6129 --- /dev/null +++ b/libraries/netcdf-fortran/netcdf.SlackBuild @@ -0,0 +1,141 @@ +#!/bin/bash + +# SlackBuild script for netcdf. +# +# Copyright 2022 Gregory J. L. Tourte <artourter@gmail.com> +# Copyright 2009 Pierre Cazenave <pwcazenave {at} gmail [dot] com> +# 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. +# +# 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. +# +# Maintained until 2018 by David Spencer <baildon.research@googlemail.com> + +cd $(dirname $0) ; CWD=$(pwd) + +PRGNAM=netcdf +SRCNAM=netcdf-c +VERSION=${VERSION:-4.9.0} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} +PKGTYPE=${PKGTYPE:-tgz} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i586 ;; + arm*) ARCH=arm ;; + *) ARCH=$( uname -m ) ;; + esac +fi + +# If the variable PRINT_PACKAGE_NAME is set, then this script will report what +# the name of the created package would be, and then exit. This information +# could be useful to other scripts. +if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then + echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE" + exit 0 +fi + +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="-O2 -fPIC" + LIBDIRSUFFIX="64" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +fi + +set -e + +if [[ ${TESTBUILD:='NO'} == 'NO' ]]; then + TESTBUILDFLAGS='--disable-testsets' +fi + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $SRCNAM-$VERSION +tar xvf $CWD/$SRCNAM-$VERSION.tar.gz +cd $SRCNAM-$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 {} \; + +if [ "${HDF4:-no}" = 'yes' ]; then + hdf4opt="--enable-hdf4" + export LDFLAGS="-ljpeg" +else + hdf4opt="" +fi + +CFLAGS="$SLKCFLAGS" \ +CXXFLAGS="$SLKCFLAGS" \ +./configure \ + --prefix=/usr \ + --libdir=/usr/lib${LIBDIRSUFFIX} \ + --sysconfdir=/etc \ + --localstatedir=/var \ + --mandir=/usr/man \ + --datarootdir=/usr \ + --docdir=/usr/doc/$PRGNAM-$VERSION \ + --enable-static=no \ + --disable-examples \ + --disable-plugins \ + ${TESTBUILDFLAGS} \ + ${hdf4opt} \ + --build=$ARCH-slackware-linux + +make +[[ $TESTBUILD == "YES" ]] && make check +make install DESTDIR=$PKG + +rm -rf examples/C/.{libs,deps}/ + +find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \ + | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true + +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 COPYRIGHT README.md RELEASE_NOTES.md \ + examples/ $PKG/usr/doc/$PRGNAM-$VERSION + +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild +cat $CWD/README > $PKG/usr/doc/$PRGNAM-$VERSION/README$TAG + +find $PKG/usr/doc/$PRGNAM-$VERSION -type f -exec chmod 644 {} \; + +rm -f $PKG/usr/lib*/*.la + +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 diff --git a/libraries/netcdf-fortran/slack-desc b/libraries/netcdf-fortran/slack-desc new file mode 100644 index 0000000000..8f2e091cf0 --- /dev/null +++ b/libraries/netcdf-fortran/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 ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +netcdf-fortran: netcdf-fortran (netCDF Fortran API) +netcdf-fortran: +netcdf-fortran: netCDF (network Common Data Form) is an interface for scientific data +netcdf-fortran: access and also provides a machine-independent format for +netcdf-fortran: representing scientific data. The netcdf-fortran package provides +netcdf-fortran: Fortran application interfaces for accessing netCDF data. +netcdf-fortran: +netcdf-fortran: +netcdf-fortran: +netcdf-fortran: https://www.unidata.ucar.edu/software/netcdf/ +netcdf-fortran: |