/* * Copyright (C) 1998 NCSA * All rights reserved. * * Programmer: Robb Matzke * Monday, March 23, 1998 */ #include #include #include #include #include #include #include #ifndef HAVE_ATTRIBUTE # undef __attribute__ # define __attribute__(X) /*void*/ # define __unused__ /*void*/ #else # define __unused__ __attribute__((unused)) #endif /* Command-line switches */ static int verbose_g = 0; static int dump_g = 0; static int width_g = 80; /*------------------------------------------------------------------------- * Function: usage * * Purpose: Prints a usage message on stderr and then returns. * * Return: void * * Programmer: Robb Matzke * Thursday, July 16, 1998 * * Modifications: * *------------------------------------------------------------------------- */ static void usage (const char *progname) { fprintf(stderr, "\ usage: %s [OPTIONS] FILE [GROUP]\n\ OPTIONS\n\ -h, -?, --help Print a usage message and exit\n\ -d, --dump Print the values of datasets\n\ -wN, --width=N Set the number of columns of output\n\ -v, --verbose Generate more verbose output\n\ -V, --version Print version number and exit\n\ FILE\n\ The file name may include a printf(3C) integer format such as\n\ \"%%05d\" to open a file family.\n\ GROUP\n\ If a group name is not specified then the contents of the root group\n\ \"/\" are displayed.\n", progname); } /*------------------------------------------------------------------------- * Function: dump_dataset_values * * Purpose: Prints all values of a dataset. * * Return: void * * Programmer: Robb Matzke * Tuesday, July 21, 1998 * * Modifications: * *------------------------------------------------------------------------- */ static void dump_dataset_values(hid_t dset) { hid_t f_type, m_type=-1; h5dump_t info; size_t size; /* Set to all default values and then override */ memset(&info, 0, sizeof info); info.idx_fmt = " (%s) "; info.line_ncols = width_g; /* * Decide which data type to use for printing the values and make any * necessary adjustments to the way the values will be formatted. */ f_type = H5Dget_type(dset); size = H5Tget_size(f_type); switch (H5Tget_class(f_type)) { case H5T_INTEGER: if (1==size) { /* * Assume that the dataset is being used to hold character values * and print the values as strings. */ info.elmt_suf1 = ""; info.elmt_suf2 = ""; info.idx_fmt = " (%s) \""; info.line_suf = "\""; } /* * For printing use an integer which is the same width and sign as * the file but in native byte order. */ m_type = H5Tcopy(H5T_NATIVE_INT); H5Tset_offset(m_type, 0); H5Tset_precision(m_type, size*8); H5Tset_size(m_type, size); H5Tset_sign(m_type, H5Tget_sign(f_type)); break; case H5T_FLOAT: if (size==sizeof(float)) { m_type = H5Tcopy(H5T_NATIVE_FLOAT); } else { m_type = H5Tcopy(H5T_NATIVE_DOUBLE); } break; case H5T_COMPOUND: printf(" Data: printing of compound data types is not implemented " "yet\n"); break; default: /*unable to print*/ printf(" Data: [unable to print]\n"); break; } H5Tclose(f_type); if (m_type<0) return; /*not printable*/ /* * Print all the values. */ printf(" Data:\n"); h5dump(stdout, &info, dset, m_type); H5Tclose(m_type); } /*------------------------------------------------------------------------- * Function: list_attr * * Purpose: Prints information about attributes. * * Return: Success: 0 * * Failure: -1 * * Programmer: Robb Matzke * Friday, June 5, 1998 * * Modifications: * *------------------------------------------------------------------------- */ static herr_t list_attr (hid_t obj, const char *attr_name, void __unused__ *op_data) { hid_t attr; int i; printf ("%*s%s", 26, "", attr_name); if ((attr = H5Aopen_name (obj, attr_name))) { hid_t space = H5Aget_space (attr); hsize_t size[64]; int ndims = H5Sextent_dims (space, size, NULL); H5Sclose (space); printf (" {"); for (i=0; i=0) { sprintf (buf, "%lu:%lu:%lu:%lu", statbuf.fileno[1], statbuf.fileno[0], statbuf.objno[1], statbuf.objno[0]); printf ("%-20s ", buf); } if ((obj=H5Dopen (group, name))>=0) { hsize_t size[64]; hsize_t maxsize[64]; hid_t space = H5Dget_space (obj); int ndims = H5Sextent_dims(space, size, maxsize); printf ("Dataset {"); for (i=0; i0) { HDfprintf(stdout, "/%Hu", maxsize[i]); } } printf ("}\n"); H5Dclose (space); H5Aiterate (obj, NULL, list_attr, NULL); if (dump_g) dump_dataset_values(obj); H5Dclose (obj); } else if ((obj=H5Gopen (group, name))>=0) { printf ("Group\n"); H5Aiterate (obj, NULL, list_attr, NULL); H5Gclose (obj); } else if (H5Gget_linkval (group, name, sizeof(buf), buf)>=0) { if (NULL==HDmemchr (buf, 0, sizeof(buf))) { strcpy (buf+sizeof(buf)-4, "..."); } printf (" -> %s\n", buf); } else if ((obj=H5Topen (group, name))>=0) { printf ("Data type\n"); H5Aiterate (obj, NULL, list_attr, NULL); H5Tclose (obj); } else { printf ("Unknown Type\n"); } /* Display the comment if the object has one */ comment[0] = '\0'; H5Gget_comment(group, name, sizeof(comment), comment); strcpy(comment+sizeof(comment)-4, "..."); if (comment[0]) printf("%26s%s\n", "", comment); /* Restore error reporting */ H5Eset_auto (func, edata); return 0; } /*------------------------------------------------------------------------- * Function: main * * Purpose: Opens a file and lists the specified group * * Return: Success: 0 * * Failure: 1 * * Programmer: Robb Matzke * Monday, March 23, 1998 * * Modifications: * *------------------------------------------------------------------------- */ int main (int argc, char *argv[]) { hid_t file, plist=H5P_DEFAULT; const char *fname = NULL; const char *gname = "/"; const char *progname; const char *s; char *rest; int argno; /* Name of this program without the path */ if ((progname=strrchr (argv[0], '/'))) progname++; else progname = argv[0]; /* Switches come before non-switch arguments */ for (argno=1; argno=argc) { usage(progname); exit(1); } else { s = argv[++argno]; } width_g = strtol(s, &rest, 0); if (width_g<=0 || *rest) { usage(progname); exit(1); } } else if ('-'!=argv[argno][1]) { /* Single-letter switches */ for (s=argv[argno]+1; *s; s++) { switch (*s) { case '?': case 'h': /* --help */ usage(progname); exit(0); case 'd': /* --dump */ dump_g++; break; case 'v': /* --verbose */ verbose_g++; break; case 'V': /* --version */ printf("This is %s version %u.%u release %u\n", progname, H5_VERS_MAJOR, H5_VERS_MINOR, H5_VERS_RELEASE); exit(0); default: usage(progname); exit(1); } } } else { usage(progname); exit(1); } } /* Non-switch arguments */ if (argno