diff options
author | Mohamad Chaarawi <chaarawi@hdfgroup.org> | 2012-07-03 22:06:42 (GMT) |
---|---|---|
committer | Mohamad Chaarawi <chaarawi@hdfgroup.org> | 2012-07-03 22:06:42 (GMT) |
commit | e4a60d86caa7a76001dd4e09af246c4c0fad19ea (patch) | |
tree | 98f4a575adade88f83e264264faa8804d14bd5a8 /src/H5VLnative.c | |
parent | 34050a7d9c9ae16326711cfb69c575bfe75e422e (diff) | |
download | hdf5-e4a60d86caa7a76001dd4e09af246c4c0fad19ea.zip hdf5-e4a60d86caa7a76001dd4e09af246c4c0fad19ea.tar.gz hdf5-e4a60d86caa7a76001dd4e09af246c4c0fad19ea.tar.bz2 |
[svn-r22513] fix some committed datatype issues
update get_type routines to construct a VOL datatype if the type is named
Diffstat (limited to 'src/H5VLnative.c')
-rw-r--r-- | src/H5VLnative.c | 23 |
1 files changed, 9 insertions, 14 deletions
diff --git a/src/H5VLnative.c b/src/H5VLnative.c index 413bb2f..9f79946 100644 --- a/src/H5VLnative.c +++ b/src/H5VLnative.c @@ -473,8 +473,7 @@ H5VL_native_attr_create(void *obj, H5VL_loc_params_t loc_params, const char *att hbool_t loc_found = FALSE; H5P_genplist_t *plist; /* Property list pointer */ hid_t type_id, space_id; - H5T_t *type; /* Datatype to use for attribute */ - H5T_t *named_type; /* Named Datatype to use for attribute */ + H5T_t *type, *dt; /* Datatype to use for attribute */ H5S_t *space; /* Dataspace to use for attribute */ H5A_t *attr = NULL; void *ret_value = NULL; @@ -495,16 +494,16 @@ H5VL_native_attr_create(void *obj, H5VL_loc_params_t loc_params, const char *att HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, NULL, "not a file or file object") if(0 == (H5F_INTENT(loc.oloc->file) & H5F_ACC_RDWR)) HGOTO_ERROR(H5E_ARGS, H5E_WRITEERROR, NULL, "no write intent on file") - if(NULL == (type = (H5T_t *)H5I_object_verify(type_id, H5I_DATATYPE))) + + if(NULL == (dt = (H5T_t *)H5I_object_verify(type_id, H5I_DATATYPE))) HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, NULL, "not a type") + /* Get the actual datatype object if this is a named datatype */ + if(NULL == (type = (H5T_t *)H5T_get_named_type(dt))) + type = dt; + if(NULL == (space = (H5S_t *)H5I_object_verify(space_id, H5I_DATASPACE))) HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, NULL, "not a data space") - //if(NULL != (named_type = (H5T_t *)H5T_get_named_type(type))) - if(H5T_STATE_OPEN == type->shared->state || H5T_STATE_NAMED == type->shared->state){ - type = (H5T_t *)(type->vol_obj); - } - if(loc_params.type == H5VL_OBJECT_BY_SELF) { /* H5Acreate */ /* Go do the real work for attaching the attribute to the dataset */ if(NULL == (attr = H5A_create(&loc, attr_name, type, space, acpl_id, H5AC_dxpl_id))) @@ -1022,7 +1021,7 @@ H5VL_native_datatype_commit(void *obj, H5VL_loc_params_t loc_params, const char /* Copy the datatype - the copied one will be the type that is committed, and attached to original datatype above the VOL layer*/ - if(NULL == (type = H5T_copy(dt, H5T_COPY_TRANSIENT))) + if(NULL == (type = H5T_copy(dt, H5T_COPY_REOPEN))) HGOTO_ERROR(H5E_DATATYPE, H5E_CANTINIT, NULL, "unable to copy"); if(NULL != name) { /* H5Tcommit */ @@ -1049,11 +1048,7 @@ H5VL_native_datatype_commit(void *obj, H5VL_loc_params_t loc_params, const char } /* end if */ } ret_value = (void *)type; - /* Increment reference count on atom because the commit callback in the native implementation - return the same object as the type ID itself - if(H5I_inc_ref(type_id, TRUE) < 0) - HGOTO_ERROR(H5E_ATOM, H5E_CANTSET, FAIL, "incrementing type ID failed") - */ + done: FUNC_LEAVE_NOAPI(ret_value) } /* end H5VL_native_datatype_commit() */ |