Merge branch 'master' into ejh_func_cleanup3

This commit is contained in:
Ward Fisher 2018-08-06 11:32:45 -06:00 committed by GitHub
commit 5f89204bdb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 42 additions and 26 deletions

2
cf
View File

@ -1,6 +1,6 @@
#!/bin/bash #!/bin/bash
#NB=1 #NB=1
#DB=1 DB=1
#X=-x #X=-x
#FAST=1 #FAST=1

View File

@ -567,7 +567,8 @@ getlimitnumber(const char* limit)
case 'K': case 'k': multiplier = KILOBYTE; break; case 'K': case 'k': multiplier = KILOBYTE; break;
default: break; default: break;
} }
sscanf(limit,"%lu",&lu); if(sscanf(limit,"%lu",&lu) != 1)
return 0;
return (lu*multiplier); return (lu*multiplier);
} }

View File

@ -128,14 +128,17 @@ range(DCEparsestate* state, Object sfirst, Object sstride, Object slast)
/* Note: that incoming arguments are strings; we must convert to size_t; /* Note: that incoming arguments are strings; we must convert to size_t;
but we do know they are legal integers or NULL */ but we do know they are legal integers or NULL */
sscanf((char*)sfirst,"%lu",&first); /* always defined */ if(sscanf((char*)sfirst,"%lu",&first) != 1) /* always defined */
if(slast != NULL) return NULL;
sscanf((char*)slast,"%lu",&last); if(slast != NULL) {
else if(sscanf((char*)slast,"%lu",&last) != 1)
return NULL;
} else
last = first; last = first;
if(sstride != NULL) if(sstride != NULL) {
sscanf((char*)sstride,"%lu",&stride); if(sscanf((char*)sstride,"%lu",&stride) != 1)
else return NULL;
} else
stride = 1; /* default */ stride = 1; /* default */
if(stride == 0) if(stride == 0)
@ -158,7 +161,8 @@ Object
range1(DCEparsestate* state, Object rangenumber) range1(DCEparsestate* state, Object rangenumber)
{ {
int range = -1; int range = -1;
sscanf((char*)rangenumber,"%u",&range); if(sscanf((char*)rangenumber,"%u",&range) != 1)
range = -1;
if(range < 0) { if(range < 0) {
dceerror(state,"Illegal range index"); dceerror(state,"Illegal range index");
} }
@ -199,7 +203,8 @@ array_indices(DCEparsestate* state, Object list0, Object indexno)
long long start = -1; long long start = -1;
NClist* list = (NClist*)list0; NClist* list = (NClist*)list0;
if(list == NULL) list = nclistnew(); if(list == NULL) list = nclistnew();
sscanf((char*)indexno,"%lld",&start); if(sscanf((char*)indexno,"%lld",&start) != 1)
start = -1;
if(start < 0) { if(start < 0) {
dceerror(state,"Illegal array index"); dceerror(state,"Illegal array index");
start = 1; start = 1;

View File

@ -2090,7 +2090,7 @@ printhashmap(NC_hashmap* hm)
NC_hentry e = hm->table[i]; NC_hentry e = hm->table[i];
if(e.flags == ACTIVE) { if(e.flags == ACTIVE) {
fprintf(stderr,"[%ld] flags=ACTIVE hashkey=%lu data=%p keysize=%u key=(%llu)|%s|\n", fprintf(stderr,"[%ld] flags=ACTIVE hashkey=%lu data=%p keysize=%u key=(%llu)|%s|\n",
(unsigned long)i,(unsigned long)e.hashkey,(void*)e.data,(unsigned)e.keysize,(unsigned long long)e.key,e.key); (unsigned long)i,(unsigned long)e.hashkey,(void*)e.data,(unsigned)e.keysize,(unsigned long long)(uintptr_t)e.key,e.key);
running = 0; running = 0;
} else if(e.flags == DELETED) { } else if(e.flags == DELETED) {
fprintf(stderr,"[%ld] flags=DELETED hashkey=%lu\n", fprintf(stderr,"[%ld] flags=DELETED hashkey=%lu\n",

View File

@ -226,7 +226,9 @@ nc4_close_netcdf4_file(NC_FILE_INFO_T *h5, int abort, int extractmem)
exit: exit:
/* Free the nc4_info struct; above code should have reclaimed /* Free the nc4_info struct; above code should have reclaimed
everything else */ everything else */
if (!retval) if (!retval)
free(h5); free(h5);
return retval; return retval;
} }

View File

@ -101,7 +101,7 @@ echo "*** Testing dynamic filters using nccopy"
rm -f ./unfiltered.nc ./filtered.nc ./tmp.nc ./filtered.dump ./tst_filter.txt rm -f ./unfiltered.nc ./filtered.nc ./tmp.nc ./filtered.dump ./tst_filter.txt
${NCGEN} -4 -lb -o unfiltered.nc ${srcdir}/unfiltered.cdl ${NCGEN} -4 -lb -o unfiltered.nc ${srcdir}/unfiltered.cdl
echo " *** Testing simple filter application" echo " *** Testing simple filter application"
${NCCOPY} -F "/g/var,307,9,4" unfiltered.nc filtered.nc ${NCCOPY} -M0 -F "/g/var,307,9,4" unfiltered.nc filtered.nc
${NCDUMP} -s filtered.nc > ./tst_filter.txt ${NCDUMP} -s filtered.nc > ./tst_filter.txt
# Remove irrelevant -s output # Remove irrelevant -s output
sclean ./tst_filter.txt ./filtered.dump sclean ./tst_filter.txt ./filtered.dump
@ -119,7 +119,7 @@ echo " *** Pass: pass-thru of filters"
echo " *** Testing -F none" echo " *** Testing -F none"
rm -f ./tst_filter.txt ./tst_filter2.txt ./tst_filter.nc rm -f ./tst_filter.txt ./tst_filter2.txt ./tst_filter.nc
${NCCOPY} -F none ./filtered.nc ./tst_filter.nc ${NCCOPY} -M0 -F none ./filtered.nc ./tst_filter.nc
${NCDUMP} -s tst_filter.nc > ./tst_filter.txt ${NCDUMP} -s tst_filter.nc > ./tst_filter.txt
sed -e '/_Filter/p' -e d < ./tst_filter.txt >./tst_filter2.txt sed -e '/_Filter/p' -e d < ./tst_filter.txt >./tst_filter2.txt
test ! -s tst_filter2.txt test ! -s tst_filter2.txt
@ -127,7 +127,7 @@ echo " *** Pass: -F none"
echo " *** Testing -F var,none " echo " *** Testing -F var,none "
rm -f ./tst_filter.txt ./tst_filter.nc rm -f ./tst_filter.txt ./tst_filter.nc
${NCCOPY} -F "/g/var,none" ./filtered.nc ./tst_filter.nc ${NCCOPY} -M0 -F "/g/var,none" ./filtered.nc ./tst_filter.nc
${NCDUMP} -s tst_filter.nc > ./tst_filter.txt ${NCDUMP} -s tst_filter.nc > ./tst_filter.txt
sed -e '/_Filter/p' -e d < ./tst_filter.txt >tst_filter2.txt sed -e '/_Filter/p' -e d < ./tst_filter.txt >tst_filter2.txt
test ! -s tst_filter2.txt test ! -s tst_filter2.txt

View File

@ -2133,6 +2133,8 @@ main(int argc, char**argv)
if(level >= 0) if(level >= 0)
nc_set_log_level(level); nc_set_log_level(level);
} }
#else
error("-L specified, but logging support not enabled");
#endif #endif
break; break;
case 'F': /* optional filter spec for a specified variable */ case 'F': /* optional filter spec for a specified variable */
@ -2154,8 +2156,12 @@ main(int argc, char**argv)
#else #else
error("-F requires netcdf-4"); error("-F requires netcdf-4");
#endif #endif
break;
case 'M': /* set min chunk size */ case 'M': /* set min chunk size */
#ifdef USE_NETCDF4 #ifdef USE_NETCDF4
if(optarg == NULL)
option_min_chunk_bytes = -1;
else
option_min_chunk_bytes = atol(optarg); option_min_chunk_bytes = atol(optarg);
if(option_min_chunk_bytes < 0) if(option_min_chunk_bytes < 0)
error("-M value must be non-negative integer"); error("-M value must be non-negative integer");

View File

@ -217,7 +217,7 @@ main(int argc, char **argv)
break; break;
case 'D': { case 'D': {
int c0; int c0;
if(strlen(optarg) == 0) usage("missing -D argument"); if(optarg == NULL || strlen(optarg) == 0) usage("missing -D argument");
c0 = optarg[0]; c0 = optarg[0];
if(c0 >= '0' && c0 <= '9') {/* debug level */ if(c0 >= '0' && c0 <= '9') {/* debug level */
ocopt.debug.debuglevel = atoi(optarg); break; ocopt.debug.debuglevel = atoi(optarg); break;
@ -245,6 +245,8 @@ main(int argc, char **argv)
case 'o': case 'o':
if(ocopt.output != NULL) fclose(ocopt.output); if(ocopt.output != NULL) fclose(ocopt.output);
if(optarg == NULL)
usage("-o does not specify a file name");
ocopt.output = fopen(optarg,"w"); ocopt.output = fopen(optarg,"w");
if(ocopt.output == NULL) if(ocopt.output == NULL)
usage("-o file not writeable"); usage("-o file not writeable");
@ -255,6 +257,8 @@ main(int argc, char **argv)
break; break;
case 'p': case 'p':
if(optarg == NULL)
usage("-p does not specify an argument");
if(strcasecmp(optarg,"das")==0) ocopt.optdas=1; if(strcasecmp(optarg,"das")==0) ocopt.optdas=1;
else if(strcasecmp(optarg,"dds")==0) ocopt.optdds=1; else if(strcasecmp(optarg,"dds")==0) ocopt.optdds=1;
else if(strcasecmp(optarg,"data")==0) ocopt.optdatadds=1; else if(strcasecmp(optarg,"data")==0) ocopt.optdatadds=1;
@ -280,7 +284,8 @@ main(int argc, char **argv)
if(ocopt.logging) { if(ocopt.logging) {
ncloginit(); ncloginit();
ncsetlogging(1); ncsetlogging(1);
nclogopen(NULL); if(!nclogopen(NULL))
fprintf(stderr,"Failed to open logging output\n");
} }
argc -= optind; argc -= optind;
@ -479,9 +484,6 @@ processdata(OCflags flags)
if(ocopt.optdatadds) { if(ocopt.optdatadds) {
ocstat = oc_fetch(link,ocopt.url->query,OCDATADDS,flags,&dataddsroot); ocstat = oc_fetch(link,ocopt.url->query,OCDATADDS,flags,&dataddsroot);
if(ocstat) { if(ocstat) {
if(ocopt.url->query)
fprintf(stderr,"Cannot read DATADDS: %s\n",ocopt.surl);
else
fprintf(stderr,"Cannot read DATADDS: %s\n",ocopt.surl); fprintf(stderr,"Cannot read DATADDS: %s\n",ocopt.surl);
exit(1); exit(1);
} }
@ -556,8 +558,8 @@ printdata_container(OClink link, OCdatanode datanode, NCbytes* buffer, int istop
pushstack(field); pushstack(field);
FAIL(printdata_indices(link,field,buffer,istoplevel)); FAIL(printdata_indices(link,field,buffer,istoplevel));
popstack(); popstack();
oc_data_free(link,field); if(oc_data_free(link,field) != OC_NOERR)
if(stat != OC_NOERR) break; break;
} }
return stat; return stat;
} }
@ -997,7 +999,7 @@ dumpdatanode(OClink link, OCdatanode datanode, size_t count, void* memory, NCbyt
OCtype atomtype; OCtype atomtype;
OCtype octype; OCtype octype;
NCbytes* path = NULL; NCbytes* path = NULL;
char* name; char* name = NULL;
char id[1024]; char id[1024];
char tmp[1024]; char tmp[1024];
struct DUMPPATH* entry = NULL; struct DUMPPATH* entry = NULL;

View File

@ -103,7 +103,7 @@ dap_unrecognizedresponse(DAPparsestate* state)
unsigned int httperr = 0; unsigned int httperr = 0;
int i; int i;
char iv[32]; char iv[32];
sscanf(state->lexstate->input,"%u ",&httperr); (void)sscanf(state->lexstate->input,"%u ",&httperr);
sprintf(iv,"%u",httperr); sprintf(iv,"%u",httperr);
state->lexstate->next = state->lexstate->input; state->lexstate->next = state->lexstate->input;
/* Limit the amount of input to prevent runaway */ /* Limit the amount of input to prevent runaway */