netcdf-c/dap4_test/dump.c
Dennis Heimbigner d1d2808919 Additional DAP4 fixes
This change-set modifies PR https://github.com/Unidata/netcdf-c/pull/2555
to add the changes listed below. Most of these changes are required
by changes to the Java remotetest.unidata.ucar.edu server.

## DAP4 Related Changes
* Add tests *dap4_test/test_constraints.sh* and *dap4_test/test_hyrax.sh*.
* Provide explicit list of remotetest files to test.
* Cleanup local checksum computing and verification.
* Define a temporary Hyrax hack flag to deal with the way Hyrax handles checksums and add "#hyrax" fragment flag for it.
* Add a hack to get past an LGTM problem with using "http:".
* Improve debug support.

## Other Changes
* Cleanup the recipe in *docs/nczarr.md* for building *aws-sdk-cpp* library.
2023-01-18 19:47:29 -07:00

97 lines
2.1 KiB
C

/*********************************************************************
* Copyright 2018, UCAR/Unidata
* See netcdf/COPYRIGHT file for copying and redistribution conditions.
* $Header: /upc/share/CVS/netcdf-3/ncgen3/main.c,v 1.20 2010/03/31 18:18:40 dmh Exp $
*********************************************************************/
#include "config.h"
#include <stdio.h>
#include <stdlib.h>
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
#include <string.h>
#ifdef HAVE_GETOPT_H
#include <getopt.h>
#endif
#if defined(_WIN32) && !defined(__MINGW32__)
#include "XGetopt.h"
#endif
#include "netcdf.h"
#include "netcdf_aux.h"
#include "ncbytes.h"
#include "ncpathmgr.h"
extern void NCD4_dumpbytes(size_t size, const void* data0, int swap);
extern void NCD4_tagdump(size_t size, const void* data0, int swap, const char* tag);
static char* progname = NULL;
static void
usage(void)
{
fprintf(stderr,"Usage: %s [ -O ][ -f infile | file ]",progname);
exit(1);
}
int
main(int argc, char *argv[])
{
int c;
char* fname = NULL;
char* tag = NULL;
size_t offset = 0;
size_t len = 0;
char* data0 = NULL;
char* data = NULL;
int swap = 0;
progname = strdup(argv[0]);
while ((c = getopt(argc, argv, "SO:f:t:")) != EOF) {
switch(c) {
case 'f':
fname = strdup(optarg);
break;
case 't':
tag = strdup(optarg);
break;
case 'S':
swap = 1;
break;
case 'O':
offset = atol(optarg);
break;
case '?':
usage();
}
}
argc -= optind;
argv += optind;
if(fname == NULL) {
if (argc > 1) {
fprintf(stderr,"%s: only one input file argument permitted",progname);
return(1);
}
fname = strdup(argv[0]);
}
if(tag == NULL) tag = strdup(progname);
if(ncaux_readfile(fname,&len,(void**)&data0)) usage();
if(offset >= len) {
fprintf(stderr,"Offset too large: file length = %u\n",(unsigned)len);
return 1;
}
data = data0 + offset;
NCD4_tagdump(len,data,swap,tag);
nullfree(data0);
nullfree(fname);
nullfree(tag);
return 0;
}