diff options
Diffstat (limited to 'tools/h5dump/h5dump.c')
-rw-r--r-- | tools/h5dump/h5dump.c | 165 |
1 files changed, 92 insertions, 73 deletions
diff --git a/tools/h5dump/h5dump.c b/tools/h5dump/h5dump.c index 5f76c16..163bad8 100644 --- a/tools/h5dump/h5dump.c +++ b/tools/h5dump/h5dump.c @@ -54,8 +54,10 @@ static int display_dcpl = FALSE; /*dcpl */ static int display_fi = FALSE; /*file index */ static int display_ai = TRUE; /*array index */ static int display_escape = FALSE; /*escape non printable characters */ - - +static int display_dsets = TRUE; /*display datasets */ +static int display_groups = TRUE; /*display groups */ +static int display_dtypes = TRUE; /*display named datatypes */ +static int display_links = TRUE; /*display soft links */ /** ** Added for XML ** @@ -341,7 +343,7 @@ struct handler_t { * parameters. The long-named ones can be partially spelled. When * adding more, make sure that they don't clash with each other. */ -static const char *s_opts = "hnpeyBHirVa:c:d:f:g:k:l:t:w:xD:uX:o:s:S:A"; +static const char *s_opts = "hnpeyBHLGTEirVa:c:d:f:g:k:l:t:w:xD:uX:o:s:S:A"; static struct long_options l_opts[] = { { "help", no_arg, 'h' }, { "hel", no_arg, 'h' }, @@ -592,6 +594,10 @@ usage(const char *prog) fprintf(stdout, " -o F, --output=F Output raw data into file F\n"); fprintf(stdout, " -t P, --datatype=P Print the specified named data type\n"); fprintf(stdout, " -w N, --width=N Set the number of columns of output\n"); + fprintf(stdout, " -L Do not print soft links\n"); + fprintf(stdout, " -G Do not print groups\n"); + fprintf(stdout, " -T Do not print named datatypes\n"); + fprintf(stdout, " -E Do not print datasets\n"); fprintf(stdout, " -x, --xml Output in XML using Schema\n"); fprintf(stdout, " -u, --use-dtd Output in XML using DTD\n"); fprintf(stdout, " -D U, --xml-dtd=U Use the DTD or schema at U\n"); @@ -1308,6 +1314,7 @@ dump_all(hid_t group, const char *name, void * op_data) switch (statbuf.type) { case H5G_LINK: + if (display_links) { indentation(indent); targbuf = malloc(statbuf.linklen); @@ -1396,9 +1403,11 @@ dump_all(hid_t group, const char *name, void * op_data) } free(targbuf); + } break; case H5G_GROUP: + if (display_groups) { if ((obj = H5Gopen(group, name)) < 0) { error_msg(progname, "unable to dump group \"%s\"\n", name); d_status = EXIT_FAILURE; @@ -1417,9 +1426,11 @@ dump_all(hid_t group, const char *name, void * op_data) H5Gclose(obj); } + } break; case H5G_DATASET: + if (display_dsets) { if ((obj = H5Dopen(group, name)) >= 0) { /* hard link */ H5Gget_objinfo(obj, ".", TRUE, &statbuf); @@ -1513,10 +1524,11 @@ dump_all(hid_t group, const char *name, void * op_data) d_status = EXIT_FAILURE; ret = FAIL; } - + } break; case H5G_TYPE: + if (display_dtypes) { if ((obj = H5Topen(group, name)) < 0) { error_msg(progname, "unable to dump data type \"%s\"\n", name); d_status = EXIT_FAILURE; @@ -1525,7 +1537,7 @@ dump_all(hid_t group, const char *name, void * op_data) dump_function_table->dump_named_datatype_function(obj, name); H5Tclose(obj); } - + } break; default: @@ -1941,7 +1953,7 @@ dump_data(hid_t obj_id, int obj_data, struct subset_t *sset, int pindex) outputformat->pindex=pindex; if (outputformat->pindex) { - outputformat->idx_fmt = "(%s)"; + outputformat->idx_fmt = "(%s),"; outputformat->idx_n_fmt = "%lu"; outputformat->idx_sep = ","; outputformat->line_pre = " %s "; @@ -2102,8 +2114,6 @@ static void dump_fill_value(hid_t dcpl,hid_t type_id, hid_t obj_id) * * Programmer: pvn * - * Modifications: - * *------------------------------------------------------------------------- */ static void @@ -2134,7 +2144,6 @@ dump_dcpl(hid_t dcpl_id,hid_t type_id, hid_t obj_id) ioffset=H5Dget_offset(obj_id); next=H5Pget_external_count(dcpl_id); strcpy(f_name,"\0"); - /*------------------------------------------------------------------------- * STORAGE_LAYOUT @@ -2204,7 +2213,6 @@ dump_dcpl(hid_t dcpl_id,hid_t type_id, hid_t obj_id) indentation(indent + COL); printf("%s\n",END); } - else { /*start indent */ @@ -2226,13 +2234,13 @@ dump_dcpl(hid_t dcpl_id,hid_t type_id, hid_t obj_id) *------------------------------------------------------------------------- */ nfilters = H5Pget_nfilters(dcpl_id); + + indentation(indent + COL); + printf("%s %s\n", FILTERS, BEGIN); + indent += COL; + if (nfilters) { - - indentation(indent + COL); - printf("%s %s\n", FILTERS, BEGIN); - indent += COL; - for (i=0; i<nfilters; i++) { cd_nelmts = NELMTS(cd_values); @@ -2267,7 +2275,6 @@ dump_dcpl(hid_t dcpl_id,hid_t type_id, hid_t obj_id) printf("%s %s\n",SZIP, BEGIN); /*start indent */ - indent += COL; indentation(indent + COL); printf("PIXELS_PER_BLOCK %d\n", szip_pixels_per_block); @@ -2295,7 +2302,6 @@ dump_dcpl(hid_t dcpl_id,hid_t type_id, hid_t obj_id) printf("HEADER %s\n", "RAW"); /*end indent */ - indent -= COL; indentation(indent + COL); printf("%s\n",END); @@ -2326,71 +2332,50 @@ dump_dcpl(hid_t dcpl_id,hid_t type_id, hid_t obj_id) break; }/*switch*/ } /*i*/ - - indent -= COL; - indentation(indent + COL); - printf("%s\n",END); }/*nfilters*/ + else + { + indentation(indent + COL); + printf("NONE\n"); + } + indent -= COL; + indentation(indent + COL); + printf("%s\n",END); /*------------------------------------------------------------------------- * FILLVALUE *------------------------------------------------------------------------- */ - indentation(indent + COL); printf("%s %s\n", FILLVALUE, BEGIN); - /*start indent */ indent += COL; - indentation(indent + COL); printf("FILL_TIME "); - H5Pget_fill_time(dcpl_id, &ft); switch ( ft ) { case H5D_FILL_TIME_ALLOC: - printf("%s", "ALLOC\n"); + printf("%s", "H5D_FILL_TIME_ALLOC\n"); break; case H5D_FILL_TIME_NEVER: - printf("%s", "NEVER\n"); + printf("%s", "H5D_FILL_TIME_NEVER\n"); break; case H5D_FILL_TIME_IFSET: - printf("%s", "IFSET\n"); - break; - } - - indentation(indent + COL); - printf("%s", "ALLOC_TIME "); - H5Pget_alloc_time(dcpl_id, &at); - - switch (at) - { - case H5D_ALLOC_TIME_EARLY: - printf("%s", "EARLY\n"); - break; - case H5D_ALLOC_TIME_INCR: - printf("%s", "INCR\n"); - break; - case H5D_ALLOC_TIME_LATE: - printf("%s", "LATE\n"); + printf("%s", "H5D_FILL_TIME_IFSET\n"); break; } - indentation(indent + COL); printf("%s ", "VALUE "); - H5Pfill_value_defined(dcpl_id, &fvstatus); - if (fvstatus == H5D_FILL_VALUE_UNDEFINED) { - printf("%s\n", "UNDEFINED"); + printf("%s\n", "H5D_FILL_VALUE_UNDEFINED"); } else { dump_fill_value(dcpl_id,type_id,obj_id); } - /* end indent */ indent -= COL; indentation(indent + COL); @@ -2398,6 +2383,33 @@ dump_dcpl(hid_t dcpl_id,hid_t type_id, hid_t obj_id) indentation(indent + COL); printf("%s\n",END); +/*------------------------------------------------------------------------- + * ALLOCATION_TIME + *------------------------------------------------------------------------- + */ + indentation(indent + COL); + printf("ALLOCATION_TIME %s\n",BEGIN); + /*start indent */ + indent += COL; + indentation(indent + COL); + H5Pget_alloc_time(dcpl_id, &at); + switch (at) + { + case H5D_ALLOC_TIME_EARLY: + printf("%s", "H5D_ALLOC_TIME_EARLY\n"); + break; + case H5D_ALLOC_TIME_INCR: + printf("%s", "H5D_ALLOC_TIME_INCR\n"); + break; + case H5D_ALLOC_TIME_LATE: + printf("%s", "H5D_ALLOC_TIME_LATE\n"); + break; + } + /* end indent */ + indent -= COL; + indentation(indent + COL); + printf("%s\n",END); + } /*------------------------------------------------------------------------- @@ -2453,7 +2465,11 @@ dump_fcpl(hid_t fid) fapl=h5_fileaccess(); fdriver=H5Pget_driver(fapl); H5Pclose(fapl); - + +/*------------------------------------------------------------------------- + * SUPER_BLOCK + *------------------------------------------------------------------------- + */ printf("%s %s\n",SUPER_BLOCK, BEGIN); indentation(indent + COL); printf("%s %d\n","SUPERBLOCK_VERSION", super); @@ -2464,8 +2480,6 @@ dump_fcpl(hid_t fid) indentation(indent + COL); printf("%s %d\n","OBJECTHEADER_VERSION", (int)shhdr); indentation(indent + COL); - HDfprintf(stdout,"%s %Hu\n","USERBLOCK_VERSION", userblock); - indentation(indent + COL); HDfprintf(stdout,"%s %Hd\n","OFFSET_SIZE", (long_long)off_size); indentation(indent + COL); HDfprintf(stdout,"%s %Hd\n","LENGTH_SIZE", (long_long)len_size); @@ -2517,7 +2531,15 @@ dump_fcpl(hid_t fid) printf("%s %s\n","FILE_DRIVER", dname); indentation(indent + COL); printf("%s %d\n","ISTORE_K", istore_ik); - + printf("%s\n",END); + +/*------------------------------------------------------------------------- + * USER_BLOCK + *------------------------------------------------------------------------- + */ + printf("USER_BLOCK %s\n",BEGIN); + indentation(indent + COL); + HDfprintf(stdout,"%s %Hu\n","USERBLOCK_SIZE", userblock); printf("%s\n",END); } @@ -2534,30 +2556,20 @@ dump_fcpl(hid_t fid) * *------------------------------------------------------------------------- */ - static void dump_list(hid_t fid) { - int nobjects; - trav_info_t *info=NULL; - - /* get the number of objects in the files */ - nobjects = h5trav_getinfo(fid, NULL); + printf("%s %s\n",FILE_CONTENTS, BEGIN); - /* get the list of objects in the files */ - info = (trav_info_t*) malloc( nobjects * sizeof(trav_info_t)); - if (info==NULL) - return; + /* print objects in the files */ + h5trav_getinfo(fid, NULL, 1); - h5trav_getinfo(fid, info); - printf("%s %s\n",FILE_CONTENTS, BEGIN); - h5trav_printinfo(nobjects,info); printf(" %s\n",END); - h5trav_freeinfo(info,nobjects); } + /*------------------------------------------------------------------------- * Function: set_output_file * @@ -3042,11 +3054,6 @@ parse_command_line(int argc, const char *argv[]) while ((opt = get_option(argc, argv, s_opts, l_opts)) != EOF) { parse_start: switch ((char)opt) { -#if 0 - case 'b': - /* binary output */ - break; -#endif /* 0 */ case 'B': display_bb = TRUE; last_was_dset = FALSE; @@ -3064,6 +3071,18 @@ parse_start: case 'e': display_escape = TRUE; break; + case 'L': + display_links = FALSE; + break; + case 'G': + display_groups = FALSE; + break; + case 'T': + display_dtypes = FALSE; + break; + case 'E': + display_dsets = FALSE; + break; case 'H': display_data = FALSE; display_attr_data = FALSE; |