Merge branch 'develop' into feature/GRIB2-discipline192-legacy

This commit is contained in:
Shahram Najm 2020-04-23 17:42:46 +01:00
commit 186b2e8b41
20 changed files with 1323 additions and 1066 deletions

View File

@ -210,6 +210,7 @@ _if (stepType is "instant" ) {
meta stepRange g1step_range(P1,P2,timeRangeIndicator,unitOfTimeRange,stepUnits,stepType) : dump;
meta startStep long_vector(stepRange,0) : dump,no_copy;
meta endStep long_vector(stepRange,1) : dump,no_copy;
meta stepHumanReadable step_human_readable(stepUnits, stepRange): hidden,no_copy;
alias stepInHours = endStep;
alias ls.stepRange = stepRange;

View File

@ -16,6 +16,7 @@ alias ls.stepRange=stepRange;
concept stepTypeInternal {
"instant" = {dummy=1;}
}
meta stepHumanReadable step_human_readable(stepUnits, stepRange): hidden,no_copy;
alias time.stepType=stepType;
alias time.stepRange=stepRange;

View File

@ -96,6 +96,7 @@ list( APPEND grib_api_srcs
grib_accessor_class_codetable.c
grib_accessor_class_codetable_units.c
grib_accessor_class_codetable_title.c
grib_accessor_class_step_human_readable.c
grib_accessor_class_count_file.c
grib_accessor_class_count_total.c
grib_accessor_class_double.c

View File

@ -196,6 +196,7 @@ extern grib_accessor_class* grib_accessor_class_spectral_truncation;
extern grib_accessor_class* grib_accessor_class_sprintf;
extern grib_accessor_class* grib_accessor_class_statistics;
extern grib_accessor_class* grib_accessor_class_statistics_spectral;
extern grib_accessor_class* grib_accessor_class_step_human_readable;
extern grib_accessor_class* grib_accessor_class_step_in_units;
extern grib_accessor_class* grib_accessor_class_sum;
extern grib_accessor_class* grib_accessor_class_suppressed;

View File

@ -543,6 +543,7 @@ static int get_descriptors(grib_accessor* a)
return ret;
numberOfDescriptors = grib_bufr_descriptors_array_used_size(self->expanded);
if (self->canBeMissing ) grib_context_free(c, self->canBeMissing);
self->canBeMissing = (int*)grib_context_malloc_clear(c, numberOfDescriptors * sizeof(int));
for (i = 0; i < numberOfDescriptors; i++)
self->canBeMissing[i] = grib_bufr_descriptor_can_be_missing(self->expanded->v[i]);
@ -860,6 +861,7 @@ static int encode_double_array(grib_context* c, grib_buffer* buff, long* pos, bu
}
grib_buffer_set_ulength_bits(c, buff, buff->ulength_bits + 6);
grib_encode_unsigned_longb(buff->data, localWidth, pos, 6);
grib_context_free(c, values);
return err;
}

View File

@ -380,6 +380,8 @@ static int grib_load_smart_table(grib_context* c, const char* filename,
numberOfColumns = 0;
while (*s) {
char* tcol = t->entries[code].column[numberOfColumns];
if ( tcol ) grib_context_free_persistent(c, tcol);
t->entries[code].column[numberOfColumns] = grib_context_strdup_persistent(c, s);
numberOfColumns++;
Assert(numberOfColumns < MAX_SMART_TABLE_COLUMNS);

View File

@ -0,0 +1,199 @@
/*
* (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 "grib_api_internal.h"
/*
This is used by make_class.pl
START_CLASS_DEF
CLASS = accessor
SUPER = grib_accessor_class_gen
IMPLEMENTS = init;unpack_string; get_native_type
MEMBERS = const char* stepUnits
MEMBERS = const char* step
END_CLASS_DEF
*/
/* START_CLASS_IMP */
/*
Don't edit anything between START_CLASS_IMP and END_CLASS_IMP
Instead edit values between START_CLASS_DEF and END_CLASS_DEF
or edit "accessor.class" and rerun ./make_class.pl
*/
static int get_native_type(grib_accessor*);
static int unpack_string(grib_accessor*, char*, size_t* len);
static void init(grib_accessor*, const long, grib_arguments*);
static void init_class(grib_accessor_class*);
typedef struct grib_accessor_step_human_readable
{
grib_accessor att;
/* Members defined in gen */
/* Members defined in step_human_readable */
const char* stepUnits;
const char* step;
} grib_accessor_step_human_readable;
extern grib_accessor_class* grib_accessor_class_gen;
static grib_accessor_class _grib_accessor_class_step_human_readable = {
&grib_accessor_class_gen, /* super */
"step_human_readable", /* name */
sizeof(grib_accessor_step_human_readable), /* size */
0, /* inited */
&init_class, /* init_class */
&init, /* init */
0, /* post_init */
0, /* free mem */
0, /* describes himself */
0, /* get length of section */
0, /* get length of string */
0, /* get number of values */
0, /* get number of bytes */
0, /* get offset to bytes */
&get_native_type, /* get native type */
0, /* get sub_section */
0, /* grib_pack procedures long */
0, /* grib_pack procedures long */
0, /* grib_pack procedures long */
0, /* grib_unpack procedures long */
0, /* grib_pack procedures double */
0, /* grib_unpack procedures double */
0, /* grib_pack procedures string */
&unpack_string, /* grib_unpack procedures string */
0, /* grib_pack array procedures string */
0, /* grib_unpack array procedures string */
0, /* grib_pack procedures bytes */
0, /* grib_unpack procedures bytes */
0, /* pack_expression */
0, /* notify_change */
0, /* update_size */
0, /* preferred_size */
0, /* resize */
0, /* nearest_smaller_value */
0, /* next accessor */
0, /* compare vs. another accessor */
0, /* unpack only ith value */
0, /* unpack a subarray */
0, /* clear */
0, /* clone accessor */
};
grib_accessor_class* grib_accessor_class_step_human_readable = &_grib_accessor_class_step_human_readable;
static void init_class(grib_accessor_class* c)
{
c->dump = (*(c->super))->dump;
c->next_offset = (*(c->super))->next_offset;
c->string_length = (*(c->super))->string_length;
c->value_count = (*(c->super))->value_count;
c->byte_count = (*(c->super))->byte_count;
c->byte_offset = (*(c->super))->byte_offset;
c->sub_section = (*(c->super))->sub_section;
c->pack_missing = (*(c->super))->pack_missing;
c->is_missing = (*(c->super))->is_missing;
c->pack_long = (*(c->super))->pack_long;
c->unpack_long = (*(c->super))->unpack_long;
c->pack_double = (*(c->super))->pack_double;
c->unpack_double = (*(c->super))->unpack_double;
c->pack_string = (*(c->super))->pack_string;
c->pack_string_array = (*(c->super))->pack_string_array;
c->unpack_string_array = (*(c->super))->unpack_string_array;
c->pack_bytes = (*(c->super))->pack_bytes;
c->unpack_bytes = (*(c->super))->unpack_bytes;
c->pack_expression = (*(c->super))->pack_expression;
c->notify_change = (*(c->super))->notify_change;
c->update_size = (*(c->super))->update_size;
c->preferred_size = (*(c->super))->preferred_size;
c->resize = (*(c->super))->resize;
c->nearest_smaller_value = (*(c->super))->nearest_smaller_value;
c->next = (*(c->super))->next;
c->compare = (*(c->super))->compare;
c->unpack_double_element = (*(c->super))->unpack_double_element;
c->unpack_double_subarray = (*(c->super))->unpack_double_subarray;
c->clear = (*(c->super))->clear;
c->make_clone = (*(c->super))->make_clone;
}
/* END_CLASS_IMP */
static void init(grib_accessor* a, const long len, grib_arguments* params)
{
grib_accessor_step_human_readable* self = (grib_accessor_step_human_readable*)a;
int n = 0;
grib_handle* h = grib_handle_of_accessor(a);
self->stepUnits = grib_arguments_get_name(h, params, n++);
self->step = grib_arguments_get_name(h, params, n++);
a->length = 0;
a->flags |= GRIB_ACCESSOR_FLAG_READ_ONLY;
}
static int get_native_type(grib_accessor* a)
{
return GRIB_TYPE_STRING;
}
static int get_step_human_readable(grib_handle* h, char* result, size_t* length)
{
int err = 0;
size_t slen = 2;
long step, hour, minute, second;
/* Change units to seconds (highest resolution)
* before computing the step value
*/
err = grib_set_string(h, "stepUnits", "s", &slen);
if (err) return err;
err = grib_get_long(h, "step", &step);
if (err) return err;
hour = step/3600;
minute = step/60 % 60;
second = step % 60;
/* sprintf(result, "%ld:%ld:%ld", hour, minute, second); */
if (second) {
sprintf(result, "%ldh %ldm %lds", hour, minute, second);
} else {
if (minute) sprintf(result, "%ldh %ldm", hour, minute);
else sprintf(result, "%ldh", hour);
}
*length = strlen(result);
return GRIB_SUCCESS;
}
static int unpack_string(grib_accessor* a, char* buffer, size_t* len)
{
grib_accessor_step_human_readable* self = (grib_accessor_step_human_readable*)a;
grib_handle* h = grib_handle_of_accessor(a);
long stepUnits;
int err = 0;
/* Save the current value of stepUnits */
err = grib_get_long_internal(h, self->stepUnits, &stepUnits);
if (err) return err;
/* This will change stepUnits to seconds for its calculation */
err = get_step_human_readable(h, buffer, len);
/* Restore stepUnits */
grib_set_long(h, self->stepUnits, stepUnits);
return err;
}

File diff suppressed because it is too large Load Diff

View File

@ -195,6 +195,7 @@
{ "sprintf", &grib_accessor_class_sprintf, },
{ "statistics", &grib_accessor_class_statistics, },
{ "statistics_spectral", &grib_accessor_class_statistics_spectral, },
{ "step_human_readable", &grib_accessor_class_step_human_readable, },
{ "step_in_units", &grib_accessor_class_step_in_units, },
{ "sum", &grib_accessor_class_sum, },
{ "suppressed", &grib_accessor_class_suppressed, },

View File

@ -196,6 +196,7 @@ spectral_truncation, &grib_accessor_class_spectral_truncation
sprintf, &grib_accessor_class_sprintf
statistics, &grib_accessor_class_statistics
statistics_spectral, &grib_accessor_class_statistics_spectral
step_human_readable, &grib_accessor_class_step_human_readable
step_in_units, &grib_accessor_class_step_in_units
sum, &grib_accessor_class_sum
suppressed, &grib_accessor_class_suppressed

View File

@ -491,8 +491,10 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment)
err = grib_unpack_string(a, value, &size);
p = value;
r = compute_bufr_key_rank(h, self->keys, a->name);
if (grib_is_missing_string(a, (unsigned char*)value, size))
if (grib_is_missing_string(a, (unsigned char*)value, size)) {
grib_context_free(c, value);
return;
}
while (*p) {
if (!isprint(*p))

View File

@ -517,8 +517,10 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment)
err = grib_unpack_string(a, value, &size);
p = value;
r = compute_bufr_key_rank(h, self->keys, a->name);
if (grib_is_missing_string(a, (unsigned char*)value, size))
if (grib_is_missing_string(a, (unsigned char*)value, size)) {
grib_context_free(c, value);
return;
}
while (*p) {
if (!isprint(*p))

View File

@ -530,8 +530,10 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment)
err = grib_unpack_string(a, value, &size);
p = value;
r = compute_bufr_key_rank(h, self->keys, a->name);
if (grib_is_missing_string(a, (unsigned char*)value, size))
if (grib_is_missing_string(a, (unsigned char*)value, size)) {
grib_context_free(c, value);
return;
}
while (*p) {
if (!isprint(*p))

File diff suppressed because it is too large Load Diff

View File

@ -57,6 +57,7 @@ list(APPEND tests_no_data_reqd
grib_ecc-136
grib_ecc-967
grib_ecc-1065
grib_ecc-1053
julian
bufr_dump_samples
bufr_json_samples

View File

@ -160,6 +160,7 @@ int main(int argc, char** argv)
void* runner(void* ptr)
{
do_stuff(ptr);
free(ptr);
pthread_exit(0);
}

27
tests/grib_ecc-1053.sh Executable file
View File

@ -0,0 +1,27 @@
#!/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.sh
set -u
# ---------------------------------------------------------
# This is the test for the JIRA issue ECC-1053
# It tests the human readable step key
# ---------------------------------------------------------
label="grib_ecc-1053-test"
temp=temp.${label}.grib
sample_g1=$ECCODES_SAMPLES_PATH/GRIB1.tmpl
${tools_dir}/grib_set -s unitOfTimeRange=254,P1=250 $sample_g1 $temp
grib_check_key_equals $temp stepHumanReadable '0h 4m 10s'
${tools_dir}/grib_set -s unitOfTimeRange=0,P1=200 $sample_g1 $temp
grib_check_key_equals $temp stepHumanReadable '3h 20m'
rm -f $temp

View File

@ -2068,299 +2068,300 @@ statistics,2062
status,2063
step,2064
stepForClustering,2065
stepInHours,2066
stepRange,2067
stepRangeInHours,2068
stepType,2069
stepTypeForConversion,2070
stepTypeInternal,2071
stepUnits,2072
stepZero,2073
stream,2074
streamOfAnalysis,2075
stretchingFactor,2076
stretchingFactorScaled,2077
stringValues,2078
subCentre,2079
subDefinitions1,2080
subDefinitions2,2081
subLocalDefinition1,2082
subLocalDefinition2,2083
subLocalDefinitionLength1,2084
subLocalDefinitionLength2,2085
subLocalDefinitionNumber1,2086
subLocalDefinitionNumber2,2087
subSetJ,2088
subSetK,2089
subSetM,2090
subcentreOfAnalysis,2091
subdivisionsOfBasicAngle,2092
suiteName,2093
superblockExtensionAddress,2094
swapScanningLat,2095
swapScanningLon,2096
swapScanningX,2097
swapScanningY,2098
system,2099
systemNumber,2100
t,2101
table2Version,2102
tableCode,2103
tableNumber,2104
tableReference,2105
tablesLocalDir,2106
tablesMasterDir,2107
tablesVersion,2108
tablesVersionLatest,2109
targetCompressionRatio,2110
td,2111
tempPressureUnits,2112
temperature,2113
temperatureAndDewpointPresent,2114
templatesLocalDir,2115
templatesMasterDir,2116
theHindcastMarsStream,2117
theMessage,2118
thisExperimentVersionNumber,2119
thisMarsClass,2120
thisMarsStream,2121
thisMarsType,2122
thousand,2123
three,2124
threshold,2125
thresholdIndicator,2126
tiggeCentre,2127
tiggeLAMName,2128
tiggeLocalVersion,2129
tiggeModel,2130
tiggeSection,2131
tiggeSuiteID,2132
tigge_name,2133
tigge_short_name,2134
tileClassification,2135
tileIndex,2136
time,2137
timeCoordinateDefinition,2138
timeDomainTemplate,2139
timeDomainTemplateNumber,2140
timeIncrement,2141
timeIncrementBetweenSuccessiveFields,2142
timeOfAnalysis,2143
timeOfForecast,2144
timeOfModelVersion,2145
timeOfReference,2146
timeRangeIndicator,2147
timeRangeIndicatorFromStepRange,2148
timeUnitFlag,2149
timerepres,2150
topLevel,2151
total,2152
totalAerosolBinsNumbers,2153
totalInitialConditions,2154
totalLength,2155
totalNumber,2156
totalNumberOfClusters,2157
totalNumberOfDataValuesMissingInStatisticalProcess,2158
totalNumberOfDirections,2159
totalNumberOfForecastProbabilities,2160
totalNumberOfFrequencies,2161
totalNumberOfGridPoints,2162
totalNumberOfIterations,2163
totalNumberOfRepetitions,2164
totalNumberOfTileAttributePairs,2165
totalNumberOfTubes,2166
totalNumberOfValuesInUnpackedSubset,2167
totalNumberOfdimensions,2168
treatmentOfMissingData,2169
true,2170
trueLengthOfLastGroup,2171
truncateDegrees,2172
truncateLaplacian,2173
tsectionNumber3,2174
tsectionNumber4,2175
tsectionNumber5,2176
tubeDomain,2177
tubeNumber,2178
two,2179
twoOrdersOfSPD,2180
type,2181
typeOfAnalysis,2182
typeOfAuxiliaryInformation,2183
typeOfCalendar,2184
typeOfCompressionUsed,2185
typeOfDistributionFunction,2186
typeOfEnsembleForecast,2187
typeOfEnsembleMember,2188
typeOfFirstFixedSurface,2189
typeOfGeneratingProcess,2190
typeOfGrid,2191
typeOfHorizontalLine,2192
typeOfIntervalForFirstAndSecondSize,2193
typeOfIntervalForFirstAndSecondWavelength,2194
typeOfLevel,2195
typeOfLevelECMF,2196
typeOfOriginalFieldValues,2197
typeOfPacking,2198
typeOfPostProcessing,2199
typeOfPreProcessing,2200
typeOfProcessedData,2201
typeOfSSTFieldUsed,2202
typeOfSecondFixedSurface,2203
typeOfSizeInterval,2204
typeOfStatisticalPostProcessingOfEnsembleMembers,2205
typeOfStatisticalProcessing,2206
typeOfTimeIncrement,2207
typeOfTimeIncrementBetweenSuccessiveFieldsUsedInTheStatisticalProcessing,2208
typeOfWavelengthInterval,2209
typicalCentury,2210
typicalDate,2211
typicalDateTime,2212
typicalDay,2213
typicalHour,2214
typicalMinute,2215
typicalMonth,2216
typicalSecond,2217
typicalTime,2218
typicalYear,2219
typicalYear2,2220
typicalYearOfCentury,2221
uco,2222
ucs,2223
unexpandedDescriptors,2224
unexpandedDescriptorsEncoded,2225
unitOfOffsetFromReferenceTime,2226
unitOfTime,2227
unitOfTimeIncrement,2228
unitOfTimeRange,2229
units,2230
unitsBias,2231
unitsConversionOffset,2232
unitsConversionScaleFactor,2233
unitsDecimalScaleFactor,2234
unitsECMF,2235
unitsFactor,2236
unitsOfFirstFixedSurface,2237
unitsOfSecondFixedSurface,2238
unknown,2239
unpack,2240
unpackedError,2241
unpackedSubsetPrecision,2242
unpackedValues,2243
unsignedIntegers,2244
unusedBitsInBitmap,2245
updateSequenceNumber,2246
upperLimit,2247
upperRange,2248
upperThreshold,2249
upperThresholdValue,2250
userDateEnd,2251
userDateStart,2252
userDateTimeEnd,2253
userDateTimeStart,2254
userTimeEnd,2255
userTimeStart,2256
uuidOfHGrid,2257
uuidOfVGrid,2258
uvRelativeToGrid,2259
validityDate,2260
validityTime,2261
values,2262
variationOfVisibility,2263
variationOfVisibilityDirection,2264
variationOfVisibilityDirectionAngle,2265
variationOfVisibilityDirectionTrend1,2266
variationOfVisibilityDirectionTrend2,2267
variationOfVisibilityDirectionTrend3,2268
variationOfVisibilityDirectionTrend4,2269
variationOfVisibilityTrend1,2270
variationOfVisibilityTrend2,2271
variationOfVisibilityTrend3,2272
variationOfVisibilityTrend4,2273
varno,2274
verificationDate,2275
verificationMonth,2276
verificationYear,2277
verifyingMonth,2278
version,2279
versionNumOfFilesFreeSpaceStorage,2280
versionNumOfRootGroupSymbolTableEntry,2281
versionNumOfSharedHeaderMessageFormat,2282
versionNumberOfExperimentalSuite,2283
versionNumberOfGribLocalTables,2284
versionNumberOfSuperblock,2285
versionOfModelClimate,2286
verticalCoordinate,2287
verticalCoordinateDefinition,2288
verticalDomainTemplate,2289
verticalDomainTemplateNumber,2290
verticalVisibility,2291
verticalVisibilityCoded,2292
visibility,2293
visibilityInKilometresTrend1,2294
visibilityInKilometresTrend2,2295
visibilityInKilometresTrend3,2296
visibilityInKilometresTrend4,2297
visibilityTrend1,2298
visibilityTrend2,2299
visibilityTrend3,2300
visibilityTrend4,2301
waveDomain,2302
weightAppliedToClimateMonth1,2303
westLongitudeOfCluster,2304
westLongitudeOfDomainOfTubing,2305
westernLongitudeOfClusterDomain,2306
westernLongitudeOfDomain,2307
widthOfFirstOrderValues,2308
widthOfLengths,2309
widthOfSPD,2310
widthOfWidths,2311
windDirection,2312
windDirectionTrend1,2313
windDirectionTrend2,2314
windDirectionTrend3,2315
windDirectionTrend4,2316
windGust,2317
windGustTrend1,2318
windGustTrend2,2319
windGustTrend3,2320
windGustTrend4,2321
windPresent,2322
windSpeed,2323
windSpeedTrend1,2324
windSpeedTrend2,2325
windSpeedTrend3,2326
windSpeedTrend4,2327
windUnits,2328
windUnitsTrend1,2329
windUnitsTrend2,2330
windUnitsTrend3,2331
windUnitsTrend4,2332
windVariableDirection,2333
windVariableDirectionTrend1,2334
windVariableDirectionTrend2,2335
windVariableDirectionTrend3,2336
windVariableDirectionTrend4,2337
wrongPadding,2338
xCoordinateOfOriginOfSectorImage,2339
xCoordinateOfSubSatellitePoint,2340
xDirectionGridLength,2341
xDirectionGridLengthInMetres,2342
xDirectionGridLengthInMillimetres,2343
xFirst,2344
xLast,2345
yCoordinateOfOriginOfSectorImage,2346
yCoordinateOfSubSatellitePoint,2347
yDirectionGridLength,2348
yDirectionGridLengthInMetres,2349
yDirectionGridLengthInMillimetres,2350
yFirst,2351
yLast,2352
year,2353
yearOfAnalysis,2354
yearOfCentury,2355
yearOfEndOfOverallTimeInterval,2356
yearOfForecast,2357
yearOfModelVersion,2358
yearOfReference,2359
zero,2360
zeros,2361
stepHumanReadable,2066
stepInHours,2067
stepRange,2068
stepRangeInHours,2069
stepType,2070
stepTypeForConversion,2071
stepTypeInternal,2072
stepUnits,2073
stepZero,2074
stream,2075
streamOfAnalysis,2076
stretchingFactor,2077
stretchingFactorScaled,2078
stringValues,2079
subCentre,2080
subDefinitions1,2081
subDefinitions2,2082
subLocalDefinition1,2083
subLocalDefinition2,2084
subLocalDefinitionLength1,2085
subLocalDefinitionLength2,2086
subLocalDefinitionNumber1,2087
subLocalDefinitionNumber2,2088
subSetJ,2089
subSetK,2090
subSetM,2091
subcentreOfAnalysis,2092
subdivisionsOfBasicAngle,2093
suiteName,2094
superblockExtensionAddress,2095
swapScanningLat,2096
swapScanningLon,2097
swapScanningX,2098
swapScanningY,2099
system,2100
systemNumber,2101
t,2102
table2Version,2103
tableCode,2104
tableNumber,2105
tableReference,2106
tablesLocalDir,2107
tablesMasterDir,2108
tablesVersion,2109
tablesVersionLatest,2110
targetCompressionRatio,2111
td,2112
tempPressureUnits,2113
temperature,2114
temperatureAndDewpointPresent,2115
templatesLocalDir,2116
templatesMasterDir,2117
theHindcastMarsStream,2118
theMessage,2119
thisExperimentVersionNumber,2120
thisMarsClass,2121
thisMarsStream,2122
thisMarsType,2123
thousand,2124
three,2125
threshold,2126
thresholdIndicator,2127
tiggeCentre,2128
tiggeLAMName,2129
tiggeLocalVersion,2130
tiggeModel,2131
tiggeSection,2132
tiggeSuiteID,2133
tigge_name,2134
tigge_short_name,2135
tileClassification,2136
tileIndex,2137
time,2138
timeCoordinateDefinition,2139
timeDomainTemplate,2140
timeDomainTemplateNumber,2141
timeIncrement,2142
timeIncrementBetweenSuccessiveFields,2143
timeOfAnalysis,2144
timeOfForecast,2145
timeOfModelVersion,2146
timeOfReference,2147
timeRangeIndicator,2148
timeRangeIndicatorFromStepRange,2149
timeUnitFlag,2150
timerepres,2151
topLevel,2152
total,2153
totalAerosolBinsNumbers,2154
totalInitialConditions,2155
totalLength,2156
totalNumber,2157
totalNumberOfClusters,2158
totalNumberOfDataValuesMissingInStatisticalProcess,2159
totalNumberOfDirections,2160
totalNumberOfForecastProbabilities,2161
totalNumberOfFrequencies,2162
totalNumberOfGridPoints,2163
totalNumberOfIterations,2164
totalNumberOfRepetitions,2165
totalNumberOfTileAttributePairs,2166
totalNumberOfTubes,2167
totalNumberOfValuesInUnpackedSubset,2168
totalNumberOfdimensions,2169
treatmentOfMissingData,2170
true,2171
trueLengthOfLastGroup,2172
truncateDegrees,2173
truncateLaplacian,2174
tsectionNumber3,2175
tsectionNumber4,2176
tsectionNumber5,2177
tubeDomain,2178
tubeNumber,2179
two,2180
twoOrdersOfSPD,2181
type,2182
typeOfAnalysis,2183
typeOfAuxiliaryInformation,2184
typeOfCalendar,2185
typeOfCompressionUsed,2186
typeOfDistributionFunction,2187
typeOfEnsembleForecast,2188
typeOfEnsembleMember,2189
typeOfFirstFixedSurface,2190
typeOfGeneratingProcess,2191
typeOfGrid,2192
typeOfHorizontalLine,2193
typeOfIntervalForFirstAndSecondSize,2194
typeOfIntervalForFirstAndSecondWavelength,2195
typeOfLevel,2196
typeOfLevelECMF,2197
typeOfOriginalFieldValues,2198
typeOfPacking,2199
typeOfPostProcessing,2200
typeOfPreProcessing,2201
typeOfProcessedData,2202
typeOfSSTFieldUsed,2203
typeOfSecondFixedSurface,2204
typeOfSizeInterval,2205
typeOfStatisticalPostProcessingOfEnsembleMembers,2206
typeOfStatisticalProcessing,2207
typeOfTimeIncrement,2208
typeOfTimeIncrementBetweenSuccessiveFieldsUsedInTheStatisticalProcessing,2209
typeOfWavelengthInterval,2210
typicalCentury,2211
typicalDate,2212
typicalDateTime,2213
typicalDay,2214
typicalHour,2215
typicalMinute,2216
typicalMonth,2217
typicalSecond,2218
typicalTime,2219
typicalYear,2220
typicalYear2,2221
typicalYearOfCentury,2222
uco,2223
ucs,2224
unexpandedDescriptors,2225
unexpandedDescriptorsEncoded,2226
unitOfOffsetFromReferenceTime,2227
unitOfTime,2228
unitOfTimeIncrement,2229
unitOfTimeRange,2230
units,2231
unitsBias,2232
unitsConversionOffset,2233
unitsConversionScaleFactor,2234
unitsDecimalScaleFactor,2235
unitsECMF,2236
unitsFactor,2237
unitsOfFirstFixedSurface,2238
unitsOfSecondFixedSurface,2239
unknown,2240
unpack,2241
unpackedError,2242
unpackedSubsetPrecision,2243
unpackedValues,2244
unsignedIntegers,2245
unusedBitsInBitmap,2246
updateSequenceNumber,2247
upperLimit,2248
upperRange,2249
upperThreshold,2250
upperThresholdValue,2251
userDateEnd,2252
userDateStart,2253
userDateTimeEnd,2254
userDateTimeStart,2255
userTimeEnd,2256
userTimeStart,2257
uuidOfHGrid,2258
uuidOfVGrid,2259
uvRelativeToGrid,2260
validityDate,2261
validityTime,2262
values,2263
variationOfVisibility,2264
variationOfVisibilityDirection,2265
variationOfVisibilityDirectionAngle,2266
variationOfVisibilityDirectionTrend1,2267
variationOfVisibilityDirectionTrend2,2268
variationOfVisibilityDirectionTrend3,2269
variationOfVisibilityDirectionTrend4,2270
variationOfVisibilityTrend1,2271
variationOfVisibilityTrend2,2272
variationOfVisibilityTrend3,2273
variationOfVisibilityTrend4,2274
varno,2275
verificationDate,2276
verificationMonth,2277
verificationYear,2278
verifyingMonth,2279
version,2280
versionNumOfFilesFreeSpaceStorage,2281
versionNumOfRootGroupSymbolTableEntry,2282
versionNumOfSharedHeaderMessageFormat,2283
versionNumberOfExperimentalSuite,2284
versionNumberOfGribLocalTables,2285
versionNumberOfSuperblock,2286
versionOfModelClimate,2287
verticalCoordinate,2288
verticalCoordinateDefinition,2289
verticalDomainTemplate,2290
verticalDomainTemplateNumber,2291
verticalVisibility,2292
verticalVisibilityCoded,2293
visibility,2294
visibilityInKilometresTrend1,2295
visibilityInKilometresTrend2,2296
visibilityInKilometresTrend3,2297
visibilityInKilometresTrend4,2298
visibilityTrend1,2299
visibilityTrend2,2300
visibilityTrend3,2301
visibilityTrend4,2302
waveDomain,2303
weightAppliedToClimateMonth1,2304
westLongitudeOfCluster,2305
westLongitudeOfDomainOfTubing,2306
westernLongitudeOfClusterDomain,2307
westernLongitudeOfDomain,2308
widthOfFirstOrderValues,2309
widthOfLengths,2310
widthOfSPD,2311
widthOfWidths,2312
windDirection,2313
windDirectionTrend1,2314
windDirectionTrend2,2315
windDirectionTrend3,2316
windDirectionTrend4,2317
windGust,2318
windGustTrend1,2319
windGustTrend2,2320
windGustTrend3,2321
windGustTrend4,2322
windPresent,2323
windSpeed,2324
windSpeedTrend1,2325
windSpeedTrend2,2326
windSpeedTrend3,2327
windSpeedTrend4,2328
windUnits,2329
windUnitsTrend1,2330
windUnitsTrend2,2331
windUnitsTrend3,2332
windUnitsTrend4,2333
windVariableDirection,2334
windVariableDirectionTrend1,2335
windVariableDirectionTrend2,2336
windVariableDirectionTrend3,2337
windVariableDirectionTrend4,2338
wrongPadding,2339
xCoordinateOfOriginOfSectorImage,2340
xCoordinateOfSubSatellitePoint,2341
xDirectionGridLength,2342
xDirectionGridLengthInMetres,2343
xDirectionGridLengthInMillimetres,2344
xFirst,2345
xLast,2346
yCoordinateOfOriginOfSectorImage,2347
yCoordinateOfSubSatellitePoint,2348
yDirectionGridLength,2349
yDirectionGridLengthInMetres,2350
yDirectionGridLengthInMillimetres,2351
yFirst,2352
yLast,2353
year,2354
yearOfAnalysis,2355
yearOfCentury,2356
yearOfEndOfOverallTimeInterval,2357
yearOfForecast,2358
yearOfModelVersion,2359
yearOfReference,2360
zero,2361
zeros,2362

View File

@ -1296,8 +1296,10 @@ static int compare_all_dump_keys(grib_handle* handle1, grib_handle* handle2, gri
prefix = (char*)xa->name;
}
if (blacklisted(prefix))
if (blacklisted(prefix)) {
if (dofree) grib_context_free(context, prefix);
continue;
}
/* Compare the key itself */
if (compare_values(options, handle1, handle2, prefix, GRIB_TYPE_UNDEFINED)) {

View File

@ -396,6 +396,7 @@
<ClCompile Include="..\..\..\src\grib_accessor_class_sprintf.c" />
<ClCompile Include="..\..\..\src\grib_accessor_class_statistics.c" />
<ClCompile Include="..\..\..\src\grib_accessor_class_statistics_spectral.c" />
<ClCompile Include="..\..\..\src\grib_accessor_class_step_human_readable.c" />
<ClCompile Include="..\..\..\src\grib_accessor_class_step_in_units.c" />
<ClCompile Include="..\..\..\src\grib_accessor_class_sum.c" />
<ClCompile Include="..\..\..\src\grib_accessor_class_suppressed.c" />