mirror of https://github.com/ecmwf/eccodes.git
60 lines
899 B
Bash
Executable File
60 lines
899 B
Bash
Executable File
#!/bin/sh
|
|
set -e
|
|
|
|
if [ $# -lt 2 ]
|
|
then
|
|
echo "usage: $0 [-f] in.grib1 out.grib2"
|
|
echo "-f convert to grib2 only typeOfLevel='hybrid' and copy other level types as grib1"
|
|
exit 1
|
|
fi
|
|
|
|
grib_filter=/var/tmp/masn/p4/grib_api/releases/2.0.0/bin/grib_filter
|
|
rules_filter=rules.filter$$
|
|
|
|
force=0
|
|
out=$2
|
|
in=$1
|
|
while getopts fd:D:t:b:w:e:r:s:n:p: options
|
|
do
|
|
case $options in
|
|
f) force=1
|
|
out=$3
|
|
in=$2
|
|
;;
|
|
esac
|
|
done
|
|
|
|
|
|
if [ $force = 1 ]
|
|
then
|
|
|
|
cat >> $rules_filter <<EOF
|
|
if ( typeOfLevel is 'hybrid' ) {
|
|
set edition=2;
|
|
}
|
|
write;
|
|
EOF
|
|
|
|
else
|
|
|
|
cat >> $rules_filter <<EOF
|
|
if ( ! typeOfLevel is 'hybrid' ) {
|
|
print "Error: typeOfLevel='[typeOfLevel]' unable to convert. Only typeOfLevel='hybrid' can be converted.";
|
|
assert( typeOfLevel is 'hybrid' );
|
|
}
|
|
set edition=2;
|
|
write;
|
|
EOF
|
|
|
|
fi
|
|
|
|
set +e
|
|
$grib_filter -o $out $rules_filter $in
|
|
|
|
error=$?
|
|
|
|
rm -f $rules_filter
|
|
|
|
exit $error
|
|
|