#!/bin/sh # (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 REDIRECT=/dev/null grib1=${data_dir}/regular_latlon_surface.grib1 grib2=${data_dir}/regular_latlon_surface.grib2 infile=${data_dir}/reduced_gaussian_model_level.grib1 outfile=${data_dir}/with_bitmap.grib1 outfile1=${data_dir}/without_bitmap.grib1 temp1=out.bmp.grib1 temp2=out.bmp.grib2 tempData1=out.bmp.grib1.data tempData2=out.bmp.grib2.data tempRules=bitmap.rules tempRef=grib_bitmap.ref tempOut=grib_bitmap.txt rm -f $outfile # Add a bitmap # ------------- ${tools_dir}/grib_set -s bitmapPresent=1 $infile $outfile >$REDIRECT ${tools_dir}/grib_dump $infile | grep -v FILE > $infile.dump ${tools_dir}/grib_dump $outfile | grep -v FILE > $outfile.dump grib_check_key_equals $outfile section1Flags,section3Length '192 772' if [ $ECCODES_ON_WINDOWS -eq 0 ]; then # There are some minute floating point differences on Windows # so the diff would not work there diff $outfile.dump ${data_dir}/bitmap.diff diff $infile.dump ${data_dir}/no_bitmap.diff fi ${tools_dir}/grib_dump -O -p bitmap $outfile | grep -v FILE > $outfile.dump cat > $tempRef <$REDIRECT ${tools_dir}/grib_dump $outfile1 | grep -v FILE > $outfile1.dump ${tools_dir}/grib_dump $outfile | grep -v FILE > $outfile.dump if [ $ECCODES_ON_WINDOWS -eq 0 ]; then diff $outfile1.dump ${data_dir}/no_bitmap.diff fi rm -f $outfile1 $outfile1.dump $outfile $outfile.dump cat > $tempRules< $tempData1 ${tools_dir}/grib_get_data -m missing $temp2 > $tempData2 diff $tempData1 $tempData2 rm -f $tempData1 $tempData2 # ECC-1233: Allow printing of 'byte' keys e.g., bitmap, section paddings # ----------------------------------------------------------------------- cat > $tempRules< $tempData1 cat $tempData1 cat > $tempRef < $tempOut 2>&1 status=$? set -e [ $status -ne 0 ] grep -q "missing bitmap" $tempOut # Clean up rm -f $tempData1 $tempData2 $temp1 $temp2 $tempRules $tempOut