2016-07-19 16:05:25 +00:00
|
|
|
#!/bin/sh
|
|
|
|
# Copyright 2005-2016 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.sh
|
|
|
|
|
|
|
|
#Define a common label for all the tmp files
|
|
|
|
label="bufr_dump_fortran_test"
|
|
|
|
|
|
|
|
#Create log file
|
|
|
|
fLog=${label}".log"
|
|
|
|
rm -f $fLog
|
|
|
|
|
2016-07-20 10:19:38 +00:00
|
|
|
tempBufr=outfile.bufr
|
2016-07-19 16:05:25 +00:00
|
|
|
|
2016-07-21 09:39:31 +00:00
|
|
|
bufr_files=`cat ${data_dir}/bufr/bufr_data_files.txt`
|
2016-07-19 16:05:25 +00:00
|
|
|
|
2016-07-20 16:06:40 +00:00
|
|
|
# If FORTRAN is enabled, then the pkgconfig should be one level above the test dir
|
2016-07-20 10:19:38 +00:00
|
|
|
PKGCONFIG_FILE=../eccodes_f90.pc
|
|
|
|
CACHE_FILE=../CMakeCache.txt
|
2016-07-19 16:05:25 +00:00
|
|
|
|
2016-07-20 13:39:37 +00:00
|
|
|
COMPILE_AND_RUN=0
|
|
|
|
|
2016-07-20 10:19:38 +00:00
|
|
|
if command -v pkg-config >/dev/null 2>&1; then
|
2016-07-20 16:06:40 +00:00
|
|
|
if [ -f "$PKGCONFIG_FILE" ]; then
|
2016-07-22 11:49:57 +00:00
|
|
|
# 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 13:39:37 +00:00
|
|
|
|
2016-07-20 16:06:40 +00:00
|
|
|
# The pkgconfig variables refer to the install directory. Change to build dir
|
|
|
|
BUILD_DIR=`grep -w eccodes_BINARY_DIR $CACHE_FILE | cut -d'=' -f2`
|
|
|
|
INSTALL_DIR=`grep -w CMAKE_INSTALL_PREFIX $CACHE_FILE | cut -d'=' -f2`
|
|
|
|
FLAGS_LINKER=`echo $FLAGS_LINKER | sed -e "s:$INSTALL_DIR:$BUILD_DIR:g"`
|
|
|
|
FLAGS_COMPILER=`echo $FLAGS_COMPILER | sed -e "s:$INSTALL_DIR:$BUILD_DIR:g"`
|
2016-07-19 16:05:25 +00:00
|
|
|
|
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
|
|
|
|
fi
|
2016-07-20 13:39:37 +00:00
|
|
|
fi
|
2016-07-20 10:19:38 +00:00
|
|
|
|
2016-07-19 16:05:25 +00:00
|
|
|
for file in ${bufr_files}
|
|
|
|
do
|
2016-07-22 11:49:57 +00:00
|
|
|
tempSrc=$label.$file.f90
|
|
|
|
tempExe=$label.$file.exe
|
|
|
|
|
2016-07-19 16:30:11 +00:00
|
|
|
# Generate F90 code from BUFR file
|
2016-07-19 16:05:25 +00:00
|
|
|
${tools_dir}bufr_dump -Efortran ${data_dir}/bufr/$file > $tempSrc
|
2016-07-19 16:30:11 +00:00
|
|
|
|
|
|
|
# Compile
|
2016-07-20 13:39:37 +00:00
|
|
|
if [ $COMPILE_AND_RUN -eq 1 ]; then
|
2016-07-20 10:19:38 +00:00
|
|
|
$COMPILER -o $tempExe $tempSrc $FLAGS_COMPILER $FLAGS_LINKER
|
2016-07-20 13:39:37 +00:00
|
|
|
# The executable always creates a file called outfile.bufr
|
2016-07-21 17:01:37 +00:00
|
|
|
# valgrind --error-exitcode=1 ./$tempExe
|
2016-07-20 10:19:38 +00:00
|
|
|
./$tempExe
|
|
|
|
${tools_dir}bufr_compare ${data_dir}/bufr/$file $tempBufr
|
2016-07-21 12:51:46 +00:00
|
|
|
|
2016-07-21 15:00:06 +00:00
|
|
|
TEMP_JSON1=${label}.$file.json
|
|
|
|
TEMP_JSON2=${label}.$tempBufr.json
|
|
|
|
${tools_dir}bufr_dump ${data_dir}/bufr/$file > $TEMP_JSON1
|
|
|
|
${tools_dir}bufr_dump $tempBufr > $TEMP_JSON2
|
2016-07-22 11:49:57 +00:00
|
|
|
diff $TEMP_JSON1 $TEMP_JSON2
|
2016-07-21 15:00:06 +00:00
|
|
|
rm -f $TEMP_JSON1 $TEMP_JSON2
|
2016-07-19 16:30:11 +00:00
|
|
|
fi
|
2016-07-19 16:05:25 +00:00
|
|
|
|
2016-07-22 11:49:57 +00:00
|
|
|
rm -f $tempExe $tempSrc $tempBufr
|
|
|
|
done
|