mirror of https://github.com/ecmwf/eccodes.git
ECC-1958 BUFR encoding: Delayed replication: Too many elements (#268)
* ECC-1958: BUFR encoding: Delayed replication: Too many elements * ECC-1958: Test * ECC-1958: Add test * ECC-1958: Add test for -d
This commit is contained in:
parent
4d91fbb9fb
commit
c2724bc41a
|
@ -209,15 +209,16 @@ void grib_accessor_expanded_descriptors_t::__expand(bufr_descriptors_array* unex
|
|||
#endif
|
||||
expanded = grib_bufr_descriptors_array_append(expanded, inner_expanded);
|
||||
uidx = grib_bufr_descriptors_array_get(expanded, idx);
|
||||
if (size > 100) {
|
||||
grib_context_log(c, GRIB_LOG_ERROR,
|
||||
"Delayed replication %06ld: Too many elements (%lu). "
|
||||
"Hint: This may be due to associated field descriptors",
|
||||
uidx->code, size);
|
||||
*err = GRIB_DECODING_ERROR;
|
||||
return;
|
||||
}
|
||||
grib_bufr_descriptor_set_code(uidx, (size - 1) * 1000 + 100000);
|
||||
Assert( uidx->type == BUFR_DESCRIPTOR_TYPE_REPLICATION );
|
||||
Assert( uidx->F == 1 );
|
||||
Assert( uidx->Y == 0 );
|
||||
// ECC-1958 and ECC-1054:
|
||||
// Here size can exceed 63 (num bits in X is 6)
|
||||
// We need to set X but not the descriptor code
|
||||
uidx->X = (int)(size - 1);
|
||||
if (size < 64)
|
||||
uidx->code = (size - 1) * 1000 + 100000;
|
||||
//grib_bufr_descriptor_set_code(uidx, (size - 1) * 1000 + 100000);
|
||||
size++;
|
||||
}
|
||||
else {
|
||||
|
|
|
@ -258,6 +258,7 @@ if( HAVE_BUILD_TOOLS )
|
|||
bufr_ecc-1476
|
||||
bufr_ecc-1623
|
||||
bufr_ecc-1785
|
||||
bufr_ecc-1958
|
||||
bufr_ecc-1938
|
||||
grib_ecc-490
|
||||
grib_ecc-756
|
||||
|
|
|
@ -0,0 +1,61 @@
|
|||
#!/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
|
||||
|
||||
label="bufr_ecc-1958_test"
|
||||
tempBufr=temp.$label.bufr
|
||||
tempFilt=temp.$label.filt
|
||||
tempLog=temp.$label.log
|
||||
tempOut=temp.$label.txt
|
||||
tempRef=temp.$label.ref
|
||||
|
||||
sample_bufr4=$ECCODES_SAMPLES_PATH/BUFR4.tmpl
|
||||
|
||||
# 005074 indexInRangeDirection
|
||||
# 005075 indexInAzimuthalDirection
|
||||
# 008085 beamIdentifier
|
||||
# 022161 waveSpectra
|
||||
# 002134 antennaBeamAzimuth
|
||||
|
||||
cat >$tempFilt<<EOF
|
||||
set numberOfSubsets = 1;
|
||||
set inputExtendedDelayedDescriptorReplicationFactor = {32};
|
||||
set masterTablesVersionNumber = 41;
|
||||
set updateSequenceNumber = 0;
|
||||
set bufrHeaderSubCentre = 0;
|
||||
set unexpandedDescriptors = { 109000,31002,5074,107024,5075,8085,22161,8085,102003,2134,22161 };
|
||||
write;
|
||||
EOF
|
||||
${tools_dir}/codes_bufr_filter -o $tempBufr $tempFilt $sample_bufr4
|
||||
|
||||
# Check descriptor dump
|
||||
${tools_dir}/bufr_dump -d $tempBufr > $tempOut
|
||||
c=$( grep -c -w antennaBeamAzimuth $tempOut )
|
||||
[ $c -eq 72 ]
|
||||
|
||||
# Check full dump
|
||||
${tools_dir}/bufr_dump -p $tempBufr > $tempOut
|
||||
c=$( grep -c -w indexInRangeDirection $tempOut )
|
||||
[ $c -eq 32 ]
|
||||
|
||||
# 32*24 = 768
|
||||
c=$( grep -c -w indexInAzimuthalDirection $tempOut )
|
||||
[ $c -eq 768 ]
|
||||
|
||||
# 32*24*3 = 2304
|
||||
c=$( grep -c -w antennaBeamAzimuth $tempOut )
|
||||
[ $c -eq 2304 ]
|
||||
|
||||
|
||||
# Clean up
|
||||
rm -f $tempBufr $tempFilt $tempLog $tempOut $tempRef
|
Loading…
Reference in New Issue