summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorRaymond Lu <songyulu@hdfgroup.org>2004-07-07 17:03:02 (GMT)
committerRaymond Lu <songyulu@hdfgroup.org>2004-07-07 17:03:02 (GMT)
commitc949e7c391fe606bf8a680bbc41848d2cd7cc627 (patch)
tree3aa06572baed0dc3037756cbdf77ffa960ed553c /src
parentfaa845f84b89eea5dd527de8f79adf151dd2f92d (diff)
downloadhdf5-c949e7c391fe606bf8a680bbc41848d2cd7cc627.zip
hdf5-c949e7c391fe606bf8a680bbc41848d2cd7cc627.tar.gz
hdf5-c949e7c391fe606bf8a680bbc41848d2cd7cc627.tar.bz2
[svn-r8818]
Purpose: Potential bug fix Description: In H5Fget_filesize, file size was returned as haddr_t. Change it to hsize_t and return it as parameter to make fortran interface easier. Platforms tested: fuss(simple change).
Diffstat (limited to 'src')
-rw-r--r--src/H5F.c21
-rw-r--r--src/H5Fpublic.h2
2 files changed, 13 insertions, 10 deletions
diff --git a/src/H5F.c b/src/H5F.c
index 03aa5a2..1755e5d 100644
--- a/src/H5F.c
+++ b/src/H5F.c
@@ -4714,7 +4714,7 @@ done:
* is called after an existing file is opened in order
* to learn the true size of the underlying file.
*
- * Return: Success: File size
+ * Return: Success: Non-negative
* Failure: Negative
*
* Programmer: David Pitt
@@ -4725,22 +4725,25 @@ done:
*
*-------------------------------------------------------------------------
*/
-haddr_t
-H5Fget_filesize(hid_t file_id)
+herr_t
+H5Fget_filesize(hid_t file_id, hsize_t *size)
{
H5F_t *file=NULL; /* File object for file ID */
- haddr_t ret_value; /* Return value */
+ herr_t ret_value = SUCCEED; /* Return value */
+ haddr_t eof;
- FUNC_ENTER_API(H5Fget_filesize, HADDR_UNDEF)
- H5TRACE1("a","i",file_id);
+ FUNC_ENTER_API(H5Fget_filesize, FAIL)
+ H5TRACE2("e","i*h",file_id,size);
/* Check args */
if(NULL==(file=H5I_object_verify(file_id, H5I_FILE)))
- HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, HADDR_UNDEF, "not a file ID")
+ HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "not a file ID")
/* Go get the actual file size */
- if((ret_value = H5FDget_eof(file->shared->lf))==HADDR_UNDEF)
- HGOTO_ERROR(H5E_FILE, H5E_CANTGET, HADDR_UNDEF, "unable to get file size")
+ if((eof = H5FDget_eof(file->shared->lf))==HADDR_UNDEF)
+ HGOTO_ERROR(H5E_FILE, H5E_CANTGET, FAIL, "unable to get file size")
+
+ *size = (hsize_t)eof;
done:
FUNC_LEAVE_API(ret_value)
diff --git a/src/H5Fpublic.h b/src/H5Fpublic.h
index c372130..c83f12e 100644
--- a/src/H5Fpublic.h
+++ b/src/H5Fpublic.h
@@ -113,7 +113,7 @@ H5_DLL herr_t H5Fget_vfd_handle(hid_t file_id, hid_t fapl, void** file_handle);
H5_DLL herr_t H5Fmount(hid_t loc, const char *name, hid_t child, hid_t plist);
H5_DLL herr_t H5Funmount(hid_t loc, const char *name);
H5_DLL hssize_t H5Fget_freespace(hid_t file_id);
-H5_DLL haddr_t H5Fget_filesize(hid_t file_id);
+H5_DLL herr_t H5Fget_filesize(hid_t file_id, hsize_t *size);
H5_DLL ssize_t H5Fget_name(hid_t obj_id, char *name, size_t size);
#ifdef __cplusplus