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-19 16:30:11 +00:00
|
|
|
#Define temp files
|
2016-07-20 10:19:38 +00:00
|
|
|
tempBufr=outfile.bufr
|
2016-07-19 16:05:25 +00:00
|
|
|
tempSrc=$label.temp.f90
|
2016-07-19 16:30:11 +00:00
|
|
|
tempExe=$label.temp.exe
|
2016-07-19 16:05:25 +00:00
|
|
|
|
2016-07-20 10:19:38 +00:00
|
|
|
# Not all BUFR files generate correct Fortran. So here we select a subset
|
2016-07-19 16:05:25 +00:00
|
|
|
# bufr_files=`cat ${data_dir}/bufr/bufr_data_files.txt`
|
|
|
|
bufr_files="207003.bufr PraticaTemp.bufr aaen_55.bufr aben_55.bufr ahws_139.bufr airc_142.bufr airc_144.bufr airs_57.bufr alws_139.bufr
|
|
|
|
amda_144.bufr amsa_55.bufr amsb_55.bufr amse_55.bufr amsu_55.bufr amv2_87.bufr amv3_87.bufr asbh_139.bufr asbl_139.bufr
|
|
|
|
asca_139.bufr asch_139.bufr ascs_139.bufr aseh_139.bufr asel_139.bufr ashs_139.bufr atap_55.bufr ateu_155.bufr atms_201.bufr
|
|
|
|
atov_55.bufr avhm_87.bufr avhn_87.bufr avhr_58.bufr b002_95.bufr b002_96.bufr b003_56.bufr b004_145.bufr b005_87.bufr
|
|
|
|
b005_89.bufr b006_96.bufr b007_31.bufr bssh_170.bufr bssh_176.bufr bssh_178.bufr bssh_180.bufr btem_109.bufr buoy_27.bufr
|
|
|
|
cmwi_87.bufr cmwn_87.bufr cnow_28.bufr cori_156.bufr crit_202.bufr csrh_189.bufr emsg_189.bufr emsg_87.bufr euwv_87.bufr
|
|
|
|
fy3a_154.bufr fy3b_154.bufr g2nd_208.bufr g2to_206.bufr go15_87.bufr goee_87.bufr goes_87.bufr goga_89.bufr gosat.bufr
|
|
|
|
grst_26.bufr gsd1_208.bufr gsd2_208.bufr gsd3_208.bufr gst4_26.bufr hirb_55.bufr hirs_55.bufr iasi_241.bufr ifco_208.bufr
|
|
|
|
ikco_217.bufr itrg_208.bufr itwt_233.bufr j2eo_216.bufr j2nb_216.bufr jaso_214.bufr kond_209.bufr maer_207.bufr meta_140.bufr
|
|
|
|
mhen_55.bufr mhsa_55.bufr mhsb_55.bufr mhse_55.bufr mloz_206.bufr modi_87.bufr modw_87.bufr monw_87.bufr new.bufr nomi_206.bufr
|
|
|
|
nos1_208.bufr nos2_208.bufr nos3_208.bufr nos4_208.bufr nos5_208.bufr nos6_208.bufr nos7_208.bufr nos8_208.bufr ocea_131.bufr
|
|
|
|
ocea_132.bufr ocea_133.bufr ocea_21.bufr pgps_110.bufr pilo_91.bufr profiler_european.bufr rada_250.bufr rado_250.bufr s4kn_165.bufr
|
|
|
|
sb19_206.bufr sbu8_206.bufr ship_11.bufr ship_12.bufr ship_13.bufr ship_14.bufr ship_19.bufr ship_9.bufr smin_49.bufr smis_49.bufr
|
|
|
|
smiu_49.bufr smos_203.bufr sn4k_165.bufr soil_7.bufr ssbt_127.bufr stuk_7.bufr syno_1.bufr syno_2.bufr syno_3.bufr syno_4.bufr
|
|
|
|
synop_multi_subset.bufr temp_101.bufr temp_102.bufr temp_106.bufr tmr7_129.bufr tros_31.bufr uegabe.bufr wavb_134.bufr"
|
|
|
|
|
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 10:19:38 +00:00
|
|
|
# Work out the Fortran compiler, the flags etc from pkgconfig
|
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
|
|
|
|
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-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-20 10:19:38 +00:00
|
|
|
./$tempExe
|
|
|
|
${tools_dir}bufr_compare ${data_dir}/bufr/$file $tempBufr
|
2016-07-19 16:30:11 +00:00
|
|
|
fi
|
2016-07-19 16:05:25 +00:00
|
|
|
done
|
|
|
|
|
2016-07-20 10:19:38 +00:00
|
|
|
rm -f $tempSrc $tempExe $tempBufr
|