summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tools/h5tools.c232
1 files changed, 225 insertions, 7 deletions
diff --git a/tools/h5tools.c b/tools/h5tools.c
index fd35088..7b14edc 100644
--- a/tools/h5tools.c
+++ b/tools/h5tools.c
@@ -37,7 +37,12 @@ static void display_string(hsize_t hs_nelmts, hid_t p_type,
static void display_compound_data(hsize_t hs_nelmts, hid_t p_type,
unsigned char *sm_buf, size_t p_type_nbytes,
hsize_t p_nelmts, hsize_t elmtno);
-
+#if 0
+static void display_reference_data(hsize_t hs_nelmts, hid_t p_type,
+ unsigned char *sm_buf, size_t p_type_nbytes,
+ hsize_t p_nelmts, hsize_t dim_n_size,
+ hsize_t elmtno, hid_t container);
+#endif
int h5dump_attr(hid_t oid, hid_t ptype);
/*
* If REPEAT_VERBOSE is defined then character strings will be printed so
@@ -1308,6 +1313,9 @@ h5dump_simple_dset(FILE *stream, const h5dump_t *info, hid_t dset,
case H5T_REFERENCE:
display_numeric_data(hs_nelmts, p_type, sm_buf, p_type_nbytes,
p_nelmts, dim_n_size, elmtno, dset);
+
+/* display_reference_data(hs_nelmts, p_type, sm_buf, p_type_nbytes,
+ p_nelmts, dim_n_size, elmtno, dset);*/
default:
break;
}
@@ -1737,6 +1745,11 @@ hsize_t i;
char* out_buf = malloc(sizeof(char) * nCols);
struct h5dump_str_t tempstr;
int x;
+hbool_t isref = FALSE;
+int totalspace;
+hbool_t done;
+int temp;
+
/******************************************************************************************/
h5dump_t info;
@@ -1756,7 +1769,12 @@ int x;
/*********************************************************************************************/
+ /* i added this too*/
+ if (H5Tequal(p_type, H5T_STD_REF_DSETREG)) {
+ isref = TRUE;
+ }
+
out_buf[0] = '\0';
if ((indent+COL) > nCols) indent = 0;
memset(&tempstr, 0, sizeof(h5dump_str_t));
@@ -1764,15 +1782,30 @@ int x;
for (i=0; i<hs_nelmts && (elmtno+i) < p_nelmts; i++) {
h5dump_str_reset(&tempstr);
h5dump_sprint(&tempstr, &info, container, p_type, sm_buf+i*p_type_nbytes);
- for (x = 0; x <tempstr.len; x++){
- /* removes the strange characters */
- if (tempstr.s[x] == 1){
- memmove(tempstr.s+x, tempstr.s+(x+1), strlen(tempstr.s+x));
- tempstr.len --;
- }
+ if (isref) {
+ for (x = 0; x <tempstr.len; x++){
+ /* removes the strange characters */
+ if (tempstr.s[x] == 1){
+ memmove(tempstr.s+x, tempstr.s+(x+1), strlen(tempstr.s+x));
+ tempstr.len --;
+ }
+ }
}
+ totalspace = nCols - indent - COL;
+
if ((int)(strlen(out_buf)+tempstr.len+1) > (nCols-indent-COL)) {
+ if (isref){
+ /* i added this */
+ temp = strlen(out_buf);
+ if ((strlen(out_buf) + 7) < (totalspace)){ /* 7 for the word dataset */
+ memcpy(out_buf+strlen(out_buf), tempstr.s, totalspace - strlen(out_buf));
+ out_buf[totalspace] = '\0';
+ memmove(tempstr.s, tempstr.s+(totalspace - temp), tempstr.len - (totalspace - temp));
+ tempstr.s[tempstr.len - totalspace + temp] = '\0';
+ tempstr.len = strlen(tempstr.s);
+ }
+ }
/* first row of member */
if (compound_data && (elmtno+i+1) == dim_n_size)
printf("%s\n", out_buf);
@@ -1781,6 +1814,28 @@ int x;
printf("%s\n", out_buf);
}
strcpy(out_buf, tempstr.s);
+
+ /* i added this too*/
+ if (isref) {
+ done = FALSE;
+ while (!done) {
+ if (tempstr.len > totalspace) {
+ /* keep printing until we can fit in the totalspace */
+ memmove(out_buf,tempstr.s, totalspace);
+ out_buf[totalspace] = '\0';
+ memmove(tempstr.s,tempstr.s+totalspace, strlen(tempstr.s + totalspace));
+ tempstr.s[tempstr.len - totalspace] = '\0';
+ tempstr.len = strlen(tempstr.s);
+ indentation(indent+COL);
+ printf(out_buf);
+
+ } else {
+ strcpy(out_buf, tempstr.s);
+ done = TRUE;
+ }
+ }
+ }
+
if ((elmtno+i+1) % dim_n_size)
strcat(out_buf, ", ");
else { /* end of a row, flush out_buf */
@@ -1829,7 +1884,9 @@ int x;
}
}
}
+#if !defined (WIN32) && !defined (_DEBUG)
free(out_buf);
+#endif
}
@@ -2520,10 +2577,171 @@ int h5dump_attr(hid_t oid, hid_t p_type){
case H5T_REFERENCE:
display_numeric_data(nelmts, p_type, sm_buf, p_type_nbytes,
nelmts, dim_n_size, 0, oid);
+
+/* display_reference_data(nelmts, p_type, sm_buf, p_type_nbytes,
+ nelmts, dim_n_size, 0, oid);*/
break;
default: break;
}
free(sm_buf);
return (status);
}
+#if 0
+
+/*-------------------------------------------------------------------------
+ * Function: display_numeric_data
+ *
+ * Purpose: Display numeric data in ddl format.
+ *
+ * Return: void
+ *
+ * Comment: hs_nelmts number of elements to be printed
+ * p_type memory data type
+ * sm_buf data buffer
+ * p_type_nbytes size of p_type
+ * p_nelmts total number of elements
+ * dim_n_size size of dimemsion n
+ * elmtno element index
+ *
+ *-------------------------------------------------------------------------
+ */
+static void display_reference_data
+(hsize_t hs_nelmts, hid_t p_type, unsigned char *sm_buf, size_t p_type_nbytes,
+ hsize_t p_nelmts, hsize_t dim_n_size, hsize_t elmtno, hid_t container) {
+
+hsize_t i;
+/*char p_buf[256]; */
+char* out_buf = malloc(sizeof(char) * nCols);
+struct h5dump_str_t tempstr;
+int x;
+int totalspace;
+hbool_t done;
+int temp;
+
+/******************************************************************************************/
+ h5dump_t info;
+
+ /* Set to all default values and then override */
+ memset(&info, 0, sizeof info);
+ info.idx_fmt = "(%s)";
+ info.line_ncols = nCols;
+ info.line_multi_new = 1;
+
+ /*
+ * If a compound datatype is split across multiple lines then add an
+ * ellipsis to the beginning of the continuation line.
+ */
+ info.line_pre = " %s ";
+ info.line_cont = " %s ";
+/*********************************************************************************************/
+
+
+ out_buf[0] = '\0';
+ if ((indent+COL) > nCols) indent = 0;
+ memset(&tempstr, 0, sizeof(h5dump_str_t));
+
+ for (i=0; i<hs_nelmts && (elmtno+i) < p_nelmts; i++) {
+ h5dump_str_reset(&tempstr);
+ h5dump_sprint(&tempstr, &info, container, p_type, sm_buf+i*p_type_nbytes);
+ for (x = 0; x <tempstr.len; x++){
+ /* removes the strange characters */
+ if (tempstr.s[x] == 1){
+ memmove(tempstr.s+x, tempstr.s+(x+1), strlen(tempstr.s+x));
+ tempstr.len --;
+ }
+
+ }
+ totalspace = nCols - indent - COL;
+
+ if ((int)(strlen(out_buf)+tempstr.len+1) > (totalspace)) {
+ /* first row of member */
+
+ /* i added this */
+ temp = strlen(out_buf);
+ if ((strlen(out_buf) + 7) < (totalspace)){ /* 7 for the word dataset */
+ memcpy(out_buf+strlen(out_buf), tempstr.s, totalspace - strlen(out_buf));
+ out_buf[totalspace] = '\0';
+ memmove(tempstr.s, tempstr.s+(totalspace - temp), tempstr.len - (totalspace - temp));
+ tempstr.s[tempstr.len - totalspace + temp] = '\0';
+ tempstr.len = strlen(tempstr.s);
+ }
+ /* first row of member */
+ if (compound_data && (elmtno+i+1) == dim_n_size)
+ printf("%s\n", out_buf);
+ else {
+ indentation(indent+COL);
+ printf("%s\n", out_buf);
+ }
+ strcpy(out_buf, tempstr.s);
+
+ /* i added this too*/
+ done = FALSE;
+ while (!done) {
+ if (tempstr.len > totalspace) {
+ /* keep printing until we can fit in the totalspace */
+ memmove(out_buf,tempstr.s, totalspace);
+ out_buf[totalspace] = '\0';
+ memmove(tempstr.s,tempstr.s+totalspace, strlen(tempstr.s + totalspace));
+ tempstr.s[tempstr.len - totalspace] = '\0';
+ tempstr.len = strlen(tempstr.s);
+ indentation(indent+COL);
+ printf(out_buf);
+
+ } else {
+ strcpy(out_buf, tempstr.s);
+ done = TRUE;
+ }
+ }
+
+ if ((elmtno+i+1) % dim_n_size)
+ strcat(out_buf, ", ");
+ else { /* end of a row, flush out_buf */
+ indentation(indent+COL);
+ printf("%s", out_buf);
+ if ((elmtno+i+1) != p_nelmts) /* not last element */
+ printf(",\n");
+ else if (compound_data) { /* last element of member data*/
+ if ((nCols-strlen(out_buf)-indent-COL) < 2) {
+ /* 2 for space and ] */
+ printf("\n");
+ indentation(indent+COL-3);
+ }
+ } else
+ printf("\n"); /* last row */
+ *out_buf = '\0';
+ }
+ } else {
+ strcat(out_buf, tempstr.s);
+ if ((elmtno+i+1) % dim_n_size) {
+ if ((nCols-strlen(out_buf)-indent-COL-1) > 0)
+ strcat(out_buf, ", ");
+ else
+ strcat(out_buf, ",");
+ } else { /* end of a row */
+ /* 1st row of member data */
+ if (compound_data && (elmtno+i+1) == dim_n_size)
+ printf("%s", out_buf);
+ else {
+ indentation(indent+COL);
+ printf("%s", out_buf);
+ }
+
+ /* if it's the last element */
+ if ((elmtno+i+1) != p_nelmts)
+ printf(",\n");
+ else if (compound_data) { /* last row of member data*/
+ /* 2 for space and ] */
+ if ((nCols-strlen(out_buf)-indent-COL) < 2) {
+ printf("\n");
+ indentation(indent+COL-3);
+ }
+ } else
+ printf("\n"); /* last row */
+ *out_buf = '\0';
+ }
+ }
+ }
+ free(out_buf);
+}
+#endif