mirror of https://github.com/ecmwf/eccodes.git
Merge branch 'develop' into feature/GRIB2-discipline192-legacy
This commit is contained in:
commit
186b2e8b41
|
@ -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;
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
|
||||
|
|
|
@ -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);
|
||||
|
|
|
@ -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
|
@ -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, },
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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))
|
||||
|
|
|
@ -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))
|
||||
|
|
|
@ -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
|
@ -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
|
||||
|
|
|
@ -160,6 +160,7 @@ int main(int argc, char** argv)
|
|||
void* runner(void* ptr)
|
||||
{
|
||||
do_stuff(ptr);
|
||||
free(ptr);
|
||||
pthread_exit(0);
|
||||
}
|
||||
|
||||
|
|
|
@ -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
|
593
tests/keys
593
tests/keys
|
@ -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
|
||||
|
|
|
@ -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)) {
|
||||
|
|
|
@ -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" />
|
||||
|
|
Loading…
Reference in New Issue