summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPedro Vicente Nunes <pvn@hdfgroup.org>2006-12-19 18:14:26 (GMT)
committerPedro Vicente Nunes <pvn@hdfgroup.org>2006-12-19 18:14:26 (GMT)
commitf2344833726caadaec1e26404549cb1d445c85cc (patch)
treee39f226c7eb0688202733146f793e5c1880d6ece
parentd4946be1f210ec189296c7e10167f2deffca87fc (diff)
downloadhdf5-f2344833726caadaec1e26404549cb1d445c85cc.zip
hdf5-f2344833726caadaec1e26404549cb1d445c85cc.tar.gz
hdf5-f2344833726caadaec1e26404549cb1d445c85cc.tar.bz2
[svn-r13076]
fix for bugzilla bug #551 several programming errors contributed to this bug 1) the parsing of subsetting was using atoi to convert the parameter to an int, which caused problems for numbers greater that int. Substitute with atof 2) several index counters were declared as int, use hsize_t instead 3) the numerical format passed for printf was %lu, defined one compatible with hsize_t instead (unsigned long long)
-rw-r--r--tools/h5dump/h5dump.c3
-rw-r--r--tools/lib/h5tools.h3
-rw-r--r--tools/lib/h5tools_str.c8
3 files changed, 10 insertions, 4 deletions
diff --git a/tools/h5dump/h5dump.c b/tools/h5dump/h5dump.c
index 97644bf..fbe7c75 100644
--- a/tools/h5dump/h5dump.c
+++ b/tools/h5dump/h5dump.c
@@ -96,6 +96,7 @@ static int xml_name_to_XID(const char *, char *, int , int );
static void init_prefix(char **prfx, size_t prfx_len);
static void add_prefix(char **prfx, size_t *prfx_len, const char *name);
+
static h5tool_format_t dataformat = {
0, /*raw */
@@ -2116,7 +2117,7 @@ dump_data(hid_t obj_id, int obj_data, struct subset_t *sset, int display_index)
outputformat->pindex=display_index;
if (outputformat->pindex) {
outputformat->idx_fmt = "(%s): ";
- outputformat->idx_n_fmt = "%lu";
+ outputformat->idx_n_fmt = HSIZE_T_FORMAT;
outputformat->idx_sep = ",";
outputformat->line_pre = "%s";
}
diff --git a/tools/lib/h5tools.h b/tools/lib/h5tools.h
index 70d8734..a86b9cd 100644
--- a/tools/lib/h5tools.h
+++ b/tools/lib/h5tools.h
@@ -46,6 +46,9 @@
*/
#define H5TOOLS_MALLOCSIZE ((size_t)1024 * 1024 * 1024)
+/* format for hsize_t */
+#define HSIZE_T_FORMAT "%"H5_PRINTF_LL_WIDTH"u"
+
/*
* Information about how to format output.
*/
diff --git a/tools/lib/h5tools_str.c b/tools/lib/h5tools_str.c
index 76bb81f..a1cfc83 100644
--- a/tools/lib/h5tools_str.c
+++ b/tools/lib/h5tools_str.c
@@ -28,6 +28,7 @@
#include "h5tools_ref.h"
#include "h5tools_str.h" /*function prototypes */
+
/*
* If REPEAT_VERBOSE is defined then character strings will be printed so
* that repeated character sequences like "AAAAAAAAAA" are displayed as
@@ -335,12 +336,13 @@ h5tools_str_prefix(h5tools_str_t *str/*in,out*/, const h5tool_format_t *info,
if (i)
h5tools_str_append(str, "%s", OPT(info->idx_sep, ","));
- h5tools_str_append(str, OPT(info->idx_n_fmt, "%lu"),
- (unsigned long)ctx->pos[i]);
+ h5tools_str_append(str, OPT(info->idx_n_fmt, HSIZE_T_FORMAT),
+ (hsize_t)ctx->pos[i]);
+
}
} else {
/* Scalar */
- h5tools_str_append(str, OPT(info->idx_n_fmt, "%lu"), (unsigned long)0);
+ h5tools_str_append(str, OPT(info->idx_n_fmt, HSIZE_T_FORMAT), (hsize_t)0);
}
/* Add prefix and suffix to the index */