summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAllen Byrne <byrn@hdfgroup.org>2018-06-29 14:40:34 (GMT)
committerAllen Byrne <byrn@hdfgroup.org>2018-06-29 14:40:34 (GMT)
commitb1f5c9e9d63e16d67089f08ef2becc5119592a76 (patch)
tree4a726f9c7af3d4460a79444ccc4bdabe6698b264
parent2f53075ea9bb1079c8eaebbaa51c058c5107f8b2 (diff)
downloadhdf5-b1f5c9e9d63e16d67089f08ef2becc5119592a76.zip
hdf5-b1f5c9e9d63e16d67089f08ef2becc5119592a76.tar.gz
hdf5-b1f5c9e9d63e16d67089f08ef2becc5119592a76.tar.bz2
Fix ptr arith
-rw-r--r--java/src/jni/h5dImp.c2
-rw-r--r--java/src/jni/h5util.c85
2 files changed, 39 insertions, 48 deletions
diff --git a/java/src/jni/h5dImp.c b/java/src/jni/h5dImp.c
index 6d4d8f1..cea6bb4 100644
--- a/java/src/jni/h5dImp.c
+++ b/java/src/jni/h5dImp.c
@@ -1470,7 +1470,7 @@ H5DwriteVL_str
wdata = (char**)HDmalloc((size_t)size * sizeof (char*));
if (!wdata) {
- h5JNIFatalError(env, "H5DwriteVL_string: cannot allocate buffer");
+ h5JNIFatalError(env, "H5DwriteVL_str: cannot allocate buffer");
} /* end if */
else {
HDmemset(wdata, 0, (size_t)size * sizeof(char*));
diff --git a/java/src/jni/h5util.c b/java/src/jni/h5util.c
index 5905a1a..33dca7f 100644
--- a/java/src/jni/h5util.c
+++ b/java/src/jni/h5util.c
@@ -323,16 +323,15 @@ h5str_convert
switch (tclass) {
case H5T_FLOAT:
+ token = HDstrtok (this_str, delimiter);
if (sizeof(float) == size) {
/* if (H5Tequal(tid, H5T_NATIVE_FLOAT)) */
- token = HDstrtok (this_str, delimiter);
tmp_float = 0;
sscanf(token, "%f", &tmp_float);
HDmemcpy(cptr, &tmp_float, sizeof(float));
}
else if (sizeof(double) == size) {
/* if (H5Tequal(tid, H5T_NATIVE_DOUBLE)) */
- token = HDstrtok (this_str, delimiter);
tmp_double = 0;
sscanf(token, "%%lf", &tmp_double);
HDmemcpy(cptr, &tmp_double, sizeof(double));
@@ -340,7 +339,6 @@ h5str_convert
#if H5_SIZEOF_LONG_DOUBLE !=0
else if (sizeof(long double) == size) {
/* if (H5Tequal(tid, H5T_NATIVE_LDOUBLE)) */
- token = HDstrtok (this_str, delimiter);
tmp_ldouble = 0;
sscanf(token, "%Lf", &tmp_ldouble);
HDmemcpy(cptr, &tmp_ldouble, sizeof(long double));
@@ -358,17 +356,16 @@ h5str_convert
}
break;
case H5T_INTEGER:
+ token = HDstrtok (this_str, delimiter);
if (sizeof(char) == size) {
if(H5T_SGN_NONE == nsign) {
/* if (H5Tequal(tid, H5T_NATIVE_UCHAR)) */
- token = HDstrtok (this_str, delimiter);
tmp_uchar = 0;
sscanf(token, "%hu", &tmp_uchar);
HDmemcpy(cptr, &tmp_uchar, sizeof(unsigned char));
}
else {
/* if (H5Tequal(tid, H5T_NATIVE_SCHAR)) */
- token = HDstrtok (this_str, delimiter);
tmp_char = 0;
sscanf(token, "%hd", &tmp_char);
HDmemcpy(cptr, &tmp_char, sizeof(char));
@@ -377,14 +374,12 @@ h5str_convert
else if (sizeof(int) == size) {
if(H5T_SGN_NONE == nsign) {
/* if (H5Tequal(tid, H5T_NATIVE_UINT)) */
- token = HDstrtok (this_str, delimiter);
tmp_uint = 0;
sscanf(token, "%u", &tmp_uint);
HDmemcpy(cptr, &tmp_uint, sizeof(unsigned int));
}
else {
/* if (H5Tequal(tid, H5T_NATIVE_INT)) */
- token = HDstrtok (this_str, delimiter);
tmp_int = 0;
sscanf(token, "%d", &tmp_int);
HDmemcpy(cptr, &tmp_int, sizeof(int));
@@ -393,14 +388,12 @@ h5str_convert
else if (sizeof(short) == size) {
if(H5T_SGN_NONE == nsign) {
/* if (H5Tequal(tid, H5T_NATIVE_USHORT)) */
- token = HDstrtok (this_str, delimiter);
tmp_ushort = 0;
sscanf(token, "%u", &tmp_ushort);
HDmemcpy(&tmp_ushort, cptr, sizeof(unsigned short));
}
else {
/* if (H5Tequal(tid, H5T_NATIVE_SHORT)) */
- token = HDstrtok (this_str, delimiter);
tmp_short = 0;
sscanf(token, "%d", &tmp_short);
HDmemcpy(&tmp_short, cptr, sizeof(short));
@@ -409,14 +402,12 @@ h5str_convert
else if (sizeof(long) == size) {
if(H5T_SGN_NONE == nsign) {
/* if (H5Tequal(tid, H5T_NATIVE_ULONG)) */
- token = HDstrtok (this_str, delimiter);
tmp_ulong = 0;
sscanf(token, "%lu", &tmp_ulong);
HDmemcpy(cptr, &tmp_ulong, sizeof(unsigned long));
}
else {
/* if (H5Tequal(tid, H5T_NATIVE_LONG)) */
- token = HDstrtok (this_str, delimiter);
tmp_long = 0;
sscanf(token, "%ld", &tmp_long);
HDmemcpy(cptr, &tmp_long, sizeof(long));
@@ -425,14 +416,12 @@ h5str_convert
else if (sizeof(long long) == size) {
if(H5T_SGN_NONE == nsign) {
/* if (H5Tequal(tid, H5T_NATIVE_ULLONG)) */
- token = HDstrtok (this_str, delimiter);
tmp_ullong = 0;
sscanf(token, fmt_ullong, &tmp_ullong);
HDmemcpy(cptr, &tmp_ullong, sizeof(unsigned long long));
}
else {
/* if (H5Tequal(tid, H5T_NATIVE_LLONG)) */
- token = HDstrtok (this_str, delimiter);
tmp_llong = 0;
sscanf(token, fmt_llong, &tmp_llong);
HDmemcpy(cptr, &tmp_llong, sizeof(long long));
@@ -444,27 +433,27 @@ h5str_convert
unsigned i;
n = H5Tget_nmembers(tid);
/* remove compound indicators */
- if (str[0] == ' ')
- str++;
- if (str[0] == '{')
- str++;
+ if ((*str)[0] == ' ')
+ (*str)++;
+ if ((*str)[0] == '{')
+ (*str)++;
for (i = 0; i < n; i++) {
offset = H5Tget_member_offset(tid, i);
mtid = H5Tget_member_type(tid, i);
h5str_convert(str, container, mtid, ptr, offset, expand_data);
/* remove compound indicators */
- if (str[0] == ',')
- str++;
- if (str[0] == ' ')
- str++;
+ if ((*str)[0] == ',')
+ (*str)++;
+ if ((*str)[0] == ' ')
+ (*str)++;
H5Tclose(mtid);
}
/* remove compound indicators */
- if (str[0] == '}')
- str++;
- if (str[0] == ' ')
- str++;
+ if ((*str)[0] == '}')
+ (*str)++;
+ if ((*str)[0] == ' ')
+ (*str)++;
}
break;
case H5T_ENUM:
@@ -505,10 +494,10 @@ h5str_convert
int rank = 0;
hsize_t i, dims[H5S_MAX_RANK], total_elmts;
/* remove array indicators */
- if (str[0] == '[')
- str++;
- if (str[0] == ' ')
- str++;
+ if ((*str)[0] == '[')
+ (*str)++;
+ if ((*str)[0] == ' ')
+ (*str)++;
mtid = H5Tget_super(tid);
offset = H5Tget_size(mtid);
@@ -524,19 +513,19 @@ h5str_convert
for (i = 0; i < total_elmts; i++) {
h5str_convert(str, container, mtid, cptr + (i*offset), offset, expand_data);
/* remove array indicators */
- if (str[0] == ',')
- str++;
- if (str[0] == ' ')
- str++;
+ if ((*str)[0] == ',')
+ (*str)++;
+ if ((*str)[0] == ' ')
+ (*str)++;
}
H5Tclose(mtid);
/* remove array indicators */
- if (str[0] == ' ')
- str++;
- if (str[0] == ']')
- str++;
- if (str[0] == ' ')
- str++;
+ if ((*str)[0] == ' ')
+ (*str)++;
+ if ((*str)[0] == ']')
+ (*str)++;
+ if ((*str)[0] == ' ')
+ (*str)++;
}
break;
case H5T_VLEN:
@@ -546,21 +535,23 @@ h5str_convert
offset = H5Tget_size(mtid);
/* remove vlen indicators */
- if (str[0] == '{')
- str++;
+ if ((*str)[0] == '{')
+ (*str)++;
cptr = HDcalloc(offset, sizeof(hvl_t));
for (i = 0; (i*offset) < (int)size; i++) {
h5str_convert(str, container, mtid, cptr + (i*offset), offset, expand_data);
/* remove vlen indicators */
- if (str[0] == ',')
- str++;
- if (str[0] == ' ')
- str++;
+ if ((*str)[0] == ',')
+ (*str)++;
+ if ((*str)[0] == ' ')
+ (*str)++;
+ if ((*str)[0] == '}')
+ break;
}
H5Tclose(mtid);
/* remove vlen indicators */
- if (str[0] == '}')
- str++;
+ if ((*str)[0] == '}')
+ (*str)++;
}
break;