diff options
author | Quincey Koziol <koziol@hdfgroup.org> | 2000-12-14 16:10:32 (GMT) |
---|---|---|
committer | Quincey Koziol <koziol@hdfgroup.org> | 2000-12-14 16:10:32 (GMT) |
commit | 10c6d6d500ec4188862f408ee0a414bd3fc61374 (patch) | |
tree | 5e52abc1b0d4e5edfa933d06f3c4bded89a7435c | |
parent | 375f018aa18eeb5fc854f2efba2a65d5a057f1a7 (diff) | |
download | hdf5-10c6d6d500ec4188862f408ee0a414bd3fc61374.zip hdf5-10c6d6d500ec4188862f408ee0a414bd3fc61374.tar.gz hdf5-10c6d6d500ec4188862f408ee0a414bd3fc61374.tar.bz2 |
[svn-r3138] Purpose:
Bug Fix
Description:
More descrimination is necessary for the type of background buffer needed.
Compound types need H5T_BKG_TEMP and vlen & array types need H5T_BKG_YES.
Solution:
Make the internal routine be more specific about the background type set.
Platforms tested:
FreeBSD 4.2 (hawkwind)
-rw-r--r-- | src/H5Tconv.c | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/src/H5Tconv.c b/src/H5Tconv.c index f63f30d..9b70ea1 100644 --- a/src/H5Tconv.c +++ b/src/H5Tconv.c @@ -796,7 +796,7 @@ H5T_conv_b_b(hid_t src_id, hid_t dst_id, H5T_cdata_t *cdata, size_t nelmts, *------------------------------------------------------------------------- */ static herr_t -H5T_conv_need_bkg (H5T_t *src, H5T_t *dst, H5T_cdata_t *cdata, H5T_bkg_t bkg_type) +H5T_conv_need_bkg (H5T_t *src, H5T_t *dst, H5T_cdata_t *cdata) { FUNC_ENTER (H5T_conv_need_bkg, FAIL); @@ -804,8 +804,15 @@ H5T_conv_need_bkg (H5T_t *src, H5T_t *dst, H5T_cdata_t *cdata, H5T_bkg_t bkg_typ assert(dst); assert(cdata); + /* Compound datatypes only need a "temp" buffer */ if (H5T_detect_class(src,H5T_COMPOUND)==TRUE || H5T_detect_class(dst,H5T_COMPOUND)==TRUE) - cdata->need_bkg = bkg_type; + cdata->need_bkg = H5T_BKG_TEMP; + + /* Compound datatypes need a "yes" buffer though */ + if (H5T_detect_class(src,H5T_VLEN)==TRUE || H5T_detect_class(dst,H5T_VLEN)==TRUE) + cdata->need_bkg = H5T_BKG_YES; + if (H5T_detect_class(src,H5T_ARRAY)==TRUE || H5T_detect_class(dst,H5T_ARRAY)==TRUE) + cdata->need_bkg = H5T_BKG_YES; FUNC_LEAVE (SUCCEED); } @@ -931,7 +938,7 @@ H5T_conv_struct_init (H5T_t *src, H5T_t *dst, H5T_cdata_t *cdata) } /* Check if we need a background buffer */ - H5T_conv_need_bkg (src, dst, cdata, H5T_BKG_TEMP); + H5T_conv_need_bkg (src, dst, cdata); cdata->recalc = FALSE; FUNC_LEAVE (SUCCEED); @@ -1845,7 +1852,7 @@ H5T_conv_vlen(hid_t src_id, hid_t dst_id, H5T_cdata_t *cdata, size_t nelmts, assert (H5T_VLEN==dst->type); /* Check if we need a background buffer */ - H5T_conv_need_bkg (src, dst, cdata, H5T_BKG_YES); + H5T_conv_need_bkg (src, dst, cdata); break; @@ -2080,7 +2087,7 @@ H5T_conv_array(hid_t src_id, hid_t dst_id, H5T_cdata_t *cdata, size_t nelmts, #endif /* LATER */ /* Check if we need a background buffer */ - H5T_conv_need_bkg (src, dst, cdata, H5T_BKG_YES); + H5T_conv_need_bkg (src, dst, cdata); break; |