diff options
author | Quincey Koziol <koziol@hdfgroup.org> | 2003-09-12 04:35:48 (GMT) |
---|---|---|
committer | Quincey Koziol <koziol@hdfgroup.org> | 2003-09-12 04:35:48 (GMT) |
commit | 965a4cd7c9a2339bd559a3d5fbbc14a957318da4 (patch) | |
tree | 61df28e4cbb1d88eb1d3390e5a04e1db8cfb4276 /src/H5T.c | |
parent | 987e281c8afa3ebd4113d9efba251be4074fd55f (diff) | |
download | hdf5-965a4cd7c9a2339bd559a3d5fbbc14a957318da4.zip hdf5-965a4cd7c9a2339bd559a3d5fbbc14a957318da4.tar.gz hdf5-965a4cd7c9a2339bd559a3d5fbbc14a957318da4.tar.bz2 |
[svn-r7468] Purpose:
Code cleanup, etc.
Description:
Generalize Ray's datatype fixes to handle packing compound datatypes which
are the base type of an array or variable-length type, etc.
Also track "packedness" of a compound datatype from it's creation, instead
of only setting the 'packed' flag after the datatype was explicitly packed.
Updated docs to reflect that a compound datatype is allowed to grow (but
not shrink).
Platforms tested:
FreeBSD 4.9 (sleipnir)
h5committest
Diffstat (limited to 'src/H5T.c')
-rw-r--r-- | src/H5T.c | 10 |
1 files changed, 7 insertions, 3 deletions
@@ -2633,7 +2633,7 @@ H5Tset_size(hid_t type_id, size_t size) HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "size must be positive"); if (size == H5T_VARIABLE && dt->type!=H5T_STRING) HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "only strings may be variable length"); - if ((H5T_ENUM==dt->type && dt->u.enumer.nmembs>0)) + if (H5T_ENUM==dt->type && dt->u.enumer.nmembs>0) HGOTO_ERROR(H5E_DATATYPE, H5E_CANTINIT, FAIL, "operation not allowed after members are defined"); if (H5T_REFERENCE==dt->type) HGOTO_ERROR(H5E_DATATYPE, H5E_CANTINIT, FAIL, "operation not defined for this datatype"); @@ -3307,6 +3307,8 @@ H5T_create(H5T_class_t type, size_t size) if (NULL==(dt = H5FL_CALLOC(H5T_t))) HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, NULL, "memory allocation failed"); dt->type = type; + if(type==H5T_COMPOUND) + dt->u.compnd.packed=TRUE; /* Start out packed */ break; case H5T_ENUM: @@ -3955,10 +3957,12 @@ H5T_set_size(H5T_t *dt, size_t size) case H5T_OPAQUE: /* nothing to check */ break; + case H5T_COMPOUND: - if(size>dt->size) - dt->size = size; + if(size<dt->size) + HGOTO_ERROR(H5E_DATATYPE, H5E_BADVALUE, FAIL, "can't shrink compound datatype"); break; + case H5T_STRING: /* Convert string to variable-length datatype */ if(size==H5T_VARIABLE) { |