eccodes/tests/bufr_dump_encode_fortran.sh

88 lines
2.4 KiB
Bash
Raw Normal View History

#!/bin/sh
2020-01-28 14:32:34 +00:00
# (C) Copyright 2005- ECMWF.
#
# This software is licensed under the terms of the Apache Licence Version 2.0
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
#
# In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
# virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
#
. ./include.ctest.sh
2020-07-04 14:30:10 +00:00
# Define a common label for all the tmp files
label="bufr_dump_encode_fortran_test"
2020-07-04 14:30:10 +00:00
# Create log file
fLog=temp.${label}".log"
rm -f $fLog
tempBufr=outfile.bufr
tempDir=temp.${label}.dir
2018-11-06 17:26:58 +00:00
rm -rf $tempDir
2016-08-08 11:43:16 +00:00
mkdir -p $tempDir
bufr_files=`cat ${data_dir}/bufr/bufr_data_files.txt`
2016-07-20 16:06:40 +00:00
# If FORTRAN is enabled, then the pkgconfig should be one level above the test dir
PKGCONFIG_FILE=../../lib/pkgconfig/eccodes_f90.pc
2018-11-06 17:26:58 +00:00
CACHE_FILE=../../CMakeCache.txt
COMPILE_AND_RUN=0
2018-11-06 17:26:58 +00:00
cd $tempDir
if command -v pkg-config >/dev/null 2>&1; then
2016-07-20 16:06:40 +00:00
if [ -f "$PKGCONFIG_FILE" ]; then
2018-11-06 17:26:58 +00:00
sed -e "s#^prefix=.*#prefix=$build_dir#" < $PKGCONFIG_FILE > temp.pc
PKGCONFIG_FILE=temp.pc
# Work out the Fortran compiler and flags from pkgconfig
2016-07-20 16:06:40 +00:00
COMPILER=`pkg-config --variable=FC $PKGCONFIG_FILE`
FLAGS_COMPILER=`pkg-config --cflags $PKGCONFIG_FILE`
FLAGS_LINKER=`pkg-config --libs $PKGCONFIG_FILE`
2016-07-20 16:06:40 +00:00
# TODO: For now only support when shared libs enabled
#SHARED_LIBS=`grep -w BUILD_SHARED_LIBS $CACHE_FILE | cut -d'=' -f2`
#if [ "$SHARED_LIBS" = "ON" ]; then
# COMPILE_AND_RUN=1
#fi
2016-07-20 16:06:40 +00:00
fi
fi
for file in ${bufr_files}
do
tempSrc=temp.$label.$file.f90
tempExe=$label.$file.exe
2016-07-19 16:30:11 +00:00
# Generate F90 code from BUFR file
2017-02-03 14:21:24 +00:00
${tools_dir}/bufr_dump -Efortran ${data_dir}/bufr/$file > $tempSrc
2016-09-15 15:44:39 +00:00
# Too large for this test
if [ "$file" = "ias1_240.bufr" ]; then
continue
fi
2016-07-19 16:30:11 +00:00
# Compile
if [ $COMPILE_AND_RUN -eq 1 ]; then
$COMPILER -o $tempExe $tempSrc $FLAGS_COMPILER $FLAGS_LINKER
# The executable always creates a file called outfile.bufr
# valgrind --error-exitcode=1 ./$tempExe
./$tempExe
2018-11-01 11:50:00 +00:00
${tools_dir}/bufr_compare ${data_dir}/bufr/$file $tempBufr
TEMP_OUT1=${label}.$file.dump.out
TEMP_OUT2=${label}.$tempBufr.dump.out
${tools_dir}/bufr_dump -p ${data_dir}/bufr/$file > $TEMP_OUT1
${tools_dir}/bufr_dump -p $tempBufr > $TEMP_OUT2
diff $TEMP_OUT1 $TEMP_OUT2
rm -f $TEMP_OUT1 $TEMP_OUT2
2016-07-19 16:30:11 +00:00
fi
rm -f $tempExe $tempSrc $tempBufr
done
2016-09-14 10:54:57 +00:00
cd $test_dir
rm -fr $tempDir