mirror of https://github.com/ecmwf/eccodes.git
Merge branch 'develop' into feature/Performance_nearest
This commit is contained in:
commit
e0188ee4e7
|
@ -2682,7 +2682,7 @@
|
||||||
parameterNumber = 0 ;
|
parameterNumber = 0 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most severe) in the last 1 hour
|
#Precipitation type (most severe) in the last 1 hour
|
||||||
'sev_ptype1h' = {
|
'ptype_sev1h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2691,7 +2691,7 @@
|
||||||
lengthOfTimeRange = 1 ;
|
lengthOfTimeRange = 1 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most severe) in the last 3 hours
|
#Precipitation type (most severe) in the last 3 hours
|
||||||
'sev_ptype3h' = {
|
'ptype_sev3h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2700,7 +2700,7 @@
|
||||||
lengthOfTimeRange = 3 ;
|
lengthOfTimeRange = 3 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most frequent) in the last 1 hour
|
#Precipitation type (most frequent) in the last 1 hour
|
||||||
'freq_ptype1h' = {
|
'ptype_freq1h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2709,7 +2709,7 @@
|
||||||
lengthOfTimeRange = 1 ;
|
lengthOfTimeRange = 1 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most frequent) in the last 3 hours
|
#Precipitation type (most frequent) in the last 3 hours
|
||||||
'freq_ptype3h' = {
|
'ptype_freq3h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2717,6 +2717,24 @@
|
||||||
typeOfStatisticalProcessing = 101 ;
|
typeOfStatisticalProcessing = 101 ;
|
||||||
lengthOfTimeRange = 3 ;
|
lengthOfTimeRange = 3 ;
|
||||||
}
|
}
|
||||||
|
#Precipitation type (most severe) in the last 6 hours
|
||||||
|
'ptype_sev6h' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 100 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
|
#Precipitation type (most frequent) in the last 6 hours
|
||||||
|
'ptype_freq6h' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 101 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
#Soil temperature
|
#Soil temperature
|
||||||
'sot' = {
|
'sot' = {
|
||||||
discipline = 2 ;
|
discipline = 2 ;
|
||||||
|
|
|
@ -2717,6 +2717,24 @@
|
||||||
typeOfStatisticalProcessing = 101 ;
|
typeOfStatisticalProcessing = 101 ;
|
||||||
lengthOfTimeRange = 3 ;
|
lengthOfTimeRange = 3 ;
|
||||||
}
|
}
|
||||||
|
#Precipitation type (most severe) in the last 6 hours
|
||||||
|
'Precipitation type (most severe) in the last 6 hours' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 100 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
|
#Precipitation type (most frequent) in the last 6 hours
|
||||||
|
'Precipitation type (most frequent) in the last 6 hours' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 101 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
#Soil temperature
|
#Soil temperature
|
||||||
'Soil temperature' = {
|
'Soil temperature' = {
|
||||||
discipline = 2 ;
|
discipline = 2 ;
|
||||||
|
|
|
@ -2717,6 +2717,24 @@
|
||||||
typeOfStatisticalProcessing = 101 ;
|
typeOfStatisticalProcessing = 101 ;
|
||||||
lengthOfTimeRange = 3 ;
|
lengthOfTimeRange = 3 ;
|
||||||
}
|
}
|
||||||
|
#Precipitation type (most severe) in the last 6 hours
|
||||||
|
'260338' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 100 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
|
#Precipitation type (most frequent) in the last 6 hours
|
||||||
|
'260339' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 101 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
#Soil temperature
|
#Soil temperature
|
||||||
'260360' = {
|
'260360' = {
|
||||||
discipline = 2 ;
|
discipline = 2 ;
|
||||||
|
|
|
@ -2682,7 +2682,7 @@
|
||||||
parameterNumber = 0 ;
|
parameterNumber = 0 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most severe) in the last 1 hour
|
#Precipitation type (most severe) in the last 1 hour
|
||||||
'sev_ptype1h' = {
|
'ptype_sev1h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2691,7 +2691,7 @@
|
||||||
lengthOfTimeRange = 1 ;
|
lengthOfTimeRange = 1 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most severe) in the last 3 hours
|
#Precipitation type (most severe) in the last 3 hours
|
||||||
'sev_ptype3h' = {
|
'ptype_sev3h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2700,7 +2700,7 @@
|
||||||
lengthOfTimeRange = 3 ;
|
lengthOfTimeRange = 3 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most frequent) in the last 1 hour
|
#Precipitation type (most frequent) in the last 1 hour
|
||||||
'freq_ptype1h' = {
|
'ptype_freq1h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2709,7 +2709,7 @@
|
||||||
lengthOfTimeRange = 1 ;
|
lengthOfTimeRange = 1 ;
|
||||||
}
|
}
|
||||||
#Precipitation type (most frequent) in the last 3 hours
|
#Precipitation type (most frequent) in the last 3 hours
|
||||||
'freq_ptype3h' = {
|
'ptype_freq3h' = {
|
||||||
discipline = 0 ;
|
discipline = 0 ;
|
||||||
parameterCategory = 1 ;
|
parameterCategory = 1 ;
|
||||||
parameterNumber = 19 ;
|
parameterNumber = 19 ;
|
||||||
|
@ -2717,6 +2717,24 @@
|
||||||
typeOfStatisticalProcessing = 101 ;
|
typeOfStatisticalProcessing = 101 ;
|
||||||
lengthOfTimeRange = 3 ;
|
lengthOfTimeRange = 3 ;
|
||||||
}
|
}
|
||||||
|
#Precipitation type (most severe) in the last 6 hours
|
||||||
|
'ptype_sev6h' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 100 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
|
#Precipitation type (most frequent) in the last 6 hours
|
||||||
|
'ptype_freq6h' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 101 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
#Soil temperature
|
#Soil temperature
|
||||||
'sot' = {
|
'sot' = {
|
||||||
discipline = 2 ;
|
discipline = 2 ;
|
||||||
|
|
|
@ -2717,6 +2717,24 @@
|
||||||
typeOfStatisticalProcessing = 101 ;
|
typeOfStatisticalProcessing = 101 ;
|
||||||
lengthOfTimeRange = 3 ;
|
lengthOfTimeRange = 3 ;
|
||||||
}
|
}
|
||||||
|
#Precipitation type (most severe) in the last 6 hours
|
||||||
|
'code table (4.201)' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 100 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
|
#Precipitation type (most frequent) in the last 6 hours
|
||||||
|
'code table (4.201)' = {
|
||||||
|
discipline = 0 ;
|
||||||
|
parameterCategory = 1 ;
|
||||||
|
parameterNumber = 19 ;
|
||||||
|
indicatorOfUnitForTimeRange = 1 ;
|
||||||
|
typeOfStatisticalProcessing = 101 ;
|
||||||
|
lengthOfTimeRange = 6 ;
|
||||||
|
}
|
||||||
#Soil temperature
|
#Soil temperature
|
||||||
'K' = {
|
'K' = {
|
||||||
discipline = 2 ;
|
discipline = 2 ;
|
||||||
|
|
|
@ -1047,7 +1047,7 @@ int grib_f_open_file_(int* fid, char* name , char* op, int lname, int lop) {
|
||||||
while (*p != '\0') { *p=tolower(*p);p++;}
|
while (*p != '\0') { *p=tolower(*p);p++;}
|
||||||
|
|
||||||
trimmed = cast_char_no_cut(fname,name,lname); /* ECC-1392 */
|
trimmed = cast_char_no_cut(fname,name,lname); /* ECC-1392 */
|
||||||
rtrim( trimmed );
|
string_rtrim( trimmed );
|
||||||
f = fopen(trimmed, oper);
|
f = fopen(trimmed, oper);
|
||||||
if(!f) {
|
if(!f) {
|
||||||
ioerr=errno;
|
ioerr=errno;
|
||||||
|
@ -2891,7 +2891,7 @@ int grib_f_index_select_string_(int* gid, char* key, char* val, int len, int val
|
||||||
|
|
||||||
/* ECC-1316 */
|
/* ECC-1316 */
|
||||||
cast_char_no_cut(bufval,val,vallen);
|
cast_char_no_cut(bufval,val,vallen);
|
||||||
rtrim( bufval );
|
string_rtrim( bufval );
|
||||||
|
|
||||||
return grib_index_select_string(h, cast_char(buf,key,len), bufval);
|
return grib_index_select_string(h, cast_char(buf,key,len), bufval);
|
||||||
}
|
}
|
||||||
|
@ -3257,7 +3257,7 @@ int grib_f_set_string_array_(int* gid, char* key, char* val,int* nvals,int* slen
|
||||||
for (i=0;i<lsize;i++) {
|
for (i=0;i<lsize;i++) {
|
||||||
cval[i]=(char*)grib_context_malloc_clear(c,sizeof(char)* (*slen+1));
|
cval[i]=(char*)grib_context_malloc_clear(c,sizeof(char)* (*slen+1));
|
||||||
cast_char_no_cut(cval[i],p,*slen);
|
cast_char_no_cut(cval[i],p,*slen);
|
||||||
rtrim( cval[i] ); /* trim spaces at end of string */
|
string_rtrim( cval[i] ); /* trim spaces at end of string */
|
||||||
p+= *slen;
|
p+= *slen;
|
||||||
}
|
}
|
||||||
err = grib_set_string_array(h, cast_char(buf,key,len), (const char **)cval, lsize);
|
err = grib_set_string_array(h, cast_char(buf,key,len), (const char **)cval, lsize);
|
||||||
|
@ -3327,7 +3327,7 @@ int grib_f_set_string_(int* gid, char* key, char* val, int len, int len2){
|
||||||
/* So do not use cast_char. cast_char_no_cut does not stop at first space */
|
/* So do not use cast_char. cast_char_no_cut does not stop at first space */
|
||||||
val_str = cast_char_no_cut(buf2,val,len2);
|
val_str = cast_char_no_cut(buf2,val,len2);
|
||||||
if (val_str && !is_all_spaces(val_str)) {
|
if (val_str && !is_all_spaces(val_str)) {
|
||||||
rtrim( val_str ); /* trim spaces at end of string */
|
string_rtrim( val_str ); /* trim spaces at end of string */
|
||||||
}
|
}
|
||||||
|
|
||||||
return grib_set_string(h, cast_char(buf,key,len), val_str, &lsize);
|
return grib_set_string(h, cast_char(buf,key,len), val_str, &lsize);
|
||||||
|
|
|
@ -282,7 +282,7 @@ static int bufr_decode_extra_rdb_keys(const void* message, long offset_section2,
|
||||||
}
|
}
|
||||||
temp[i] = '\0';
|
temp[i] = '\0';
|
||||||
pTemp = temp;
|
pTemp = temp;
|
||||||
lrtrim(&pTemp, 1, 1); /* Trim left and right */
|
string_lrtrim(&pTemp, 1, 1); /* Trim left and right */
|
||||||
strncpy(hdr->ident, pTemp, IDENT_LEN - 1);
|
strncpy(hdr->ident, pTemp, IDENT_LEN - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1457,16 +1457,17 @@ int codes_bufr_key_is_header(const grib_handle* h, const char* key, int* err);
|
||||||
|
|
||||||
/* string_util.c */
|
/* string_util.c */
|
||||||
int strcmp_nocase(const char* s1, const char* s2);
|
int strcmp_nocase(const char* s1, const char* s2);
|
||||||
void rtrim(char* s);
|
void string_rtrim(char* s);
|
||||||
void lrtrim(char** x, int do_left, int do_right);
|
void string_lrtrim(char** x, int do_left, int do_right);
|
||||||
const char* extract_filename(const char* filepath);
|
const char* extract_filename(const char* filepath);
|
||||||
char** string_split(char* inputString, const char* delimiter);
|
char** string_split(char* inputString, const char* delimiter);
|
||||||
int string_to_long(const char* input, long* output);
|
int string_to_long(const char* input, long* output);
|
||||||
int string_ends_with(const char* str1, const char* str2);
|
int string_ends_with(const char* str1, const char* str2);
|
||||||
int count_char_in_string(const char* str, char c);
|
int string_count_char(const char* str, char c);
|
||||||
const char* codes_get_product_name(ProductKind product);
|
const char* codes_get_product_name(ProductKind product);
|
||||||
const char* grib_get_type_name(int type);
|
const char* grib_get_type_name(int type);
|
||||||
|
char* string_replace_char(char *str, char oldc, char newc);
|
||||||
|
void string_remove_char(char * str, char c);
|
||||||
|
|
||||||
/* functions.c */
|
/* functions.c */
|
||||||
long grib_op_eq(long a, long b);
|
long grib_op_eq(long a, long b);
|
||||||
|
|
|
@ -506,7 +506,7 @@ static int grib_load_codetable(grib_context* c, const char* filename,
|
||||||
|
|
||||||
Assert(*abbreviation);
|
Assert(*abbreviation);
|
||||||
Assert(*title);
|
Assert(*title);
|
||||||
rtrim(title); /* ECC-1315 */
|
string_rtrim(title); /* ECC-1315 */
|
||||||
|
|
||||||
if (t->entries[code].abbreviation != NULL) {
|
if (t->entries[code].abbreviation != NULL) {
|
||||||
grib_context_log(c, GRIB_LOG_WARNING, "code_table_entry: duplicate code in %s: %d (table size=%ld)", filename, code, size);
|
grib_context_log(c, GRIB_LOG_WARNING, "code_table_entry: duplicate code in %s: %d (table size=%ld)", filename, code, size);
|
||||||
|
|
|
@ -161,7 +161,7 @@ static int unpack_string(grib_accessor* a, char* val, size_t* len)
|
||||||
err = grib_get_string(h, self->input, input, &size);
|
err = grib_get_string(h, self->input, input, &size);
|
||||||
if (err) return err;
|
if (err) return err;
|
||||||
|
|
||||||
lrtrim(&pInput, self->trim_left, self->trim_right);
|
string_lrtrim(&pInput, self->trim_left, self->trim_right);
|
||||||
sprintf(val, "%s", pInput);
|
sprintf(val, "%s", pInput);
|
||||||
size = strlen(val);
|
size = strlen(val);
|
||||||
*len = size + 1;
|
*len = size + 1;
|
||||||
|
@ -189,7 +189,7 @@ static int pack_string(grib_accessor* a, const char* val, size_t* len)
|
||||||
|
|
||||||
sprintf(buf, "%s", val);
|
sprintf(buf, "%s", val);
|
||||||
pBuf = buf;
|
pBuf = buf;
|
||||||
lrtrim(&pBuf, self->trim_left, self->trim_right);
|
string_lrtrim(&pBuf, self->trim_left, self->trim_right);
|
||||||
|
|
||||||
return grib_pack_string(inputAccesstor, pBuf, len);
|
return grib_pack_string(inputAccesstor, pBuf, len);
|
||||||
}
|
}
|
||||||
|
|
|
@ -707,6 +707,8 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment)
|
||||||
while (*p) {
|
while (*p) {
|
||||||
if (!isprint(*p))
|
if (!isprint(*p))
|
||||||
*p = '.';
|
*p = '.';
|
||||||
|
if (*p == '"')
|
||||||
|
*p = '\''; /* ECC-1401 */
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -646,6 +646,8 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment)
|
||||||
while (*p) {
|
while (*p) {
|
||||||
if (!isprint(*p))
|
if (!isprint(*p))
|
||||||
*p = '.';
|
*p = '.';
|
||||||
|
if (*p == '"')
|
||||||
|
*p = '\''; /* ECC-1401 */
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -660,6 +660,8 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment)
|
||||||
while (*p) {
|
while (*p) {
|
||||||
if (!isprint(*p))
|
if (!isprint(*p))
|
||||||
*p = '.';
|
*p = '.';
|
||||||
|
if (*p == '"')
|
||||||
|
*p = '\''; /* ECC-1401 */
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -498,6 +498,8 @@ static void dump_string(grib_dumper* d, grib_accessor* a, const char* comment)
|
||||||
while (*p) {
|
while (*p) {
|
||||||
if (!isprint(*p))
|
if (!isprint(*p))
|
||||||
*p = '.';
|
*p = '.';
|
||||||
|
if (*p == '"')
|
||||||
|
*p = '\''; /* ECC-1401 */
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ int strcmp_nocase(const char* s1, const char* s2)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Strip whitespace from the end of a string */
|
/* Strip whitespace from the end of a string */
|
||||||
void rtrim(char* s)
|
void string_rtrim(char* s)
|
||||||
{
|
{
|
||||||
size_t len = 0;
|
size_t len = 0;
|
||||||
if (!s)
|
if (!s)
|
||||||
|
@ -38,7 +38,7 @@ void rtrim(char* s)
|
||||||
s[len] = '\0';
|
s[len] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
void lrtrim(char** x, int do_left, int do_right)
|
void string_lrtrim(char** x, int do_left, int do_right)
|
||||||
{
|
{
|
||||||
DebugAssert(do_left || do_right);
|
DebugAssert(do_left || do_right);
|
||||||
if (do_left) {
|
if (do_left) {
|
||||||
|
@ -161,7 +161,7 @@ int string_ends_with(const char* s, const char* suffix)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int count_char_in_string(const char* str, char c)
|
int string_count_char(const char* str, char c)
|
||||||
{
|
{
|
||||||
int i = 0, count = 0;
|
int i = 0, count = 0;
|
||||||
DebugAssert(str);
|
DebugAssert(str);
|
||||||
|
@ -208,3 +208,30 @@ const char* grib_get_type_name(int type)
|
||||||
}
|
}
|
||||||
return "unknown";
|
return "unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Replace all occurrences of character in string.
|
||||||
|
* Returns pointer to the NUL byte at the end of 's'
|
||||||
|
*/
|
||||||
|
char *string_replace_char(char *s, char oldc, char newc)
|
||||||
|
{
|
||||||
|
for (; *s; ++s)
|
||||||
|
if (*s == oldc)
|
||||||
|
*s = newc;
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Remove all instances of character 'c' from 'str' */
|
||||||
|
void string_remove_char(char * str, char c)
|
||||||
|
{
|
||||||
|
size_t i, j;
|
||||||
|
size_t len = strlen(str);
|
||||||
|
for(i=0; i<len; i++) {
|
||||||
|
if(str[i] == c) {
|
||||||
|
for(j=i; j<len; j++) {
|
||||||
|
str[j] = str[j+1];
|
||||||
|
}
|
||||||
|
len--;
|
||||||
|
i--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -10,6 +10,12 @@
|
||||||
|
|
||||||
. ./include.ctest.sh
|
. ./include.ctest.sh
|
||||||
|
|
||||||
|
label="bufr_json_data_test"
|
||||||
|
tempRules=temp.${label}.filter
|
||||||
|
tempOut=temp.${label}.txt
|
||||||
|
tempBufr=temp.${label}.bufr
|
||||||
|
|
||||||
|
|
||||||
REDIRECT=/dev/null
|
REDIRECT=/dev/null
|
||||||
|
|
||||||
cd ${data_dir}/bufr
|
cd ${data_dir}/bufr
|
||||||
|
@ -49,6 +55,7 @@ for file in ${bufr_files}; do
|
||||||
done
|
done
|
||||||
|
|
||||||
# ECC-233: Test JSON dump when selecting messages with '-w' switch
|
# ECC-233: Test JSON dump when selecting messages with '-w' switch
|
||||||
|
# -----------------------------------------------------------------
|
||||||
file=tropical_cyclone.bufr
|
file=tropical_cyclone.bufr
|
||||||
for c in 1 3 1/3; do
|
for c in 1 3 1/3; do
|
||||||
${tools_dir}/bufr_dump -w count=$c $file 2> $REDIRECT > ${file}.json
|
${tools_dir}/bufr_dump -w count=$c $file 2> $REDIRECT > ${file}.json
|
||||||
|
@ -60,5 +67,24 @@ done
|
||||||
|
|
||||||
|
|
||||||
# ECC-272
|
# ECC-272
|
||||||
|
# ------------
|
||||||
file=aaen_55.bufr
|
file=aaen_55.bufr
|
||||||
${tools_dir}/bufr_dump -jf $file | grep -q -w channelRadiance
|
${tools_dir}/bufr_dump -jf $file | grep -q -w channelRadiance
|
||||||
|
|
||||||
|
|
||||||
|
# ECC-1401: BUFR: bufr_dump generates invalid JSON
|
||||||
|
# -------------------------------------------------
|
||||||
|
cat > $tempRules <<EOF
|
||||||
|
set unexpandedDescriptors = { 1015 };
|
||||||
|
set stationOrSiteName = 'Contains "bad" chars';
|
||||||
|
set pack = 1;
|
||||||
|
write;
|
||||||
|
EOF
|
||||||
|
${tools_dir}/codes_bufr_filter -o $tempBufr $tempRules $samp_dir/BUFR4.tmpl
|
||||||
|
${tools_dir}/bufr_dump $tempBufr > $tempOut
|
||||||
|
if test "x$JSON_CHECK" != "x"; then
|
||||||
|
json_xs -t none < $tempOut
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
rm -f $tempRules $tempOut $tempBufr
|
||||||
|
|
|
@ -1511,19 +1511,19 @@ static void test_trimming()
|
||||||
|
|
||||||
printf("Testing: test_trimming...\n");
|
printf("Testing: test_trimming...\n");
|
||||||
|
|
||||||
lrtrim(&pA, 0, 1); /*right only*/
|
string_lrtrim(&pA, 0, 1); /*right only*/
|
||||||
assert( strcmp(pA, " Standing")==0 );
|
assert( strcmp(pA, " Standing")==0 );
|
||||||
|
|
||||||
lrtrim(&pB, 1, 0); /*left only*/
|
string_lrtrim(&pB, 1, 0); /*left only*/
|
||||||
assert( strcmp(pB, "Weeping ")==0 );
|
assert( strcmp(pB, "Weeping ")==0 );
|
||||||
|
|
||||||
lrtrim(&pC, 1, 1); /*both ends*/
|
string_lrtrim(&pC, 1, 1); /*both ends*/
|
||||||
assert( strcmp(pC, "Silhouette")==0 );
|
assert( strcmp(pC, "Silhouette")==0 );
|
||||||
|
|
||||||
lrtrim(&pD, 1, 1); /*make sure other spaces are not removed*/
|
string_lrtrim(&pD, 1, 1); /*make sure other spaces are not removed*/
|
||||||
assert( strcmp(pD, "The Forest Of October")==0 );
|
assert( strcmp(pD, "The Forest Of October")==0 );
|
||||||
|
|
||||||
lrtrim(&pE, 1, 1); /* Other chars */
|
string_lrtrim(&pE, 1, 1); /* Other chars */
|
||||||
assert( strcmp(pE, "Apostle In Triumph")==0 );
|
assert( strcmp(pE, "Apostle In Triumph")==0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -135,7 +135,7 @@ int grib_tool_new_handle_action(grib_runtime_options* options, grib_handle* h)
|
||||||
if (grib_options_on("L:")) {
|
if (grib_options_on("L:")) {
|
||||||
/* Do a very basic sanity check */
|
/* Do a very basic sanity check */
|
||||||
const char* str = grib_options_get_option("L:");
|
const char* str = grib_options_get_option("L:");
|
||||||
if (count_char_in_string(str, '%') != 2) {
|
if (string_count_char(str, '%') != 2) {
|
||||||
fprintf(stderr, "ERROR: Invalid lats/lons format option \"%s\".\nThe default is: \"%s\"\n",
|
fprintf(stderr, "ERROR: Invalid lats/lons format option \"%s\".\nThe default is: \"%s\"\n",
|
||||||
str, default_format_latlons);
|
str, default_format_latlons);
|
||||||
exit(1);
|
exit(1);
|
||||||
|
|
Loading…
Reference in New Issue