summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/H5Pdcpl.c62
1 files changed, 59 insertions, 3 deletions
diff --git a/src/H5Pdcpl.c b/src/H5Pdcpl.c
index bbdddde..33de459 100644
--- a/src/H5Pdcpl.c
+++ b/src/H5Pdcpl.c
@@ -1222,11 +1222,11 @@ done:
*
* Return: Non-negative on success/Negative on failure
*
- * Programmer: Kent Yang
- * Wednesday, November 13, 2002
+ * Programmer: Xiaowen Wu
+ * Wednesday, December 22, 2004
*
* Modifications:
- * Xiaowen Wu
+ *
*
*-------------------------------------------------------------------------
*/
@@ -1259,8 +1259,64 @@ H5Pset_nbit(hid_t plist_id)
done:
FUNC_LEAVE_API(ret_value);
} /* end H5Pset_nbit() */
+
+/*-------------------------------------------------------------------------
+ * Function: H5Pset_scaleoffset
+ *
+ * Purpose: Sets scaleoffset filter for a dataset creation property list
+ * and user-supplied minimum number of bits
+ *
+ * Return: Non-negative on success/Negative on failure
+ *
+ * Programmer: Xiaowen Wu
+ * Wednesday, February 9, 2005
+ *
+ * Modifications:
+ *
+ *
+ *-------------------------------------------------------------------------
+ */
+herr_t
+H5Pset_scaleoffset(hid_t plist_id, unsigned min_bits)
+{
+ H5O_pline_t pline;
+ H5P_genplist_t *plist; /* Property list pointer */
+ unsigned cd_values[1]; /* Filter parameters */
+ unsigned int config_flags;
+ herr_t ret_value=SUCCEED; /* return value */
+ FUNC_ENTER_API(H5Pset_scaleoffset, FAIL);
+ H5TRACE2("e","iIu",plist_id,min_bits);
+
+ /* Check arguments */
+ if(TRUE != H5P_isa_class(plist_id, H5P_DATASET_CREATE))
+ HGOTO_ERROR (H5E_ARGS, H5E_BADTYPE, FAIL, "not a dataset creation property list");
+
+ /* Get the plist structure */
+ if(NULL == (plist = H5I_object(plist_id)))
+ HGOTO_ERROR(H5E_ATOM, H5E_BADATOM, FAIL, "can't find object for ID");
+
+ if(min_bits < 0)
+ HGOTO_ERROR (H5E_ARGS, H5E_BADVALUE, FAIL, "minimum number of bits can't be positive");
+
+ /* Set the parameter for the filter */
+ /* if min_bits is zero, the scaleoffset filter will automatically calculate min_bits */
+ cd_values[0] = min_bits;
+
+ /* Add the scaleoffset filter */
+ if(H5P_get(plist, H5D_CRT_DATA_PIPELINE_NAME, &pline) < 0)
+ HGOTO_ERROR(H5E_PLIST, H5E_CANTGET, FAIL, "can't get pipeline");
+ if(H5Z_append(&pline, H5Z_FILTER_SCALEOFFSET, H5Z_FLAG_OPTIONAL, 1, cd_values)<0)
+ HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to add scaleoffset filter to pipeline");
+ if(H5P_set(plist, H5D_CRT_DATA_PIPELINE_NAME, &pline) < 0)
+ HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to set pipeline");
+
+done:
+ FUNC_LEAVE_API(ret_value);
+} /* end H5Pset_scaleoffset() */
+
+
/*-------------------------------------------------------------------------
* Function: H5Pset_fletcher32
*