summaryrefslogtreecommitdiffstats
path: root/src/H5VLnative.c
diff options
context:
space:
mode:
authorMohamad Chaarawi <chaarawi@hdfgroup.org>2012-04-11 22:09:30 (GMT)
committerMohamad Chaarawi <chaarawi@hdfgroup.org>2012-04-11 22:09:30 (GMT)
commit1f15e6e9d482396e47df6785b161229e7efa1d80 (patch)
tree7c1cad2c4ca3cd80d0f84cea950e26f2aa3e91eb /src/H5VLnative.c
parentf70f5b17403c20bef94e4c43bdf86e7fd4b88ec8 (diff)
downloadhdf5-1f15e6e9d482396e47df6785b161229e7efa1d80.zip
hdf5-1f15e6e9d482396e47df6785b161229e7efa1d80.tar.gz
hdf5-1f15e6e9d482396e47df6785b161229e7efa1d80.tar.bz2
[svn-r22279] implement the attribute delete VOL callback
use the VOL get_space instead of the API routine in vlen_get_size
Diffstat (limited to 'src/H5VLnative.c')
-rw-r--r--src/H5VLnative.c47
1 files changed, 46 insertions, 1 deletions
diff --git a/src/H5VLnative.c b/src/H5VLnative.c
index 34a35bb..afabef7 100644
--- a/src/H5VLnative.c
+++ b/src/H5VLnative.c
@@ -68,6 +68,7 @@ static herr_t H5VL_native_attr_read(hid_t attr_id, hid_t dtype_id, void *buf);
static herr_t H5VL_native_attr_write(hid_t attr_id, hid_t dtype_id, const void *buf);
static herr_t H5VL_native_attr_get(hid_t id, H5VL_attr_get_t get_type, va_list arguments);
static herr_t H5VL_native_attr_generic(hid_t id, H5VL_attr_generic_t generic_type, va_list arguments);
+static herr_t H5VL_native_attr_delete(hid_t loc_id, void *location, const char *attr_name);
static herr_t H5VL_native_attr_close(hid_t attr_id);
static herr_t H5VL_native_datatype_commit(hid_t loc_id, const char *name, hid_t type_id,
@@ -117,9 +118,9 @@ H5VL_class_t H5VL_native_g = {
H5VL_native_attr_open, /* open */
H5VL_native_attr_read, /* read */
H5VL_native_attr_write, /* write */
- NULL, /* delete */
H5VL_native_attr_get, /* get */
H5VL_native_attr_generic, /* generic */
+ H5VL_native_attr_delete, /* delete */
H5VL_native_attr_close /* close */
},
{ /* datatype_cls */
@@ -630,6 +631,50 @@ done:
/*-------------------------------------------------------------------------
+ * Function: H5VL_native_attr_delete
+ *
+ * Purpose: Deletes an attribute from a location
+ *
+ * Return: Success: 0
+ * Failure: -1, attr not deleted.
+ *
+ * Programmer: Mohamad Chaarawi
+ * March, 2012
+ *
+ *-------------------------------------------------------------------------
+ */
+static herr_t
+H5VL_native_attr_delete(hid_t loc_id, void *location, const char *attr_name)
+{
+ H5G_loc_t loc; /* Object location */
+ herr_t ret_value = SUCCEED; /* Return value */
+
+ FUNC_ENTER_NOAPI_NOINIT
+
+ if(H5G_loc(loc_id, &loc) < 0)
+ HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a location")
+
+ if(NULL == location) { /* H5Adelete */
+ /* Delete the attribute from the location */
+ if(H5O_attr_remove(loc.oloc, attr_name, H5AC_dxpl_id) < 0)
+ HGOTO_ERROR(H5E_ATTR, H5E_CANTDELETE, FAIL, "unable to delete attribute")
+ }
+ else { /* H5Adelete_by_name */
+ H5G_loc_t *obj_loc = (H5G_loc_t *)location;
+
+ /* Delete the attribute from the location */
+ if(H5O_attr_remove(obj_loc->oloc, attr_name, H5AC_dxpl_id) < 0)
+ HGOTO_ERROR(H5E_ATTR, H5E_CANTDELETE, FAIL, "unable to delete attribute")
+
+ if(H5G_loc_free(obj_loc) < 0)
+ HDONE_ERROR(H5E_SYM, H5E_CANTRELEASE, FAIL, "can't free location")
+ }
+done:
+ FUNC_LEAVE_NOAPI(ret_value)
+} /* end H5VL_native_attr_delete() */
+
+
+/*-------------------------------------------------------------------------
* Function: H5VL_native_attr_close
*
* Purpose: Closes an attribute.